monacopilot 0.15.1 → 0.15.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/build/index.js CHANGED
@@ -1,56 +1,71 @@
1
1
  'use strict';
2
2
 
3
- var U=["groq","openai","anthropic","google"],J={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-mini":"o1-mini","gemini-1.5-flash-8b":"gemini-1.5-flash-8b","gemini-1.5-flash":"gemini-1.5-flash","gemini-1.5-pro":"gemini-1.5-pro"},K={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},Z="anthropic",Q="claude-3-5-haiku",O={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models"},M=.1;var ee={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var fe={createEndpoint:()=>O.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:A(t),...!o&&{temperature:M},messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Pe={createEndpoint:()=>O.groq,createRequestBody:(t,e)=>({model:A(t),temperature:M,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},ye={createEndpoint:()=>O.anthropic,createRequestBody:(t,e)=>({model:A(t),temperature:M,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ee[t]}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},xe={createEndpoint:(t,e)=>`${O.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:A(t),system_instruction:{parts:{text:e.system}},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},I={openai:fe,groq:Pe,anthropic:ye,google:xe},te=(t,e,o)=>I[o].createEndpoint(t,e),oe=(t,e,o)=>I[e].createRequestBody(t,o),re=(t,e)=>I[e].createHeaders(t),ne=(t,e)=>I[e].parseCompletion(t),A=t=>J[t];var Re="\x1B[91m",ie="\x1B[93m",W="\x1B[0m",z="\x1B[1m",y=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${Re}${z}[MONACOPILOT ERROR] ${e}${W}`;return console.error(o),{message:e}},se=t=>{console.warn(`${ie}${z}[MONACOPILOT WARN] ${t}${W}`);};var L=(t,e,o)=>console.warn(`${ie}${z}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${W}`);var T=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,Y=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
3
+ var U=["groq","openai","anthropic","google"],J={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-mini":"o1-mini","gemini-1.5-flash-8b":"gemini-1.5-flash-8b","gemini-1.5-flash":"gemini-1.5-flash","gemini-1.5-pro":"gemini-1.5-pro"},K={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},Z="anthropic",Q="claude-3-5-haiku",x={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models"},M=.1;var T=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,W=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
4
4
  `),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(a=>a==="")?`
5
5
  `.repeat(e):s.join(`
6
6
  `)}let i=r.slice(0,e);return i.every(s=>s==="")?`
7
7
  `.repeat(e):i.join(`
8
- `)};var w=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],D=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ae=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),h=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),S=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var le=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok){let s=`
9
- `+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},Oe=(t,e)=>le(t,"GET",e),Te=(t,e,o)=>le(t,"POST",{...o,body:e}),N={GET:Oe,POST:Te};var pe=(t,e)=>{let o=D(t,e).trim(),r=ae(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var F=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,a)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=a,o=setTimeout(()=>{s(t(...i)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var ve=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n}=t,i=T([n,...e].filter(a=>typeof a=="string"&&!!a));return [`You are an expert ${i?`${i} `:""}developer assistant specialized in precise code completion.`,`Your primary task is to provide accurate, context-aware code completions that seamlessly integrate with existing codebases${o?` in '${o}'`:""}.`,`You must:
10
- - Generate only the exact code required.
11
- - Maintain strict adherence to provided instructions.
12
- - Follow established code patterns and conventions.
13
- - Consider the full context before generating code.`,r?.length?"Analyze and incorporate context from all provided related files to ensure consistent and appropriate code completion.":"",n?`Apply ${n}-specific best practices, idioms, and syntax conventions in all generated code.`:""].filter(Boolean).join(`
14
-
15
- `)},Ee=t=>t?.length?t.map(({path:e,content:o})=>`
8
+ `)};var I=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],A=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ee=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),h=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),L=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var te=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok){let s=`
9
+ `+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},Ce=(t,e)=>te(t,"GET",e),he=(t,e,o)=>te(t,"POST",{...o,body:e}),w={GET:Ce,POST:he};var oe=(t,e)=>{let o=A(t,e).trim(),r=ee(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var D=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,a)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=a,o=setTimeout(()=>{s(t(...i)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var fe=t=>t?.length?t.map(({path:e,content:o})=>`
16
10
  <related_file>
17
11
  <path>${e}</path>
18
- <content_context>
12
+ <content>
19
13
  \`\`\`
20
14
  ${o}
21
15
  \`\`\`
22
- </content_context>
16
+ </content>
23
17
  </related_file>`.trim()).join(`
24
18
 
25
- `):"",be=(t="",e)=>{let{relatedFiles:o}=e;return `
26
- <task_context>
27
- <primary_instructions>
28
- ${t.trim()}
29
- </primary_instructions>${o?.length?`
30
- <reference_files>
31
- ${Ee(o)}
32
- </reference_files>`:""}
33
- </task_context>`.trim()},ce=(t,e)=>({system:ve(e),user:be(t,e)});var Me=({textBeforeCursor:t="",textAfterCursor:e="",editorState:{completionMode:o},language:r,...n})=>{let i=`
34
- Given the ${r||"code"} context:
35
-
36
- ${t}<cursor>${e}
37
-
38
- CRITICAL RULES:
39
- 1. NEVER repeat text before <cursor>
40
- 2. Start EXACTLY at cursor position
41
- 3. Output ONLY new code
42
- 4. No explanations/comments
43
- 5. Do not add unnecessary quotes or backticks around code
44
- 6. Follow ${o} mode: ${o==="continue"?"continue writing":o==="insert"?"insert exactly missing code between":"complete block"}
45
- 7. Respect Monaco editor subwordSmart inline suggest mode (MANDATORY)
46
-
47
- Analyze context, maintain style, ensure syntax correctness. Provide ONLY the completion code without any explanations or comments.`.trim();return ce(i,{textBeforeCursor:t,textAfterCursor:e,editorState:{completionMode:o},language:r,...n})},de=Me;var G=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??Z,this.model=o.model??Q,this.validateInputs();}validateInputs(){if(!U.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${T(U)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!K[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${T(K[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},a=this.generatePrompt(n,s),{endpoint:l,requestBody:m,headers:c}=this.prepareRequestDetails(a);try{let d=await this.sendCompletionRequest(l,m,{...c,...i});return this.processCompletionResponse(d)}catch(d){return this.handleCompletionError(d)}}generatePrompt(e,o){let r=de(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=te(this.model,this.apiKey,this.provider),r,n=re(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let i=this.model.config(this.apiKey,e);o=i.endpoint??o,r=i.body??{},n={...n,...i.headers};}else r=oe(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return N.POST(e,o,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&L("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return {completion:ne(e,this.provider),raw:e}}handleCompletionError(e){return {error:y(e).message,completion:null}}};var _=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
19
+ `):"",re=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:a}}=t,l=T([n,...e].filter(p=>typeof p=="string"&&!!p)),d=`You are an expert ${l?`${l} `:""}AI code completion assistant specialized in generating precise, contextually-aware code completions.
20
+
21
+ ROLE AND CONTEXT:
22
+ - You complete code exactly where the <cursor> placeholder is located in the provided code
23
+ - You are working in file: ${o||"current file"}
24
+ - Primary language: ${n||"detected from context"}
25
+ - Completion mode: ${a}
26
+
27
+ CRITICAL COMPLETION RULES:
28
+ 1. Generate ONLY the exact code needed at cursor position - no explanations, no comments
29
+ 2. NEVER repeat any code that appears before <cursor>
30
+ 3. Start completion EXACTLY at cursor position
31
+ 4. Maintain consistent code style and patterns with surrounding code
32
+ 5. Preserve proper spacing and indentation:
33
+ - Add spaces between tokens for readability
34
+ - Match existing indentation patterns
35
+ - Use appropriate newlines for multi-line completions
36
+ 6. Follow ${a} mode requirements:
37
+ ${a==="continue"?"- Continue writing code naturally from cursor position":a==="insert"?"- Insert precisely fitting code between before/after cursor segments":"- Complete the current code block or structure"}
38
+ 7. Respect Monaco editor's subwordSmart inline suggestion behavior
39
+ 8. Ensure completions are syntactically correct and contextually appropriate
40
+ 9. Consider and maintain consistency with any provided related files
41
+
42
+ COMPLETION SPACING AND INDENTATION EXAMPLES:
43
+ 1. Input: "console.log('Hello<cursor>');"
44
+ Output: " World" (note the leading space)
45
+
46
+ 2. Input: "function calc(a,<cursor>)"
47
+ Output: " b, c" (note the spaces around parameters)
48
+
49
+ 3. Input:
50
+ {
51
+ name: "John",
52
+ <cursor>
53
+ }
54
+ Output: "age: 30,
55
+ city: 'New York'" (note indentation)
56
+
57
+ Analyze all context carefully before generating completions. Ensure high relevance and accuracy.`,c=`${fe(r)}
58
+
59
+ Current code with cursor position:
60
+ \`\`\`
61
+ ${i}<cursor>${s}
62
+ \`\`\``;return {system:d,user:c}};var ne={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var Pe={createEndpoint:()=>x.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:S(t),...!o&&{temperature:M},messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},ye={createEndpoint:()=>x.groq,createRequestBody:(t,e)=>({model:S(t),temperature:M,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Re={createEndpoint:()=>x.anthropic,createRequestBody:(t,e)=>({model:S(t),temperature:M,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ne[t]}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},Oe={createEndpoint:(t,e)=>`${x.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:S(t),system_instruction:{parts:{text:e.system}},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},N={openai:Pe,groq:ye,anthropic:Re,google:Oe},ie=(t,e,o)=>N[o].createEndpoint(t,e),se=(t,e,o)=>N[e].createRequestBody(t,o),ae=(t,e)=>N[e].createHeaders(t),le=(t,e)=>N[e].parseCompletion(t),S=t=>J[t];var xe="\x1B[91m",pe="\x1B[93m",z="\x1B[0m",Y="\x1B[1m",y=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${xe}${Y}[MONACOPILOT ERROR] ${e}${z}`;return console.error(o),{message:e}},ce=t=>{console.warn(`${pe}${Y}[MONACOPILOT WARN] ${t}${z}`);};var B=(t,e,o)=>console.warn(`${pe}${Y}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${z}`);var G=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??Z,this.model=o.model??Q,this.validateInputs();}validateInputs(){if(!U.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${T(U)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!K[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${T(K[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},a=this.generatePrompt(n,s),{endpoint:l,requestBody:d,headers:c}=this.prepareRequestDetails(a);try{let p=await this.sendCompletionRequest(l,d,{...c,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let r=re(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=ie(this.model,this.apiKey,this.provider),r,n=ae(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let i=this.model.config(this.apiKey,e);o=i.endpoint??o,r=i.body??{},n={...n,...i.headers};}else r=se(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return w.POST(e,o,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&B("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return {completion:le(e,this.provider),raw:e}}handleCompletionError(e){return {error:y(e).message,completion:null}}};var F=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
48
63
  `).slice(1,-1).join(`
49
64
  `);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
50
65
 
51
- `),this}build(){return this.formattedCompletion}};var B=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !pe(this.cursorPos,this.mdl)}};var q=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let o;return this.size===this.capacity&&(o=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,o}dequeue(){if(this.size===0)return;let e=this.buffer[this.head];return this.buffer[this.head]=void 0,this.head=(this.head+1)%this.capacity,this.size--,e}getAll(){return this.buffer.filter(e=>e!==void 0)}clear(){this.buffer=new Array(this.capacity),this.head=0,this.tail=0,this.size=0;}getSize(){return this.size}isEmpty(){return this.size===0}isFull(){return this.size===this.capacity}};var g=class g{constructor(){this.cache=new q(g.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return h(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:a,endLineNumber:l,endColumn:m}=n,{lineNumber:c,column:d}=o,p=c===s&&d===a;if(s===l)return p||i.startsWith(r)&&c===s&&d>=a-g.LOOK_AROUND&&d<=m+g.LOOK_AROUND;let u=i.startsWith(r)&&c>=s&&c<=l&&(c===s&&d>=a-g.LOOK_AROUND||c===l&&d<=m+g.LOOK_AROUND||c>s&&c<l);return p||u}};g.MAX_CACHE_SIZE=10,g.LOOK_AROUND=10;var k=g;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,r){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=w(e,r),i=o[0];if(!n||i===n)return this.calculateRangeWithoutOverlap(e,o);let s=r.getOffsetAt(e),a=h(e,r),l=S(e,r);if(s>=r.getValue().length||!l.length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let m=this.getSuffixOverlapLength(o,a),c=this.computeMaxOverlapLength(o,l),d=m>0?r.getPositionAt(s-m):e,p=s+c,u=r.getPositionAt(p);return new this.monaco.Range(d.lineNumber,d.column,u.lineNumber,u.column)}calculateRangeWithoutOverlap(e,o){let r=e.lineNumber,n=e.column,i=o.split(`
52
- `),s=i.length-1,a=r+s,l=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,a,l)}computeMaxOverlapLength(e,o){let r=this.getPrefixOverlapLength(e,o),n=this.getSuffixPrefixOverlapLength(e,o),i=Math.max(r,n);return i===0&&(i=this.getInternalOverlapLength(e,o)),i}getSuffixOverlapLength(e,o){let r=Math.min(e.length,o.length),n=0;for(let i=1;i<=r;i++)e.substring(0,i)===o.slice(-i)&&(n=i);return n}getPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=0;n<r;n++)if(e[n]!==o[n])return n;return r}getSuffixPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=r;n>0;n--)if(e.slice(-n)===o.slice(0,n))return n;return 0}getInternalOverlapLength(e,o){for(let r=1;r<e.length;r++)if(o.startsWith(e.substring(r)))return e.length-r;return 0}};var Ie="application/json",me=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await N.POST(e,o,{headers:{"Content-Type":Ie},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},ue=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:a}=o,l=Ae(t,e),c=!!s?.length?3:2,d=a?Math.floor(a/c):void 0,p=(P,C,V)=>{let b=P(t,e);return C?Y(b,C,V):b},u=(P,C)=>!P||!C?P:P.map(({content:V,...b})=>({...b,content:Y(V,C)})),j=p(h,d,{from:"end"}),E=p(S,d),R=u(s,d);return {filename:r,language:n,technologies:i,relatedFiles:R,textBeforeCursor:j,textAfterCursor:E,cursorPosition:t,editorState:{completionMode:l}}},Ae=(t,e)=>{let o=w(t,e),r=D(t,e);return o?"insert":r.trim()?"complete":"continue"};var ge=t=>_.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),f=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var X={onTyping:300,onIdle:600,onDemand:0},we=t=>({onTyping:F(t,X.onTyping),onIdle:F(t,X.onIdle),onDemand:F(t,X.onDemand)}),H=new k,De=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:a="onIdle",endpoint:l,enableCaching:m=!0,onError:c,requestHandler:d}=s;if(!new B(o,e).shouldProvideCompletions())return f([]);if(m){let p=H.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(p.length>0)return i(),f(p)}if(r.isCancellationRequested||n)return f([]);try{let u=we(d??me)[a];r.onCancellationRequested(()=>{u.cancel();});let j=ue({pos:o,mdl:e,options:s}),{completion:E}=await u({endpoint:l,body:{completionMetadata:j}});if(E){let R=ge(E),C=new $(t).computeInsertionRange(o,R,e);return m&&H.add({completion:R,range:C,textBeforeCursor:h(o,e)}),i(),f([{insertText:R,range:C}])}}catch(p){if(Se(p))return f([]);c?c(p):y(p);}return f([])},Se=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,Ce=De;var x=new WeakMap,v=null,he=(t,e,o)=>{v&&v.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};x.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(l,m,c,d)=>{let p=x.get(e);if(!(!p||o.trigger==="onDemand"&&!p.isManualTrigger))return Ce({monaco:t,mdl:l,pos:m,token:d,isCompletionAccepted:p.isCompletionAccepted,onShowCompletion:()=>{p.isCompletionVisible=!0,p.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(l=>{let m=x.get(e);if(!m)return;let c=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;m.isCompletionVisible&&c?(m.isCompletionAccepted=!0,m.isCompletionVisible=!1):m.isCompletionAccepted=!1;});r.push(s);let a={deregister:()=>{r.forEach(l=>l.dispose()),H.clear(),x.delete(e),v=null;},trigger:()=>Ne(e)};return v=a,a}catch(i){return o.onError?o.onError(i):y(i),{deregister:()=>{r.forEach(s=>s.dispose()),x.delete(e),v=null;},trigger:()=>{}}}},Ne=t=>{let e=x.get(t);if(!e){se("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},Fe=(...t)=>(L("registerCopilot","registerCompletion"),he(...t));
66
+ `),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !oe(this.cursorPos,this.mdl)}};var k=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let o;return this.size===this.capacity&&(o=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,o}dequeue(){if(this.size===0)return;let e=this.buffer[this.head];return this.buffer[this.head]=void 0,this.head=(this.head+1)%this.capacity,this.size--,e}getAll(){return this.buffer.filter(e=>e!==void 0)}clear(){this.buffer=new Array(this.capacity),this.head=0,this.tail=0,this.size=0;}getSize(){return this.size}isEmpty(){return this.size===0}isFull(){return this.size===this.capacity}};var g=class g{constructor(){this.cache=new k(g.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return h(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:a,endLineNumber:l,endColumn:d}=n,{lineNumber:c,column:p}=o,m=c===s&&p===a;if(s===l)return m||i.startsWith(r)&&c===s&&p>=a-g.LOOK_AROUND&&p<=d+g.LOOK_AROUND;let u=i.startsWith(r)&&c>=s&&c<=l&&(c===s&&p>=a-g.LOOK_AROUND||c===l&&p<=d+g.LOOK_AROUND||c>s&&c<l);return m||u}};g.MAX_CACHE_SIZE=10,g.LOOK_AROUND=10;var _=g;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,r){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=I(e,r),i=o[0];if(!n||i===n)return this.calculateRangeWithoutOverlap(e,o);let s=r.getOffsetAt(e),a=h(e,r),l=L(e,r);if(s>=r.getValue().length||!l.length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let d=this.getSuffixOverlapLength(o,a),c=this.computeMaxOverlapLength(o,l),p=d>0?r.getPositionAt(s-d):e,m=s+c,u=r.getPositionAt(m);return new this.monaco.Range(p.lineNumber,p.column,u.lineNumber,u.column)}calculateRangeWithoutOverlap(e,o){let r=e.lineNumber,n=e.column,i=o.split(`
67
+ `),s=i.length-1,a=r+s,l=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,a,l)}computeMaxOverlapLength(e,o){let r=this.getPrefixOverlapLength(e,o),n=this.getSuffixPrefixOverlapLength(e,o),i=Math.max(r,n);return i===0&&(i=this.getInternalOverlapLength(e,o)),i}getSuffixOverlapLength(e,o){let r=Math.min(e.length,o.length),n=0;for(let i=1;i<=r;i++)e.substring(0,i)===o.slice(-i)&&(n=i);return n}getPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=0;n<r;n++)if(e[n]!==o[n])return n;return r}getSuffixPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=r;n>0;n--)if(e.slice(-n)===o.slice(0,n))return n;return 0}getInternalOverlapLength(e,o){for(let r=1;r<e.length;r++)if(o.startsWith(e.substring(r)))return e.length-r;return 0}};var Te="application/json",de=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await w.POST(e,o,{headers:{"Content-Type":Te},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},me=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:a}=o,l=Ee(t,e),c=!!s?.length?3:2,p=a?Math.floor(a/c):void 0,m=(P,C,j)=>{let b=P(t,e);return C?W(b,C,j):b},u=(P,C)=>!P||!C?P:P.map(({content:j,...b})=>({...b,content:W(j,C)})),V=m(h,p,{from:"end"}),v=m(L,p),O=u(s,p);return {filename:r,language:n,technologies:i,relatedFiles:O,textBeforeCursor:V,textAfterCursor:v,cursorPosition:t,editorState:{completionMode:l}}},Ee=(t,e)=>{let o=I(t,e),r=A(t,e);return o?"insert":r.trim()?"complete":"continue"};var f=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var X={onTyping:300,onIdle:600,onDemand:0},be=t=>({onTyping:D(t,X.onTyping),onIdle:D(t,X.onIdle),onDemand:D(t,X.onDemand)}),H=new _,Me=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:a="onIdle",endpoint:l,enableCaching:d=!0,onError:c,requestHandler:p}=s;if(!new q(o,e).shouldProvideCompletions())return f([]);if(d){let m=H.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(m.length>0)return i(),f(m)}if(r.isCancellationRequested||n)return f([]);try{let u=be(p??de)[a];r.onCancellationRequested(()=>{u.cancel();});let V=me({pos:o,mdl:e,options:s}),{completion:v}=await u({endpoint:l,body:{completionMetadata:V}});if(v){let O=F.create(v).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),C=new $(t).computeInsertionRange(o,O,e);return d&&H.add({completion:O,range:C,textBeforeCursor:h(o,e)}),i(),f([{insertText:O,range:C}])}}catch(m){if(Ie(m))return f([]);c?c(m):y(m);}return f([])},Ie=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,ue=Me;var R=new WeakMap,E=null,ge=(t,e,o)=>{E&&E.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};R.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(l,d,c,p)=>{let m=R.get(e);if(!(!m||o.trigger==="onDemand"&&!m.isManualTrigger))return ue({monaco:t,mdl:l,pos:d,token:p,isCompletionAccepted:m.isCompletionAccepted,onShowCompletion:()=>{m.isCompletionVisible=!0,m.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(l=>{let d=R.get(e);if(!d)return;let c=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;d.isCompletionVisible&&c?(d.isCompletionAccepted=!0,d.isCompletionVisible=!1):d.isCompletionAccepted=!1;});r.push(s);let a={deregister:()=>{r.forEach(l=>l.dispose()),H.clear(),R.delete(e),E=null;},trigger:()=>Ae(e)};return E=a,a}catch(i){return o.onError?o.onError(i):y(i),{deregister:()=>{r.forEach(s=>s.dispose()),R.delete(e),E=null;},trigger:()=>{}}}},Ae=t=>{let e=R.get(t);if(!e){ce("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},Le=(...t)=>(B("registerCopilot","registerCompletion"),ge(...t));
53
68
 
54
69
  exports.Copilot = G;
55
- exports.registerCompletion = he;
56
- exports.registerCopilot = Fe;
70
+ exports.registerCompletion = ge;
71
+ exports.registerCopilot = Le;
package/build/index.mjs CHANGED
@@ -1,52 +1,67 @@
1
- var U=["groq","openai","anthropic","google"],J={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-mini":"o1-mini","gemini-1.5-flash-8b":"gemini-1.5-flash-8b","gemini-1.5-flash":"gemini-1.5-flash","gemini-1.5-pro":"gemini-1.5-pro"},K={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},Z="anthropic",Q="claude-3-5-haiku",O={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models"},M=.1;var ee={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var fe={createEndpoint:()=>O.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:A(t),...!o&&{temperature:M},messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Pe={createEndpoint:()=>O.groq,createRequestBody:(t,e)=>({model:A(t),temperature:M,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},ye={createEndpoint:()=>O.anthropic,createRequestBody:(t,e)=>({model:A(t),temperature:M,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ee[t]}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},xe={createEndpoint:(t,e)=>`${O.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:A(t),system_instruction:{parts:{text:e.system}},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},I={openai:fe,groq:Pe,anthropic:ye,google:xe},te=(t,e,o)=>I[o].createEndpoint(t,e),oe=(t,e,o)=>I[e].createRequestBody(t,o),re=(t,e)=>I[e].createHeaders(t),ne=(t,e)=>I[e].parseCompletion(t),A=t=>J[t];var Re="\x1B[91m",ie="\x1B[93m",W="\x1B[0m",z="\x1B[1m",y=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${Re}${z}[MONACOPILOT ERROR] ${e}${W}`;return console.error(o),{message:e}},se=t=>{console.warn(`${ie}${z}[MONACOPILOT WARN] ${t}${W}`);};var L=(t,e,o)=>console.warn(`${ie}${z}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${W}`);var T=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,Y=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
1
+ var U=["groq","openai","anthropic","google"],J={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-mini":"o1-mini","gemini-1.5-flash-8b":"gemini-1.5-flash-8b","gemini-1.5-flash":"gemini-1.5-flash","gemini-1.5-pro":"gemini-1.5-pro"},K={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},Z="anthropic",Q="claude-3-5-haiku",x={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models"},M=.1;var T=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,W=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
2
2
  `),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(a=>a==="")?`
3
3
  `.repeat(e):s.join(`
4
4
  `)}let i=r.slice(0,e);return i.every(s=>s==="")?`
5
5
  `.repeat(e):i.join(`
6
- `)};var w=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],D=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ae=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),h=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),S=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var le=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok){let s=`
7
- `+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},Oe=(t,e)=>le(t,"GET",e),Te=(t,e,o)=>le(t,"POST",{...o,body:e}),N={GET:Oe,POST:Te};var pe=(t,e)=>{let o=D(t,e).trim(),r=ae(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var F=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,a)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=a,o=setTimeout(()=>{s(t(...i)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var ve=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n}=t,i=T([n,...e].filter(a=>typeof a=="string"&&!!a));return [`You are an expert ${i?`${i} `:""}developer assistant specialized in precise code completion.`,`Your primary task is to provide accurate, context-aware code completions that seamlessly integrate with existing codebases${o?` in '${o}'`:""}.`,`You must:
8
- - Generate only the exact code required.
9
- - Maintain strict adherence to provided instructions.
10
- - Follow established code patterns and conventions.
11
- - Consider the full context before generating code.`,r?.length?"Analyze and incorporate context from all provided related files to ensure consistent and appropriate code completion.":"",n?`Apply ${n}-specific best practices, idioms, and syntax conventions in all generated code.`:""].filter(Boolean).join(`
12
-
13
- `)},Ee=t=>t?.length?t.map(({path:e,content:o})=>`
6
+ `)};var I=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],A=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ee=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),h=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),L=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var te=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok){let s=`
7
+ `+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},Ce=(t,e)=>te(t,"GET",e),he=(t,e,o)=>te(t,"POST",{...o,body:e}),w={GET:Ce,POST:he};var oe=(t,e)=>{let o=A(t,e).trim(),r=ee(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var D=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,a)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=a,o=setTimeout(()=>{s(t(...i)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var fe=t=>t?.length?t.map(({path:e,content:o})=>`
14
8
  <related_file>
15
9
  <path>${e}</path>
16
- <content_context>
10
+ <content>
17
11
  \`\`\`
18
12
  ${o}
19
13
  \`\`\`
20
- </content_context>
14
+ </content>
21
15
  </related_file>`.trim()).join(`
22
16
 
23
- `):"",be=(t="",e)=>{let{relatedFiles:o}=e;return `
24
- <task_context>
25
- <primary_instructions>
26
- ${t.trim()}
27
- </primary_instructions>${o?.length?`
28
- <reference_files>
29
- ${Ee(o)}
30
- </reference_files>`:""}
31
- </task_context>`.trim()},ce=(t,e)=>({system:ve(e),user:be(t,e)});var Me=({textBeforeCursor:t="",textAfterCursor:e="",editorState:{completionMode:o},language:r,...n})=>{let i=`
32
- Given the ${r||"code"} context:
33
-
34
- ${t}<cursor>${e}
35
-
36
- CRITICAL RULES:
37
- 1. NEVER repeat text before <cursor>
38
- 2. Start EXACTLY at cursor position
39
- 3. Output ONLY new code
40
- 4. No explanations/comments
41
- 5. Do not add unnecessary quotes or backticks around code
42
- 6. Follow ${o} mode: ${o==="continue"?"continue writing":o==="insert"?"insert exactly missing code between":"complete block"}
43
- 7. Respect Monaco editor subwordSmart inline suggest mode (MANDATORY)
44
-
45
- Analyze context, maintain style, ensure syntax correctness. Provide ONLY the completion code without any explanations or comments.`.trim();return ce(i,{textBeforeCursor:t,textAfterCursor:e,editorState:{completionMode:o},language:r,...n})},de=Me;var G=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??Z,this.model=o.model??Q,this.validateInputs();}validateInputs(){if(!U.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${T(U)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!K[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${T(K[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},a=this.generatePrompt(n,s),{endpoint:l,requestBody:m,headers:c}=this.prepareRequestDetails(a);try{let d=await this.sendCompletionRequest(l,m,{...c,...i});return this.processCompletionResponse(d)}catch(d){return this.handleCompletionError(d)}}generatePrompt(e,o){let r=de(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=te(this.model,this.apiKey,this.provider),r,n=re(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let i=this.model.config(this.apiKey,e);o=i.endpoint??o,r=i.body??{},n={...n,...i.headers};}else r=oe(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return N.POST(e,o,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&L("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return {completion:ne(e,this.provider),raw:e}}handleCompletionError(e){return {error:y(e).message,completion:null}}};var _=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
17
+ `):"",re=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:a}}=t,l=T([n,...e].filter(p=>typeof p=="string"&&!!p)),d=`You are an expert ${l?`${l} `:""}AI code completion assistant specialized in generating precise, contextually-aware code completions.
18
+
19
+ ROLE AND CONTEXT:
20
+ - You complete code exactly where the <cursor> placeholder is located in the provided code
21
+ - You are working in file: ${o||"current file"}
22
+ - Primary language: ${n||"detected from context"}
23
+ - Completion mode: ${a}
24
+
25
+ CRITICAL COMPLETION RULES:
26
+ 1. Generate ONLY the exact code needed at cursor position - no explanations, no comments
27
+ 2. NEVER repeat any code that appears before <cursor>
28
+ 3. Start completion EXACTLY at cursor position
29
+ 4. Maintain consistent code style and patterns with surrounding code
30
+ 5. Preserve proper spacing and indentation:
31
+ - Add spaces between tokens for readability
32
+ - Match existing indentation patterns
33
+ - Use appropriate newlines for multi-line completions
34
+ 6. Follow ${a} mode requirements:
35
+ ${a==="continue"?"- Continue writing code naturally from cursor position":a==="insert"?"- Insert precisely fitting code between before/after cursor segments":"- Complete the current code block or structure"}
36
+ 7. Respect Monaco editor's subwordSmart inline suggestion behavior
37
+ 8. Ensure completions are syntactically correct and contextually appropriate
38
+ 9. Consider and maintain consistency with any provided related files
39
+
40
+ COMPLETION SPACING AND INDENTATION EXAMPLES:
41
+ 1. Input: "console.log('Hello<cursor>');"
42
+ Output: " World" (note the leading space)
43
+
44
+ 2. Input: "function calc(a,<cursor>)"
45
+ Output: " b, c" (note the spaces around parameters)
46
+
47
+ 3. Input:
48
+ {
49
+ name: "John",
50
+ <cursor>
51
+ }
52
+ Output: "age: 30,
53
+ city: 'New York'" (note indentation)
54
+
55
+ Analyze all context carefully before generating completions. Ensure high relevance and accuracy.`,c=`${fe(r)}
56
+
57
+ Current code with cursor position:
58
+ \`\`\`
59
+ ${i}<cursor>${s}
60
+ \`\`\``;return {system:d,user:c}};var ne={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var Pe={createEndpoint:()=>x.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:S(t),...!o&&{temperature:M},messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},ye={createEndpoint:()=>x.groq,createRequestBody:(t,e)=>({model:S(t),temperature:M,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Re={createEndpoint:()=>x.anthropic,createRequestBody:(t,e)=>({model:S(t),temperature:M,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ne[t]}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},Oe={createEndpoint:(t,e)=>`${x.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:S(t),system_instruction:{parts:{text:e.system}},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},N={openai:Pe,groq:ye,anthropic:Re,google:Oe},ie=(t,e,o)=>N[o].createEndpoint(t,e),se=(t,e,o)=>N[e].createRequestBody(t,o),ae=(t,e)=>N[e].createHeaders(t),le=(t,e)=>N[e].parseCompletion(t),S=t=>J[t];var xe="\x1B[91m",pe="\x1B[93m",z="\x1B[0m",Y="\x1B[1m",y=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${xe}${Y}[MONACOPILOT ERROR] ${e}${z}`;return console.error(o),{message:e}},ce=t=>{console.warn(`${pe}${Y}[MONACOPILOT WARN] ${t}${z}`);};var B=(t,e,o)=>console.warn(`${pe}${Y}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${z}`);var G=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??Z,this.model=o.model??Q,this.validateInputs();}validateInputs(){if(!U.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${T(U)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!K[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${T(K[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},a=this.generatePrompt(n,s),{endpoint:l,requestBody:d,headers:c}=this.prepareRequestDetails(a);try{let p=await this.sendCompletionRequest(l,d,{...c,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let r=re(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=ie(this.model,this.apiKey,this.provider),r,n=ae(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let i=this.model.config(this.apiKey,e);o=i.endpoint??o,r=i.body??{},n={...n,...i.headers};}else r=se(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return w.POST(e,o,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&B("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return {completion:le(e,this.provider),raw:e}}handleCompletionError(e){return {error:y(e).message,completion:null}}};var F=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
46
61
  `).slice(1,-1).join(`
47
62
  `);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
48
63
 
49
- `),this}build(){return this.formattedCompletion}};var B=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !pe(this.cursorPos,this.mdl)}};var q=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let o;return this.size===this.capacity&&(o=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,o}dequeue(){if(this.size===0)return;let e=this.buffer[this.head];return this.buffer[this.head]=void 0,this.head=(this.head+1)%this.capacity,this.size--,e}getAll(){return this.buffer.filter(e=>e!==void 0)}clear(){this.buffer=new Array(this.capacity),this.head=0,this.tail=0,this.size=0;}getSize(){return this.size}isEmpty(){return this.size===0}isFull(){return this.size===this.capacity}};var g=class g{constructor(){this.cache=new q(g.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return h(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:a,endLineNumber:l,endColumn:m}=n,{lineNumber:c,column:d}=o,p=c===s&&d===a;if(s===l)return p||i.startsWith(r)&&c===s&&d>=a-g.LOOK_AROUND&&d<=m+g.LOOK_AROUND;let u=i.startsWith(r)&&c>=s&&c<=l&&(c===s&&d>=a-g.LOOK_AROUND||c===l&&d<=m+g.LOOK_AROUND||c>s&&c<l);return p||u}};g.MAX_CACHE_SIZE=10,g.LOOK_AROUND=10;var k=g;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,r){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=w(e,r),i=o[0];if(!n||i===n)return this.calculateRangeWithoutOverlap(e,o);let s=r.getOffsetAt(e),a=h(e,r),l=S(e,r);if(s>=r.getValue().length||!l.length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let m=this.getSuffixOverlapLength(o,a),c=this.computeMaxOverlapLength(o,l),d=m>0?r.getPositionAt(s-m):e,p=s+c,u=r.getPositionAt(p);return new this.monaco.Range(d.lineNumber,d.column,u.lineNumber,u.column)}calculateRangeWithoutOverlap(e,o){let r=e.lineNumber,n=e.column,i=o.split(`
50
- `),s=i.length-1,a=r+s,l=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,a,l)}computeMaxOverlapLength(e,o){let r=this.getPrefixOverlapLength(e,o),n=this.getSuffixPrefixOverlapLength(e,o),i=Math.max(r,n);return i===0&&(i=this.getInternalOverlapLength(e,o)),i}getSuffixOverlapLength(e,o){let r=Math.min(e.length,o.length),n=0;for(let i=1;i<=r;i++)e.substring(0,i)===o.slice(-i)&&(n=i);return n}getPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=0;n<r;n++)if(e[n]!==o[n])return n;return r}getSuffixPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=r;n>0;n--)if(e.slice(-n)===o.slice(0,n))return n;return 0}getInternalOverlapLength(e,o){for(let r=1;r<e.length;r++)if(o.startsWith(e.substring(r)))return e.length-r;return 0}};var Ie="application/json",me=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await N.POST(e,o,{headers:{"Content-Type":Ie},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},ue=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:a}=o,l=Ae(t,e),c=!!s?.length?3:2,d=a?Math.floor(a/c):void 0,p=(P,C,V)=>{let b=P(t,e);return C?Y(b,C,V):b},u=(P,C)=>!P||!C?P:P.map(({content:V,...b})=>({...b,content:Y(V,C)})),j=p(h,d,{from:"end"}),E=p(S,d),R=u(s,d);return {filename:r,language:n,technologies:i,relatedFiles:R,textBeforeCursor:j,textAfterCursor:E,cursorPosition:t,editorState:{completionMode:l}}},Ae=(t,e)=>{let o=w(t,e),r=D(t,e);return o?"insert":r.trim()?"complete":"continue"};var ge=t=>_.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),f=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var X={onTyping:300,onIdle:600,onDemand:0},we=t=>({onTyping:F(t,X.onTyping),onIdle:F(t,X.onIdle),onDemand:F(t,X.onDemand)}),H=new k,De=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:a="onIdle",endpoint:l,enableCaching:m=!0,onError:c,requestHandler:d}=s;if(!new B(o,e).shouldProvideCompletions())return f([]);if(m){let p=H.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(p.length>0)return i(),f(p)}if(r.isCancellationRequested||n)return f([]);try{let u=we(d??me)[a];r.onCancellationRequested(()=>{u.cancel();});let j=ue({pos:o,mdl:e,options:s}),{completion:E}=await u({endpoint:l,body:{completionMetadata:j}});if(E){let R=ge(E),C=new $(t).computeInsertionRange(o,R,e);return m&&H.add({completion:R,range:C,textBeforeCursor:h(o,e)}),i(),f([{insertText:R,range:C}])}}catch(p){if(Se(p))return f([]);c?c(p):y(p);}return f([])},Se=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,Ce=De;var x=new WeakMap,v=null,he=(t,e,o)=>{v&&v.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};x.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(l,m,c,d)=>{let p=x.get(e);if(!(!p||o.trigger==="onDemand"&&!p.isManualTrigger))return Ce({monaco:t,mdl:l,pos:m,token:d,isCompletionAccepted:p.isCompletionAccepted,onShowCompletion:()=>{p.isCompletionVisible=!0,p.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(l=>{let m=x.get(e);if(!m)return;let c=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;m.isCompletionVisible&&c?(m.isCompletionAccepted=!0,m.isCompletionVisible=!1):m.isCompletionAccepted=!1;});r.push(s);let a={deregister:()=>{r.forEach(l=>l.dispose()),H.clear(),x.delete(e),v=null;},trigger:()=>Ne(e)};return v=a,a}catch(i){return o.onError?o.onError(i):y(i),{deregister:()=>{r.forEach(s=>s.dispose()),x.delete(e),v=null;},trigger:()=>{}}}},Ne=t=>{let e=x.get(t);if(!e){se("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},Fe=(...t)=>(L("registerCopilot","registerCompletion"),he(...t));
64
+ `),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !oe(this.cursorPos,this.mdl)}};var k=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let o;return this.size===this.capacity&&(o=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,o}dequeue(){if(this.size===0)return;let e=this.buffer[this.head];return this.buffer[this.head]=void 0,this.head=(this.head+1)%this.capacity,this.size--,e}getAll(){return this.buffer.filter(e=>e!==void 0)}clear(){this.buffer=new Array(this.capacity),this.head=0,this.tail=0,this.size=0;}getSize(){return this.size}isEmpty(){return this.size===0}isFull(){return this.size===this.capacity}};var g=class g{constructor(){this.cache=new k(g.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return h(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:a,endLineNumber:l,endColumn:d}=n,{lineNumber:c,column:p}=o,m=c===s&&p===a;if(s===l)return m||i.startsWith(r)&&c===s&&p>=a-g.LOOK_AROUND&&p<=d+g.LOOK_AROUND;let u=i.startsWith(r)&&c>=s&&c<=l&&(c===s&&p>=a-g.LOOK_AROUND||c===l&&p<=d+g.LOOK_AROUND||c>s&&c<l);return m||u}};g.MAX_CACHE_SIZE=10,g.LOOK_AROUND=10;var _=g;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,r){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=I(e,r),i=o[0];if(!n||i===n)return this.calculateRangeWithoutOverlap(e,o);let s=r.getOffsetAt(e),a=h(e,r),l=L(e,r);if(s>=r.getValue().length||!l.length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let d=this.getSuffixOverlapLength(o,a),c=this.computeMaxOverlapLength(o,l),p=d>0?r.getPositionAt(s-d):e,m=s+c,u=r.getPositionAt(m);return new this.monaco.Range(p.lineNumber,p.column,u.lineNumber,u.column)}calculateRangeWithoutOverlap(e,o){let r=e.lineNumber,n=e.column,i=o.split(`
65
+ `),s=i.length-1,a=r+s,l=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,a,l)}computeMaxOverlapLength(e,o){let r=this.getPrefixOverlapLength(e,o),n=this.getSuffixPrefixOverlapLength(e,o),i=Math.max(r,n);return i===0&&(i=this.getInternalOverlapLength(e,o)),i}getSuffixOverlapLength(e,o){let r=Math.min(e.length,o.length),n=0;for(let i=1;i<=r;i++)e.substring(0,i)===o.slice(-i)&&(n=i);return n}getPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=0;n<r;n++)if(e[n]!==o[n])return n;return r}getSuffixPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=r;n>0;n--)if(e.slice(-n)===o.slice(0,n))return n;return 0}getInternalOverlapLength(e,o){for(let r=1;r<e.length;r++)if(o.startsWith(e.substring(r)))return e.length-r;return 0}};var Te="application/json",de=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await w.POST(e,o,{headers:{"Content-Type":Te},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},me=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:a}=o,l=Ee(t,e),c=!!s?.length?3:2,p=a?Math.floor(a/c):void 0,m=(P,C,j)=>{let b=P(t,e);return C?W(b,C,j):b},u=(P,C)=>!P||!C?P:P.map(({content:j,...b})=>({...b,content:W(j,C)})),V=m(h,p,{from:"end"}),v=m(L,p),O=u(s,p);return {filename:r,language:n,technologies:i,relatedFiles:O,textBeforeCursor:V,textAfterCursor:v,cursorPosition:t,editorState:{completionMode:l}}},Ee=(t,e)=>{let o=I(t,e),r=A(t,e);return o?"insert":r.trim()?"complete":"continue"};var f=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var X={onTyping:300,onIdle:600,onDemand:0},be=t=>({onTyping:D(t,X.onTyping),onIdle:D(t,X.onIdle),onDemand:D(t,X.onDemand)}),H=new _,Me=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:a="onIdle",endpoint:l,enableCaching:d=!0,onError:c,requestHandler:p}=s;if(!new q(o,e).shouldProvideCompletions())return f([]);if(d){let m=H.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(m.length>0)return i(),f(m)}if(r.isCancellationRequested||n)return f([]);try{let u=be(p??de)[a];r.onCancellationRequested(()=>{u.cancel();});let V=me({pos:o,mdl:e,options:s}),{completion:v}=await u({endpoint:l,body:{completionMetadata:V}});if(v){let O=F.create(v).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),C=new $(t).computeInsertionRange(o,O,e);return d&&H.add({completion:O,range:C,textBeforeCursor:h(o,e)}),i(),f([{insertText:O,range:C}])}}catch(m){if(Ie(m))return f([]);c?c(m):y(m);}return f([])},Ie=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,ue=Me;var R=new WeakMap,E=null,ge=(t,e,o)=>{E&&E.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};R.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(l,d,c,p)=>{let m=R.get(e);if(!(!m||o.trigger==="onDemand"&&!m.isManualTrigger))return ue({monaco:t,mdl:l,pos:d,token:p,isCompletionAccepted:m.isCompletionAccepted,onShowCompletion:()=>{m.isCompletionVisible=!0,m.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(l=>{let d=R.get(e);if(!d)return;let c=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;d.isCompletionVisible&&c?(d.isCompletionAccepted=!0,d.isCompletionVisible=!1):d.isCompletionAccepted=!1;});r.push(s);let a={deregister:()=>{r.forEach(l=>l.dispose()),H.clear(),R.delete(e),E=null;},trigger:()=>Ae(e)};return E=a,a}catch(i){return o.onError?o.onError(i):y(i),{deregister:()=>{r.forEach(s=>s.dispose()),R.delete(e),E=null;},trigger:()=>{}}}},Ae=t=>{let e=R.get(t);if(!e){ce("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},Le=(...t)=>(B("registerCopilot","registerCompletion"),ge(...t));
51
66
 
52
- export { G as Copilot, he as registerCompletion, Fe as registerCopilot };
67
+ export { G as Copilot, ge as registerCompletion, Le as registerCopilot };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "monacopilot",
3
- "version": "0.15.1",
3
+ "version": "0.15.2",
4
4
  "description": "AI auto-completion plugin for Monaco Editor",
5
5
  "main": "./build/index.js",
6
6
  "module": "./build/index.mjs",