monacopilot 0.17.0 → 0.17.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/build/index.d.mts CHANGED
@@ -1,28 +1,27 @@
1
1
  import { Message, MessageCreateParams } from '@anthropic-ai/sdk/resources';
2
- import { ModelParams, GenerateContentResponse } from '@google/generative-ai';
2
+ import { GenerateContentRequest, GenerateContentResponse } from '@google/generative-ai';
3
3
  import { ChatCompletion as ChatCompletion$1, ChatCompletionCreateParamsBase as ChatCompletionCreateParamsBase$1 } from 'groq-sdk/resources/chat/completions';
4
4
  import { ChatCompletion, ChatCompletionCreateParamsBase } from 'openai/resources/chat/completions';
5
5
  import * as monaco from 'monaco-editor/esm/vs/editor/editor.api';
6
6
 
7
- declare const COPILOT_MODEL_IDS: Record<CopilotModel, string>;
7
+ declare const MODEL_IDS: Record<Model, string>;
8
8
 
9
+ /**
10
+ * Providers supported by Copilot.
11
+ */
12
+ type Provider = 'openai' | 'groq' | 'anthropic' | 'google' | 'deepseek';
9
13
  type DeepSeekChatCompletionType = {
10
14
  choices: {
11
15
  text: string;
12
16
  }[];
13
17
  };
14
18
  type DeepSeekChatCompletionCreateParamsBase = {
15
- model: (typeof COPILOT_MODEL_IDS)['v3'];
19
+ model: (typeof MODEL_IDS)['v3'];
16
20
  prompt: string;
17
21
  suffix: string;
18
22
  temperature: number;
19
23
  max_tokens: number;
20
24
  };
21
-
22
- /**
23
- * Providers supported by Copilot.
24
- */
25
- type CopilotProvider = 'openai' | 'groq' | 'anthropic' | 'google' | 'deepseek';
26
25
  /**
27
26
  * Core type mapping for provider-specific implementations
28
27
  */
@@ -44,7 +43,7 @@ interface ProviderImplementationMap {
44
43
  };
45
44
  google: {
46
45
  Model: 'gemini-1.5-flash' | 'gemini-1.5-flash-8b' | 'gemini-1.5-pro';
47
- Params: ModelParams;
46
+ Params: GenerateContentRequest;
48
47
  Completion: GenerateContentResponse;
49
48
  };
50
49
  deepseek: {
@@ -62,13 +61,14 @@ type AnthropicModel = ProviderImplementationMap['anthropic']['Model'];
62
61
  /**
63
62
  * Union of all predefined Copilot models
64
63
  */
65
- type CopilotModel = {
66
- [K in CopilotProvider]: ProviderImplementationMap[K]['Model'];
67
- }[CopilotProvider];
64
+ type Model = {
65
+ [K in Provider]: ProviderImplementationMap[K]['Model'];
66
+ }[Provider];
68
67
  type OpenAIChatCompletion = ChatCompletion;
69
68
  type DeepSeekChatCompletion = DeepSeekChatCompletionType;
70
69
  type GroqChatCompletion = ChatCompletion$1;
71
70
  type AnthropicChatCompletion = Message;
71
+
72
72
  /**
73
73
  * Data structure representing the prompt data.
74
74
  */
@@ -99,18 +99,15 @@ interface CustomCopilotModel {
99
99
  /** Response transformer */
100
100
  transformResponse: CustomCopilotModelTransformResponse;
101
101
  }
102
- /**
103
- * Enhanced Copilot options using mapped types
104
- */
105
- type ProviderOptions<T extends CopilotProvider> = {
106
- provider: T;
107
- model: ProviderImplementationMap[T]['Model'];
108
- };
109
102
  type CustomOptions = {
110
103
  provider?: undefined;
111
104
  model: CustomCopilotModel;
112
105
  };
113
106
  type CopilotOptions = ProviderOptions<'openai'> | ProviderOptions<'groq'> | ProviderOptions<'anthropic'> | ProviderOptions<'google'> | ProviderOptions<'deepseek'> | CustomOptions;
107
+ type ProviderOptions<T extends Provider> = {
108
+ provider: T;
109
+ model: ProviderImplementationMap[T]['Model'];
110
+ };
114
111
 
115
112
  type Monaco = typeof monaco;
116
113
  type StandaloneCodeEditor = monaco.editor.IStandaloneCodeEditor;
@@ -355,4 +352,4 @@ declare class Copilot {
355
352
  */
356
353
  declare const registerCompletion: (monaco: Monaco, editor: StandaloneCodeEditor, options: RegisterCompletionOptions) => CompletionRegistration;
357
354
 
358
- export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type CopilotModel, type CopilotOptions, type CopilotProvider, type CustomCopilotModel, type CustomCopilotModelConfig, type CustomCopilotModelTransformResponse, type DeepSeekChatCompletion, type GroqChatCompletion, type GroqModel, type Monaco, type OpenAIChatCompletion, type OpenAIModel, type RegisterCompletionOptions, type StandaloneCodeEditor, registerCompletion };
355
+ export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type CopilotOptions, type CustomCopilotModel, type CustomCopilotModelConfig, type CustomCopilotModelTransformResponse, type DeepSeekChatCompletion, type GroqChatCompletion, type GroqModel, type Model, type Monaco, type OpenAIChatCompletion, type OpenAIModel, type Provider, type RegisterCompletionOptions, type StandaloneCodeEditor, registerCompletion };
package/build/index.d.ts CHANGED
@@ -1,28 +1,27 @@
1
1
  import { Message, MessageCreateParams } from '@anthropic-ai/sdk/resources';
