Claude Code Buddy ترمیم گائیڈ: چمکدار لیجنڈری پالتو جانور کیسے حاصل کریں
Claude Code Buddy ترمیم گائیڈ: چمکدار لیجنڈری پالتو جانور کیسے حاصل کریں
2026年4月1日،Anthropic 在 Claude Code 2.1.89 版本中悄然上线了一个彩蛋功能——/buddy 宠物系统。在终端输入 /buddy 后,一只 ASCII 风格的小动物会"孵化"在你的输入框旁边,陪你写代码、吐槽 bug。
每只 Buddy 由账号 ID 通过确定性算法生成,意味着同一个账号永远获得同一只宠物。但通过修改配置文件中的 userID,我们可以"重ROLL"出心仪的宠物。本文将详细介绍算法原理和完整的修改脚本。
一、Buddy 系统概览
18 种物种
系统目前包含 18 种可爱的物种:
- duck - بطخ (کلاسیکی Rubber Duck Debugging)
- goose - ہنس (شرارتی)
- blob - جیلی (نرم اور غیر متعین شکل)
- cat - بلی (ٹھنڈی اور مغرور)
- dragon - ڈریگن (طاقتور محافظ)
- octopus - آکٹوپس (کثیر تھریڈ سوچ)
- owl - اُلو (عقلمند استاد)
- penguin - پینگوئن (فارمل لباس میں)
- turtle - کچھوا (مضبوط اور قابل اعتماد)
- snail - گھونسلہ (آہستہ کام میں مہارت)
- ghost - بھوت (غائب اور ظاہر)
- axolotl - ایکسلوٹل (پیاری اور شفا بخش)
- capybara - کیپی بارا (بہت آرام دہ)
- cactus - کیکٹس (دل کو گرم کرنے والا پودا)
- robot - روبوٹ (عقلی طور پر سب سے اوپر)
- rabbit - خرگوش (چست اور پھرتیلا)
- mushroom - مشروم (خاموش مشاہدہ)
- chonk - موٹا (گول مٹول)
5 级稀有度
- Common(عام) - 60% امکان، بغیر ٹوپی کی سجاوٹ
- Uncommon(نایاب) - 25% امکان، ٹوپی کو انلاک کریں
- Rare(نایاب) - 10% امکان، مزید سجاوٹ
- Epic(شاندار) - 4% امکان، خصوصی سجاوٹ
- Legendary(لیجنڈری) - 1% امکان، اعلیٰ سجاوٹ
二、算法原理深度解析
Buddy 的生成采用确定性随机算法,核心流程如下:
1. 种子字符串拼接
const SALT = "friend-2026-401"; // 4月1日愚人节彩蛋 const key = userId + SALT;
Salt 值 friend-2026-401 中的 401 代表 4月1日——一个精心设计的愚人节彩蛋。
2. FNV-1a 32-bit 哈希
将种子字符串转换为 32 位整数:
function hashString(s) { let h = 2166136261; // FNV offset basis for (let i = 0; i < s.length; i++) { h ^= s.charCodeAt(i); h = Math.imul(h, 16777619); // FNV prime } return h >>> 0; }
3. Mulberry32 PRNG
用哈希值初始化伪随机数生成器:function mulberry32(seed) { let a = seed >>> 0; return function() { a |= 0; a = (a + 0x6d2b79f5) | 0; let t = Math.imul(a ^ (a >>> 15), 1 | a); t = (t + Math.imul(t ^ (t >>> 7), 61 | t)) ^ t; return ((t ^ (t >>> 14)) >>> 0) / 4294967296; }; }
ملبری32 ایک ہلکا پھلکا PRNG ہے جو کھیل کی ترقی میں عام طور پر استعمال ہوتا ہے، یہ پروگراماتی تخلیق اور لوٹ کے گرنے کی فہرست کے لیے موزوں ہے۔
4. نایابیت کا انتخاب (اہم!)
const RARITIES = ["common", "uncommon", "rare", "epic", "legendary"]; const RARITYWEIGHTS = { common: 60, uncommon: 25, rare: 10, epic: 4, legendary: 1 };
function rollRarity(rng) { const total = 60 + 25 + 10 + 4 + 1; // = 100 let roll = rng() total; for (const rarity of RARITIES) { roll -= RARITYWEIGHTS[rarity]; if (roll < 0) return rarity; } return "common"; }
重要:RARITIES 数组的顺序必须是从低到高,这是加权随机选择的标准实现。
三、完整 Reroll 脚本
以下脚本可以搜索并生成闪光传说级 Buddy 的 userID:
// Claude Code Buddy Reroll 脚本 // 基于 Claude Code 源码逆向分析
// FNV-1a 32-bit hash function hashString(s) { let h = 2166136261; for (let i = 0; i < s.length; i++) { h ^= s.charCodeAt(i); h = Math.imul(h, 16777619); } return h >>> 0; }
// ملبری32 PRNG function mulberry32(seed) { let a = seed >>> 0; return function() { a |= 0; a = (a + 0x6d2b79f5) | 0; let t = Math.imul(a ^ (a >>> 15), 1 | a); t = (t + Math.imul(t ^ (t >>> 7), 61 | t)) ^ t; return ((t ^ (t >>> 14)) >>> 0) / 4294967296; }; }
const SPECIES = [ "duck", "goose", "blob", "cat", "dragon", "octopus", "owl", "penguin", "turtle", "snail", "ghost", "axolotl", "capybara", "cactus", "robot", "rabbit", "mushroom", "chonk" ];- اسکرپٹ محفوظ کریں: اوپر دی گئی کوڈ کو buddy-reroll.js کے طور پر محفوظ کریں
- اسکرپٹ چلائیں:
node buddy-reroll.js(مخصوص نوع کو منتخب کرنے کے لیے:node buddy-reroll.js dragon)
- userID کاپی کریں: اسکرپٹ ایک چمکدار افسانوی سطح کے Buddy کا userID آؤٹ پٹ کرے گا
function pick(rng, arr) { return arr[Math.floor(rng() arr.length)]; }
function rollRarity(rng) { const total = Object.values(RARITYWEIGHTS).reduce((a, b) => a + b, 0); let roll = rng() total; for (const rarity of RARITIES) { roll -= RARITY_WEIGHTS[rarity]; if (roll < 0) return rarity; } return "common"; }
function testUserId(userId) { const key = userId + SALT; const seed = hashString(key); const rng = mulberry32(seed); const rarity = rollRarity(rng); const species = pick(rng, SPECIES); const shiny = rng() < 0.01; return { rarity, species, shiny }; }
function randomUserId() { let id = ""; for (let i = 0; i < 64; i++) { id += Math.floor(Math.random() 16).toString(16); } return id; }
// چمکدار افسانوی کی تلاش console.log("چمکدار افسانوی Buddy کی تلاش... "); const targetSpecies = process.argv[2] || null;
while (true) { const userId = randomUserId(); const result = testUserId(userId);
if (result.rarity === "legendary" && result.shiny) { if (!targetSpecies || result.species === targetSpecies) { console.log("مل گیا!"); console.log("نوع: ", result.species); console.log("نایابیت: افسانوی"); console.log("چمکدار: ہاں!"); console.log("userID: ", userId); break; } } }- ترتیب میں تبدیلی: # ایڈٹ کریں ~/.claude.json cat ~/.claude.json | jq '.userID = "آپ کا نیا userID" | del(.companion)' > /tmp/claude-new.json && mv /tmp/claude-new.json ~/.claude.json
- Claude Code کو دوبارہ شروع کریں،
/buddyدرج کریں اور آپ کو نیا پالتو جانور نظر آئے گا!
پانچ، دھوکہ دہی سے بچنے کے ڈیزائن کے اصول
Claude Code کا ڈیزائن بہت ہی چالاک ہے، ہڈیوں (Bones) اور روح (Soul) کی علیحدگی کے ڈھانچے کا استعمال کرتا ہے:
- Bones (ہڈیاں): نوع، نایابیت، ظاہری شکل، خصوصیات——ہر بار userID سے دوبارہ حساب لگایا جاتا ہے، کبھی بھی مستقل نہیں ہوتا
- Soul (روح): نام، کردار کی وضاحت——مقامی ترتیب میں مستقل ہوتا ہے
roll(userID) کے نتیجے سے اوور رائٹ کرے گا۔ تبصرہ بہت واضح ہے: editing config.companion can't fake a rarity۔
لیکن userID خود کو تبدیل کیا جا سکتا ہے، یہی اس مضمون کے طریقہ کار کا اصول ہے۔
چھ، خلاصہ
Claude Code Buddy ایک خوبصورت ڈیزائن کردہ ایڈونچر کی خصوصیت ہے، جو کہ ملا کر:
- مقررہ تصادفی: FNV-1a + Mulberry32 کا کلاسک مجموعہ
- کارڈ کھینچنے کا طریقہ: 5 سطح کی نایابیت + 1% چمکدار، Gacha کھیل کی روح
- دھوکہ دہی سے بچنے کا ڈیزائن: ہڈیاں/روح کی علیحدگی، انصاف کو یقینی بنانا
- احمقوں کے دن کا ایڈونچر: نمک کی قیمت میں 1 اپریل کے وقت کا نشان چھپا ہوا ہے

