monacopilot 0.17.3 → 0.18.0

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/README.md CHANGED
@@ -46,6 +46,7 @@
46
46
  - [Completion Event Handlers](#completion-event-handlers)
47
47
  - [onCompletionShown](#oncompletionshown)
48
48
  - [onCompletionAccepted](#oncompletionaccepted)
49
+ - [onCompletionRejected](#oncompletionrejected)
49
50
  - [Copilot Options](#copilot-options)
50
51
  - [Changing the Provider and Model](#changing-the-provider-and-model)
51
52
  - [Custom Model](#custom-model)
@@ -53,6 +54,7 @@
53
54
  - [Custom Headers for LLM Requests](#custom-headers-for-llm-requests)
54
55
  - [Custom Prompt](#custom-prompt)
55
56
  - [Cross-Language API Handler Implementation](#cross-language-api-handler-implementation)
57
+ - [Security](#security)
56
58
  - [Contributing](#contributing)
57
59
 
58
60
  ### Examples
@@ -458,6 +460,19 @@ registerCompletion(monaco, editor, {
458
460
  });
459
461
  ```
460
462
 
463
+ #### onCompletionRejected
464
+
465
+ Event triggered when a completion suggestion is rejected by the user.
466
+
467
+ ```javascript
468
+ registerCompletion(monaco, editor, {
469
+ // ... other options
470
+ onCompletionRejected: () => {
471
+ console.log('Completion rejected');
472
+ },
473
+ });
474
+ ```
475
+
461
476
  ## Copilot Options
462
477
 
463
478
  ### Changing the Provider and Model
@@ -721,6 +736,12 @@ registerCompletion(monaco, editor, {
721
736
  });
722
737
  ```
723
738
 
739
+ ## Security
740
+
741
+ Monacopilot takes security seriously. Your code remains completely private since Monacopilot never stores or transmits code from the editor.
742
+
743
+ Additionally, your AI provider API keys are protected by being stored and used exclusively on your server-side API handler, never being exposed to the client side.
744
+
724
745
  ## Contributing
725
746
 
726
747
  For guidelines on contributing, please read the [contributing guide](https://github.com/arshad-yaseen/monacopilot/blob/main/CONTRIBUTING.md).
package/build/index.d.mts CHANGED
@@ -218,6 +218,10 @@ interface RegisterCompletionOptions {
218
218
  * Callback function triggered when a completion is accepted by the user.
219
219
  */
220
220
  onCompletionAccepted?: () => void;
221
+ /**
222
+ * Callback function triggered when a completion is rejected by the user.
223
+ */
224
+ onCompletionRejected?: () => void;
221
225
  }
222
226
  interface CompletionRegistration {
223
227
  /**
package/build/index.d.ts CHANGED
@@ -218,6 +218,10 @@ interface RegisterCompletionOptions {
218
218
  * Callback function triggered when a completion is accepted by the user.
219
219
  */
220
220
  onCompletionAccepted?: () => void;
221
+ /**
222
+ * Callback function triggered when a completion is rejected by the user.
223
+ */
224
+ onCompletionRejected?: () => void;
221
225
  }
222
226
  interface CompletionRegistration {
223
227
  /**
package/build/index.js CHANGED
@@ -1,12 +1,12 @@
1
1
  'use strict';
2
2
 
3
- var I=o=>!o||o.length===0?"":o.length===1?o[0]:`${o.slice(0,-1).join(", ")} and ${o.slice(-1)}`,ee=o=>o.charAt(0).toUpperCase()+o.slice(1),W=(o,e,t={})=>{if(e<=0)return "";let r=o.split(`
4
- `),i=r.length;if(e>=i)return o;if(t.from==="end"){let s=r.slice(-e);return s.every(m=>m==="")?`
3
+ var k=o=>!o||o.length===0?"":o.length===1?o[0]:`${o.slice(0,-1).join(", ")} and ${o.slice(-1)}`,oe=o=>o.charAt(0).toUpperCase()+o.slice(1),W=(o,e,t={})=>{if(e<=0)return "";let r=o.split(`
4
+ `),n=r.length;if(e>=n)return o;if(t.from==="end"){let s=r.slice(-e);return s.every(l=>l==="")?`
5
5
  `.repeat(e):s.join(`
6
- `)}let n=r.slice(0,e);return n.every(s=>s==="")?`
7
- `.repeat(e):n.join(`
8
- `)};var te=(o,e)=>e.getLineContent(o.lineNumber)[o.column-1];var oe=(o,e)=>e.getLineContent(o.lineNumber).slice(0,o.column-1),v=(o,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:o.lineNumber,endColumn:o.column}),X=(o,e)=>e.getValueInRange({startLineNumber:o.lineNumber,startColumn:o.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var re=async(o,e,t={})=>{let r=t.timeout??3e4,i=AbortSignal.timeout(r),n=t.signal?AbortSignal.any([i,t.signal]):i,s={"Content-Type":"application/json",...t.headers},m=e==="POST"&&t.body?JSON.stringify(t.body):void 0,c=await fetch(o,{method:e,headers:s,body:m,signal:n});if(!c.ok){let l=await c.json().catch(()=>null),p=l?`
9
- ${JSON.stringify(l,null,2)}`:"",a=t.fallbackError||"Network request failed";throw new Error(`${a} (${c.status})${p}`)}return c.json()},fe=(o,e)=>re(o,"GET",e),he=(o,e,t)=>re(o,"POST",{...t,body:e}),w={GET:fe,POST:he};var L=(o,e=600,t=200)=>{let r=null,i=0,n=null,s=null,m=!1,c=(...l)=>{if(m)return Promise.resolve(void 0);n=l;let p=Date.now(),a=p-i;i=p,r&&(clearTimeout(r),r=null);let u=a<t?e:t;return s=new Promise((f,T)=>{r=setTimeout(async()=>{m=!0;try{if(n){let C=await o(...n);f(C);}else f(void 0);}catch(C){T(C);}finally{m=!1,r=null,n=null;}},u);}),s};return c.cancel=()=>{r&&(clearTimeout(r),r=null),n=null;},c};var Pe=o=>!o||o.length===0?"":o.map(({path:e,content:t})=>`
6
+ `)}let i=r.slice(0,e);return i.every(s=>s==="")?`
7
+ `.repeat(e):i.join(`
8
+ `)};var re=(o,e)=>e.getLineContent(o.lineNumber)[o.column-1];var ne=(o,e)=>e.getLineContent(o.lineNumber).slice(0,o.column-1),v=(o,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:o.lineNumber,endColumn:o.column}),X=(o,e)=>e.getValueInRange({startLineNumber:o.lineNumber,startColumn:o.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var ie=async(o,e,t={})=>{let r=t.timeout??3e4,n=AbortSignal.timeout(r),i=t.signal?AbortSignal.any([n,t.signal]):n,s={"Content-Type":"application/json",...t.headers},l=e==="POST"&&t.body?JSON.stringify(t.body):void 0,p=await fetch(o,{method:e,headers:s,body:l,signal:i});if(!p.ok){let d=await p.json().catch(()=>null),c=d?`
9
+ ${JSON.stringify(d,null,2)}`:"",a=t.fallbackError||"Network request failed";throw new Error(`${a} (${p.status})${c}`)}return p.json()},Te=(o,e)=>ie(o,"GET",e),be=(o,e,t)=>ie(o,"POST",{...t,body:e}),S={GET:Te,POST:be};var w=(o,e=600,t=200)=>{let r=null,n=0,i=null,s=null,l=!1,p=(...d)=>{if(l)return Promise.resolve(void 0);i=d;let c=Date.now(),a=c-n;n=c,r&&(clearTimeout(r),r=null);let u=a<t?e:t;return s=new Promise((f,M)=>{r=setTimeout(async()=>{l=!0;try{if(i){let C=await o(...i);f(C);}else f(void 0);}catch(C){M(C);}finally{l=!1,r=null,i=null;}},u);}),s};return p.cancel=()=>{r&&(clearTimeout(r),r=null),i=null;},p};var ve=o=>!o||o.length===0?"":o.map(({path:e,content:t})=>`
10
10
  <related_file>
11
11
  <filePath>${e}</filePath>
12
12
  <fileContent>
@@ -16,34 +16,34 @@ ${t}
16
16
  </fileContent>
17
17
  </related_file>`.trim()).join(`
18
18
 
19
- `),ne=o=>{let{technologies:e=[],filename:t,relatedFiles:r,language:i,textBeforeCursor:n="",textAfterCursor:s="",editorState:{completionMode:m}}=o,c=I([i,...e].filter(a=>typeof a=="string"&&!!a)),l=`
19
+ `),se=o=>{let{technologies:e=[],filename:t,relatedFiles:r,language:n,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:l}}=o,p=k([n,...e].filter(a=>typeof a=="string"&&!!a)),d=`
20
20
  You are an expert code completion assistant.
21
21
 
22
22
  **Context:**
23
23
  File: ${t||"Untitled"}
24
- Language: ${i||"Undetermined"}
25
- Mode: ${m}
26
- Stack: ${c||"None"}`,p=`
24
+ Language: ${n||"Undetermined"}
25
+ Mode: ${l}
26
+ Stack: ${p||"None"}`,c=`
27
27
  **Related Files:**
28
- ${Pe(r)}
28
+ ${ve(r)}
29
29
 
30
30
  **Source:**
31
31
  \`\`\`
32
- ${n}<cursor>${s}
32
+ ${i}<cursor>${s}
33
33
  \`\`\`
34
34
 
35
- ${ee(m)} the code at <cursor>.
35
+ ${oe(l)} the code at <cursor>.
36
36
 
37
- Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:l,user:p}};var G=["groq","openai","anthropic","google","deepseek"],P={"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",v3:"deepseek-chat"},J={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"],deepseek:["v3"]},R={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",deepseek:"https://api.deepseek.com/beta/completions"};var g=class{};var N=class extends g{createEndpoint(){return R.anthropic}createRequestBody(e,t){return {model:P[e],temperature:.1,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}}parseCompletion(e){let t=e.content?.[0];return t&&"text"in t?t.text:null}};var S=class extends g{createEndpoint(){return R.deepseek}createRequestBody(e,t,r){return {model:P[e],prompt:r.textBeforeCursor,suffix:r.textAfterCursor,temperature:.1,max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return typeof e.choices?.[0]?.text=="string"?e.choices[0].text:null}};var _=class extends g{createEndpoint(e,t){return `${R.google}/${P[e]}:generateContent?key=${t}`}createRequestBody(e,t){return {systemInstruction:{role:"system",parts:[{text:t.system}]},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{role:"user",parts:[{text:t.user}]}]}}createHeaders(){return {"Content-Type":"application/json"}}parseCompletion(e){return e.candidates?.[0]?.content?.parts?.[0]?.text??null}};var B=class extends g{createEndpoint(){return R.groq}createRequestBody(e,t){return {model:P[e],temperature:.1,max_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var F=class extends g{createEndpoint(){return R.openai}createRequestBody(e,t){let r=e==="o1-mini";return {model:P[e],...!r&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var q={openai:new F,groq:new B,anthropic:new N,google:new _,deepseek:new S},ie=(o,e,t)=>q[t].createEndpoint(o,e),se=(o,e,t,r)=>q[e].createRequestBody(o,t,r),ae=(o,e)=>q[e].createHeaders(o),le=(o,e)=>q[e].parseCompletion(o);var Re="\x1B[91m",pe="\x1B[93m",Y="\x1B[0m",Z="\x1B[1m",me=o=>o instanceof Error?o.message:typeof o=="string"?o:"An unknown error occurred",$=o=>{let e=me(o),t=`${Re}${Z}[MONACOPILOT ERROR] ${e}${Y}`;return console.error(t),{message:e}},k=(o,e)=>{console.warn(`${pe}${Z}[MONACOPILOT WARN] ${o}${e?`
38
- ${me(e)}`:""}${Y}`);};var ce=(o,e,t)=>console.warn(`${pe}${Z}[MONACOPILOT DEPRECATED] "${o}" is deprecated${` in ${t}`}. Please use "${e}" instead. It will be removed in a future version.${Y}`);var Q=class{constructor(e,t){this.validateParams(e,t),this.apiKey=e,this.provider=t.provider,this.model=t.model,this.validateInputs();}validateParams(e,t){if(!e)throw new Error("Please provide an API key.");if(!t||typeof t=="object"&&Object.keys(t).length===0)throw new Error("Please provide options.")}validateInputs(){if(typeof this.model=="object"){if(this.provider!==void 0)throw new Error("Provider should not be specified when using a custom model.");if(!("config"in this.model)||!("transformResponse"in this.model))throw new Error("Please ensure both config and transformResponse are provided for custom model.");return}if(!this.provider||!G.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${I(G)}`);if(typeof this.model=="string"&&!J[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${I(J[this.provider])}`)}async complete(e){let{body:t,options:r}=e,{completionMetadata:i}=t,{headers:n={},customPrompt:s}=r??{},m=this.generatePrompt(i,s),{endpoint:c,requestBody:l,headers:p}=this.prepareRequestDetails(m,i);try{let a=await this.sendCompletionRequest(c,l,{...p,...n});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,t){let r=ne(e);return t?{...r,...t(e)}:r}prepareRequestDetails(e,t){if(typeof this.model=="object"&&"config"in this.model){let r=this.model.config(this.apiKey,e),i=r.endpoint,n=r.body??{},s=r.headers??{};return {endpoint:i,requestBody:n,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let r=ie(this.model,this.apiKey,this.provider),i=ae(this.apiKey,this.provider),n=se(this.model,this.provider,e,t);return {endpoint:r,requestBody:n,headers:i}}}async sendCompletionRequest(e,t,r){return w.POST(e,t,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let t=this.model.transformResponse(e);return "completion"in t&&ce("completion","text","Copilot.options.model.transformResponse"),{completion:t.text??t.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:le(e,this.provider),raw:e}}}handleCompletionError(e){return {error:$(e).message,completion:null}}};var H=class{constructor(e,t,r){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=t,this.textBeforeCursorInLine=r;}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}indentByColumn(){let e=this.formattedCompletion.split(`
37
+ Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:d,user:c}};var G=["groq","openai","anthropic","google","deepseek"],P={"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",v3:"deepseek-chat"},J={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"],deepseek:["v3"]},E={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",deepseek:"https://api.deepseek.com/beta/completions"};var g=class{};var L=class extends g{createEndpoint(){return E.anthropic}createRequestBody(e,t){return {model:P[e],temperature:.1,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}}parseCompletion(e){let t=e.content?.[0];return t&&"text"in t?t.text:null}};var N=class extends g{createEndpoint(){return E.deepseek}createRequestBody(e,t,r){return {model:P[e],prompt:r.textBeforeCursor,suffix:r.textAfterCursor,temperature:.1,max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return typeof e.choices?.[0]?.text=="string"?e.choices[0].text:null}};var _=class extends g{createEndpoint(e,t){return `${E.google}/${P[e]}:generateContent?key=${t}`}createRequestBody(e,t){return {systemInstruction:{role:"system",parts:[{text:t.system}]},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{role:"user",parts:[{text:t.user}]}]}}createHeaders(){return {"Content-Type":"application/json"}}parseCompletion(e){return e.candidates?.[0]?.content?.parts?.[0]?.text??null}};var B=class extends g{createEndpoint(){return E.groq}createRequestBody(e,t){return {model:P[e],temperature:.1,max_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var F=class extends g{createEndpoint(){return E.openai}createRequestBody(e,t){let r=e==="o1-mini";return {model:P[e],...!r&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var q={openai:new F,groq:new B,anthropic:new L,google:new _,deepseek:new N},ae=(o,e,t)=>q[t].createEndpoint(o,e),le=(o,e,t,r)=>q[e].createRequestBody(o,t,r),pe=(o,e)=>q[e].createHeaders(o),me=(o,e)=>q[e].parseCompletion(o);var Oe="\x1B[91m",ce="\x1B[93m",Y="\x1B[0m",Z="\x1B[1m",de=o=>o instanceof Error?o.message:typeof o=="string"?o:"An unknown error occurred",$=o=>{let e=de(o),t=`${Oe}${Z}[MONACOPILOT ERROR] ${e}${Y}`;return console.error(t),{message:e}},O=(o,e)=>{console.warn(`${ce}${Z}[MONACOPILOT WARN] ${o}${e?`
38
+ ${de(e)}`:""}${Y}`);};var ue=(o,e,t)=>console.warn(`${ce}${Z}[MONACOPILOT DEPRECATED] "${o}" is deprecated${` in ${t}`}. Please use "${e}" instead. It will be removed in a future version.${Y}`);var Q=class{constructor(e,t){this.validateParams(e,t),this.apiKey=e,this.provider=t.provider,this.model=t.model,this.validateInputs();}validateParams(e,t){if(!e)throw new Error("Please provide an API key.");if(!t||typeof t=="object"&&Object.keys(t).length===0)throw new Error("Please provide options.")}validateInputs(){if(typeof this.model=="object"){if(this.provider!==void 0)throw new Error("Provider should not be specified when using a custom model.");if(!("config"in this.model)||!("transformResponse"in this.model))throw new Error("Please ensure both config and transformResponse are provided for custom model.");return}if(!this.provider||!G.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${k(G)}`);if(typeof this.model=="string"&&!J[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${k(J[this.provider])}`)}async complete(e){let{body:t,options:r}=e,{completionMetadata:n}=t,{headers:i={},customPrompt:s}=r??{},l=this.generatePrompt(n,s),{endpoint:p,requestBody:d,headers:c}=this.prepareRequestDetails(l,n);try{let a=await this.sendCompletionRequest(p,d,{...c,...i});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,t){let r=se(e);return t?{...r,...t(e)}:r}prepareRequestDetails(e,t){if(typeof this.model=="object"&&"config"in this.model){let r=this.model.config(this.apiKey,e),n=r.endpoint,i=r.body??{},s=r.headers??{};return {endpoint:n,requestBody:i,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let r=ae(this.model,this.apiKey,this.provider),n=pe(this.apiKey,this.provider),i=le(this.model,this.provider,e,t);return {endpoint:r,requestBody:i,headers:n}}}async sendCompletionRequest(e,t,r){return S.POST(e,t,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let t=this.model.transformResponse(e);return "completion"in t&&ue("completion","text","Copilot.options.model.transformResponse"),{completion:t.text??t.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:me(e,this.provider),raw:e}}}handleCompletionError(e){return {error:$(e).message,completion:null}}};var j=class{constructor(e,t,r){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=t,this.textBeforeCursorInLine=r;}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}indentByColumn(){let e=this.formattedCompletion.split(`
39
39
  `);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let t=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
40
40
  `+e.slice(1).map(r=>t+r).join(`
41
- `),this}removeMarkdownCodeBlocks(e){let t=/```[\s\S]*?```/g,r=e,i;for(;(i=t.exec(e))!==null;){let n=i[0],s=n.split(`
41
+ `),this}removeMarkdownCodeBlocks(e){let t=/```[\s\S]*?```/g,r=e,n;for(;(n=t.exec(e))!==null;){let i=n[0],s=i.split(`
42
42
  `).slice(1,-1).join(`
43
- `);r=r.replace(n,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
43
+ `);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
44
44
 
45
- `),this}build(){return this.formattedCompletion}};var V=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let t;return this.size===this.capacity&&(t=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,t}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 U=class U{constructor(){this.cache=new V(U.MAX_CACHE_SIZE);}get(e,t){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,t))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,t,r){let i=r.getValueInRange(e.range),n=v(t,r);return n.length<e.textBeforeCursor.length||!n.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,t,i)}isPositionValid(e,t,r){let{range:i,completion:n}=e,{startLineNumber:s,startColumn:m,endLineNumber:c,endColumn:l}=i,{lineNumber:p,column:a}=t;if(!n.startsWith(r))return !1;let u=p===s&&a===m;if(s===c)return u||p===s&&a>=m&&a<=l;let f=p>s&&p<c?!0:p===s&&a>=m||p===c&&a<=l;return u||f}};U.MAX_CACHE_SIZE=10;var j=U;var K=class{constructor(e){this.monaco=e;}computeInsertionRange(e,t,r){if(!t)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let i=r.getOffsetAt(e),n=r.getValue().substring(0,i),s=r.getValue().substring(i),m=0,c=0,l=0,p=0,a=t.length,u=n.length,f=s.length;if(i>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(f===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let T=Math.min(a,u);for(let d=1;d<=T;d++){let b=t.substring(0,d),ge=n.slice(-d);b===ge&&(p=d);}let C=Math.min(a,f);for(let d=0;d<C&&t[d]===s[d];d++)m++;for(let d=1;d<=C;d++)t.slice(-d)===s.slice(0,d)&&(c=d);if(l=Math.max(m,c),l===0){for(let d=1;d<a;d++)if(s.startsWith(t.substring(d))){l=a-d;break}}let x=p>0?r.getPositionAt(i-p):e,y=i+l,h=r.getPositionAt(y);return new this.monaco.Range(x.lineNumber,x.column,h.lineNumber,h.column)}computeCacheRange(e,t){let r=e.lineNumber,i=e.column,n=t.split(`
46
- `),s=n.length-1,m=r+s,c=s===0?i+n[0].length:n[s].length+1;return new this.monaco.Range(r,i,m,c)}};var ye="application/json",de=async o=>{let{endpoint:e,body:t}=o,{completion:r,error:i}=await w.POST(e,t,{headers:{"Content-Type":ye},fallbackError:"Error while fetching completion item"});if(i)throw new Error(i);return {completion:r}},ue=({pos:o,mdl:e,options:t})=>{let{filename:r,language:i,technologies:n,relatedFiles:s,maxContextLines:m}=t,c=Ee(o,e),p=!!s?.length?3:2,a=m?Math.floor(m/p):void 0,u=(y,h,d)=>{let b=y(o,e);return h?W(b,h,d):b},f=(y,h)=>!y||!h?y:y.map(({content:d,...b})=>({...b,content:W(d,h)})),T=u(v,a,{from:"end"}),C=u(X,a),x=f(s,a);return {filename:r,language:i,technologies:n,relatedFiles:x,textBeforeCursor:T,textAfterCursor:C,cursorPosition:o,editorState:{completionMode:c}}},Ee=(o,e)=>{let t=te(o,e),r=X(o,e);return t?"insert":r.trim()?"complete":"continue"};var O=o=>({items:o,enableForwardStability:!0,suppressSuggestions:!0});var Te=o=>({onTyping:L(o,600,200),onIdle:L(o,600,400),onDemand:L(o,0,0)}),z=new j,xe=async({monaco:o,mdl:e,pos:t,token:r,isCompletionAccepted:i,options:n})=>{let{trigger:s="onIdle",endpoint:m,enableCaching:c=!0,onError:l,requestHandler:p}=n;if(c){let a=z.get(t,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return O(a)}if(r.isCancellationRequested||i)return O([]);try{let u=Te(p??de)[s];r.onCancellationRequested(()=>{u.cancel();});let f=ue({pos:t,mdl:e,options:n}),{completion:T}=await u({endpoint:m,body:{completionMetadata:f}});if(T){let C=new H(T,t.column,oe(t,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),x=new K(o),y=x.computeInsertionRange(t,C,e),h=x.computeCacheRange(t,C);return c&&z.add({completion:C,range:h,textBeforeCursor:v(t,e)}),O([{insertText:C,range:y}])}}catch(a){if(be(a))return O([]);l?l(a):k("Cannot provide completion",a);}return O([])},be=o=>typeof o=="string"?o==="Cancelled"||o==="AbortError":o instanceof Error?o.message==="Cancelled"||o.name==="AbortError":!1,Ce=xe;var D=new WeakMap,A=null,ve=(o,e,t)=>{A&&A.deregister();let r=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};D.set(e,i),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let n=D.get(e);if(!n)return k("Completion is not registered properly. State not found."),{deregister:()=>{},trigger:()=>{}};let s=o.languages.registerInlineCompletionsProvider(t.language,{provideInlineCompletions:(l,p,a,u)=>{if(!(t.trigger==="onDemand"&&!n.isManualTrigger))return Ce({monaco:o,mdl:l,pos:p,token:u,isCompletionAccepted:n.isCompletionAccepted,options:t})},handleItemDidShow:(l,p,a)=>{n.isCompletionVisible=!0,n.isManualTrigger=!1,!n.isCompletionAccepted&&t.onCompletionShown?.(a,p.range);},freeInlineCompletions:()=>{}});r.push(s);let m=e.onKeyDown(l=>{let p=l.keyCode===o.KeyCode.Tab||l.keyCode===o.KeyCode.RightArrow&&l.metaKey;n.isCompletionVisible&&p?(t.onCompletionAccepted?.(),n.isCompletionAccepted=!0,n.isCompletionVisible=!1):n.isCompletionAccepted=!1;});r.push(m);let c={deregister:()=>{r.forEach(l=>l.dispose()),z.clear(),D.delete(e),A=null;},trigger:()=>Oe(e)};return A=c,c}catch(n){return t.onError?t.onError(n):$(n),{deregister:()=>{r.forEach(s=>s.dispose()),D.delete(e),A=null;},trigger:()=>{}}}},Oe=o=>{let e=D.get(o);if(!e){k("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,o.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};
45
+ `),this}build(){return this.formattedCompletion}};var ee=new WeakMap,A=o=>ee.get(o),Ce=(o,e)=>{ee.set(o,e);},te=o=>{ee.delete(o);},ge=()=>({isCompletionAccepted:!1,isCompletionVisible:!1,isExplicitlyTriggered:!1,hasRejectedCurrentCompletion:!1});var H=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let t;return this.size===this.capacity&&(t=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,t}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 V=class V{constructor(){this.cache=new H(V.MAX_CACHE_SIZE);}get(e,t){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,t))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,t,r){let n=r.getValueInRange(e.range),i=v(t,r);return i.length<e.textBeforeCursor.length||!i.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,t,n)}isPositionValid(e,t,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:l,endLineNumber:p,endColumn:d}=n,{lineNumber:c,column:a}=t;if(!i.startsWith(r))return !1;let u=c===s&&a===l;if(s===p)return u||c===s&&a>=l&&a<=d;let f=c>s&&c<p?!0:c===s&&a>=l||c===p&&a<=d;return u||f}};V.MAX_CACHE_SIZE=10;var K=V;var U=class{constructor(e){this.monaco=e;}computeInsertionRange(e,t,r){if(!t)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=r.getOffsetAt(e),i=r.getValue().substring(0,n),s=r.getValue().substring(n),l=0,p=0,d=0,c=0,a=t.length,u=i.length,f=s.length;if(n>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(f===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let M=Math.min(a,u);for(let m=1;m<=M;m++){let b=t.substring(0,m),Me=i.slice(-m);b===Me&&(c=m);}let C=Math.min(a,f);for(let m=0;m<C&&t[m]===s[m];m++)l++;for(let m=1;m<=C;m++)t.slice(-m)===s.slice(0,m)&&(p=m);if(d=Math.max(l,p),d===0){for(let m=1;m<a;m++)if(s.startsWith(t.substring(m))){d=a-m;break}}let T=c>0?r.getPositionAt(n-c):e,R=n+d,h=r.getPositionAt(R);return new this.monaco.Range(T.lineNumber,T.column,h.lineNumber,h.column)}computeCacheRange(e,t){let r=e.lineNumber,n=e.column,i=t.split(`
46
+ `),s=i.length-1,l=r+s,p=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,l,p)}};var Ie="application/json",fe=async o=>{let{endpoint:e,body:t}=o,{completion:r,error:n}=await S.POST(e,t,{headers:{"Content-Type":Ie},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},he=({pos:o,mdl:e,options:t})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:l}=t,p=ke(o,e),c=!!s?.length?3:2,a=l?Math.floor(l/c):void 0,u=(R,h,m)=>{let b=R(o,e);return h?W(b,h,m):b},f=(R,h)=>!R||!h?R:R.map(({content:m,...b})=>({...b,content:W(m,h)})),M=u(v,a,{from:"end"}),C=u(X,a),T=f(s,a);return {filename:r,language:n,technologies:i,relatedFiles:T,textBeforeCursor:M,textAfterCursor:C,cursorPosition:o,editorState:{completionMode:p}}},ke=(o,e)=>{let t=re(o,e),r=X(o,e);return t?"insert":r.trim()?"complete":"continue"};var I=o=>({items:o,enableForwardStability:!0,suppressSuggestions:!0});var De=o=>({onTyping:w(o,600,200),onIdle:w(o,600,400),onDemand:w(o,0,0)}),z=new K,Pe=async({monaco:o,mdl:e,pos:t,token:r,isCompletionAccepted:n,options:i})=>{let{trigger:s="onIdle",endpoint:l,enableCaching:p=!0,onError:d,requestHandler:c}=i;if(p){let a=z.get(t,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return I(a)}if(r.isCancellationRequested||n)return I([]);try{let u=De(c??fe)[s];r.onCancellationRequested(()=>{u.cancel();});let f=he({pos:t,mdl:e,options:i}),{completion:M}=await u({endpoint:l,body:{completionMetadata:f}});if(M){let C=new j(M,t.column,ne(t,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),T=new U(o),R=T.computeInsertionRange(t,C,e),h=T.computeCacheRange(t,C);return p&&z.add({completion:C,range:h,textBeforeCursor:v(t,e)}),I([{insertText:C,range:R}])}}catch(a){if(Se(a))return I([]);d?d(a):O("Cannot provide completion",a);}return I([])},Se=o=>typeof o=="string"?o==="Cancelled"||o==="AbortError":o instanceof Error?o.message==="Cancelled"||o.name==="AbortError":!1;var Ee=(o,e,t)=>{let r=A(e);return r?o.languages.registerInlineCompletionsProvider(t.language,{provideInlineCompletions:(n,i,s,l)=>{if(!(t.trigger==="onDemand"&&!r.isExplicitlyTriggered))return Pe({monaco:o,mdl:n,pos:i,token:l,isCompletionAccepted:r.isCompletionAccepted,options:t})},handleItemDidShow:(n,i,s)=>{r.hasRejectedCurrentCompletion=!1,!r.isCompletionAccepted&&(r.isCompletionVisible=!0,t.onCompletionShown?.(s,i.range));},freeInlineCompletions:()=>{}}):null},Re=o=>{let e=A(o);if(!e){O("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isExplicitlyTriggered=!0,o.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};var ye=(o,e,t,r)=>(t.isExplicitlyTriggered=!1,e.onKeyDown(n=>{we({monaco:o,event:n,state:t,options:r}),Le({monaco:o,event:n,state:t,options:r});})),we=({monaco:o,event:e,state:t,options:r})=>t.isCompletionVisible&&xe(o,e)?(r.onCompletionAccepted?.(),t.isCompletionAccepted=!0,t.isCompletionVisible=!1,!0):(t.isCompletionAccepted=!1,!1),Le=({monaco:o,event:e,state:t,options:r})=>{let n=!xe(o,e);return t.isCompletionVisible&&!t.hasRejectedCurrentCompletion&&!t.isCompletionAccepted&&n?(r.onCompletionRejected?.(),t.hasRejectedCurrentCompletion=!0,!0):!1},xe=(o,e)=>e.keyCode===o.KeyCode.Tab||e.keyCode===o.KeyCode.RightArrow&&e.metaKey;var D=null,Ne=(o,e,t)=>{D&&D.deregister();let r=[];Ce(e,ge()),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let n=A(e);if(!n)return O("Completion is not registered properly. State not found."),_e();let i=Ee(o,e,t);i&&r.push(i);let s=ye(o,e,n,t);r.push(s);let l={deregister:()=>{r.forEach(p=>p.dispose()),z.clear(),te(e),D=null;},trigger:()=>Re(e)};return D=l,l}catch(n){return t.onError?t.onError(n):$(n),{deregister:()=>{r.forEach(i=>i.dispose()),te(e),D=null;},trigger:()=>{}}}},_e=()=>({deregister:()=>{},trigger:()=>{}});
47
47
 
48
48
  exports.Copilot = Q;
49
- exports.registerCompletion = ve;
49
+ exports.registerCompletion = Ne;
package/build/index.mjs CHANGED
@@ -1,10 +1,10 @@
1
- var I=o=>!o||o.length===0?"":o.length===1?o[0]:`${o.slice(0,-1).join(", ")} and ${o.slice(-1)}`,ee=o=>o.charAt(0).toUpperCase()+o.slice(1),W=(o,e,t={})=>{if(e<=0)return "";let r=o.split(`
2
- `),i=r.length;if(e>=i)return o;if(t.from==="end"){let s=r.slice(-e);return s.every(m=>m==="")?`
1
+ var k=o=>!o||o.length===0?"":o.length===1?o[0]:`${o.slice(0,-1).join(", ")} and ${o.slice(-1)}`,oe=o=>o.charAt(0).toUpperCase()+o.slice(1),W=(o,e,t={})=>{if(e<=0)return "";let r=o.split(`
2
+ `),n=r.length;if(e>=n)return o;if(t.from==="end"){let s=r.slice(-e);return s.every(l=>l==="")?`
3
3
  `.repeat(e):s.join(`
4
- `)}let n=r.slice(0,e);return n.every(s=>s==="")?`
5
- `.repeat(e):n.join(`
6
- `)};var te=(o,e)=>e.getLineContent(o.lineNumber)[o.column-1];var oe=(o,e)=>e.getLineContent(o.lineNumber).slice(0,o.column-1),v=(o,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:o.lineNumber,endColumn:o.column}),X=(o,e)=>e.getValueInRange({startLineNumber:o.lineNumber,startColumn:o.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var re=async(o,e,t={})=>{let r=t.timeout??3e4,i=AbortSignal.timeout(r),n=t.signal?AbortSignal.any([i,t.signal]):i,s={"Content-Type":"application/json",...t.headers},m=e==="POST"&&t.body?JSON.stringify(t.body):void 0,c=await fetch(o,{method:e,headers:s,body:m,signal:n});if(!c.ok){let l=await c.json().catch(()=>null),p=l?`
7
- ${JSON.stringify(l,null,2)}`:"",a=t.fallbackError||"Network request failed";throw new Error(`${a} (${c.status})${p}`)}return c.json()},fe=(o,e)=>re(o,"GET",e),he=(o,e,t)=>re(o,"POST",{...t,body:e}),w={GET:fe,POST:he};var L=(o,e=600,t=200)=>{let r=null,i=0,n=null,s=null,m=!1,c=(...l)=>{if(m)return Promise.resolve(void 0);n=l;let p=Date.now(),a=p-i;i=p,r&&(clearTimeout(r),r=null);let u=a<t?e:t;return s=new Promise((f,T)=>{r=setTimeout(async()=>{m=!0;try{if(n){let C=await o(...n);f(C);}else f(void 0);}catch(C){T(C);}finally{m=!1,r=null,n=null;}},u);}),s};return c.cancel=()=>{r&&(clearTimeout(r),r=null),n=null;},c};var Pe=o=>!o||o.length===0?"":o.map(({path:e,content:t})=>`
4
+ `)}let i=r.slice(0,e);return i.every(s=>s==="")?`
5
+ `.repeat(e):i.join(`
6
+ `)};var re=(o,e)=>e.getLineContent(o.lineNumber)[o.column-1];var ne=(o,e)=>e.getLineContent(o.lineNumber).slice(0,o.column-1),v=(o,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:o.lineNumber,endColumn:o.column}),X=(o,e)=>e.getValueInRange({startLineNumber:o.lineNumber,startColumn:o.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var ie=async(o,e,t={})=>{let r=t.timeout??3e4,n=AbortSignal.timeout(r),i=t.signal?AbortSignal.any([n,t.signal]):n,s={"Content-Type":"application/json",...t.headers},l=e==="POST"&&t.body?JSON.stringify(t.body):void 0,p=await fetch(o,{method:e,headers:s,body:l,signal:i});if(!p.ok){let d=await p.json().catch(()=>null),c=d?`
7
+ ${JSON.stringify(d,null,2)}`:"",a=t.fallbackError||"Network request failed";throw new Error(`${a} (${p.status})${c}`)}return p.json()},Te=(o,e)=>ie(o,"GET",e),be=(o,e,t)=>ie(o,"POST",{...t,body:e}),S={GET:Te,POST:be};var w=(o,e=600,t=200)=>{let r=null,n=0,i=null,s=null,l=!1,p=(...d)=>{if(l)return Promise.resolve(void 0);i=d;let c=Date.now(),a=c-n;n=c,r&&(clearTimeout(r),r=null);let u=a<t?e:t;return s=new Promise((f,M)=>{r=setTimeout(async()=>{l=!0;try{if(i){let C=await o(...i);f(C);}else f(void 0);}catch(C){M(C);}finally{l=!1,r=null,i=null;}},u);}),s};return p.cancel=()=>{r&&(clearTimeout(r),r=null),i=null;},p};var ve=o=>!o||o.length===0?"":o.map(({path:e,content:t})=>`
8
8
  <related_file>
9
9
  <filePath>${e}</filePath>
10
10
  <fileContent>
@@ -14,33 +14,33 @@ ${t}
14
14
  </fileContent>
15
15
  </related_file>`.trim()).join(`
16
16
 
17
- `),ne=o=>{let{technologies:e=[],filename:t,relatedFiles:r,language:i,textBeforeCursor:n="",textAfterCursor:s="",editorState:{completionMode:m}}=o,c=I([i,...e].filter(a=>typeof a=="string"&&!!a)),l=`
17
+ `),se=o=>{let{technologies:e=[],filename:t,relatedFiles:r,language:n,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:l}}=o,p=k([n,...e].filter(a=>typeof a=="string"&&!!a)),d=`
18
18
  You are an expert code completion assistant.
19
19
 
20
20
  **Context:**
21
21
  File: ${t||"Untitled"}
22
- Language: ${i||"Undetermined"}
23
- Mode: ${m}
24
- Stack: ${c||"None"}`,p=`
22
+ Language: ${n||"Undetermined"}
23
+ Mode: ${l}
24
+ Stack: ${p||"None"}`,c=`
25
25
  **Related Files:**
26
- ${Pe(r)}
26
+ ${ve(r)}
27
27
 
28
28
  **Source:**
29
29
  \`\`\`
30
- ${n}<cursor>${s}
30
+ ${i}<cursor>${s}
31
31
  \`\`\`
32
32
 
33
- ${ee(m)} the code at <cursor>.
33
+ ${oe(l)} the code at <cursor>.
34
34
 
35
- Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:l,user:p}};var G=["groq","openai","anthropic","google","deepseek"],P={"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",v3:"deepseek-chat"},J={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"],deepseek:["v3"]},R={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",deepseek:"https://api.deepseek.com/beta/completions"};var g=class{};var N=class extends g{createEndpoint(){return R.anthropic}createRequestBody(e,t){return {model:P[e],temperature:.1,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}}parseCompletion(e){let t=e.content?.[0];return t&&"text"in t?t.text:null}};var S=class extends g{createEndpoint(){return R.deepseek}createRequestBody(e,t,r){return {model:P[e],prompt:r.textBeforeCursor,suffix:r.textAfterCursor,temperature:.1,max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return typeof e.choices?.[0]?.text=="string"?e.choices[0].text:null}};var _=class extends g{createEndpoint(e,t){return `${R.google}/${P[e]}:generateContent?key=${t}`}createRequestBody(e,t){return {systemInstruction:{role:"system",parts:[{text:t.system}]},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{role:"user",parts:[{text:t.user}]}]}}createHeaders(){return {"Content-Type":"application/json"}}parseCompletion(e){return e.candidates?.[0]?.content?.parts?.[0]?.text??null}};var B=class extends g{createEndpoint(){return R.groq}createRequestBody(e,t){return {model:P[e],temperature:.1,max_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var F=class extends g{createEndpoint(){return R.openai}createRequestBody(e,t){let r=e==="o1-mini";return {model:P[e],...!r&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var q={openai:new F,groq:new B,anthropic:new N,google:new _,deepseek:new S},ie=(o,e,t)=>q[t].createEndpoint(o,e),se=(o,e,t,r)=>q[e].createRequestBody(o,t,r),ae=(o,e)=>q[e].createHeaders(o),le=(o,e)=>q[e].parseCompletion(o);var Re="\x1B[91m",pe="\x1B[93m",Y="\x1B[0m",Z="\x1B[1m",me=o=>o instanceof Error?o.message:typeof o=="string"?o:"An unknown error occurred",$=o=>{let e=me(o),t=`${Re}${Z}[MONACOPILOT ERROR] ${e}${Y}`;return console.error(t),{message:e}},k=(o,e)=>{console.warn(`${pe}${Z}[MONACOPILOT WARN] ${o}${e?`
36
- ${me(e)}`:""}${Y}`);};var ce=(o,e,t)=>console.warn(`${pe}${Z}[MONACOPILOT DEPRECATED] "${o}" is deprecated${` in ${t}`}. Please use "${e}" instead. It will be removed in a future version.${Y}`);var Q=class{constructor(e,t){this.validateParams(e,t),this.apiKey=e,this.provider=t.provider,this.model=t.model,this.validateInputs();}validateParams(e,t){if(!e)throw new Error("Please provide an API key.");if(!t||typeof t=="object"&&Object.keys(t).length===0)throw new Error("Please provide options.")}validateInputs(){if(typeof this.model=="object"){if(this.provider!==void 0)throw new Error("Provider should not be specified when using a custom model.");if(!("config"in this.model)||!("transformResponse"in this.model))throw new Error("Please ensure both config and transformResponse are provided for custom model.");return}if(!this.provider||!G.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${I(G)}`);if(typeof this.model=="string"&&!J[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${I(J[this.provider])}`)}async complete(e){let{body:t,options:r}=e,{completionMetadata:i}=t,{headers:n={},customPrompt:s}=r??{},m=this.generatePrompt(i,s),{endpoint:c,requestBody:l,headers:p}=this.prepareRequestDetails(m,i);try{let a=await this.sendCompletionRequest(c,l,{...p,...n});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,t){let r=ne(e);return t?{...r,...t(e)}:r}prepareRequestDetails(e,t){if(typeof this.model=="object"&&"config"in this.model){let r=this.model.config(this.apiKey,e),i=r.endpoint,n=r.body??{},s=r.headers??{};return {endpoint:i,requestBody:n,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let r=ie(this.model,this.apiKey,this.provider),i=ae(this.apiKey,this.provider),n=se(this.model,this.provider,e,t);return {endpoint:r,requestBody:n,headers:i}}}async sendCompletionRequest(e,t,r){return w.POST(e,t,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let t=this.model.transformResponse(e);return "completion"in t&&ce("completion","text","Copilot.options.model.transformResponse"),{completion:t.text??t.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:le(e,this.provider),raw:e}}}handleCompletionError(e){return {error:$(e).message,completion:null}}};var H=class{constructor(e,t,r){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=t,this.textBeforeCursorInLine=r;}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}indentByColumn(){let e=this.formattedCompletion.split(`
35
+ Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:d,user:c}};var G=["groq","openai","anthropic","google","deepseek"],P={"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",v3:"deepseek-chat"},J={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"],deepseek:["v3"]},E={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",deepseek:"https://api.deepseek.com/beta/completions"};var g=class{};var L=class extends g{createEndpoint(){return E.anthropic}createRequestBody(e,t){return {model:P[e],temperature:.1,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}}parseCompletion(e){let t=e.content?.[0];return t&&"text"in t?t.text:null}};var N=class extends g{createEndpoint(){return E.deepseek}createRequestBody(e,t,r){return {model:P[e],prompt:r.textBeforeCursor,suffix:r.textAfterCursor,temperature:.1,max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return typeof e.choices?.[0]?.text=="string"?e.choices[0].text:null}};var _=class extends g{createEndpoint(e,t){return `${E.google}/${P[e]}:generateContent?key=${t}`}createRequestBody(e,t){return {systemInstruction:{role:"system",parts:[{text:t.system}]},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{role:"user",parts:[{text:t.user}]}]}}createHeaders(){return {"Content-Type":"application/json"}}parseCompletion(e){return e.candidates?.[0]?.content?.parts?.[0]?.text??null}};var B=class extends g{createEndpoint(){return E.groq}createRequestBody(e,t){return {model:P[e],temperature:.1,max_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var F=class extends g{createEndpoint(){return E.openai}createRequestBody(e,t){let r=e==="o1-mini";return {model:P[e],...!r&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var q={openai:new F,groq:new B,anthropic:new L,google:new _,deepseek:new N},ae=(o,e,t)=>q[t].createEndpoint(o,e),le=(o,e,t,r)=>q[e].createRequestBody(o,t,r),pe=(o,e)=>q[e].createHeaders(o),me=(o,e)=>q[e].parseCompletion(o);var Oe="\x1B[91m",ce="\x1B[93m",Y="\x1B[0m",Z="\x1B[1m",de=o=>o instanceof Error?o.message:typeof o=="string"?o:"An unknown error occurred",$=o=>{let e=de(o),t=`${Oe}${Z}[MONACOPILOT ERROR] ${e}${Y}`;return console.error(t),{message:e}},O=(o,e)=>{console.warn(`${ce}${Z}[MONACOPILOT WARN] ${o}${e?`
36
+ ${de(e)}`:""}${Y}`);};var ue=(o,e,t)=>console.warn(`${ce}${Z}[MONACOPILOT DEPRECATED] "${o}" is deprecated${` in ${t}`}. Please use "${e}" instead. It will be removed in a future version.${Y}`);var Q=class{constructor(e,t){this.validateParams(e,t),this.apiKey=e,this.provider=t.provider,this.model=t.model,this.validateInputs();}validateParams(e,t){if(!e)throw new Error("Please provide an API key.");if(!t||typeof t=="object"&&Object.keys(t).length===0)throw new Error("Please provide options.")}validateInputs(){if(typeof this.model=="object"){if(this.provider!==void 0)throw new Error("Provider should not be specified when using a custom model.");if(!("config"in this.model)||!("transformResponse"in this.model))throw new Error("Please ensure both config and transformResponse are provided for custom model.");return}if(!this.provider||!G.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${k(G)}`);if(typeof this.model=="string"&&!J[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${k(J[this.provider])}`)}async complete(e){let{body:t,options:r}=e,{completionMetadata:n}=t,{headers:i={},customPrompt:s}=r??{},l=this.generatePrompt(n,s),{endpoint:p,requestBody:d,headers:c}=this.prepareRequestDetails(l,n);try{let a=await this.sendCompletionRequest(p,d,{...c,...i});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,t){let r=se(e);return t?{...r,...t(e)}:r}prepareRequestDetails(e,t){if(typeof this.model=="object"&&"config"in this.model){let r=this.model.config(this.apiKey,e),n=r.endpoint,i=r.body??{},s=r.headers??{};return {endpoint:n,requestBody:i,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let r=ae(this.model,this.apiKey,this.provider),n=pe(this.apiKey,this.provider),i=le(this.model,this.provider,e,t);return {endpoint:r,requestBody:i,headers:n}}}async sendCompletionRequest(e,t,r){return S.POST(e,t,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let t=this.model.transformResponse(e);return "completion"in t&&ue("completion","text","Copilot.options.model.transformResponse"),{completion:t.text??t.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:me(e,this.provider),raw:e}}}handleCompletionError(e){return {error:$(e).message,completion:null}}};var j=class{constructor(e,t,r){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=t,this.textBeforeCursorInLine=r;}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}indentByColumn(){let e=this.formattedCompletion.split(`
37
37
  `);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let t=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
38
38
  `+e.slice(1).map(r=>t+r).join(`
39
- `),this}removeMarkdownCodeBlocks(e){let t=/```[\s\S]*?```/g,r=e,i;for(;(i=t.exec(e))!==null;){let n=i[0],s=n.split(`
39
+ `),this}removeMarkdownCodeBlocks(e){let t=/```[\s\S]*?```/g,r=e,n;for(;(n=t.exec(e))!==null;){let i=n[0],s=i.split(`
40
40
  `).slice(1,-1).join(`
41
- `);r=r.replace(n,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
41
+ `);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
42
42
 
43
- `),this}build(){return this.formattedCompletion}};var V=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let t;return this.size===this.capacity&&(t=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,t}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 U=class U{constructor(){this.cache=new V(U.MAX_CACHE_SIZE);}get(e,t){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,t))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,t,r){let i=r.getValueInRange(e.range),n=v(t,r);return n.length<e.textBeforeCursor.length||!n.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,t,i)}isPositionValid(e,t,r){let{range:i,completion:n}=e,{startLineNumber:s,startColumn:m,endLineNumber:c,endColumn:l}=i,{lineNumber:p,column:a}=t;if(!n.startsWith(r))return !1;let u=p===s&&a===m;if(s===c)return u||p===s&&a>=m&&a<=l;let f=p>s&&p<c?!0:p===s&&a>=m||p===c&&a<=l;return u||f}};U.MAX_CACHE_SIZE=10;var j=U;var K=class{constructor(e){this.monaco=e;}computeInsertionRange(e,t,r){if(!t)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let i=r.getOffsetAt(e),n=r.getValue().substring(0,i),s=r.getValue().substring(i),m=0,c=0,l=0,p=0,a=t.length,u=n.length,f=s.length;if(i>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(f===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let T=Math.min(a,u);for(let d=1;d<=T;d++){let b=t.substring(0,d),ge=n.slice(-d);b===ge&&(p=d);}let C=Math.min(a,f);for(let d=0;d<C&&t[d]===s[d];d++)m++;for(let d=1;d<=C;d++)t.slice(-d)===s.slice(0,d)&&(c=d);if(l=Math.max(m,c),l===0){for(let d=1;d<a;d++)if(s.startsWith(t.substring(d))){l=a-d;break}}let x=p>0?r.getPositionAt(i-p):e,y=i+l,h=r.getPositionAt(y);return new this.monaco.Range(x.lineNumber,x.column,h.lineNumber,h.column)}computeCacheRange(e,t){let r=e.lineNumber,i=e.column,n=t.split(`
44
- `),s=n.length-1,m=r+s,c=s===0?i+n[0].length:n[s].length+1;return new this.monaco.Range(r,i,m,c)}};var ye="application/json",de=async o=>{let{endpoint:e,body:t}=o,{completion:r,error:i}=await w.POST(e,t,{headers:{"Content-Type":ye},fallbackError:"Error while fetching completion item"});if(i)throw new Error(i);return {completion:r}},ue=({pos:o,mdl:e,options:t})=>{let{filename:r,language:i,technologies:n,relatedFiles:s,maxContextLines:m}=t,c=Ee(o,e),p=!!s?.length?3:2,a=m?Math.floor(m/p):void 0,u=(y,h,d)=>{let b=y(o,e);return h?W(b,h,d):b},f=(y,h)=>!y||!h?y:y.map(({content:d,...b})=>({...b,content:W(d,h)})),T=u(v,a,{from:"end"}),C=u(X,a),x=f(s,a);return {filename:r,language:i,technologies:n,relatedFiles:x,textBeforeCursor:T,textAfterCursor:C,cursorPosition:o,editorState:{completionMode:c}}},Ee=(o,e)=>{let t=te(o,e),r=X(o,e);return t?"insert":r.trim()?"complete":"continue"};var O=o=>({items:o,enableForwardStability:!0,suppressSuggestions:!0});var Te=o=>({onTyping:L(o,600,200),onIdle:L(o,600,400),onDemand:L(o,0,0)}),z=new j,xe=async({monaco:o,mdl:e,pos:t,token:r,isCompletionAccepted:i,options:n})=>{let{trigger:s="onIdle",endpoint:m,enableCaching:c=!0,onError:l,requestHandler:p}=n;if(c){let a=z.get(t,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return O(a)}if(r.isCancellationRequested||i)return O([]);try{let u=Te(p??de)[s];r.onCancellationRequested(()=>{u.cancel();});let f=ue({pos:t,mdl:e,options:n}),{completion:T}=await u({endpoint:m,body:{completionMetadata:f}});if(T){let C=new H(T,t.column,oe(t,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),x=new K(o),y=x.computeInsertionRange(t,C,e),h=x.computeCacheRange(t,C);return c&&z.add({completion:C,range:h,textBeforeCursor:v(t,e)}),O([{insertText:C,range:y}])}}catch(a){if(be(a))return O([]);l?l(a):k("Cannot provide completion",a);}return O([])},be=o=>typeof o=="string"?o==="Cancelled"||o==="AbortError":o instanceof Error?o.message==="Cancelled"||o.name==="AbortError":!1,Ce=xe;var D=new WeakMap,A=null,ve=(o,e,t)=>{A&&A.deregister();let r=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};D.set(e,i),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let n=D.get(e);if(!n)return k("Completion is not registered properly. State not found."),{deregister:()=>{},trigger:()=>{}};let s=o.languages.registerInlineCompletionsProvider(t.language,{provideInlineCompletions:(l,p,a,u)=>{if(!(t.trigger==="onDemand"&&!n.isManualTrigger))return Ce({monaco:o,mdl:l,pos:p,token:u,isCompletionAccepted:n.isCompletionAccepted,options:t})},handleItemDidShow:(l,p,a)=>{n.isCompletionVisible=!0,n.isManualTrigger=!1,!n.isCompletionAccepted&&t.onCompletionShown?.(a,p.range);},freeInlineCompletions:()=>{}});r.push(s);let m=e.onKeyDown(l=>{let p=l.keyCode===o.KeyCode.Tab||l.keyCode===o.KeyCode.RightArrow&&l.metaKey;n.isCompletionVisible&&p?(t.onCompletionAccepted?.(),n.isCompletionAccepted=!0,n.isCompletionVisible=!1):n.isCompletionAccepted=!1;});r.push(m);let c={deregister:()=>{r.forEach(l=>l.dispose()),z.clear(),D.delete(e),A=null;},trigger:()=>Oe(e)};return A=c,c}catch(n){return t.onError?t.onError(n):$(n),{deregister:()=>{r.forEach(s=>s.dispose()),D.delete(e),A=null;},trigger:()=>{}}}},Oe=o=>{let e=D.get(o);if(!e){k("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,o.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};
43
+ `),this}build(){return this.formattedCompletion}};var ee=new WeakMap,A=o=>ee.get(o),Ce=(o,e)=>{ee.set(o,e);},te=o=>{ee.delete(o);},ge=()=>({isCompletionAccepted:!1,isCompletionVisible:!1,isExplicitlyTriggered:!1,hasRejectedCurrentCompletion:!1});var H=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let t;return this.size===this.capacity&&(t=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,t}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 V=class V{constructor(){this.cache=new H(V.MAX_CACHE_SIZE);}get(e,t){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,t))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,t,r){let n=r.getValueInRange(e.range),i=v(t,r);return i.length<e.textBeforeCursor.length||!i.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,t,n)}isPositionValid(e,t,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:l,endLineNumber:p,endColumn:d}=n,{lineNumber:c,column:a}=t;if(!i.startsWith(r))return !1;let u=c===s&&a===l;if(s===p)return u||c===s&&a>=l&&a<=d;let f=c>s&&c<p?!0:c===s&&a>=l||c===p&&a<=d;return u||f}};V.MAX_CACHE_SIZE=10;var K=V;var U=class{constructor(e){this.monaco=e;}computeInsertionRange(e,t,r){if(!t)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=r.getOffsetAt(e),i=r.getValue().substring(0,n),s=r.getValue().substring(n),l=0,p=0,d=0,c=0,a=t.length,u=i.length,f=s.length;if(n>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(f===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let M=Math.min(a,u);for(let m=1;m<=M;m++){let b=t.substring(0,m),Me=i.slice(-m);b===Me&&(c=m);}let C=Math.min(a,f);for(let m=0;m<C&&t[m]===s[m];m++)l++;for(let m=1;m<=C;m++)t.slice(-m)===s.slice(0,m)&&(p=m);if(d=Math.max(l,p),d===0){for(let m=1;m<a;m++)if(s.startsWith(t.substring(m))){d=a-m;break}}let T=c>0?r.getPositionAt(n-c):e,R=n+d,h=r.getPositionAt(R);return new this.monaco.Range(T.lineNumber,T.column,h.lineNumber,h.column)}computeCacheRange(e,t){let r=e.lineNumber,n=e.column,i=t.split(`
44
+ `),s=i.length-1,l=r+s,p=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,l,p)}};var Ie="application/json",fe=async o=>{let{endpoint:e,body:t}=o,{completion:r,error:n}=await S.POST(e,t,{headers:{"Content-Type":Ie},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},he=({pos:o,mdl:e,options:t})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:l}=t,p=ke(o,e),c=!!s?.length?3:2,a=l?Math.floor(l/c):void 0,u=(R,h,m)=>{let b=R(o,e);return h?W(b,h,m):b},f=(R,h)=>!R||!h?R:R.map(({content:m,...b})=>({...b,content:W(m,h)})),M=u(v,a,{from:"end"}),C=u(X,a),T=f(s,a);return {filename:r,language:n,technologies:i,relatedFiles:T,textBeforeCursor:M,textAfterCursor:C,cursorPosition:o,editorState:{completionMode:p}}},ke=(o,e)=>{let t=re(o,e),r=X(o,e);return t?"insert":r.trim()?"complete":"continue"};var I=o=>({items:o,enableForwardStability:!0,suppressSuggestions:!0});var De=o=>({onTyping:w(o,600,200),onIdle:w(o,600,400),onDemand:w(o,0,0)}),z=new K,Pe=async({monaco:o,mdl:e,pos:t,token:r,isCompletionAccepted:n,options:i})=>{let{trigger:s="onIdle",endpoint:l,enableCaching:p=!0,onError:d,requestHandler:c}=i;if(p){let a=z.get(t,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return I(a)}if(r.isCancellationRequested||n)return I([]);try{let u=De(c??fe)[s];r.onCancellationRequested(()=>{u.cancel();});let f=he({pos:t,mdl:e,options:i}),{completion:M}=await u({endpoint:l,body:{completionMetadata:f}});if(M){let C=new j(M,t.column,ne(t,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),T=new U(o),R=T.computeInsertionRange(t,C,e),h=T.computeCacheRange(t,C);return p&&z.add({completion:C,range:h,textBeforeCursor:v(t,e)}),I([{insertText:C,range:R}])}}catch(a){if(Se(a))return I([]);d?d(a):O("Cannot provide completion",a);}return I([])},Se=o=>typeof o=="string"?o==="Cancelled"||o==="AbortError":o instanceof Error?o.message==="Cancelled"||o.name==="AbortError":!1;var Ee=(o,e,t)=>{let r=A(e);return r?o.languages.registerInlineCompletionsProvider(t.language,{provideInlineCompletions:(n,i,s,l)=>{if(!(t.trigger==="onDemand"&&!r.isExplicitlyTriggered))return Pe({monaco:o,mdl:n,pos:i,token:l,isCompletionAccepted:r.isCompletionAccepted,options:t})},handleItemDidShow:(n,i,s)=>{r.hasRejectedCurrentCompletion=!1,!r.isCompletionAccepted&&(r.isCompletionVisible=!0,t.onCompletionShown?.(s,i.range));},freeInlineCompletions:()=>{}}):null},Re=o=>{let e=A(o);if(!e){O("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isExplicitlyTriggered=!0,o.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};var ye=(o,e,t,r)=>(t.isExplicitlyTriggered=!1,e.onKeyDown(n=>{we({monaco:o,event:n,state:t,options:r}),Le({monaco:o,event:n,state:t,options:r});})),we=({monaco:o,event:e,state:t,options:r})=>t.isCompletionVisible&&xe(o,e)?(r.onCompletionAccepted?.(),t.isCompletionAccepted=!0,t.isCompletionVisible=!1,!0):(t.isCompletionAccepted=!1,!1),Le=({monaco:o,event:e,state:t,options:r})=>{let n=!xe(o,e);return t.isCompletionVisible&&!t.hasRejectedCurrentCompletion&&!t.isCompletionAccepted&&n?(r.onCompletionRejected?.(),t.hasRejectedCurrentCompletion=!0,!0):!1},xe=(o,e)=>e.keyCode===o.KeyCode.Tab||e.keyCode===o.KeyCode.RightArrow&&e.metaKey;var D=null,Ne=(o,e,t)=>{D&&D.deregister();let r=[];Ce(e,ge()),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let n=A(e);if(!n)return O("Completion is not registered properly. State not found."),_e();let i=Ee(o,e,t);i&&r.push(i);let s=ye(o,e,n,t);r.push(s);let l={deregister:()=>{r.forEach(p=>p.dispose()),z.clear(),te(e),D=null;},trigger:()=>Re(e)};return D=l,l}catch(n){return t.onError?t.onError(n):$(n),{deregister:()=>{r.forEach(i=>i.dispose()),te(e),D=null;},trigger:()=>{}}}},_e=()=>({deregister:()=>{},trigger:()=>{}});
45
45
 
46
- export { Q as Copilot, ve as registerCompletion };
46
+ export { Q as Copilot, Ne as registerCompletion };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "monacopilot",
3
- "version": "0.17.3",
3
+ "version": "0.18.0",
4
4
  "description": "AI auto-completion plugin for Monaco Editor",
5
5
  "main": "./build/index.js",
6
6
  "module": "./build/index.mjs",