2
- import { ModelParams, GenerateContentResponse } from '@google/generative-ai';
2
+ import { GenerateContentRequest, GenerateContentResponse } from '@google/generative-ai';
3
3
  import { ChatCompletion as ChatCompletion$1, ChatCompletionCreateParamsBase as ChatCompletionCreateParamsBase$1 } from 'groq-sdk/resources/chat/completions';
4
4
  import { ChatCompletion, ChatCompletionCreateParamsBase } from 'openai/resources/chat/completions';
5
5
  import * as monaco from 'monaco-editor/esm/vs/editor/editor.api';
6
6
 
7
- declare const COPILOT_MODEL_IDS: Record<CopilotModel, string>;
7
+ declare const MODEL_IDS: Record<Model, string>;
8
8
 
9
+ /**
10
+ * Providers supported by Copilot.
11
+ */
12
+ type Provider = 'openai' | 'groq' | 'anthropic' | 'google' | 'deepseek';
9
13
  type DeepSeekChatCompletionType = {
10
14
  choices: {
11
15
  text: string;
12
16
  }[];
13
17
  };
14
18
  type DeepSeekChatCompletionCreateParamsBase = {
15
- model: (typeof COPILOT_MODEL_IDS)['v3'];
19
+ model: (typeof MODEL_IDS)['v3'];
16
20
  prompt: string;
17
21
  suffix: string;
18
22
  temperature: number;
19
23
  max_tokens: number;
20
24
  };
21
-
22
- /**
23
- * Providers supported by Copilot.
24
- */
25
- type CopilotProvider = 'openai' | 'groq' | 'anthropic' | 'google' | 'deepseek';
26
25
  /**
27
26
  * Core type mapping for provider-specific implementations
28
27
  */
@@ -44,7 +43,7 @@ interface ProviderImplementationMap {
44
43
  };
45
44
  google: {
46
45
  Model: 'gemini-1.5-flash' | 'gemini-1.5-flash-8b' | 'gemini-1.5-pro';
47
- Params: ModelParams;
46
+ Params: GenerateContentRequest;
48
47
  Completion: GenerateContentResponse;
49
48
  };
50
49
  deepseek: {
@@ -62,13 +61,14 @@ type AnthropicModel = ProviderImplementationMap['anthropic']['Model'];
62
61
  /**
63
62
  * Union of all predefined Copilot models
64
63
  */
65
- type CopilotModel = {
66
- [K in CopilotProvider]: ProviderImplementationMap[K]['Model'];
67
- }[CopilotProvider];
64
+ type Model = {
65
+ [K in Provider]: ProviderImplementationMap[K]['Model'];
66
+ }[Provider];
68
67
  type OpenAIChatCompletion = ChatCompletion;
69
68
  type DeepSeekChatCompletion = DeepSeekChatCompletionType;
70
69
  type GroqChatCompletion = ChatCompletion$1;
71
70
  type AnthropicChatCompletion = Message;
71
+
72
72
  /**
73
73
  * Data structure representing the prompt data.
74
74
  */
@@ -99,18 +99,15 @@ interface CustomCopilotModel {
99
99
  /** Response transformer */
100
100
  transformResponse: CustomCopilotModelTransformResponse;
101
101
  }
102
- /**
103
- * Enhanced Copilot options using mapped types
104
- */
105
- type ProviderOptions<T extends CopilotProvider> = {
106
- provider: T;
107
- model: ProviderImplementationMap[T]['Model'];
108
- };
109
102
  type CustomOptions = {
110
103
  provider?: undefined;
111
104
  model: CustomCopilotModel;
112
105
  };
113
106
  type CopilotOptions = ProviderOptions<'openai'> | ProviderOptions<'groq'> | ProviderOptions<'anthropic'> | ProviderOptions<'google'> | ProviderOptions<'deepseek'> | CustomOptions;
107
+ type ProviderOptions<T extends Provider> = {
108
+ provider: T;
109
+ model: ProviderImplementationMap[T]['Model'];
110
+ };
114
111
 
115
112
  type Monaco = typeof monaco;
116
113
  type StandaloneCodeEditor = monaco.editor.IStandaloneCodeEditor;
@@ -355,4 +352,4 @@ declare class Copilot {
355
352
  */
356
353
  declare const registerCompletion: (monaco: Monaco, editor: StandaloneCodeEditor, options: RegisterCompletionOptions) => CompletionRegistration;
357
354
 
358
- export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type CopilotModel, type CopilotOptions, type CopilotProvider, type CustomCopilotModel, type CustomCopilotModelConfig, type CustomCopilotModelTransformResponse, type DeepSeekChatCompletion, type GroqChatCompletion, type GroqModel, type Monaco, type OpenAIChatCompletion, type OpenAIModel, type RegisterCompletionOptions, type StandaloneCodeEditor, registerCompletion };
355
+ export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type CopilotOptions, type CustomCopilotModel, type CustomCopilotModelConfig, type CustomCopilotModelTransformResponse, type DeepSeekChatCompletion, type GroqChatCompletion, type GroqModel, type Model, type Monaco, type OpenAIChatCompletion, type OpenAIModel, type Provider, type RegisterCompletionOptions, type StandaloneCodeEditor, registerCompletion };
package/build/index.js CHANGED
@@ -1,49 +1,49 @@
1
1
  'use strict';
