- होम
- Documentation
- कॉन्फ़िगरेशन
- कॉन्फ़िगरेशन डिस्कवरी और रिज़ॉल्यूशन
कॉन्फ़िगरेशन डिस्कवरी और रिज़ॉल्यूशन
यह दस्तावेज़ वर्णन करता है कि coding-agent आज कॉन्फ़िगरेशन को कैसे हल करता है: कौन से रूट्स स्कैन किए जाते हैं, प्राथमिकता कैसे काम करती है, और हल किया गया कॉन्फ़िग settings, skills, hooks, tools, और extensions द्वारा कैसे उपभोग किया जाता है।
प्राथमिक कार्यान्वयन:
src/config.tssrc/config/settings.tssrc/config/settings-schema.tssrc/discovery/builtin.tssrc/discovery/helpers.ts
मुख्य एकीकरण बिंदु:
src/capability/index.tssrc/discovery/index.tssrc/extensibility/skills.tssrc/extensibility/hooks/loader.tssrc/extensibility/custom-tools/loader.tssrc/extensibility/extensions/loader.ts
रिज़ॉल्यूशन प्रवाह (दृश्य)
Section titled “रिज़ॉल्यूशन प्रवाह (दृश्य)” Config roots (ordered)┌───────────────────────────────────────┐│ 1) ~/.xcsh/agent + <cwd>/.xcsh ││ 2) ~/.claude + <cwd>/.claude ││ 3) ~/.codex + <cwd>/.codex ││ 4) ~/.gemini + <cwd>/.gemini │└───────────────────────────────────────┘ │ ▼ config.ts helper resolution (getConfigDirs/findConfigFile/findNearest...) │ ▼ capability providers enumerate items (native, claude, codex, gemini, agents, etc.) │ ▼ priority sort + per-capability dedup │ ▼ subsystem-specific consumption (settings, skills, hooks, tools, extensions)1) कॉन्फ़िग रूट्स और स्रोत क्रम
Section titled “1) कॉन्फ़िग रूट्स और स्रोत क्रम”कैनोनिकल रूट्स
Section titled “कैनोनिकल रूट्स”src/config.ts एक निश्चित स्रोत प्राथमिकता सूची परिभाषित करता है:
.xcsh(नेटिव).claude.codex.gemini
उपयोगकर्ता-स्तर के आधार:
~/.xcsh/agent~/.claude~/.codex~/.gemini
प्रोजेक्ट-स्तर के आधार:
<cwd>/.xcsh<cwd>/.claude<cwd>/.codex<cwd>/.gemini
CONFIG_DIR_NAME .xcsh है (packages/utils/src/dirs.ts)।
महत्वपूर्ण प्रतिबंध
Section titled “महत्वपूर्ण प्रतिबंध”src/config.ts में जेनेरिक हेल्पर्स स्रोत डिस्कवरी क्रम में .pi को शामिल नहीं करते हैं।
2) कोर डिस्कवरी हेल्पर्स (src/config.ts)
Section titled “2) कोर डिस्कवरी हेल्पर्स (src/config.ts)”getConfigDirs(subpath, options)
Section titled “getConfigDirs(subpath, options)”क्रमबद्ध प्रविष्टियाँ लौटाता है:
- पहले उपयोगकर्ता-स्तर की प्रविष्टियाँ (स्रोत प्राथमिकता के अनुसार)
- फिर प्रोजेक्ट-स्तर की प्रविष्टियाँ (उसी स्रोत प्राथमिकता के अनुसार)
विकल्प:
user(डिफ़ॉल्टtrue)project(डिफ़ॉल्टtrue)cwd(डिफ़ॉल्टgetProjectDir())existingOnly(डिफ़ॉल्टfalse)
यह API डायरेक्टरी-आधारित कॉन्फ़िग लुकअप (commands, hooks, tools, agents, आदि) के लिए उपयोग किया जाता है।
findConfigFile(subpath, options) / findConfigFileWithMeta(...)
Section titled “findConfigFile(subpath, options) / findConfigFileWithMeta(...)”क्रमबद्ध आधारों में पहली मौजूद फ़ाइल खोजता है, पहला मिलान लौटाता है (केवल-पथ या पथ+मेटाडेटा)।
findAllNearestProjectConfigDirs(subpath, cwd)
Section titled “findAllNearestProjectConfigDirs(subpath, cwd)”पैरेंट डायरेक्टरीज़ में ऊपर की ओर चलता है और प्रत्येक स्रोत आधार (.xcsh, .claude, .codex, .gemini) के लिए निकटतम मौजूद डायरेक्टरी लौटाता है, फिर परिणामों को स्रोत प्राथमिकता के अनुसार क्रमबद्ध करता है।
इसका उपयोग तब करें जब प्रोजेक्ट कॉन्फ़िग को पूर्वज डायरेक्टरीज़ से इनहेरिट किया जाना चाहिए (मोनोरेपो/नेस्टेड वर्कस्पेस व्यवहार)।
3) फ़ाइल कॉन्फ़िग रैपर (ConfigFile<T> src/config.ts में)
Section titled “3) फ़ाइल कॉन्फ़िग रैपर (ConfigFile<T> src/config.ts में)”ConfigFile<T> एकल कॉन्फ़िग फ़ाइलों के लिए स्कीमा-सत्यापित लोडर है।
समर्थित प्रारूप:
.yml/.yaml.json/.jsonc
व्यवहार:
- AJV के साथ प्रदान किए गए TypeBox स्कीमा के विरुद्ध पार्स किए गए डेटा को सत्यापित करता है।
invalidate()तक लोड परिणाम को कैश करता है।tryLoad()के माध्यम से त्रि-स्थिति परिणाम लौटाता है:oknot-founderror(स्कीमा/पार्स संदर्भ के साथConfigError)
लेगेसी माइग्रेशन अभी भी समर्थित:
- यदि लक्ष्य पथ
.yml/.yamlहै, तो एक सहोदर.jsonएक बार स्वचालित रूप से माइग्रेट किया जाता है (migrateJsonToYml)।
4) सेटिंग्स रिज़ॉल्यूशन मॉडल (src/config/settings.ts)
Section titled “4) सेटिंग्स रिज़ॉल्यूशन मॉडल (src/config/settings.ts)”रनटाइम सेटिंग्स मॉडल परतों में है:
- वैश्विक सेटिंग्स:
~/.xcsh/agent/config.yml - प्रोजेक्ट सेटिंग्स: settings capability के माध्यम से खोजी गई (प्रदाताओं से
settings.json) - रनटाइम ओवरराइड: इन-मेमोरी, गैर-स्थायी
- स्कीमा डिफ़ॉल्ट:
SETTINGS_SCHEMAसे
प्रभावी रीड पथ:
defaults <- global <- project <- overrides
राइट व्यवहार:
settings.set(...)वैश्विक परत (config.yml) में लिखता है और बैकग्राउंड सेव कतारबद्ध करता है।- प्रोजेक्ट सेटिंग्स capability discovery से केवल-पठनीय हैं।
माइग्रेशन व्यवहार अभी भी सक्रिय
Section titled “माइग्रेशन व्यवहार अभी भी सक्रिय”स्टार्टअप पर, यदि config.yml अनुपस्थित है:
~/.xcsh/agent/settings.jsonसे माइग्रेट करें (सफलता पर.bakमें नाम बदला जाता है)agent.dbसे लेगेसी DB सेटिंग्स के साथ मर्ज करें- मर्ज किए गए परिणाम को
config.ymlमें लिखें
#migrateRawSettings में फ़ील्ड-स्तर माइग्रेशन:
queueMode->steeringModeask.timeoutमिलीसेकंड -> सेकंड जब पुराना मान ms जैसा लगता है (> 1000)- लेगेसी फ्लैट
theme: "..."->theme.dark/theme.lightसंरचना
5) Capability/डिस्कवरी एकीकरण
Section titled “5) Capability/डिस्कवरी एकीकरण”अधिकांश गैर-कोर कॉन्फ़िग लोडिंग capability रजिस्ट्री (src/capability/index.ts + src/discovery/index.ts) के माध्यम से होती है।
प्रदाता क्रम
Section titled “प्रदाता क्रम”प्रदाता संख्यात्मक प्राथमिकता (उच्चतर पहले) के अनुसार क्रमबद्ध किए जाते हैं। उदाहरण प्राथमिकताएँ:
- नेटिव OMP (
builtin.ts):100 - Claude:
80 - Codex / agents / Claude marketplace:
70 - Gemini:
60
Provider precedence (higher wins)
native (.xcsh) priority 100claude priority 80codex / agents / ... priority 70gemini priority 60डीडुप अर्थविज्ञान
Section titled “डीडुप अर्थविज्ञान”Capabilities एक key(item) परिभाषित करती हैं:
- समान key => पहला आइटम जीतता है (उच्च-प्राथमिकता/पहले-लोड किया गया आइटम)
- कोई key नहीं (
undefined) => कोई डीडुप नहीं, सभी आइटम बनाए रखे जाते हैं
प्रासंगिक keys:
- skills:
name - tools:
name - hooks:
${type}:${tool}:${name} - extension modules:
name - extensions:
name - settings: कोई डीडुप नहीं (सभी आइटम संरक्षित)
6) नेटिव .xcsh प्रदाता व्यवहार (src/discovery/builtin.ts)
Section titled “6) नेटिव .xcsh प्रदाता व्यवहार (src/discovery/builtin.ts)”नेटिव प्रदाता (id: native) इनसे पढ़ता है:
- प्रोजेक्ट:
<cwd>/.xcsh/... - उपयोगकर्ता:
~/.xcsh/agent/...
डायरेक्टरी प्रवेश नियम
Section titled “डायरेक्टरी प्रवेश नियम”builtin.ts केवल तभी कॉन्फ़िग रूट शामिल करता है जब डायरेक्टरी मौजूद हो और गैर-रिक्त हो (ifNonEmptyDir)।
स्कोप-विशिष्ट लोडिंग
Section titled “स्कोप-विशिष्ट लोडिंग”- Skills:
skills/*/SKILL.md - Slash commands:
commands/*.md - Rules:
rules/*.{md,mdc} - Prompts:
prompts/*.md - Instructions:
instructions/*.md - Hooks:
hooks/pre/*,hooks/post/* - Tools:
tools/*.json|*.mdऔरtools/<name>/index.ts - Extension modules:
extensions/के अंतर्गत खोजे गए (+ लेगेसीsettings.json.extensionsस्ट्रिंग ऐरे) - Extensions:
extensions/<name>/gemini-extension.json - Settings capability:
settings.json
निकटतम-प्रोजेक्ट लुकअप बारीकी
Section titled “निकटतम-प्रोजेक्ट लुकअप बारीकी”SYSTEM.md और XCSH.md के लिए, नेटिव प्रदाता निकटतम-पूर्वज प्रोजेक्ट .xcsh डायरेक्टरी खोज (ऊपर की ओर चलना) का उपयोग करता है लेकिन फिर भी .xcsh dir का गैर-रिक्त होना आवश्यक है।
7) प्रमुख उपप्रणालियाँ कॉन्फ़िग का उपभोग कैसे करती हैं
Section titled “7) प्रमुख उपप्रणालियाँ कॉन्फ़िग का उपभोग कैसे करती हैं”सेटिंग्स उपप्रणाली
Section titled “सेटिंग्स उपप्रणाली”Settings.init()वैश्विकconfig.yml+ खोजी गई प्रोजेक्टsettings.jsoncapability आइटम्स लोड करता है।- केवल
level === "project"वाले capability आइटम्स प्रोजेक्ट परत में मर्ज किए जाते हैं।
Skills उपप्रणाली
Section titled “Skills उपप्रणाली”extensibility/skills.tsloadCapability(skillCapability.id, { cwd })के माध्यम से लोड करता है।- स्रोत टॉगल और फ़िल्टर लागू करता है (
ignoredSkills,includeSkills, कस्टम dirs)। - लेगेसी-नामित टॉगल अभी भी मौजूद हैं (
skills.enablePiUser,skills.enablePiProject) लेकिन वे नेटिव प्रदाता (provider === "native") को गेट करते हैं।
Hooks उपप्रणाली
Section titled “Hooks उपप्रणाली”discoverAndLoadHooks()hook capability + स्पष्ट रूप से कॉन्फ़िगर किए गए पथों से hook पथ हल करता है।- फिर Bun import के माध्यम से मॉड्यूल लोड करता है।
Tools उपप्रणाली
Section titled “Tools उपप्रणाली”discoverAndLoadCustomTools()tool capability + प्लगइन tool पथ + स्पष्ट रूप से कॉन्फ़िगर किए गए पथों से tool पथ हल करता है।- डिक्लेरेटिव
.md/.jsontool फ़ाइलें केवल मेटाडेटा हैं; निष्पादन योग्य लोडिंग कोड मॉड्यूल की अपेक्षा करता है।
Extensions उपप्रणाली
Section titled “Extensions उपप्रणाली”discoverAndLoadExtensions()extension-module capability प्लस स्पष्ट पथों से extension मॉड्यूल हल करता है।- वर्तमान कार्यान्वयन जानबूझकर लोडिंग से पहले केवल
_source.provider === "native"वाले capability आइटम्स रखता है।
8) भरोसा करने योग्य प्राथमिकता नियम
Section titled “8) भरोसा करने योग्य प्राथमिकता नियम”इस मानसिक मॉडल का उपयोग करें:
config.tsसे स्रोत डायरेक्टरी क्रम उम्मीदवार पथ क्रम निर्धारित करता है।- Capability प्रदाता प्राथमिकता क्रॉस-प्रदाता प्राथमिकता निर्धारित करती है।
- Capability key डीडुप टक्कर व्यवहार निर्धारित करता है (कुंजीबद्ध capabilities के लिए पहला जीतता है)।
- उपप्रणाली-विशिष्ट मर्ज तर्क प्रभावी प्राथमिकता को और बदल सकता है (विशेषकर settings)।
Settings-विशिष्ट चेतावनी
Section titled “Settings-विशिष्ट चेतावनी”Settings capability आइटम्स डीडुप्लिकेट नहीं किए जाते; Settings.#loadProjectSettings() लौटाए गए क्रम में प्रोजेक्ट आइटम्स को डीप-मर्ज करता है। क्योंकि मर्ज बाद के आइटम मानों को पहले के मानों पर लागू करता है, प्रभावी ओवरराइड व्यवहार प्रदाता उत्सर्जन क्रम पर निर्भर करता है, न कि केवल capability key अर्थविज्ञान पर।
9) लेगेसी/संगतता व्यवहार अभी भी मौजूद
Section titled “9) लेगेसी/संगतता व्यवहार अभी भी मौजूद”- YAML-लक्षित फ़ाइलों के लिए
ConfigFileJSON -> YAML माइग्रेशन। settings.jsonऔरagent.dbसेconfig.ymlमें Settings माइग्रेशन।- Settings key माइग्रेशन (
queueMode,ask.timeout, फ्लैटtheme)। - Extension manifest संगतता: लोडर
package.json.xcshऔरpackage.json.piदोनों manifest अनुभाग स्वीकार करता है। - लेगेसी सेटिंग नाम
skills.enablePiUser/skills.enablePiProjectअभी भी नेटिव skill स्रोत के लिए सक्रिय गेट हैं।
यदि ये संगतता पथ कोड में हटा दिए जाते हैं, तो इस दस्तावेज़ को तुरंत अपडेट करें; कई रनटाइम व्यवहार आज भी इन पर निर्भर हैं।