अपने प्रश्न को पूछें और दस्तावेज़ का सारांश प्राप्त करें, इस पृष्ठ और आपके चुने हुए AI प्रदाता का उपयोग करके
संस्करण इतिहास
- "Release LSP"v8.12.01/6/2026
इस पृष्ठ की सामग्री एक AI द्वारा अनुवादित की गई है।
अंग्रेजी में मूल सामग्री के अंतिम संस्करण देखेंअगर आपके पास इस दस्तावेज़ को सुधारने के लिए कोई विचार है, तो कृपया GitHub पर एक पुल अनुरोध सबमिट करके योगदान देने में संकोच न करें।
दस्तावेज़ के लिए GitHub लिंकदस्तावेज़ का Markdown को क्लिपबोर्ड पर कॉपी करें
Intlayer LSP सर्वर
Intlayer लैंग्वेज सर्वर (LSP) एक लैंग्वेज सर्वर प्रोटोकॉल (LSP) कार्यान्वयन है जो Intlayer-सचेत बुद्धिमत्ता के साथ आपके IDE को बेहतर बनाता है। यह वर्तमान में डिक्शनरी कुंजी कॉल्स के लिए परिभाषा पर जाएं (Go to Definition) की सुविधा प्रदान करता है, जिससे आप अपने कंपोनेंट में useIntlayer("my-key") से सीधे उस .content.ts फ़ाइल पर जा सकते हैं जो इसे घोषित करती है।
LSP का उपयोग क्यों करें?
जब आप Intlayer का उपयोग करते हैं, तो useIntlayer("homepage") जैसे कॉल और src/homepage.content.ts में इसकी घोषणा के बीच संबंध अंतर्निहित होता है। बिना टूल्स के, आपको मैन्युअल रूप से फ़ाइल खोजनी होगी। LSP उस लिंक को स्पष्ट बनाता है:
AI एजेंट जागरूकता
AI कोडिंग एजेंट (Cursor, Windsurf, GitHub Copilot, Claude Code, Codex) प्रतीकों को हल करने और फ़ाइल-क्रॉस संबंधों को समझने के लिए लैंग्वेज सर्वर पर निर्भर करते हैं। Intlayer LSP चलने के साथ, एजेंट useIntlayer("key") का उसकी घोषणा तक पीछा कर सकते हैं, जिससे उन्हें उपलब्ध कंटेंट कुंजियों, प्रत्येक डिक्शनरी के आकार और किन फ़ाइलों को पढ़ना या संपादित करना है, इसके बारे में सटीक संदर्भ मिलता है।
परिभाषा पर जाएं
किसी भी समर्थित गेटर कॉल के अंदर किसी डिक्शनरी कुंजी स्ट्रिंग पर अपना कर्सर रखें और F12 (या Cmd/Ctrl+Click) दबाएं। एडिटर कंटेंट घोषणा फ़ाइल खोलता है और कर्सर को key: लाइन पर रखता है।
मर्ज की गई डिक्शनरी का समर्थन
एक कुंजी को कई कंटेंट फ़ाइलों में विभाजित किया जा सकता है (Intlayer उन्हें मर्ज करता है)। सर्वर प्रति स्रोत फ़ाइल एक स्थान (Location) लौटाता है ताकि आप प्रत्येक घोषणा पर जा सकें।
हर जगह काम करता है
सभी *-intlayer पैकेजों का समर्थन करता है (next-intlayer, react-intlayer, vue-intlayer, svelte-intlayer, solid-intlayer, preact-intlayer, angular-intlayer, lit-intlayer, express-intlayer, hono-intlayer, fastify-intlayer, adonis-intlayer, intlayer)।
समर्थित गेटर कॉल्स
सर्वर निम्नलिखित फ़ंक्शन कॉल्स का पता लगाता है और पहले स्ट्रिंग-लिटरल तर्क को डिक्शनरी कुंजी के रूप में निकालता है:
सभी डेटा सामग्री को स्पष्ट रूप से देखने के लिए तालिका को मोडल में खोलें
| फ़ंक्शन | उदाहरण |
|---|---|
useIntlayer | useIntlayer("hero") |
getIntlayer | getIntlayer("hero", locale) |
TypeScript जेनिरिक्स और अतिरिक्त तर्कों को अनदेखा कर दिया जाता है — केवल कुंजी स्ट्रिंग मायने रखती है।
useDictionaryऔरgetDictionaryएक स्ट्रिंग कुंजी के बजाय पहले तर्क के रूप में पहले से इम्पोर्टेडDictionaryऑब्जेक्ट लेते हैं, इसलिए वे परिभाषा पर जाएं सुविधा से लाभान्वित नहीं होते हैं और सर्वर द्वारा ट्रैक नहीं किए जाते हैं।
इंस्टॉलेशन
LSP सर्वर @intlayer/lsp के हिस्से के रूप में वितरित किया जाता है:
यह पैकेज intlayer-lsp बाइनरी को उजागर करता है, जिसे एडिटर्स सर्वर एक्ज़ीक्यूटेबल के रूप में उपयोग करते हैं।
Claude Code प्लगइन के रूप में सेटअप करें
Intlayer LSP सीधे Intlayer GitHub रिपॉजिटरी में होस्ट किए गए Claude Code प्लगइन के रूप में उपलब्ध है। इसे इंस्टॉल करने से Claude Code को आपके सभी useIntlayer / getIntlayer कॉल्स के लिए मूल परिभाषा पर जाएं (Go-to-Definition) की जागरूकता मिलती है।
1. लैंग्वेज सर्वर बाइनरी इंस्टॉल करें
यह intlayer-lsp बाइनरी को आपके PATH पर रखता है, जिसे प्लगइन की lspServers प्रविष्टि कॉल करती है।
2. Intlayer मार्केटप्लेस पंजीकृत करें और प्लगइन इंस्टॉल करें
Claude Code आपके enabledPlugins में "intlayer-lsp@intlayer": true जोड़ देगा और समर्थित फ़ाइल प्रकारों (.ts, .tsx, .js, .jsx, .vue, .svelte) पर स्वचालित रूप से लैंग्वेज सर्वर शुरू कर देगा।
3. LSP टूल सक्षम करें (यदि पहले से सक्रिय नहीं है)
कुछ Claude Code संस्करणों को LSP फ़ीचर फ़्लैग सेट करने की आवश्यकता होती है। यदि इंस्टॉलेशन के बाद परिभाषा पर जाएं काम नहीं कर रहा है, तो अपनी ~/.claude/settings.json में निम्नलिखित जोड़ें:
Claude Code को पुनरारंभ करें — यह अब Intlayer कोडबेस को नेविगेट करते समय grep पर वापस जाने के बजाय goToDefinition, findReferences और अन्य LSP ऑपरेशन्स का उपयोग करेगा।
VS Code में सेटअप (एक्सटेंशन के माध्यम से — अनुशंसित)
यदि आपके पास Intlayer VS Code एक्सटेंशन इंस्टॉल है, तो लैंग्वेज सर्वर स्वचालित रूप से शुरू हो जाता है। किसी अतिरिक्त कॉन्फ़िगरेशन की आवश्यकता नहीं है। LSP को v8.12.0 के बाद से सीधे VSCode एक्सटेंशन में एकीकृत किया गया है।
इंस्टॉलेशन और अन्य सुविधाओं के लिए VS Code एक्सटेंशन दस्तावेज़ देखें।
VS Code में मैन्युअल सेटअप
यदि आप Intlayer एक्सटेंशन का उपयोग नहीं कर रहे हैं, तो आप vscode-glspc जैसे सामान्य LSP क्लाइंट एक्सटेंशन का उपयोग करके या अपना खुद का छोटा एक्सटेंशन लिखकर मैन्युअल रूप से लैंग्वेज सर्वर को कनेक्ट कर सकते हैं। अनुशंसित तरीका Intlayer एक्सटेंशन का उपयोग करना है।
संदर्भ के लिए, सर्वर stdio पर intlayer-lsp बाइनरी के माध्यम से लॉन्च होता है:
Intlayer एक्सटेंशन सर्वर लॉन्च करने के लिए इन सेटिंग्स को पढ़ता है। यदि आप पूरी तरह से एक्सटेंशन पर निर्भर हैं, तो किसी मैन्युअल सेटिंग्स की आवश्यकता नहीं है।
Cursor में सेटअप
Cursor अंतर्निहित AI सुविधाओं वाला एक VS Code फ़ोर्क है। यह समान एक्सटेंशन पारिस्थितिकी तंत्र का उपयोग करता है, इसलिए Intlayer VS Code एक्सटेंशन बिना किसी अतिरिक्त कॉन्फ़िगरेशन के काम करता है — इसे एक बार इंस्टॉल करें और Cursor इसे स्वचालित रूप से चुन लेता है।
यदि आप मैन्युअल कॉन्फ़िगरेशन पसंद करते हैं, तो Cursor वर्कस्पेस रूट से .vscode/settings.json भी पढ़ता है, इसलिए उपरोक्त VS Code स्निपेट सीधे लागू होता है।
Windsurf में सेटअप
Windsurf (Codeium द्वारा) एक अन्य VS Code-आधारित एडिटर है। VS Code मार्केटप्लेस से Intlayer एक्सटेंशन इंस्टॉल करें और लैंग्वेज सर्वर स्वचालित रूप से सक्रिय हो जाता है, ठीक वैसे ही जैसे VS Code और Cursor में होता है।
मैन्युअल कॉन्फ़िगरेशन के लिए, प्रोजेक्ट रूट पर .vscode/settings.json बनाएं:
Zed में सेटअप
Zed में इसकी भाषा सेटिंग्स के माध्यम से मूल LSP समर्थन है। अपने Zed उपयोगकर्ता सेटिंग्स (~/.config/zed/settings.json) में एक प्रविष्टि जोड़ें:
"..." प्लेसहोल्डर Zed को Intlayer वाले के साथ अपने डिफ़ॉल्ट लैंग्वेज सर्वर्स को रखने के लिए कहता है।
AI एजेंट CLI (Claude Code, Codex, आदि) के लिए सेटअप
Claude Code में प्रथम श्रेणी का LSP प्लगइन समर्थन है — सीधे अपने टर्मिनल सत्रों में परिभाषा पर जाने का पूर्ण अनुभव प्राप्त करने के लिए उपरोक्त Claude Code प्लगइन सेटअप का पालन करें।
OpenAI Codex और अन्य टर्मिनल-आधारित उपकरण अभी तक LSP क्लाइंट के रूप में कार्य नहीं करते हैं — वे लगातार लैंग्वेज सर्वर सत्र बनाए रखने के बजाय सीधे फ़ाइलों को पढ़ते और लिखते हैं। उन उपकरणों के लिए, LSP चलने का मूल्य अप्रत्यक्ष रूप से आता है: जब सर्वर एक साथी एडिटर (VS Code, Cursor, Windsurf, ...) में सक्रिय होता है, तो एडिटर का लाइव इंडेक्स किसी भी AI एजेंट के लिए उपलब्ध होता है जो एडिटर द्वारा प्रदान किए गए संदर्भ (जैसे, Cursor Composer, Windsurf Cascade, GitHub Copilot Chat) के माध्यम से इसे क्वेरी कर सकता है।
यदि आप बिना एडिटर खोले विशुद्ध रूप से टर्मिनल में काम कर रहे हैं, तो आप बैकग्राउंड में लैंग्वेज सर्वर शुरू कर सकते हैं ताकि यह किसी भी एडिटर के लिए तैयार रहे जो बाद में उसी वर्कस्पेस से जुड़ता है:
Neovim में मैन्युअल सेटअप
nvim-lspconfig का उपयोग करके, एक कस्टम सर्वर कॉन्फ़िगरेशन पंजीकृत करें:
Neovim को पुनरारंभ करने के बाद, Intlayer कुंजी पर gd दबाने से परिभाषा पर जाएं कॉल होगा।
अन्य एडिटर्स में मैन्युअल सेटअप
कोई भी एडिटर जो लैंग्वेज सर्वर प्रोटोकॉल का समर्थन करता है, @intlayer/lsp का उपयोग कर सकता है। सर्वर:
- ट्रांसपोर्ट – Node.js IPC / stdio (मानक)
- एक्ज़ीक्यूटेबल –
npx @intlayer/lsp(या स्थानीय रूप से स्थापितintlayer-lspबाइनरी) - क्षमताएं –
definitionProvider: true,textDocumentSync: Incremental
सटीक कॉन्फ़िगरेशन प्रारूप के लिए अपने एडिटर के LSP दस्तावेज़ों से परामर्श लें (उदाहरण के लिए, coc.nvim के लिए languageserver.json, या Helix में LSP क्लाइंट सेटिंग्स)।
उदाहरण: coc.nvim
उदाहरण: Helix
यह कैसे काम करता है
जब सर्वर शुरू होता है, तो यह getConfiguration() का उपयोग करके वर्कस्पेस रूट से Intlayer कॉन्फ़िगरेशन को हल करता है। यह इसे संकलित डिक्शनरी खोजने के लिए आवश्यक build और system पथ देता है।
प्रत्येक परिभाषा पर जाएं अनुरोध पर:
- सर्वर खुली हुई दस्तावेज़ का पूरा टेक्स्ट पढ़ता.
- यह एक नियमित अभिव्यक्ति का उपयोग करके गेटर कॉल्स (
useIntlayer,getIntlayerआदि) को स्कैन करता है। - यह जांचता है कि क्या कर्सर की स्थिति उन कॉल्स में से किसी एक के अंदर आती है।
- यदि ऐसा होता है, तो यह डिक्शनरी कुंजी (रेगेक्स का कैप्चर समूह 3) निकालता है और उस कुंजी को घोषित करने वाली प्रत्येक कंटेंट फ़ाइल का पता लगाने के लिए
getUnmergedDictionaries()को कॉल करता है। - यह प्रत्येक मिलान वाली फ़ाइल को पढ़ता है और कर्सर को सटीक रूप से स्थान देने के लिए
key: "<key>"वाली सटीक लाइन ढूंढता है। - यह
Locationऑब्जेक्ट्स का एक सरणी लौटाता है — प्रति स्रोत फ़ाइल एक।
कॉन्फ़िगरेशन को सुस्ती से हल किया जाता है और प्रति सत्र कैश किया जाता है; यह प्रत्येक initialize अनुरोध पर रीसेट होता है (उदाहरण के लिए, जब आप एक नया वर्कस्पेस फ़ोल्डर खोलते हैं)।
समस्या निवारण
सभी डेटा सामग्री को स्पष्ट रूप से देखने के लिए तालिका को मोडल में खोलें
| लक्षण | संभावित कारण | समाधान |
|---|---|---|
| परिभाषा पर जाएं कुछ नहीं करता | सर्वर नहीं चल रहा है | जांचें कि क्या @intlayer/lsp इंस्टॉल है और एडिटर इसे लॉन्च कर रहा है |
| गलत वर्कस्पेस रूट का पता चला | एकाधिक वर्कस्पेस फ़ोल्डर | सुनिश्चित करें कि intlayer.config.ts वाली फ़ोल्डर पहली वर्कस्पेस फ़ोल्डर है |
| किसी कुंजी के लिए परिभाषाएँ नहीं मिलीं | कॉन्फ़िगरेशन हल नहीं हुआ | सत्यापित करें कि वर्कस्पेस रूट पर intlayer.config.ts (या .js) मौजूद है |
| सर्वर स्टार्टअप पर क्रैश हो जाता है | Node.js संस्करण बहुत पुराना है | Node.js ≥ 14.18 की आवश्यकता है |