2
2
 
3
- var H=["groq","openai","anthropic","google","deepseek"],G={"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"]},x={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models",deepseek:"https://api.deepseek.com/beta/completions"};var E=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),V=(t,e,o={})=>{if(e<=0)return "";let n=t.split(`
4
- `),i=n.length;if(e>=i)return t;if(o.from==="end"){let s=n.slice(-e);return s.every(m=>m==="")?`
3
+ var W=["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"},X={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 w=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 L=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 N=class extends g{createEndpoint(e,t){return `${R.google}/${P[e]}:generateContent?key=${t}`}createRequestBody(e,t){return {systemInstruction: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 S=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 _=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 B={openai:new _,groq:new S,anthropic:new w,google:new N,deepseek:new L},ee=(o,e,t)=>B[t].createEndpoint(o,e),te=(o,e,t,r)=>B[e].createRequestBody(o,t,r),oe=(o,e)=>B[e].createHeaders(o),re=(o,e)=>B[e].parseCompletion(o);var I=o=>!o||o.length===0?"":o.length===1?o[0]:`${o.slice(0,-1).join(", ")} and ${o.slice(-1)}`,ne=o=>o.charAt(0).toUpperCase()+o.slice(1),G=(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==="")?`
5
5
  `.repeat(e):s.join(`
6
- `)}let r=n.slice(0,e);return r.every(s=>s==="")?`
7
- `.repeat(e):r.join(`
8
- `)};var J=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var Y=(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}),z=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var Z=async(t,e,o={})=>{let n=o.timeout??3e4,i=AbortSignal.timeout(n),r=o.signal?AbortSignal.any([i,o.signal]):i,s={"Content-Type":"application/json",...o.headers},m=e==="POST"&&o.body?JSON.stringify(o.body):void 0,d=await fetch(t,{method:e,headers:s,body:m,signal:r});if(!d.ok){let l=await d.json().catch(()=>null),p=l?`
9
- ${JSON.stringify(l,null,2)}`:"",a=o.fallbackError||"Network request failed";throw new Error(`${a} (${d.status})${p}`)}return d.json()},de=(t,e)=>Z(t,"GET",e),ce=(t,e,o)=>Z(t,"POST",{...o,body:e}),L={GET:de,POST:ce};var k=(t,e=600,o=200)=>{let n=null,i=0,r=null,s=null,m=!1,d=(...l)=>{if(m)return Promise.resolve(void 0);r=l;let p=Date.now(),a=p-i;i=p,n&&(clearTimeout(n),n=null);let u=a<o?e:o;return s=new Promise((g,P)=>{n=setTimeout(async()=>{m=!0;try{if(r){let C=await t(...r);g(C);}else g(void 0);}catch(C){P(C);}finally{m=!1,n=null,r=null;}},u);}),s};return d.cancel=()=>{n&&(clearTimeout(n),n=null),r=null;},d};var ue=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
6
+ `)}let n=r.slice(0,e);return n.every(s=>s==="")?`
7
+ `.repeat(e):n.join(`
8
+ `)};var ie=(o,e)=>e.getLineContent(o.lineNumber)[o.column-1];var se=(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}),J=(o,e)=>e.getValueInRange({startLineNumber:o.lineNumber,startColumn:o.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var ae=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)=>ae(o,"GET",e),he=(o,e,t)=>ae(o,"POST",{...t,body:e}),F={GET:fe,POST:he};var q=(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})=>`
10
10
  <related_file>
11
11
  <filePath>${e}</filePath>
12
12
  <fileContent>
13
13
  \`\`\`
14
- ${o}
14
+ ${t}
15
15
  \`\`\`
16
16
  </fileContent>
17
17
  </related_file>`.trim()).join(`
18
18
 
19
- `),Q=t=>{let{technologies:e=[],filename:o,relatedFiles:n,language:i,textBeforeCursor:r="",textAfterCursor:s="",editorState:{completionMode:m}}=t,d=E([i,...e].filter(a=>typeof a=="string"&&!!a)),l=`
19
+ `),le=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=`
20
20
  You are an expert code completion assistant.
21
21
 
22
22
  **Context:**
23
- File: ${o||"Untitled"}
23
+ File: ${t||"Untitled"}
24
24
  Language: ${i||"Undetermined"}
25
25
  Mode: ${m}
26
- Stack: ${d||"None"}`,p=`
26
+ Stack: ${c||"None"}`,p=`
27
27
  **Related Files:**
28
- ${ue(n)}
28
+ ${Pe(r)}
29
29
 
30
30
  **Source:**
31
31
  \`\`\`
32
- ${r}<cursor>${s}
32
+ ${n}<cursor>${s}
33
33
  \`\`\`
34
34
 
35
- ${X(m)} the code at <cursor>.
35
+ ${ne(m)} 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 Ce={createEndpoint:()=>x.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:O(t),...!o&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.[0]?.message.content??null},ge={createEndpoint:()=>x.groq,createRequestBody:(t,e)=>({model:O(t),temperature:.1,max_tokens:500,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.[0]?.message.content??null},he={createEndpoint:()=>x.anthropic,createRequestBody:(t,e)=>({model:O(t),temperature:.1,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:500}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{let e=t.content?.[0];return e&&"text"in e?e.text:null}},fe={createEndpoint:(t,e)=>`${x.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:O(t),system_instruction:{parts:[{text:e.system}]},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{parts:[{text:e.user}]}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>t.candidates?.[0]?.content?.parts?.[0]?.text??null},Pe={createEndpoint:()=>x.deepseek,createRequestBody:(t,e,o)=>({model:O(t),prompt:o.textBeforeCursor,suffix:o.textAfterCursor,temperature:.1,max_tokens:500}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>typeof t.choices?.[0]?.text=="string"?t.choices[0].text:null},S={openai:Ce,groq:ge,anthropic:he,google:fe,deepseek:Pe},ee=(t,e,o)=>S[o].createEndpoint(t,e),te=(t,e,o,n)=>S[e].createRequestBody(t,o,n),oe=(t,e)=>S[e].createHeaders(t),ne=(t,e)=>S[e].parseCompletion(t),O=t=>G[t];var ye="\x1B[91m",re="\x1B[93m",K="\x1B[0m",U="\x1B[1m",ie=t=>t instanceof Error?t.message:typeof t=="string"?t:"An unknown error occurred",B=t=>{let e=ie(t),o=`${ye}${U}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},I=(t,e)=>{console.warn(`${re}${U}[MONACOPILOT WARN] ${t}${e?`
38
- ${ie(e)}`:""}${K}`);};var se=(t,e,o)=>console.warn(`${re}${U}[MONACOPILOT DEPRECATED] "${t}" is deprecated${` in ${o}`}. Please use "${e}" instead. It will be removed in a future version.${K}`);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||!H.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${E(H)}`);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: ${E(j[this.provider])}`)}async complete(e){let{body:o,options:n}=e,{completionMetadata:i}=o,{headers:r={},customPrompt:s}=n??{},m=this.generatePrompt(i,s),{endpoint:d,requestBody:l,headers:p}=this.prepareRequestDetails(m,i);try{let a=await this.sendCompletionRequest(d,l,{...p,...r});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,o){let n=Q(e);return o?{...n,...o(e)}:n}prepareRequestDetails(e,o){if(typeof this.model=="object"&&"config"in this.model){let n=this.model.config(this.apiKey,e),i=n.endpoint,r=n.body??{},s=n.headers??{};return {endpoint:i,requestBody:r,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let n=ee(this.model,this.apiKey,this.provider),i=oe(this.apiKey,this.provider),r=te(this.model,this.provider,e,o);return {endpoint:n,requestBody:r,headers:i}}}async sendCompletionRequest(e,o,n){return L.POST(e,o,{headers:n})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&se("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:ne(e,this.provider),raw:e}}}handleCompletionError(e){return {error:B(e).message,completion:null}}};var q=class{constructor(e,o,n){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=o,this.textBeforeCursorInLine=n;}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
- `);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let o=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
40
- `+e.slice(1).map(n=>o+n).join(`
41
- `),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,n=e,i;for(;(i=o.exec(e))!==null;){let r=i[0],s=r.split(`
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 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||!W.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${I(W)}`);if(typeof this.model=="string"&&!X[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${I(X[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=le(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=ee(this.model,this.apiKey,this.provider),i=oe(this.apiKey,this.provider),n=te(this.model,this.provider,e,t);return {endpoint:r,requestBody:n,headers:i}}}async sendCompletionRequest(e,t,r){return F.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:re(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(`
39
+ `);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let t=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
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(`
42
42
  `).slice(1,-1).join(`
43
- `);n=n.replace(r,s);}return n.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
43
+ `);r=r.replace(n,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
44
44
 
45
- `),this}build(){return this.formattedCompletion}};var D=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 N=class N{constructor(){this.cache=new D(N.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(n=>this.isValidCacheItem(n,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,n){let i=n.getValueInRange(e.range),r=T(o,n);return r.length<e.textBeforeCursor.length||!r.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,o,i)}isPositionValid(e,o,n){let{range:i,completion:r}=e,{startLineNumber:s,startColumn:m,endLineNumber:d,endColumn:l}=i,{lineNumber:p,column:a}=o;if(!r.startsWith(n))return !1;let u=p===s&&a===m;if(s===d)return u||p===s&&a>=m&&a<=l;let g=p>s&&p<d?!0:p===s&&a>=m||p===d&&a<=l;return u||g}};N.MAX_CACHE_SIZE=10;var F=N;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,n){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let i=n.getOffsetAt(e),r=n.getValue().substring(0,i),s=n.getValue().substring(i),m=0,d=0,l=0,p=0,a=o.length,u=r.length,g=s.length;if(i>=n.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(g===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let P=Math.min(a,u);for(let c=1;c<=P;c++){let R=o.substring(0,c),me=r.slice(-c);R===me&&(p=c);}let C=Math.min(a,g);for(let c=0;c<C&&o[c]===s[c];c++)m++;for(let c=1;c<=C;c++)o.slice(-c)===s.slice(0,c)&&(d=c);if(l=Math.max(m,d),l===0){for(let c=1;c<a;c++)if(s.startsWith(o.substring(c))){l=a-c;break}}let y=p>0?n.getPositionAt(i-p):e,f=i+l,h=n.getPositionAt(f);return new this.monaco.Range(y.lineNumber,y.column,h.lineNumber,h.column)}computeCacheRange(e,o){let n=e.lineNumber,i=e.column,r=o.split(`
46
- `),s=r.length-1,m=n+s,d=s===0?i+r[0].length:r[s].length+1;return new this.monaco.Range(n,i,m,d)}};var Re="application/json",ae=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:i}=await L.POST(e,o,{headers:{"Content-Type":Re},fallbackError:"Error while fetching completion item"});if(i)throw new Error(i);return {completion:n}},le=({pos:t,mdl:e,options:o})=>{let{filename:n,language:i,technologies:r,relatedFiles:s,maxContextLines:m}=o,d=xe(t,e),p=!!s?.length?3:2,a=m?Math.floor(m/p):void 0,u=(f,h,c)=>{let R=f(t,e);return h?V(R,h,c):R},g=(f,h)=>!f||!h?f:f.map(({content:c,...R})=>({...R,content:V(c,h)})),P=u(T,a,{from:"end"}),C=u(z,a),y=g(s,a);return {filename:n,language:i,technologies:r,relatedFiles:y,textBeforeCursor:P,textAfterCursor:C,cursorPosition:t,editorState:{completionMode:d}}},xe=(t,e)=>{let o=J(t,e),n=z(t,e);return o?"insert":n.trim()?"complete":"continue"};var b=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var be=t=>({onTyping:k(t,600,200),onIdle:k(t,600,400),onDemand:k(t,0,0)}),_=new F,Ee=async({monaco:t,mdl:e,pos:o,token:n,isCompletionAccepted:i,options:r})=>{let{trigger:s="onIdle",endpoint:m,enableCaching:d=!0,onError:l,requestHandler:p}=r;if(d){let a=_.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return b(a)}if(n.isCancellationRequested||i)return b([]);try{let u=be(p??ae)[s];n.onCancellationRequested(()=>{u.cancel();});let g=le({pos:o,mdl:e,options:r}),{completion:P}=await u({endpoint:m,body:{completionMetadata:g}});if(P){let C=new q(P,o.column,Y(o,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),y=new $(t),f=y.computeInsertionRange(o,C,e),h=y.computeCacheRange(o,C);return d&&_.add({completion:C,range:h,textBeforeCursor:T(o,e)}),b([{insertText:C,range:f}])}}catch(a){if(Me(a))return b([]);l?l(a):I("Cannot provide completion",a);}return b([])},Me=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,pe=Ee;var A=new WeakMap,w=null,ve=(t,e,o)=>{w&&w.deregister();let n=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};A.set(e,i),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let r=A.get(e);if(!r)return I("Completion is not registered properly. State not found."),{deregister:()=>{},trigger:()=>{}};let s=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(l,p,a,u)=>{if(!(o.trigger==="onDemand"&&!r.isManualTrigger))return pe({monaco:t,mdl:l,pos:p,token:u,isCompletionAccepted:r.isCompletionAccepted,options:o})},handleItemDidShow:(l,p,a)=>{r.isCompletionVisible=!0,r.isManualTrigger=!1,!r.isCompletionAccepted&&o.onCompletionShown?.(a,p.range);},freeInlineCompletions:()=>{}});n.push(s);let m=e.onKeyDown(l=>{let p=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;r.isCompletionVisible&&p?(o.onCompletionAccepted?.(),r.isCompletionAccepted=!0,r.isCompletionVisible=!1):r.isCompletionAccepted=!1;});n.push(m);let d={deregister:()=>{n.forEach(l=>l.dispose()),_.clear(),A.delete(e),w=null;},trigger:()=>Oe(e)};return w=d,d}catch(r){return o.onError?o.onError(r):B(r),{deregister:()=>{n.forEach(s=>s.dispose()),A.delete(e),w=null;},trigger:()=>{}}}},Oe=t=>{let e=A.get(t);if(!e){I("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};
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 F.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?G(b,h,d):b},f=(y,h)=>!y||!h?y:y.map(({content:d,...b})=>({...b,content:G(d,h)})),T=u(v,a,{from:"end"}),C=u(J,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=ie(o,e),r=J(o,e);return t?"insert":r.trim()?"complete":"continue"};var O=o=>({items:o,enableForwardStability:!0,suppressSuggestions:!0});var Te=o=>({onTyping:q(o,600,200),onIdle:q(o,600,400),onDemand:q(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,se(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",{});};
47
47
 
48
- exports.Copilot = W;
48
+ exports.Copilot = Q;
49
49
  exports.registerCompletion = ve;
package/build/index.mjs CHANGED
@@ -1,46 +1,46 @@
1
- var H=["groq","openai","anthropic","google","deepseek"],G={"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"]},x={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models",deepseek:"https://api.deepseek.com/beta/completions"};var E=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),V=(t,e,o={})=>{if(e<=0)return "";let n=t.split(`
2
- `),i=n.length;if(e>=i)return t;if(o.from==="end"){let s=n.slice(-e);return s.every(m=>m==="")?`
1
+ var W=["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"},X={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 w=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 L=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 N=class extends g{createEndpoint(e,t){return `${R.google}/${P[e]}:generateContent?key=${t}`}createRequestBody(e,t){return {systemInstruction: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 S=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 _=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 B={openai:new _,groq:new S,anthropic:new w,google:new N,deepseek:new L},ee=(o,e,t)=>B[t].createEndpoint(o,e),te=(o,e,t,r)=>B[e].createRequestBody(o,t,r),oe=(o,e)=>B[e].createHeaders(o),re=(o,e)=>B[e].parseCompletion(o);var I=o=>!o||o.length===0?"":o.length===1?o[0]:`${o.slice(0,-1).join(", ")} and ${o.slice(-1)}`,ne=o=>o.charAt(0).toUpperCase()+o.slice(1),G=(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==="")?`
3
3
  `.repeat(e):s.join(`
4
- `)}let r=n.slice(0,e);return r.every(s=>s==="")?`
5
- `.repeat(e):r.join(`
6
- `)};var J=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var Y=(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}),z=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var Z=async(t,e,o={})=>{let n=o.timeout??3e4,i=AbortSignal.timeout(n),r=o.signal?AbortSignal.any([i,o.signal]):i,s={"Content-Type":"application/json",...o.headers},m=e==="POST"&&o.body?JSON.stringify(o.body):void 0,d=await fetch(t,{method:e,headers:s,body:m,signal:r});if(!d.ok){let l=await d.json().catch(()=>null),p=l?`
7
- ${JSON.stringify(l,null,2)}`:"",a=o.fallbackError||"Network request failed";throw new Error(`${a} (${d.status})${p}`)}return d.json()},de=(t,e)=>Z(t,"GET",e),ce=(t,e,o)=>Z(t,"POST",{...o,body:e}),L={GET:de,POST:ce};var k=(t,e=600,o=200)=>{let n=null,i=0,r=null,s=null,m=!1,d=(...l)=>{if(m)return Promise.resolve(void 0);r=l;let p=Date.now(),a=p-i;i=p,n&&(clearTimeout(n),n=null);let u=a<o?e:o;return s=new Promise((g,P)=>{n=setTimeout(async()=>{m=!0;try{if(r){let C=await t(...r);g(C);}else g(void 0);}catch(C){P(C);}finally{m=!1,n=null,r=null;}},u);}),s};return d.cancel=()=>{n&&(clearTimeout(n),n=null),r=null;},d};var ue=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
4
+ `)}let n=r.slice(0,e);return n.every(s=>s==="")?`
5
+ `.repeat(e):n.join(`
6
+ `)};var ie=(o,e)=>e.getLineContent(o.lineNumber)[o.column-1];var se=(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}),J=(o,e)=>e.getValueInRange({startLineNumber:o.lineNumber,startColumn:o.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var ae=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)=>ae(o,"GET",e),he=(o,e,t)=>ae(o,"POST",{...t,body:e}),F={GET:fe,POST:he};var q=(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})=>`
8
8
  <related_file>
9
9
  <filePath>${e}</filePath>
10
10
  <fileContent>
11
11
  \`\`\`
12
- ${o}
12
+ ${t}
13
13
  \`\`\`
14
14
  </fileContent>
15
15
  </related_file>`.trim()).join(`
16
16
 
17
- `),Q=t=>{let{technologies:e=[],filename:o,relatedFiles:n,language:i,textBeforeCursor:r="",textAfterCursor:s="",editorState:{completionMode:m}}=t,d=E([i,...e].filter(a=>typeof a=="string"&&!!a)),l=`
17
+ `),le=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=`
18
18
  You are an expert code completion assistant.
19
19
 
20
20
  **Context:**
21
- File: ${o||"Untitled"}
21
+ File: ${t||"Untitled"}
22
22
  Language: ${i||"Undetermined"}
23
23
  Mode: ${m}
24
- Stack: ${d||"None"}`,p=`
24
+ Stack: ${c||"None"}`,p=`
25
25
  **Related Files:**
26
- ${ue(n)}
26
+ ${Pe(r)}
27
27
 
28
28
  **Source:**
29
29
  \`\`\`
30
- ${r}<cursor>${s}
30
+ ${n}<cursor>${s}
31
31
  \`\`\`
32
32
 
33
- ${X(m)} the code at <cursor>.
33
+ ${ne(m)} 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 Ce={createEndpoint:()=>x.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:O(t),...!o&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.[0]?.message.content??null},ge={createEndpoint:()=>x.groq,createRequestBody:(t,e)=>({model:O(t),temperature:.1,max_tokens:500,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.[0]?.message.content??null},he={createEndpoint:()=>x.anthropic,createRequestBody:(t,e)=>({model:O(t),temperature:.1,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:500}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{let e=t.content?.[0];return e&&"text"in e?e.text:null}},fe={createEndpoint:(t,e)=>`${x.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:O(t),system_instruction:{parts:[{text:e.system}]},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{parts:[{text:e.user}]}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>t.candidates?.[0]?.content?.parts?.[0]?.text??null},Pe={createEndpoint:()=>x.deepseek,createRequestBody:(t,e,o)=>({model:O(t),prompt:o.textBeforeCursor,suffix:o.textAfterCursor,temperature:.1,max_tokens:500}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>typeof t.choices?.[0]?.text=="string"?t.choices[0].text:null},S={openai:Ce,groq:ge,anthropic:he,google:fe,deepseek:Pe},ee=(t,e,o)=>S[o].createEndpoint(t,e),te=(t,e,o,n)=>S[e].createRequestBody(t,o,n),oe=(t,e)=>S[e].createHeaders(t),ne=(t,e)=>S[e].parseCompletion(t),O=t=>G[t];var ye="\x1B[91m",re="\x1B[93m",K="\x1B[0m",U="\x1B[1m",ie=t=>t instanceof Error?t.message:typeof t=="string"?t:"An unknown error occurred",B=t=>{let e=ie(t),o=`${ye}${U}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},I=(t,e)=>{console.warn(`${re}${U}[MONACOPILOT WARN] ${t}${e?`
36
- ${ie(e)}`:""}${K}`);};var se=(t,e,o)=>console.warn(`${re}${U}[MONACOPILOT DEPRECATED] "${t}" is deprecated${` in ${o}`}. Please use "${e}" instead. It will be removed in a future version.${K}`);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||!H.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${E(H)}`);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: ${E(j[this.provider])}`)}async complete(e){let{body:o,options:n}=e,{completionMetadata:i}=o,{headers:r={},customPrompt:s}=n??{},m=this.generatePrompt(i,s),{endpoint:d,requestBody:l,headers:p}=this.prepareRequestDetails(m,i);try{let a=await this.sendCompletionRequest(d,l,{...p,...r});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,o){let n=Q(e);return o?{...n,...o(e)}:n}prepareRequestDetails(e,o){if(typeof this.model=="object"&&"config"in this.model){let n=this.model.config(this.apiKey,e),i=n.endpoint,r=n.body??{},s=n.headers??{};return {endpoint:i,requestBody:r,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let n=ee(this.model,this.apiKey,this.provider),i=oe(this.apiKey,this.provider),r=te(this.model,this.provider,e,o);return {endpoint:n,requestBody:r,headers:i}}}async sendCompletionRequest(e,o,n){return L.POST(e,o,{headers:n})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&se("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:ne(e,this.provider),raw:e}}}handleCompletionError(e){return {error:B(e).message,completion:null}}};var q=class{constructor(e,o,n){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=o,this.textBeforeCursorInLine=n;}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
- `);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let o=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
38
- `+e.slice(1).map(n=>o+n).join(`
39
- `),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,n=e,i;for(;(i=o.exec(e))!==null;){let r=i[0],s=r.split(`
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 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||!W.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${I(W)}`);if(typeof this.model=="string"&&!X[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${I(X[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=le(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=ee(this.model,this.apiKey,this.provider),i=oe(this.apiKey,this.provider),n=te(this.model,this.provider,e,t);return {endpoint:r,requestBody:n,headers:i}}}async sendCompletionRequest(e,t,r){return F.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:re(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
+ `);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let t=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
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(`
40
40
  `).slice(1,-1).join(`
41
- `);n=n.replace(r,s);}return n.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
41
+ `);r=r.replace(n,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
42
42
 
43
- `),this}build(){return this.formattedCompletion}};var D=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 N=class N{constructor(){this.cache=new D(N.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(n=>this.isValidCacheItem(n,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,n){let i=n.getValueInRange(e.range),r=T(o,n);return r.length<e.textBeforeCursor.length||!r.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,o,i)}isPositionValid(e,o,n){let{range:i,completion:r}=e,{startLineNumber:s,startColumn:m,endLineNumber:d,endColumn:l}=i,{lineNumber:p,column:a}=o;if(!r.startsWith(n))return !1;let u=p===s&&a===m;if(s===d)return u||p===s&&a>=m&&a<=l;let g=p>s&&p<d?!0:p===s&&a>=m||p===d&&a<=l;return u||g}};N.MAX_CACHE_SIZE=10;var F=N;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,n){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let i=n.getOffsetAt(e),r=n.getValue().substring(0,i),s=n.getValue().substring(i),m=0,d=0,l=0,p=0,a=o.length,u=r.length,g=s.length;if(i>=n.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(g===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let P=Math.min(a,u);for(let c=1;c<=P;c++){let R=o.substring(0,c),me=r.slice(-c);R===me&&(p=c);}let C=Math.min(a,g);for(let c=0;c<C&&o[c]===s[c];c++)m++;for(let c=1;c<=C;c++)o.slice(-c)===s.slice(0,c)&&(d=c);if(l=Math.max(m,d),l===0){for(let c=1;c<a;c++)if(s.startsWith(o.substring(c))){l=a-c;break}}let y=p>0?n.getPositionAt(i-p):e,f=i+l,h=n.getPositionAt(f);return new this.monaco.Range(y.lineNumber,y.column,h.lineNumber,h.column)}computeCacheRange(e,o){let n=e.lineNumber,i=e.column,r=o.split(`
44
- `),s=r.length-1,m=n+s,d=s===0?i+r[0].length:r[s].length+1;return new this.monaco.Range(n,i,m,d)}};var Re="application/json",ae=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:i}=await L.POST(e,o,{headers:{"Content-Type":Re},fallbackError:"Error while fetching completion item"});if(i)throw new Error(i);return {completion:n}},le=({pos:t,mdl:e,options:o})=>{let{filename:n,language:i,technologies:r,relatedFiles:s,maxContextLines:m}=o,d=xe(t,e),p=!!s?.length?3:2,a=m?Math.floor(m/p):void 0,u=(f,h,c)=>{let R=f(t,e);return h?V(R,h,c):R},g=(f,h)=>!f||!h?f:f.map(({content:c,...R})=>({...R,content:V(c,h)})),P=u(T,a,{from:"end"}),C=u(z,a),y=g(s,a);return {filename:n,language:i,technologies:r,relatedFiles:y,textBeforeCursor:P,textAfterCursor:C,cursorPosition:t,editorState:{completionMode:d}}},xe=(t,e)=>{let o=J(t,e),n=z(t,e);return o?"insert":n.trim()?"complete":"continue"};var b=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var be=t=>({onTyping:k(t,600,200),onIdle:k(t,600,400),onDemand:k(t,0,0)}),_=new F,Ee=async({monaco:t,mdl:e,pos:o,token:n,isCompletionAccepted:i,options:r})=>{let{trigger:s="onIdle",endpoint:m,enableCaching:d=!0,onError:l,requestHandler:p}=r;if(d){let a=_.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return b(a)}if(n.isCancellationRequested||i)return b([]);try{let u=be(p??ae)[s];n.onCancellationRequested(()=>{u.cancel();});let g=le({pos:o,mdl:e,options:r}),{completion:P}=await u({endpoint:m,body:{completionMetadata:g}});if(P){let C=new q(P,o.column,Y(o,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),y=new $(t),f=y.computeInsertionRange(o,C,e),h=y.computeCacheRange(o,C);return d&&_.add({completion:C,range:h,textBeforeCursor:T(o,e)}),b([{insertText:C,range:f}])}}catch(a){if(Me(a))return b([]);l?l(a):I("Cannot provide completion",a);}return b([])},Me=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,pe=Ee;var A=new WeakMap,w=null,ve=(t,e,o)=>{w&&w.deregister();let n=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};A.set(e,i),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let r=A.get(e);if(!r)return I("Completion is not registered properly. State not found."),{deregister:()=>{},trigger:()=>{}};let s=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(l,p,a,u)=>{if(!(o.trigger==="onDemand"&&!r.isManualTrigger))return pe({monaco:t,mdl:l,pos:p,token:u,isCompletionAccepted:r.isCompletionAccepted,options:o})},handleItemDidShow:(l,p,a)=>{r.isCompletionVisible=!0,r.isManualTrigger=!1,!r.isCompletionAccepted&&o.onCompletionShown?.(a,p.range);},freeInlineCompletions:()=>{}});n.push(s);let m=e.onKeyDown(l=>{let p=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;r.isCompletionVisible&&p?(o.onCompletionAccepted?.(),r.isCompletionAccepted=!0,r.isCompletionVisible=!1):r.isCompletionAccepted=!1;});n.push(m);let d={deregister:()=>{n.forEach(l=>l.dispose()),_.clear(),A.delete(e),w=null;},trigger:()=>Oe(e)};return w=d,d}catch(r){return o.onError?o.onError(r):B(r),{deregister:()=>{n.forEach(s=>s.dispose()),A.delete(e),w=null;},trigger:()=>{}}}},Oe=t=>{let e=A.get(t);if(!e){I("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};
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 F.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?G(b,h,d):b},f=(y,h)=>!y||!h?y:y.map(({content:d,...b})=>({...b,content:G(d,h)})),T=u(v,a,{from:"end"}),C=u(J,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=ie(o,e),r=J(o,e);return t?"insert":r.trim()?"complete":"continue"};var O=o=>({items:o,enableForwardStability:!0,suppressSuggestions:!0});var Te=o=>({onTyping:q(o,600,200),onIdle:q(o,600,400),onDemand:q(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,se(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
45
 
46
- export { W as Copilot, ve as registerCompletion };
46
+ export { Q as Copilot, ve as registerCompletion };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "monacopilot",
3
- "version": "0.17.0",
3
+ "version": "0.17.1",
4
4
  "description": "AI auto-completion plugin for Monaco Editor",
5
5
  "main": "./build/index.js",
6
6
  "module": "./build/index.mjs",