monacopilot 0.15.11 → 0.15.12

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
@@ -87,9 +87,9 @@ import {Copilot} from 'monacopilot';
87
87
 
88
88
  const app = express();
89
89
  const port = process.env.PORT || 3000;
90
- const copilot = new Copilot(process.env.ANTHROPIC_API_KEY!, {
91
- provider: 'anthropic',
92
- model: 'claude-3-5-haiku',
90
+ const copilot = new Copilot(process.env.GROQ_API_KEY, {
91
+ provider: 'groq',
92
+ model: 'llama-3-70b',
93
93
  });
94
94
 
95
95
  app.use(express.json());
@@ -428,10 +428,6 @@ const copilot = new Copilot(process.env.OPENAI_API_KEY, {
428
428
  });
429
429
  ```
430
430
 
431
- The default provider is `anthropic`, and the default model is `claude-3-5-haiku`.
432
-
433
- > **Tip:** Even though the default provider and model are `anthropic` and `claude-3-5-haiku`, it's always recommended to specify a provider and model when using Monacopilot. This ensures your code remains consistent even if the default settings change in future updates.
434
-
435
431
  There are other providers and models available. Here is a list:
436
432
 
437
433
  | Provider | Models |
package/build/index.d.mts CHANGED
@@ -99,7 +99,7 @@ type CopilotOptions = {
99
99
  * Defines the model to be used for Copilot LLM (Language Model) requests.
100
100
  * This must be a model from the 'openai' provider.
101
101
  */
102
- model?: OpenAIModel;
102
+ model: OpenAIModel;
103
103
  } | {
104
104
  /**
105
105
  * Specifies the 'groq' provider for the Copilot instance.
@@ -109,7 +109,7 @@ type CopilotOptions = {
109
109
  * Defines the model to be used for Copilot LLM requests.
110
110
  * This must be a model from the 'groq' provider.
111
111
  */
112
- model?: GroqModel;
112
+ model: GroqModel;
113
113
  } | {
114
114
  /**
115
115
  * Specifies the 'anthropic' provider for the Copilot instance.
@@ -119,7 +119,7 @@ type CopilotOptions = {
119
119
  * Defines the model to be used for Copilot LLM requests.
120
120
  * This must be a model from the 'anthropic' provider.
121
121
  */
122
- model?: AnthropicModel;
122
+ model: AnthropicModel;
123
123
  } | {
124
124
  /**
125
125
  * Specifies the 'google' provider for the Copilot instance.
@@ -129,7 +129,7 @@ type CopilotOptions = {
129
129
  * Defines the model to be used for Copilot LLM requests.
130
130
  * This must be a model from the 'google' provider.
131
131
  */
132
- model?: GoogleModel;
132
+ model: GoogleModel;
133
133
  } | {
134
134
  /**
135
135
  * When no provider is specified, only custom models are allowed.
@@ -141,7 +141,7 @@ type CopilotOptions = {
141
141
  * For more information, refer to the documentation:
142
142
  * @see https://github.com/arshad-yaseen/monacopilot?tab=readme-ov-file#custom-model
143
143
  */
144
- model?: CustomCopilotModel;
144
+ model: CustomCopilotModel;
145
145
  };
146
146
 
147
147
  type Monaco = typeof monaco;
@@ -356,7 +356,8 @@ declare class Copilot {
356
356
  private readonly apiKey;
357
357
  private provider;
358
358
  private model;
359
- constructor(apiKey: string, options?: CopilotOptions);
359
+ constructor(apiKey: string, options: CopilotOptions);
360
+ private validateParams;
360
361
  private validateInputs;
361
362
  complete(request: CompletionRequest): Promise<CompletionResponse>;
362
363
  private generatePrompt;
package/build/index.d.ts CHANGED
@@ -99,7 +99,7 @@ type CopilotOptions = {
99
99
  * Defines the model to be used for Copilot LLM (Language Model) requests.
100
100
  * This must be a model from the 'openai' provider.
101
101
  */
102
- model?: OpenAIModel;
102
+ model: OpenAIModel;
103
103
  } | {
104
104
  /**
105
105
  * Specifies the 'groq' provider for the Copilot instance.
@@ -109,7 +109,7 @@ type CopilotOptions = {
109
109
  * Defines the model to be used for Copilot LLM requests.
110
110
  * This must be a model from the 'groq' provider.
111
111
  */
112
- model?: GroqModel;
112
+ model: GroqModel;
113
113
  } | {
114
114
  /**
115
115
  * Specifies the 'anthropic' provider for the Copilot instance.
@@ -119,7 +119,7 @@ type CopilotOptions = {
119
119
  * Defines the model to be used for Copilot LLM requests.
120
120
  * This must be a model from the 'anthropic' provider.
121
121
  */
122
- model?: AnthropicModel;
122
+ model: AnthropicModel;
123
123
  } | {
124
124
  /**
125
125
  * Specifies the 'google' provider for the Copilot instance.
@@ -129,7 +129,7 @@ type CopilotOptions = {
129
129
  * Defines the model to be used for Copilot LLM requests.
130
130
  * This must be a model from the 'google' provider.
131
131
  */
132
- model?: GoogleModel;
132
+ model: GoogleModel;
133
133
  } | {
134
134
  /**
135
135
  * When no provider is specified, only custom models are allowed.
@@ -141,7 +141,7 @@ type CopilotOptions = {
141
141
  * For more information, refer to the documentation:
142
142
  * @see https://github.com/arshad-yaseen/monacopilot?tab=readme-ov-file#custom-model
143
143
  */
144
- model?: CustomCopilotModel;
144
+ model: CustomCopilotModel;
145
145
  };
146
146
 
147
147
  type Monaco = typeof monaco;
@@ -356,7 +356,8 @@ declare class Copilot {
356
356
  private readonly apiKey;
357
357
  private provider;
358
358
  private model;
359
- constructor(apiKey: string, options?: CopilotOptions);
359
+ constructor(apiKey: string, options: CopilotOptions);
360
+ private validateParams;
360
361
  private validateInputs;
361
362
  complete(request: CompletionRequest): Promise<CompletionResponse>;
362
363
  private generatePrompt;
package/build/index.js CHANGED
@@ -1,12 +1,12 @@
1
1
  'use strict';
2
2
 
3
- var V=["groq","openai","anthropic","google"],Y={"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"},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"]},X="anthropic",J="claude-3-5-haiku",M={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"},A=.1;var v=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,Z=t=>t.charAt(0).toUpperCase()+t.slice(1),U=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
3
+ var j=["groq","openai","anthropic","google"],Y={"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"},V={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"]},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"},A=.1;var v=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,X=t=>t.charAt(0).toUpperCase()+t.slice(1),K=(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 i=r.slice(-e);return i.every(l=>l==="")?`
5
5
  `.repeat(e):i.join(`
6
6
  `)}let s=r.slice(0,e);return s.every(i=>i==="")?`
7
7
  `.repeat(e):s.join(`
8
- `)};var Q=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],L=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ee=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),T=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),te=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var oe=async(t,e,o={})=>{let r=o.timeout??3e4,n=AbortSignal.timeout(r),s=o.signal?AbortSignal.any([n,o.signal]):n,i={"Content-Type":"application/json",...o.headers},l=e==="POST"&&o.body?JSON.stringify(o.body):void 0,a=await fetch(t,{method:e,headers:i,body:l,signal:s});if(!a.ok){let d=await a.json().catch(()=>null),m=d?`
9
- ${JSON.stringify(d,null,2)}`:"",p=o.fallbackError||"Network request failed";throw new Error(`${p} (${a.status})${m}`)}return a.json()},fe=(t,e)=>oe(t,"GET",e),Pe=(t,e,o)=>oe(t,"POST",{...o,body:e}),D={GET:fe,POST:Pe};var re=(t,e)=>{let o=L(t,e).trim(),r=ee(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var w=(t,e)=>{let o=null,r=null,n=(...s)=>new Promise((i,l)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=l,o=setTimeout(()=>{i(t(...s)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var ye=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
8
+ `)};var J=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],w=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),Z=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),b=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),Q=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var ee=async(t,e,o={})=>{let r=o.timeout??3e4,n=AbortSignal.timeout(r),s=o.signal?AbortSignal.any([n,o.signal]):n,i={"Content-Type":"application/json",...o.headers},l=e==="POST"&&o.body?JSON.stringify(o.body):void 0,a=await fetch(t,{method:e,headers:i,body:l,signal:s});if(!a.ok){let c=await a.json().catch(()=>null),m=c?`
9
+ ${JSON.stringify(c,null,2)}`:"",p=o.fallbackError||"Network request failed";throw new Error(`${p} (${a.status})${m}`)}return a.json()},ge=(t,e)=>ee(t,"GET",e),he=(t,e,o)=>ee(t,"POST",{...o,body:e}),L={GET:ge,POST:he};var te=(t,e)=>{let o=w(t,e).trim(),r=Z(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var S=(t,e)=>{let o=null,r=null,n=(...s)=>new Promise((i,l)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=l,o=setTimeout(()=>{i(t(...s)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var fe=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
10
10
  <related_file>
11
11
  <filePath>${e}</filePath>
12
12
  <fileContent>
@@ -16,7 +16,7 @@ ${o}
16
16
  </fileContent>
17
17
  </related_file>`.trim()).join(`
18
18
 
19
- `),ne=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n,textBeforeCursor:s="",textAfterCursor:i="",editorState:{completionMode:l}}=t,a=v([n,...e].filter(p=>typeof p=="string"&&!!p)),d=`
19
+ `),oe=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n,textBeforeCursor:s="",textAfterCursor:i="",editorState:{completionMode:l}}=t,a=v([n,...e].filter(p=>typeof p=="string"&&!!p)),c=`
20
20
  You are a code completion assistant.
21
21
 
22
22
  Context:
@@ -25,22 +25,22 @@ Language: ${n||"Undetermined"}
25
25
  Mode: ${l}
26
26
  Stack: ${a||"None"}`,m=`
27
27
  Related Files:
28
- ${ye(r)}
28
+ ${fe(r)}
29
29
 
30
30
  Source:
31
31
  \`\`\`
32
32
  ${s}<cursor>${i}
33
33
  \`\`\`
34
34
 
35
- ${Z(l)} the code at <cursor>.
35
+ ${X(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:d,user:m}};var ie={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var Re={createEndpoint:()=>M.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:F(t),...!o&&{temperature:A},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},xe={createEndpoint:()=>M.groq,createRequestBody:(t,e)=>({model:F(t),temperature:A,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},Te={createEndpoint:()=>M.anthropic,createRequestBody:(t,e)=>({model:F(t),temperature:A,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ie[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)=>`${M.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:F(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}},S={openai:Re,groq:xe,anthropic:Te,google:Oe},se=(t,e,o)=>S[o].createEndpoint(t,e),ae=(t,e,o)=>S[e].createRequestBody(t,o),le=(t,e)=>S[e].createHeaders(t),pe=(t,e)=>S[e].parseCompletion(t),F=t=>Y[t];var Ee="\x1B[91m",ce="\x1B[93m",K="\x1B[0m",z="\x1B[1m",O=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${Ee}${z}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},de=t=>{console.warn(`${ce}${z}[MONACOPILOT WARN] ${t}${K}`);};var B=(t,e,o)=>console.warn(`${ce}${z}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${K}`);var W=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??X,this.model=o.model??J,this.validateInputs();}validateInputs(){if(!V.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${v(V)}. For custom models, provider specification is not needed.`);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: ${v(j[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:s={},customPrompt:i}=r??{},l=this.generatePrompt(n,i),{endpoint:a,requestBody:d,headers:m}=this.prepareRequestDetails(l);try{let p=await this.sendCompletionRequest(a,d,{...m,...s});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let r=ne(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=se(this.model,this.apiKey,this.provider),r,n=le(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let s=this.model.config(this.apiKey,e);o=s.endpoint??o,r=s.body??{},n={...n,...s.headers};}else r=ae(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return D.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:pe(e,this.provider),raw:e}}handleCompletionError(e){return {error:O(e).message,completion:null}}};var N=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 s=n[0],i=s.split(`
37
+ Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:c,user:m}};var re={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var Pe={createEndpoint:()=>O.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:D(t),...!o&&{temperature:A},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.groq,createRequestBody:(t,e)=>({model:D(t),temperature:A,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:()=>O.anthropic,createRequestBody:(t,e)=>({model:D(t),temperature:A,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:re[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:D(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}},B={openai:Pe,groq:ye,anthropic:Re,google:xe},ne=(t,e,o)=>B[o].createEndpoint(t,e),ie=(t,e,o)=>B[e].createRequestBody(t,o),se=(t,e)=>B[e].createHeaders(t),ae=(t,e)=>B[e].parseCompletion(t),D=t=>Y[t];var be="\x1B[91m",le="\x1B[93m",U="\x1B[0m",z="\x1B[1m",T=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${be}${z}[MONACOPILOT ERROR] ${e}${U}`;return console.error(o),{message:e}},pe=t=>{console.warn(`${le}${z}[MONACOPILOT WARN] ${t}${U}`);};var q=(t,e,o)=>console.warn(`${le}${z}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${U}`);var W=class{constructor(e,o){this.validateParams(e,o),this.apiKey=e,this.provider=o.provider,this.model=o.model,this.validateInputs();}validateParams(e,o){if(!e)throw new Error("Please provide an API key.");if(!o||typeof o=="object"&&Object.keys(o).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||!j.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${v(j)}`);if(typeof this.model=="string"&&!V[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${v(V[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:s={},customPrompt:i}=r??{},l=this.generatePrompt(n,i),{endpoint:a,requestBody:c,headers:m}=this.prepareRequestDetails(l);try{let p=await this.sendCompletionRequest(a,c,{...m,...s});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let r=oe(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){if(typeof this.model=="object"&&"config"in this.model){let o=this.model.config(this.apiKey,e),r=o.endpoint,n=o.body??{},s=o.headers??{};return {endpoint:r,requestBody:n,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let o=ne(this.model,this.apiKey,this.provider),r=se(this.apiKey,this.provider),n=ie(this.model,this.provider,e);return {endpoint:o,requestBody:n,headers:r}}}async sendCompletionRequest(e,o,r){return L.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&&q("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:ae(e,this.provider),raw:e}}}handleCompletionError(e){return {error:T(e).message,completion:null}}};var N=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 s=n[0],i=s.split(`
38
38
  `).slice(1,-1).join(`
39
39
  `);r=r.replace(s,i);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
40
40
 
41
- `),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !re(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 P=class P{constructor(){this.cache=new k(P.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 T(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:s}=e,{startLineNumber:i,startColumn:l,endLineNumber:a,endColumn:d}=n,{lineNumber:m,column:p}=o,u=m===i&&p===l;if(i===a)return u||s.startsWith(r)&&m===i&&p>=l-P.LOOK_AROUND&&p<=d+P.LOOK_AROUND;let C=s.startsWith(r)&&m>=i&&m<=a&&(m===i&&p>=l-P.LOOK_AROUND||m===a&&p<=d+P.LOOK_AROUND||m>i&&m<a);return u||C}};P.MAX_CACHE_SIZE=10,P.LOOK_AROUND=10;var _=P;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=r.getOffsetAt(e),s=r.getValue().substring(0,n),i=r.getValue().substring(n),l=0,a=0,d=0,m=0,p=o.length,u=s.length,C=i.length;if(n>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(C===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let b=Math.min(p,u);for(let c=1;c<=b;c++){let x=o.substring(0,c),he=s.slice(-c);x===he&&(m=c);}let y=Math.min(p,C);for(let c=0;c<y&&o[c]===i[c];c++)l++;for(let c=1;c<=y;c++)o.slice(-c)===i.slice(0,c)&&(a=c);if(d=Math.max(l,a),d===0){for(let c=1;c<p;c++)if(i.startsWith(o.substring(c))){d=p-c;break}}let f=m>0?r.getPositionAt(n-m):e,g=n+d,h=r.getPositionAt(g);return new this.monaco.Range(f.lineNumber,f.column,h.lineNumber,h.column)}computeCacheRange(e,o){let r=e.lineNumber,n=e.column,s=o.split(`
42
- `),i=s.length-1,l=r+i,a=i===0?n+s[0].length:s[i].length+1;return new this.monaco.Range(r,n,l,a)}};var be="application/json",me=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await D.POST(e,o,{headers:{"Content-Type":be},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:s,relatedFiles:i,maxContextLines:l}=o,a=Me(t,e),m=!!i?.length?3:2,p=l?Math.floor(l/m):void 0,u=(g,h,c)=>{let x=g(t,e);return h?U(x,h,c):x},C=(g,h)=>!g||!h?g:g.map(({content:c,...x})=>({...x,content:U(c,h)})),b=u(T,p,{from:"end"}),y=u(te,p),f=C(i,p);return {filename:r,language:n,technologies:s,relatedFiles:f,textBeforeCursor:b,textAfterCursor:y,cursorPosition:t,editorState:{completionMode:a}}},Me=(t,e)=>{let o=Q(t,e),r=L(t,e);return o?"insert":r.trim()?"complete":"continue"};var R=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var G={onTyping:300,onIdle:600,onDemand:0},Ie=t=>({onTyping:w(t,G.onTyping),onIdle:w(t,G.onIdle),onDemand:w(t,G.onDemand)}),H=new _,Ae=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:s,options:i})=>{let{trigger:l="onIdle",endpoint:a,enableCaching:d=!0,onError:m,requestHandler:p}=i;if(!new q(o,e).shouldProvideCompletions())return R([]);if(d){let u=H.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return s(),R(u)}if(r.isCancellationRequested||n)return R([]);try{let C=Ie(p??me)[l];r.onCancellationRequested(()=>{C.cancel();});let b=ue({pos:o,mdl:e,options:i}),{completion:y}=await C({endpoint:a,body:{completionMetadata:b}});if(y){let f=N.create(y).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),g=new $(t),h=g.computeInsertionRange(o,f,e),c=g.computeCacheRange(o,f);return d&&H.add({completion:f,range:c,textBeforeCursor:T(o,e)}),s(),R([{insertText:f,range:h}])}}catch(u){if(Le(u))return R([]);m?m(u):O(u);}return R([])},Le=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,Ce=Ae;var E=new WeakMap,I=null,ge=(t,e,o)=>{I&&I.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};E.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let s=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,d,m,p)=>{let u=E.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return Ce({monaco:t,mdl:a,pos:d,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(s);let i=e.onKeyDown(a=>{let d=E.get(e);if(!d)return;let m=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;d.isCompletionVisible&&m?(d.isCompletionAccepted=!0,d.isCompletionVisible=!1):d.isCompletionAccepted=!1;});r.push(i);let l={deregister:()=>{r.forEach(a=>a.dispose()),H.clear(),E.delete(e),I=null;},trigger:()=>De(e)};return I=l,l}catch(s){return o.onError?o.onError(s):O(s),{deregister:()=>{r.forEach(i=>i.dispose()),E.delete(e),I=null;},trigger:()=>{}}}},De=t=>{let e=E.get(t);if(!e){de("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},we=(...t)=>(B("registerCopilot","registerCompletion"),ge(...t));
41
+ `),this}build(){return this.formattedCompletion}};var F=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !te(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 P=class P{constructor(){this.cache=new k(P.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 b(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:s}=e,{startLineNumber:i,startColumn:l,endLineNumber:a,endColumn:c}=n,{lineNumber:m,column:p}=o,u=m===i&&p===l;if(i===a)return u||s.startsWith(r)&&m===i&&p>=l-P.LOOK_AROUND&&p<=c+P.LOOK_AROUND;let C=s.startsWith(r)&&m>=i&&m<=a&&(m===i&&p>=l-P.LOOK_AROUND||m===a&&p<=c+P.LOOK_AROUND||m>i&&m<a);return u||C}};P.MAX_CACHE_SIZE=10,P.LOOK_AROUND=10;var $=P;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=r.getOffsetAt(e),s=r.getValue().substring(0,n),i=r.getValue().substring(n),l=0,a=0,c=0,m=0,p=o.length,u=s.length,C=i.length;if(n>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(C===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let M=Math.min(p,u);for(let d=1;d<=M;d++){let x=o.substring(0,d),Ce=s.slice(-d);x===Ce&&(m=d);}let y=Math.min(p,C);for(let d=0;d<y&&o[d]===i[d];d++)l++;for(let d=1;d<=y;d++)o.slice(-d)===i.slice(0,d)&&(a=d);if(c=Math.max(l,a),c===0){for(let d=1;d<p;d++)if(i.startsWith(o.substring(d))){c=p-d;break}}let f=m>0?r.getPositionAt(n-m):e,g=n+c,h=r.getPositionAt(g);return new this.monaco.Range(f.lineNumber,f.column,h.lineNumber,h.column)}computeCacheRange(e,o){let r=e.lineNumber,n=e.column,s=o.split(`
42
+ `),i=s.length-1,l=r+i,a=i===0?n+s[0].length:s[i].length+1;return new this.monaco.Range(r,n,l,a)}};var Te="application/json",de=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await L.POST(e,o,{headers:{"Content-Type":Te},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},ce=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:s,relatedFiles:i,maxContextLines:l}=o,a=Ee(t,e),m=!!i?.length?3:2,p=l?Math.floor(l/m):void 0,u=(g,h,d)=>{let x=g(t,e);return h?K(x,h,d):x},C=(g,h)=>!g||!h?g:g.map(({content:d,...x})=>({...x,content:K(d,h)})),M=u(b,p,{from:"end"}),y=u(Q,p),f=C(i,p);return {filename:r,language:n,technologies:s,relatedFiles:f,textBeforeCursor:M,textAfterCursor:y,cursorPosition:t,editorState:{completionMode:a}}},Ee=(t,e)=>{let o=J(t,e),r=w(t,e);return o?"insert":r.trim()?"complete":"continue"};var R=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var G={onTyping:300,onIdle:600,onDemand:0},Oe=t=>({onTyping:S(t,G.onTyping),onIdle:S(t,G.onIdle),onDemand:S(t,G.onDemand)}),H=new $,ve=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:s,options:i})=>{let{trigger:l="onIdle",endpoint:a,enableCaching:c=!0,onError:m,requestHandler:p}=i;if(!new F(o,e).shouldProvideCompletions())return R([]);if(c){let u=H.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return s(),R(u)}if(r.isCancellationRequested||n)return R([]);try{let C=Oe(p??de)[l];r.onCancellationRequested(()=>{C.cancel();});let M=ce({pos:o,mdl:e,options:i}),{completion:y}=await C({endpoint:a,body:{completionMetadata:M}});if(y){let f=N.create(y).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),g=new _(t),h=g.computeInsertionRange(o,f,e),d=g.computeCacheRange(o,f);return c&&H.add({completion:f,range:d,textBeforeCursor:b(o,e)}),s(),R([{insertText:f,range:h}])}}catch(u){if(Ie(u))return R([]);m?m(u):T(u);}return R([])},Ie=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,me=ve;var E=new WeakMap,I=null,ue=(t,e,o)=>{I&&I.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};E.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let s=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,c,m,p)=>{let u=E.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return me({monaco:t,mdl:a,pos:c,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(s);let i=e.onKeyDown(a=>{let c=E.get(e);if(!c)return;let m=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;c.isCompletionVisible&&m?(c.isCompletionAccepted=!0,c.isCompletionVisible=!1):c.isCompletionAccepted=!1;});r.push(i);let l={deregister:()=>{r.forEach(a=>a.dispose()),H.clear(),E.delete(e),I=null;},trigger:()=>Ae(e)};return I=l,l}catch(s){return o.onError?o.onError(s):T(s),{deregister:()=>{r.forEach(i=>i.dispose()),E.delete(e),I=null;},trigger:()=>{}}}},Ae=t=>{let e=E.get(t);if(!e){pe("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},we=(...t)=>(q("registerCopilot","registerCompletion"),ue(...t));
43
43
 
44
44
  exports.Copilot = W;
45
- exports.registerCompletion = ge;
45
+ exports.registerCompletion = ue;
46
46
  exports.registerCopilot = we;
package/build/index.mjs CHANGED
@@ -1,10 +1,10 @@
1
- var V=["groq","openai","anthropic","google"],Y={"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"},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"]},X="anthropic",J="claude-3-5-haiku",M={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"},A=.1;var v=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,Z=t=>t.charAt(0).toUpperCase()+t.slice(1),U=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
1
+ var j=["groq","openai","anthropic","google"],Y={"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"},V={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"]},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"},A=.1;var v=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,X=t=>t.charAt(0).toUpperCase()+t.slice(1),K=(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 i=r.slice(-e);return i.every(l=>l==="")?`
3
3
  `.repeat(e):i.join(`
4
4
  `)}let s=r.slice(0,e);return s.every(i=>i==="")?`
5
5
  `.repeat(e):s.join(`
6
- `)};var Q=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],L=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ee=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),T=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),te=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var oe=async(t,e,o={})=>{let r=o.timeout??3e4,n=AbortSignal.timeout(r),s=o.signal?AbortSignal.any([n,o.signal]):n,i={"Content-Type":"application/json",...o.headers},l=e==="POST"&&o.body?JSON.stringify(o.body):void 0,a=await fetch(t,{method:e,headers:i,body:l,signal:s});if(!a.ok){let d=await a.json().catch(()=>null),m=d?`
7
- ${JSON.stringify(d,null,2)}`:"",p=o.fallbackError||"Network request failed";throw new Error(`${p} (${a.status})${m}`)}return a.json()},fe=(t,e)=>oe(t,"GET",e),Pe=(t,e,o)=>oe(t,"POST",{...o,body:e}),D={GET:fe,POST:Pe};var re=(t,e)=>{let o=L(t,e).trim(),r=ee(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var w=(t,e)=>{let o=null,r=null,n=(...s)=>new Promise((i,l)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=l,o=setTimeout(()=>{i(t(...s)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var ye=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
6
+ `)};var J=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],w=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),Z=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),b=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),Q=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var ee=async(t,e,o={})=>{let r=o.timeout??3e4,n=AbortSignal.timeout(r),s=o.signal?AbortSignal.any([n,o.signal]):n,i={"Content-Type":"application/json",...o.headers},l=e==="POST"&&o.body?JSON.stringify(o.body):void 0,a=await fetch(t,{method:e,headers:i,body:l,signal:s});if(!a.ok){let c=await a.json().catch(()=>null),m=c?`
7
+ ${JSON.stringify(c,null,2)}`:"",p=o.fallbackError||"Network request failed";throw new Error(`${p} (${a.status})${m}`)}return a.json()},ge=(t,e)=>ee(t,"GET",e),he=(t,e,o)=>ee(t,"POST",{...o,body:e}),L={GET:ge,POST:he};var te=(t,e)=>{let o=w(t,e).trim(),r=Z(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var S=(t,e)=>{let o=null,r=null,n=(...s)=>new Promise((i,l)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=l,o=setTimeout(()=>{i(t(...s)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var fe=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
8
8
  <related_file>
9
9
  <filePath>${e}</filePath>
10
10
  <fileContent>
@@ -14,7 +14,7 @@ ${o}
14
14
  </fileContent>
15
15
  </related_file>`.trim()).join(`
16
16
 
17
- `),ne=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n,textBeforeCursor:s="",textAfterCursor:i="",editorState:{completionMode:l}}=t,a=v([n,...e].filter(p=>typeof p=="string"&&!!p)),d=`
17
+ `),oe=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n,textBeforeCursor:s="",textAfterCursor:i="",editorState:{completionMode:l}}=t,a=v([n,...e].filter(p=>typeof p=="string"&&!!p)),c=`
18
18
  You are a code completion assistant.
19
19
 
20
20
  Context:
@@ -23,20 +23,20 @@ Language: ${n||"Undetermined"}
23
23
  Mode: ${l}
24
24
  Stack: ${a||"None"}`,m=`
25
25
  Related Files:
26
- ${ye(r)}
26
+ ${fe(r)}
27
27
 
28
28
  Source:
29
29
  \`\`\`
30
30
  ${s}<cursor>${i}
31
31
  \`\`\`
32
32
 
33
- ${Z(l)} the code at <cursor>.
33
+ ${X(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:d,user:m}};var ie={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var Re={createEndpoint:()=>M.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:F(t),...!o&&{temperature:A},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},xe={createEndpoint:()=>M.groq,createRequestBody:(t,e)=>({model:F(t),temperature:A,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},Te={createEndpoint:()=>M.anthropic,createRequestBody:(t,e)=>({model:F(t),temperature:A,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ie[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)=>`${M.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:F(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}},S={openai:Re,groq:xe,anthropic:Te,google:Oe},se=(t,e,o)=>S[o].createEndpoint(t,e),ae=(t,e,o)=>S[e].createRequestBody(t,o),le=(t,e)=>S[e].createHeaders(t),pe=(t,e)=>S[e].parseCompletion(t),F=t=>Y[t];var Ee="\x1B[91m",ce="\x1B[93m",K="\x1B[0m",z="\x1B[1m",O=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${Ee}${z}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},de=t=>{console.warn(`${ce}${z}[MONACOPILOT WARN] ${t}${K}`);};var B=(t,e,o)=>console.warn(`${ce}${z}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${K}`);var W=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??X,this.model=o.model??J,this.validateInputs();}validateInputs(){if(!V.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${v(V)}. For custom models, provider specification is not needed.`);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: ${v(j[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:s={},customPrompt:i}=r??{},l=this.generatePrompt(n,i),{endpoint:a,requestBody:d,headers:m}=this.prepareRequestDetails(l);try{let p=await this.sendCompletionRequest(a,d,{...m,...s});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let r=ne(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=se(this.model,this.apiKey,this.provider),r,n=le(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let s=this.model.config(this.apiKey,e);o=s.endpoint??o,r=s.body??{},n={...n,...s.headers};}else r=ae(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return D.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:pe(e,this.provider),raw:e}}handleCompletionError(e){return {error:O(e).message,completion:null}}};var N=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 s=n[0],i=s.split(`
35
+ Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:c,user:m}};var re={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var Pe={createEndpoint:()=>O.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:D(t),...!o&&{temperature:A},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.groq,createRequestBody:(t,e)=>({model:D(t),temperature:A,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:()=>O.anthropic,createRequestBody:(t,e)=>({model:D(t),temperature:A,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:re[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:D(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}},B={openai:Pe,groq:ye,anthropic:Re,google:xe},ne=(t,e,o)=>B[o].createEndpoint(t,e),ie=(t,e,o)=>B[e].createRequestBody(t,o),se=(t,e)=>B[e].createHeaders(t),ae=(t,e)=>B[e].parseCompletion(t),D=t=>Y[t];var be="\x1B[91m",le="\x1B[93m",U="\x1B[0m",z="\x1B[1m",T=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${be}${z}[MONACOPILOT ERROR] ${e}${U}`;return console.error(o),{message:e}},pe=t=>{console.warn(`${le}${z}[MONACOPILOT WARN] ${t}${U}`);};var q=(t,e,o)=>console.warn(`${le}${z}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${U}`);var W=class{constructor(e,o){this.validateParams(e,o),this.apiKey=e,this.provider=o.provider,this.model=o.model,this.validateInputs();}validateParams(e,o){if(!e)throw new Error("Please provide an API key.");if(!o||typeof o=="object"&&Object.keys(o).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||!j.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${v(j)}`);if(typeof this.model=="string"&&!V[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${v(V[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:s={},customPrompt:i}=r??{},l=this.generatePrompt(n,i),{endpoint:a,requestBody:c,headers:m}=this.prepareRequestDetails(l);try{let p=await this.sendCompletionRequest(a,c,{...m,...s});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let r=oe(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){if(typeof this.model=="object"&&"config"in this.model){let o=this.model.config(this.apiKey,e),r=o.endpoint,n=o.body??{},s=o.headers??{};return {endpoint:r,requestBody:n,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let o=ne(this.model,this.apiKey,this.provider),r=se(this.apiKey,this.provider),n=ie(this.model,this.provider,e);return {endpoint:o,requestBody:n,headers:r}}}async sendCompletionRequest(e,o,r){return L.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&&q("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:ae(e,this.provider),raw:e}}}handleCompletionError(e){return {error:T(e).message,completion:null}}};var N=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 s=n[0],i=s.split(`
36
36
  `).slice(1,-1).join(`
37
37
  `);r=r.replace(s,i);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
38
38
 
39
- `),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !re(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 P=class P{constructor(){this.cache=new k(P.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 T(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:s}=e,{startLineNumber:i,startColumn:l,endLineNumber:a,endColumn:d}=n,{lineNumber:m,column:p}=o,u=m===i&&p===l;if(i===a)return u||s.startsWith(r)&&m===i&&p>=l-P.LOOK_AROUND&&p<=d+P.LOOK_AROUND;let C=s.startsWith(r)&&m>=i&&m<=a&&(m===i&&p>=l-P.LOOK_AROUND||m===a&&p<=d+P.LOOK_AROUND||m>i&&m<a);return u||C}};P.MAX_CACHE_SIZE=10,P.LOOK_AROUND=10;var _=P;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=r.getOffsetAt(e),s=r.getValue().substring(0,n),i=r.getValue().substring(n),l=0,a=0,d=0,m=0,p=o.length,u=s.length,C=i.length;if(n>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(C===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let b=Math.min(p,u);for(let c=1;c<=b;c++){let x=o.substring(0,c),he=s.slice(-c);x===he&&(m=c);}let y=Math.min(p,C);for(let c=0;c<y&&o[c]===i[c];c++)l++;for(let c=1;c<=y;c++)o.slice(-c)===i.slice(0,c)&&(a=c);if(d=Math.max(l,a),d===0){for(let c=1;c<p;c++)if(i.startsWith(o.substring(c))){d=p-c;break}}let f=m>0?r.getPositionAt(n-m):e,g=n+d,h=r.getPositionAt(g);return new this.monaco.Range(f.lineNumber,f.column,h.lineNumber,h.column)}computeCacheRange(e,o){let r=e.lineNumber,n=e.column,s=o.split(`
40
- `),i=s.length-1,l=r+i,a=i===0?n+s[0].length:s[i].length+1;return new this.monaco.Range(r,n,l,a)}};var be="application/json",me=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await D.POST(e,o,{headers:{"Content-Type":be},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:s,relatedFiles:i,maxContextLines:l}=o,a=Me(t,e),m=!!i?.length?3:2,p=l?Math.floor(l/m):void 0,u=(g,h,c)=>{let x=g(t,e);return h?U(x,h,c):x},C=(g,h)=>!g||!h?g:g.map(({content:c,...x})=>({...x,content:U(c,h)})),b=u(T,p,{from:"end"}),y=u(te,p),f=C(i,p);return {filename:r,language:n,technologies:s,relatedFiles:f,textBeforeCursor:b,textAfterCursor:y,cursorPosition:t,editorState:{completionMode:a}}},Me=(t,e)=>{let o=Q(t,e),r=L(t,e);return o?"insert":r.trim()?"complete":"continue"};var R=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var G={onTyping:300,onIdle:600,onDemand:0},Ie=t=>({onTyping:w(t,G.onTyping),onIdle:w(t,G.onIdle),onDemand:w(t,G.onDemand)}),H=new _,Ae=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:s,options:i})=>{let{trigger:l="onIdle",endpoint:a,enableCaching:d=!0,onError:m,requestHandler:p}=i;if(!new q(o,e).shouldProvideCompletions())return R([]);if(d){let u=H.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return s(),R(u)}if(r.isCancellationRequested||n)return R([]);try{let C=Ie(p??me)[l];r.onCancellationRequested(()=>{C.cancel();});let b=ue({pos:o,mdl:e,options:i}),{completion:y}=await C({endpoint:a,body:{completionMetadata:b}});if(y){let f=N.create(y).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),g=new $(t),h=g.computeInsertionRange(o,f,e),c=g.computeCacheRange(o,f);return d&&H.add({completion:f,range:c,textBeforeCursor:T(o,e)}),s(),R([{insertText:f,range:h}])}}catch(u){if(Le(u))return R([]);m?m(u):O(u);}return R([])},Le=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,Ce=Ae;var E=new WeakMap,I=null,ge=(t,e,o)=>{I&&I.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};E.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let s=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,d,m,p)=>{let u=E.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return Ce({monaco:t,mdl:a,pos:d,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(s);let i=e.onKeyDown(a=>{let d=E.get(e);if(!d)return;let m=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;d.isCompletionVisible&&m?(d.isCompletionAccepted=!0,d.isCompletionVisible=!1):d.isCompletionAccepted=!1;});r.push(i);let l={deregister:()=>{r.forEach(a=>a.dispose()),H.clear(),E.delete(e),I=null;},trigger:()=>De(e)};return I=l,l}catch(s){return o.onError?o.onError(s):O(s),{deregister:()=>{r.forEach(i=>i.dispose()),E.delete(e),I=null;},trigger:()=>{}}}},De=t=>{let e=E.get(t);if(!e){de("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},we=(...t)=>(B("registerCopilot","registerCompletion"),ge(...t));
39
+ `),this}build(){return this.formattedCompletion}};var F=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !te(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 P=class P{constructor(){this.cache=new k(P.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 b(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:s}=e,{startLineNumber:i,startColumn:l,endLineNumber:a,endColumn:c}=n,{lineNumber:m,column:p}=o,u=m===i&&p===l;if(i===a)return u||s.startsWith(r)&&m===i&&p>=l-P.LOOK_AROUND&&p<=c+P.LOOK_AROUND;let C=s.startsWith(r)&&m>=i&&m<=a&&(m===i&&p>=l-P.LOOK_AROUND||m===a&&p<=c+P.LOOK_AROUND||m>i&&m<a);return u||C}};P.MAX_CACHE_SIZE=10,P.LOOK_AROUND=10;var $=P;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=r.getOffsetAt(e),s=r.getValue().substring(0,n),i=r.getValue().substring(n),l=0,a=0,c=0,m=0,p=o.length,u=s.length,C=i.length;if(n>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(C===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let M=Math.min(p,u);for(let d=1;d<=M;d++){let x=o.substring(0,d),Ce=s.slice(-d);x===Ce&&(m=d);}let y=Math.min(p,C);for(let d=0;d<y&&o[d]===i[d];d++)l++;for(let d=1;d<=y;d++)o.slice(-d)===i.slice(0,d)&&(a=d);if(c=Math.max(l,a),c===0){for(let d=1;d<p;d++)if(i.startsWith(o.substring(d))){c=p-d;break}}let f=m>0?r.getPositionAt(n-m):e,g=n+c,h=r.getPositionAt(g);return new this.monaco.Range(f.lineNumber,f.column,h.lineNumber,h.column)}computeCacheRange(e,o){let r=e.lineNumber,n=e.column,s=o.split(`
40
+ `),i=s.length-1,l=r+i,a=i===0?n+s[0].length:s[i].length+1;return new this.monaco.Range(r,n,l,a)}};var Te="application/json",de=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await L.POST(e,o,{headers:{"Content-Type":Te},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},ce=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:s,relatedFiles:i,maxContextLines:l}=o,a=Ee(t,e),m=!!i?.length?3:2,p=l?Math.floor(l/m):void 0,u=(g,h,d)=>{let x=g(t,e);return h?K(x,h,d):x},C=(g,h)=>!g||!h?g:g.map(({content:d,...x})=>({...x,content:K(d,h)})),M=u(b,p,{from:"end"}),y=u(Q,p),f=C(i,p);return {filename:r,language:n,technologies:s,relatedFiles:f,textBeforeCursor:M,textAfterCursor:y,cursorPosition:t,editorState:{completionMode:a}}},Ee=(t,e)=>{let o=J(t,e),r=w(t,e);return o?"insert":r.trim()?"complete":"continue"};var R=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var G={onTyping:300,onIdle:600,onDemand:0},Oe=t=>({onTyping:S(t,G.onTyping),onIdle:S(t,G.onIdle),onDemand:S(t,G.onDemand)}),H=new $,ve=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:s,options:i})=>{let{trigger:l="onIdle",endpoint:a,enableCaching:c=!0,onError:m,requestHandler:p}=i;if(!new F(o,e).shouldProvideCompletions())return R([]);if(c){let u=H.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return s(),R(u)}if(r.isCancellationRequested||n)return R([]);try{let C=Oe(p??de)[l];r.onCancellationRequested(()=>{C.cancel();});let M=ce({pos:o,mdl:e,options:i}),{completion:y}=await C({endpoint:a,body:{completionMetadata:M}});if(y){let f=N.create(y).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),g=new _(t),h=g.computeInsertionRange(o,f,e),d=g.computeCacheRange(o,f);return c&&H.add({completion:f,range:d,textBeforeCursor:b(o,e)}),s(),R([{insertText:f,range:h}])}}catch(u){if(Ie(u))return R([]);m?m(u):T(u);}return R([])},Ie=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,me=ve;var E=new WeakMap,I=null,ue=(t,e,o)=>{I&&I.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};E.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let s=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,c,m,p)=>{let u=E.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return me({monaco:t,mdl:a,pos:c,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(s);let i=e.onKeyDown(a=>{let c=E.get(e);if(!c)return;let m=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;c.isCompletionVisible&&m?(c.isCompletionAccepted=!0,c.isCompletionVisible=!1):c.isCompletionAccepted=!1;});r.push(i);let l={deregister:()=>{r.forEach(a=>a.dispose()),H.clear(),E.delete(e),I=null;},trigger:()=>Ae(e)};return I=l,l}catch(s){return o.onError?o.onError(s):T(s),{deregister:()=>{r.forEach(i=>i.dispose()),E.delete(e),I=null;},trigger:()=>{}}}},Ae=t=>{let e=E.get(t);if(!e){pe("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},we=(...t)=>(q("registerCopilot","registerCompletion"),ue(...t));
41
41
 
42
- export { W as Copilot, ge as registerCompletion, we as registerCopilot };
42
+ export { W as Copilot, ue as registerCompletion, we as registerCopilot };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "monacopilot",
3
- "version": "0.15.11",
3
+ "version": "0.15.12",
4
4
  "description": "AI auto-completion plugin for Monaco Editor",
5
5
  "main": "./build/index.js",
6
6
  "module": "./build/index.mjs",