monacopilot 0.16.7 → 0.16.9

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
@@ -41,6 +41,7 @@
41
41
  - [Max Context Lines](#max-context-lines)
42
42
  - [Caching Completions](#caching-completions)
43
43
  - [Handling Errors](#handling-errors)
44
+ - [Completion Event Handlers](#completion-event-handlers)
44
45
  - [Custom Request Handler](#custom-request-handler)
45
46
  - [Copilot Options](#copilot-options)
46
47
  - [Changing the Provider and Model](#changing-the-provider-and-model)
@@ -163,7 +164,8 @@ registerCompletion(monaco, editor, {
163
164
  });
164
165
  ```
165
166
 
166
- > **Note:** The `registerCompletion` function returns a `completion` object with a `deregister` method. This method should be used to clean up the completion functionality when it's no longer needed.
167
+ > [!NOTE]
168
+ > The `registerCompletion` function returns a `completion` object with a `deregister` method. This method should be used to clean up the completion functionality when it's no longer needed.
167
169
  > For example, in a React component, you can call `completion.deregister()` within the `useEffect` cleanup function to ensure proper disposal when the component unmounts.
168
170
 
169
171
  🎉 Congratulations! The AI auto-completion is now connected to the Monaco Editor. Start typing and see completions in the editor.
@@ -188,7 +190,8 @@ registerCompletion(monaco, editor, {
188
190
 
189
191
  [OnTyping Demo](https://github.com/user-attachments/assets/22c2ce44-334c-4963-b853-01b890b8e39f)
190
192
 
191
- > **Note:** If you prefer real-time completions, you can set the `trigger` option to `'onTyping'`. This may increase the number of requests made to the provider and the cost. This should not be too costly since most small models are very inexpensive.
193
+ > [!NOTE]
194
+ > If you prefer real-time completions, you can set the `trigger` option to `'onTyping'`. This may increase the number of requests made to the provider and the cost. This should not be too costly since most small models are very inexpensive.
192
195
 
193
196
  ### Manually Trigger Completions
194
197
 
@@ -299,7 +302,8 @@ registerCompletion(monaco, editor, {
299
302
  });
300
303
  ```
301
304
 
302
- > **Note:** If you're using `Groq` as your provider, it's recommended to set `maxContextLines` to `60` or less due to its low rate limits and lack of pay-as-you-go pricing. However, `Groq` is expected to offer pay-as-you-go pricing in the near future.
305
+ > [!NOTE]
306
+ > If you're using `Groq` as your provider, it's recommended to set `maxContextLines` to `60` or less due to its low rate limits and lack of pay-as-you-go pricing. However, `Groq` is expected to offer pay-as-you-go pricing in the near future.
303
307
 
304
308
  ### Caching Completions
305
309
 
@@ -358,7 +362,8 @@ The `requestHandler` function takes an object with `endpoint` and `body` as para
358
362
  | `endpoint` | `string` | The endpoint to which the request is sent. This is the same as the `endpoint` in `registerCompletion`. |
359
363
  | `body` | `object` | The body of the request processed by Monacopilot. |
360
364
 
361
- > **Note:** The `body` object contains properties generated by Monacopilot. If you need to include additional properties in the request body, you can create a new object that combines the existing `body` with your custom properties. For example:
365
+ > [!NOTE]
366
+ > The `body` object contains properties generated by Monacopilot. If you need to include additional properties in the request body, you can create a new object that combines the existing `body` with your custom properties. For example:
362
367
  >
363
368
  > ```javascript
364
369
  > const customBody = {
@@ -415,6 +420,45 @@ registerCompletion(monaco, editor, {
415
420
  });
416
421
  ```
417
422
 
423
+ ### Completion Event Handlers
424
+
425
+ The editor provides several events to handle completion suggestions. These events allow you to respond to different stages of the completion process, such as when a suggestion is shown or accepted by the user.
426
+
427
+ #### onCompletionShown
428
+
429
+ This event is triggered when a completion suggestion is shown to the user. You can use this event to log or perform actions when a suggestion is displayed.
430
+
431
+ **Parameters:**
432
+
433
+ - `completion` (string): The completion text that is being shown
434
+ - `range` (EditorRange | undefined): The editor range where the completion will be inserted
435
+
436
+ **Example:**
437
+
438
+ ```javascript
439
+ registerCompletion(monaco, editor, {
440
+ // ... other options
441
+ onCompletionShown: (completion, range) => {
442
+ console.log('Completion suggestion:', {completion, range});
443
+ },
444
+ });
445
+ ```
446
+
447
+ #### onCompletionAccepted
448
+
449
+ Event triggered when a completion suggestion is accepted by the user.
450
+
451
+ **Example**
452
+
453
+ ```javascript
454
+ registerCompletion(monaco, editor, {
455
+ // ... other options
456
+ onCompletionAccepted: () => {
457
+ console.log('Completion accepted');
458
+ },
459
+ });
460
+ ```
461
+
418
462
  ## Copilot Options
419
463
 
420
464
  ### Changing the Provider and Model
package/build/index.d.mts CHANGED
@@ -146,6 +146,7 @@ type CopilotOptions = {
146
146
  type Monaco = typeof monaco;
147
147
  type StandaloneCodeEditor = monaco.editor.IStandaloneCodeEditor;
148
148
  type CursorPosition = monaco.IPosition;
149
+ type EditorRange = monaco.IRange;
149
150
 
150
151
  type Endpoint = string;
151
152
  type Filename = string;
@@ -241,6 +242,16 @@ interface RegisterCompletionOptions {
241
242
  * @returns {Promise<{completion: string | null}>} An object containing the completion or null if no completion is available.
242
243
  */
243
244
  requestHandler?: FetchCompletionItemHandler;
245
+ /**
246
+ * Callback function that is triggered when a completion is shown in the editor.
247
+ * @param completion - The completion text that is being shown.
248
+ * @param range - The editor range where the completion will be inserted.
249
+ */
250
+ onCompletionShown?: (completion: string, range: EditorRange | undefined) => void;
251
+ /**
252
+ * Callback function triggered when a completion is accepted by the user.
253
+ */
254
+ onCompletionAccepted?: () => void;
244
255
  }
245
256
  interface CompletionRegistration {
246
257
  /**
package/build/index.d.ts CHANGED
@@ -146,6 +146,7 @@ type CopilotOptions = {
146
146
  type Monaco = typeof monaco;
147
147
  type StandaloneCodeEditor = monaco.editor.IStandaloneCodeEditor;
148
148
  type CursorPosition = monaco.IPosition;
149
+ type EditorRange = monaco.IRange;
149
150
 
150
151
  type Endpoint = string;
151
152
  type Filename = string;
@@ -241,6 +242,16 @@ interface RegisterCompletionOptions {
241
242
  * @returns {Promise<{completion: string | null}>} An object containing the completion or null if no completion is available.
242
243
  */
243
244
  requestHandler?: FetchCompletionItemHandler;
245
+ /**
246
+ * Callback function that is triggered when a completion is shown in the editor.
247
+ * @param completion - The completion text that is being shown.
248
+ * @param range - The editor range where the completion will be inserted.
249
+ */
250
+ onCompletionShown?: (completion: string, range: EditorRange | undefined) => void;
251
+ /**
252
+ * Callback function triggered when a completion is accepted by the user.
253
+ */
254
+ onCompletionAccepted?: () => void;
244
255
  }
245
256
  interface CompletionRegistration {
246
257
  /**
package/build/index.js CHANGED
@@ -1,12 +1,12 @@
1
1
  'use strict';
2
2
 
3
- var H=["groq","openai","anthropic","google"],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"},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"]},E={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models"};var M=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
- `),r=n.length;if(e>=r)return t;if(o.from==="end"){let s=n.slice(-e);return s.every(l=>l==="")?`
3
+ var H=["groq","openai","anthropic","google"],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"},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"]},b={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"};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==="")?`
5
5
  `.repeat(e):s.join(`
6
- `)}let i=n.slice(0,e);return i.every(s=>s==="")?`
7
- `.repeat(e):i.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,r=AbortSignal.timeout(n),i=o.signal?AbortSignal.any([r,o.signal]):r,s={"Content-Type":"application/json",...o.headers},l=e==="POST"&&o.body?JSON.stringify(o.body):void 0,a=await fetch(t,{method:e,headers:s,body:l,signal:i});if(!a.ok){let m=await a.json().catch(()=>null),c=m?`
9
- ${JSON.stringify(m,null,2)}`:"",p=o.fallbackError||"Network request failed";throw new Error(`${p} (${a.status})${c}`)}return a.json()},ce=(t,e)=>Z(t,"GET",e),de=(t,e,o)=>Z(t,"POST",{...o,body:e}),O={GET:ce,POST:de};var I=(t,e=600,o=200)=>{let n=null,r=0,i=null,s=null,l=!1,a=(...m)=>{if(l)return Promise.resolve(void 0);i=m;let c=Date.now(),p=c-r;r=c,n&&(clearTimeout(n),n=null);let u=p<o?e:o;return s=new Promise((C,P)=>{n=setTimeout(async()=>{l=!0;try{if(i){let g=await t(...i);C(g);}else C(void 0);}catch(g){P(g);}finally{l=!1,n=null,i=null;}},u);}),s};return a.cancel=()=>{n&&(clearTimeout(n),n=null),i=null;},a};var ue=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
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}),I={GET:de,POST:ce};var w=(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,y)=>{n=setTimeout(async()=>{m=!0;try{if(r){let C=await t(...r);g(C);}else g(void 0);}catch(C){y(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})=>`
10
10
  <related_file>
11
11
  <filePath>${e}</filePath>
12
12
  <fileContent>
@@ -16,34 +16,34 @@ ${o}
16
16
  </fileContent>
17
17
  </related_file>`.trim()).join(`
18
18
 
19
- `),Q=t=>{let{technologies:e=[],filename:o,relatedFiles:n,language:r,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:l}}=t,a=M([r,...e].filter(p=>typeof p=="string"&&!!p)),m=`
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=`
20
20
  You are an expert code completion assistant.
21
21
 
22
22
  **Context:**
23
23
  File: ${o||"Untitled"}
24
- Language: ${r||"Undetermined"}
25
- Mode: ${l}
26
- Stack: ${a||"None"}`,c=`
24
+ Language: ${i||"Undetermined"}
25
+ Mode: ${m}
26
+ Stack: ${d||"None"}`,p=`
27
27
  **Related Files:**
28
28
  ${ue(n)}
29
29
 
30
30
  **Source:**
31
31
  \`\`\`
32
- ${i}<cursor>${s}
32
+ ${r}<cursor>${s}
33
33
  \`\`\`
34
34
 
35
- ${X(l)} the code at <cursor>.
35
+ ${X(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:m,user:c}};var Ce={createEndpoint:()=>E.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:S(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?.length?t.choices[0].message.content:null},ge={createEndpoint:()=>E.groq,createRequestBody:(t,e)=>({model:S(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?.length?t.choices[0].message.content:null},he={createEndpoint:()=>E.anthropic,createRequestBody:(t,e)=>({model:S(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=>{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}},fe={createEndpoint:(t,e)=>`${E.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:S(t),system_instruction:{parts:{text:e.system}},generationConfig:{temperature:.1,maxOutputTokens:500},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}},L={openai:Ce,groq:ge,anthropic:he,google:fe},ee=(t,e,o)=>L[o].createEndpoint(t,e),te=(t,e,o)=>L[e].createRequestBody(t,o),oe=(t,e)=>L[e].createHeaders(t),ne=(t,e)=>L[e].parseCompletion(t),S=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}},q=(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: ${M(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: ${M(j[this.provider])}`)}async complete(e){let{body:o,options:n}=e,{completionMetadata:r}=o,{headers:i={},customPrompt:s}=n??{},l=this.generatePrompt(r,s),{endpoint:a,requestBody:m,headers:c}=this.prepareRequestDetails(l);try{let p=await this.sendCompletionRequest(a,m,{...c,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let n=Q(e);return o?{...n,...o(e)}:n}prepareRequestDetails(e){if(typeof this.model=="object"&&"config"in this.model){let o=this.model.config(this.apiKey,e),n=o.endpoint,r=o.body??{},i=o.headers??{};return {endpoint:n,requestBody:r,headers:i}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let o=ee(this.model,this.apiKey,this.provider),n=oe(this.apiKey,this.provider),r=te(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}}async sendCompletionRequest(e,o,n){return O.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 F=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
+ 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:()=>b.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:B(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?.length?t.choices[0].message.content:null},ge={createEndpoint:()=>b.groq,createRequestBody:(t,e)=>({model:B(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?.length?t.choices[0].message.content:null},he={createEndpoint:()=>b.anthropic,createRequestBody:(t,e)=>({model:B(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=>{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}},fe={createEndpoint:(t,e)=>`${b.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:B(t),system_instruction:{parts:{text:e.system}},generationConfig:{temperature:.1,maxOutputTokens:500},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:Ce,groq:ge,anthropic:he,google:fe},ee=(t,e,o)=>S[o].createEndpoint(t,e),te=(t,e,o)=>S[e].createRequestBody(t,o),oe=(t,e)=>S[e].createHeaders(t),ne=(t,e)=>S[e].parseCompletion(t),B=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",q=t=>{let e=ie(t),o=`${ye}${U}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},M=(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);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){if(typeof this.model=="object"&&"config"in this.model){let o=this.model.config(this.apiKey,e),n=o.endpoint,i=o.body??{},r=o.headers??{};return {endpoint:n,requestBody:i,headers:r}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let o=ee(this.model,this.apiKey,this.provider),n=oe(this.apiKey,this.provider),i=te(this.model,this.provider,e);return {endpoint:o,requestBody:i,headers:n}}}async sendCompletionRequest(e,o,n){return I.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:q(e).message,completion:null}}};var F=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
39
  `);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let o=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
40
40
  `+e.slice(1).map(n=>o+n).join(`
41
- `),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,n=e,r;for(;(r=o.exec(e))!==null;){let i=r[0],s=i.split(`
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(`
42
42
  `).slice(1,-1).join(`
43
- `);n=n.replace(i,s);}return n.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
43
+ `);n=n.replace(r,s);}return n.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
44
44
 
45
- `),this}build(){return this.formattedCompletion}};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 N=class N{constructor(){this.cache=new k(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 r=n.getValueInRange(e.range),i=T(o,n);return i.length<e.textBeforeCursor.length||!i.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,o,r)}isPositionValid(e,o,n){let{range:r,completion:i}=e,{startLineNumber:s,startColumn:l,endLineNumber:a,endColumn:m}=r,{lineNumber:c,column:p}=o;if(!i.startsWith(n))return !1;let u=c===s&&p===l;if(s===a)return u||c===s&&p>=l&&p<=m;let C=c>s&&c<a?!0:c===s&&p>=l||c===a&&p<=m;return u||C}};N.MAX_CACHE_SIZE=10;var D=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 r=n.getOffsetAt(e),i=n.getValue().substring(0,r),s=n.getValue().substring(r),l=0,a=0,m=0,c=0,p=o.length,u=i.length,C=s.length;if(r>=n.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 P=Math.min(p,u);for(let d=1;d<=P;d++){let R=o.substring(0,d),me=i.slice(-d);R===me&&(c=d);}let g=Math.min(p,C);for(let d=0;d<g&&o[d]===s[d];d++)l++;for(let d=1;d<=g;d++)o.slice(-d)===s.slice(0,d)&&(a=d);if(m=Math.max(l,a),m===0){for(let d=1;d<p;d++)if(s.startsWith(o.substring(d))){m=p-d;break}}let y=c>0?n.getPositionAt(r-c):e,h=r+m,f=n.getPositionAt(h);return new this.monaco.Range(y.lineNumber,y.column,f.lineNumber,f.column)}computeCacheRange(e,o){let n=e.lineNumber,r=e.column,i=o.split(`
46
- `),s=i.length-1,l=n+s,a=s===0?r+i[0].length:i[s].length+1;return new this.monaco.Range(n,r,l,a)}};var Pe="application/json",ae=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:r}=await O.POST(e,o,{headers:{"Content-Type":Pe},fallbackError:"Error while fetching completion item"});if(r)throw new Error(r);return {completion:n}},le=({pos:t,mdl:e,options:o})=>{let{filename:n,language:r,technologies:i,relatedFiles:s,maxContextLines:l}=o,a=Re(t,e),c=!!s?.length?3:2,p=l?Math.floor(l/c):void 0,u=(h,f,d)=>{let R=h(t,e);return f?V(R,f,d):R},C=(h,f)=>!h||!f?h:h.map(({content:d,...R})=>({...R,content:V(d,f)})),P=u(T,p,{from:"end"}),g=u(z,p),y=C(s,p);return {filename:n,language:r,technologies:i,relatedFiles:y,textBeforeCursor:P,textAfterCursor:g,cursorPosition:t,editorState:{completionMode:a}}},Re=(t,e)=>{let o=J(t,e),n=z(t,e);return o?"insert":n.trim()?"complete":"continue"};var x=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var xe=t=>({onTyping:I(t,600,200),onIdle:I(t,600,400),onDemand:I(t,0,0)}),_=new D,be=async({monaco:t,mdl:e,pos:o,token:n,isCompletionAccepted:r,onShowCompletion:i,options:s})=>{let{trigger:l="onIdle",endpoint:a,enableCaching:m=!0,onError:c,requestHandler:p}=s;if(m){let u=_.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return i(),x(u)}if(n.isCancellationRequested||r)return x([]);try{let C=xe(p??ae)[l];n.onCancellationRequested(()=>{C.cancel();});let P=le({pos:o,mdl:e,options:s}),{completion:g}=await C({endpoint:a,body:{completionMetadata:P}});if(g){let y=new F(g,o.column,Y(o,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),h=new $(t),f=h.computeInsertionRange(o,y,e),d=h.computeCacheRange(o,y);return m&&_.add({completion:y,range:d,textBeforeCursor:T(o,e)}),i(),x([{insertText:y,range:f}])}}catch(u){if(Ee(u))return x([]);c?c(u):q("Cannot provide completion",u);}return x([])},Ee=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,pe=be;var b=new WeakMap,v=null,Me=(t,e,o)=>{v&&v.deregister();let n=[],r={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};b.set(e,r),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,m,c,p)=>{let u=b.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return pe({monaco:t,mdl:a,pos:m,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});n.push(i);let s=e.onKeyDown(a=>{let m=b.get(e);if(!m)return;let c=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;m.isCompletionVisible&&c?(m.isCompletionAccepted=!0,m.isCompletionVisible=!1):m.isCompletionAccepted=!1;});n.push(s);let l={deregister:()=>{n.forEach(a=>a.dispose()),_.clear(),b.delete(e),v=null;},trigger:()=>ve(e)};return v=l,l}catch(i){return o.onError?o.onError(i):B(i),{deregister:()=>{n.forEach(s=>s.dispose()),b.delete(e),v=null;},trigger:()=>{}}}},ve=t=>{let e=b.get(t);if(!e){q("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 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 D=class D{constructor(){this.cache=new k(D.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}};D.MAX_CACHE_SIZE=10;var N=D;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 y=Math.min(a,u);for(let c=1;c<=y;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 P=p>0?n.getPositionAt(i-p):e,f=i+l,h=n.getPositionAt(f);return new this.monaco.Range(P.lineNumber,P.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 Pe="application/json",ae=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:i}=await I.POST(e,o,{headers:{"Content-Type":Pe},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=Re(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)})),y=u(T,a,{from:"end"}),C=u(z,a),P=g(s,a);return {filename:n,language:i,technologies:r,relatedFiles:P,textBeforeCursor:y,textAfterCursor:C,cursorPosition:t,editorState:{completionMode:d}}},Re=(t,e)=>{let o=J(t,e),n=z(t,e);return o?"insert":n.trim()?"complete":"continue"};var x=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var xe=t=>({onTyping:w(t,600,200),onIdle:w(t,600,400),onDemand:w(t,0,0)}),_=new N,be=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 x(a)}if(n.isCancellationRequested||i)return x([]);try{let u=xe(p??ae)[s];n.onCancellationRequested(()=>{u.cancel();});let g=le({pos:o,mdl:e,options:r}),{completion:y}=await u({endpoint:m,body:{completionMetadata:g}});if(y){let C=new F(y,o.column,Y(o,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),P=new $(t),f=P.computeInsertionRange(o,C,e),h=P.computeCacheRange(o,C);return d&&_.add({completion:C,range:h,textBeforeCursor:T(o,e)}),x([{insertText:C,range:f}])}}catch(a){if(Ee(a))return x([]);l?l(a):M("Cannot provide completion",a);}return x([])},Ee=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,pe=be;var O=new WeakMap,v=null,Me=(t,e,o)=>{v&&v.deregister();let n=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};O.set(e,i),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let r=O.get(e);if(!r)return M("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(),O.delete(e),v=null;},trigger:()=>ve(e)};return v=d,d}catch(r){return o.onError?o.onError(r):q(r),{deregister:()=>{n.forEach(s=>s.dispose()),O.delete(e),v=null;},trigger:()=>{}}}},ve=t=>{let e=O.get(t);if(!e){M("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};
47
47
 
48
48
  exports.Copilot = W;
49
49
  exports.registerCompletion = Me;
package/build/index.mjs CHANGED
@@ -1,10 +1,10 @@
1
- var H=["groq","openai","anthropic","google"],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"},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"]},E={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models"};var M=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
- `),r=n.length;if(e>=r)return t;if(o.from==="end"){let s=n.slice(-e);return s.every(l=>l==="")?`
1
+ var H=["groq","openai","anthropic","google"],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"},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"]},b={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"};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==="")?`
3
3
  `.repeat(e):s.join(`
4
- `)}let i=n.slice(0,e);return i.every(s=>s==="")?`
5
- `.repeat(e):i.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,r=AbortSignal.timeout(n),i=o.signal?AbortSignal.any([r,o.signal]):r,s={"Content-Type":"application/json",...o.headers},l=e==="POST"&&o.body?JSON.stringify(o.body):void 0,a=await fetch(t,{method:e,headers:s,body:l,signal:i});if(!a.ok){let m=await a.json().catch(()=>null),c=m?`
7
- ${JSON.stringify(m,null,2)}`:"",p=o.fallbackError||"Network request failed";throw new Error(`${p} (${a.status})${c}`)}return a.json()},ce=(t,e)=>Z(t,"GET",e),de=(t,e,o)=>Z(t,"POST",{...o,body:e}),O={GET:ce,POST:de};var I=(t,e=600,o=200)=>{let n=null,r=0,i=null,s=null,l=!1,a=(...m)=>{if(l)return Promise.resolve(void 0);i=m;let c=Date.now(),p=c-r;r=c,n&&(clearTimeout(n),n=null);let u=p<o?e:o;return s=new Promise((C,P)=>{n=setTimeout(async()=>{l=!0;try{if(i){let g=await t(...i);C(g);}else C(void 0);}catch(g){P(g);}finally{l=!1,n=null,i=null;}},u);}),s};return a.cancel=()=>{n&&(clearTimeout(n),n=null),i=null;},a};var ue=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
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}),I={GET:de,POST:ce};var w=(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,y)=>{n=setTimeout(async()=>{m=!0;try{if(r){let C=await t(...r);g(C);}else g(void 0);}catch(C){y(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})=>`
8
8
  <related_file>
9
9
  <filePath>${e}</filePath>
10
10
  <fileContent>
@@ -14,33 +14,33 @@ ${o}
14
14
  </fileContent>
15
15
  </related_file>`.trim()).join(`
16
16
 
17
- `),Q=t=>{let{technologies:e=[],filename:o,relatedFiles:n,language:r,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:l}}=t,a=M([r,...e].filter(p=>typeof p=="string"&&!!p)),m=`
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=`
18
18
  You are an expert code completion assistant.
19
19
 
20
20
  **Context:**
21
21
  File: ${o||"Untitled"}
22
- Language: ${r||"Undetermined"}
23
- Mode: ${l}
24
- Stack: ${a||"None"}`,c=`
22
+ Language: ${i||"Undetermined"}
23
+ Mode: ${m}
24
+ Stack: ${d||"None"}`,p=`
25
25
  **Related Files:**
26
26
  ${ue(n)}
27
27
 
28
28
  **Source:**
29
29
  \`\`\`
30
- ${i}<cursor>${s}
30
+ ${r}<cursor>${s}
31
31
  \`\`\`
32
32
 
33
- ${X(l)} the code at <cursor>.
33
+ ${X(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:m,user:c}};var Ce={createEndpoint:()=>E.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:S(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?.length?t.choices[0].message.content:null},ge={createEndpoint:()=>E.groq,createRequestBody:(t,e)=>({model:S(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?.length?t.choices[0].message.content:null},he={createEndpoint:()=>E.anthropic,createRequestBody:(t,e)=>({model:S(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=>{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}},fe={createEndpoint:(t,e)=>`${E.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:S(t),system_instruction:{parts:{text:e.system}},generationConfig:{temperature:.1,maxOutputTokens:500},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}},L={openai:Ce,groq:ge,anthropic:he,google:fe},ee=(t,e,o)=>L[o].createEndpoint(t,e),te=(t,e,o)=>L[e].createRequestBody(t,o),oe=(t,e)=>L[e].createHeaders(t),ne=(t,e)=>L[e].parseCompletion(t),S=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}},q=(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: ${M(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: ${M(j[this.provider])}`)}async complete(e){let{body:o,options:n}=e,{completionMetadata:r}=o,{headers:i={},customPrompt:s}=n??{},l=this.generatePrompt(r,s),{endpoint:a,requestBody:m,headers:c}=this.prepareRequestDetails(l);try{let p=await this.sendCompletionRequest(a,m,{...c,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let n=Q(e);return o?{...n,...o(e)}:n}prepareRequestDetails(e){if(typeof this.model=="object"&&"config"in this.model){let o=this.model.config(this.apiKey,e),n=o.endpoint,r=o.body??{},i=o.headers??{};return {endpoint:n,requestBody:r,headers:i}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let o=ee(this.model,this.apiKey,this.provider),n=oe(this.apiKey,this.provider),r=te(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}}async sendCompletionRequest(e,o,n){return O.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 F=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(`
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:()=>b.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:B(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?.length?t.choices[0].message.content:null},ge={createEndpoint:()=>b.groq,createRequestBody:(t,e)=>({model:B(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?.length?t.choices[0].message.content:null},he={createEndpoint:()=>b.anthropic,createRequestBody:(t,e)=>({model:B(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=>{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}},fe={createEndpoint:(t,e)=>`${b.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:B(t),system_instruction:{parts:{text:e.system}},generationConfig:{temperature:.1,maxOutputTokens:500},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:Ce,groq:ge,anthropic:he,google:fe},ee=(t,e,o)=>S[o].createEndpoint(t,e),te=(t,e,o)=>S[e].createRequestBody(t,o),oe=(t,e)=>S[e].createHeaders(t),ne=(t,e)=>S[e].parseCompletion(t),B=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",q=t=>{let e=ie(t),o=`${ye}${U}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},M=(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);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){if(typeof this.model=="object"&&"config"in this.model){let o=this.model.config(this.apiKey,e),n=o.endpoint,i=o.body??{},r=o.headers??{};return {endpoint:n,requestBody:i,headers:r}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let o=ee(this.model,this.apiKey,this.provider),n=oe(this.apiKey,this.provider),i=te(this.model,this.provider,e);return {endpoint:o,requestBody:i,headers:n}}}async sendCompletionRequest(e,o,n){return I.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:q(e).message,completion:null}}};var F=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
37
  `);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let o=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
38
38
  `+e.slice(1).map(n=>o+n).join(`
39
- `),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,n=e,r;for(;(r=o.exec(e))!==null;){let i=r[0],s=i.split(`
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(`
40
40
  `).slice(1,-1).join(`
41
- `);n=n.replace(i,s);}return n.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
41
+ `);n=n.replace(r,s);}return n.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
42
42
 
43
- `),this}build(){return this.formattedCompletion}};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 N=class N{constructor(){this.cache=new k(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 r=n.getValueInRange(e.range),i=T(o,n);return i.length<e.textBeforeCursor.length||!i.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,o,r)}isPositionValid(e,o,n){let{range:r,completion:i}=e,{startLineNumber:s,startColumn:l,endLineNumber:a,endColumn:m}=r,{lineNumber:c,column:p}=o;if(!i.startsWith(n))return !1;let u=c===s&&p===l;if(s===a)return u||c===s&&p>=l&&p<=m;let C=c>s&&c<a?!0:c===s&&p>=l||c===a&&p<=m;return u||C}};N.MAX_CACHE_SIZE=10;var D=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 r=n.getOffsetAt(e),i=n.getValue().substring(0,r),s=n.getValue().substring(r),l=0,a=0,m=0,c=0,p=o.length,u=i.length,C=s.length;if(r>=n.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 P=Math.min(p,u);for(let d=1;d<=P;d++){let R=o.substring(0,d),me=i.slice(-d);R===me&&(c=d);}let g=Math.min(p,C);for(let d=0;d<g&&o[d]===s[d];d++)l++;for(let d=1;d<=g;d++)o.slice(-d)===s.slice(0,d)&&(a=d);if(m=Math.max(l,a),m===0){for(let d=1;d<p;d++)if(s.startsWith(o.substring(d))){m=p-d;break}}let y=c>0?n.getPositionAt(r-c):e,h=r+m,f=n.getPositionAt(h);return new this.monaco.Range(y.lineNumber,y.column,f.lineNumber,f.column)}computeCacheRange(e,o){let n=e.lineNumber,r=e.column,i=o.split(`
44
- `),s=i.length-1,l=n+s,a=s===0?r+i[0].length:i[s].length+1;return new this.monaco.Range(n,r,l,a)}};var Pe="application/json",ae=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:r}=await O.POST(e,o,{headers:{"Content-Type":Pe},fallbackError:"Error while fetching completion item"});if(r)throw new Error(r);return {completion:n}},le=({pos:t,mdl:e,options:o})=>{let{filename:n,language:r,technologies:i,relatedFiles:s,maxContextLines:l}=o,a=Re(t,e),c=!!s?.length?3:2,p=l?Math.floor(l/c):void 0,u=(h,f,d)=>{let R=h(t,e);return f?V(R,f,d):R},C=(h,f)=>!h||!f?h:h.map(({content:d,...R})=>({...R,content:V(d,f)})),P=u(T,p,{from:"end"}),g=u(z,p),y=C(s,p);return {filename:n,language:r,technologies:i,relatedFiles:y,textBeforeCursor:P,textAfterCursor:g,cursorPosition:t,editorState:{completionMode:a}}},Re=(t,e)=>{let o=J(t,e),n=z(t,e);return o?"insert":n.trim()?"complete":"continue"};var x=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var xe=t=>({onTyping:I(t,600,200),onIdle:I(t,600,400),onDemand:I(t,0,0)}),_=new D,be=async({monaco:t,mdl:e,pos:o,token:n,isCompletionAccepted:r,onShowCompletion:i,options:s})=>{let{trigger:l="onIdle",endpoint:a,enableCaching:m=!0,onError:c,requestHandler:p}=s;if(m){let u=_.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return i(),x(u)}if(n.isCancellationRequested||r)return x([]);try{let C=xe(p??ae)[l];n.onCancellationRequested(()=>{C.cancel();});let P=le({pos:o,mdl:e,options:s}),{completion:g}=await C({endpoint:a,body:{completionMetadata:P}});if(g){let y=new F(g,o.column,Y(o,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),h=new $(t),f=h.computeInsertionRange(o,y,e),d=h.computeCacheRange(o,y);return m&&_.add({completion:y,range:d,textBeforeCursor:T(o,e)}),i(),x([{insertText:y,range:f}])}}catch(u){if(Ee(u))return x([]);c?c(u):q("Cannot provide completion",u);}return x([])},Ee=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,pe=be;var b=new WeakMap,v=null,Me=(t,e,o)=>{v&&v.deregister();let n=[],r={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};b.set(e,r),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,m,c,p)=>{let u=b.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return pe({monaco:t,mdl:a,pos:m,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});n.push(i);let s=e.onKeyDown(a=>{let m=b.get(e);if(!m)return;let c=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;m.isCompletionVisible&&c?(m.isCompletionAccepted=!0,m.isCompletionVisible=!1):m.isCompletionAccepted=!1;});n.push(s);let l={deregister:()=>{n.forEach(a=>a.dispose()),_.clear(),b.delete(e),v=null;},trigger:()=>ve(e)};return v=l,l}catch(i){return o.onError?o.onError(i):B(i),{deregister:()=>{n.forEach(s=>s.dispose()),b.delete(e),v=null;},trigger:()=>{}}}},ve=t=>{let e=b.get(t);if(!e){q("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 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 D=class D{constructor(){this.cache=new k(D.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}};D.MAX_CACHE_SIZE=10;var N=D;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 y=Math.min(a,u);for(let c=1;c<=y;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 P=p>0?n.getPositionAt(i-p):e,f=i+l,h=n.getPositionAt(f);return new this.monaco.Range(P.lineNumber,P.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 Pe="application/json",ae=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:i}=await I.POST(e,o,{headers:{"Content-Type":Pe},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=Re(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)})),y=u(T,a,{from:"end"}),C=u(z,a),P=g(s,a);return {filename:n,language:i,technologies:r,relatedFiles:P,textBeforeCursor:y,textAfterCursor:C,cursorPosition:t,editorState:{completionMode:d}}},Re=(t,e)=>{let o=J(t,e),n=z(t,e);return o?"insert":n.trim()?"complete":"continue"};var x=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var xe=t=>({onTyping:w(t,600,200),onIdle:w(t,600,400),onDemand:w(t,0,0)}),_=new N,be=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 x(a)}if(n.isCancellationRequested||i)return x([]);try{let u=xe(p??ae)[s];n.onCancellationRequested(()=>{u.cancel();});let g=le({pos:o,mdl:e,options:r}),{completion:y}=await u({endpoint:m,body:{completionMetadata:g}});if(y){let C=new F(y,o.column,Y(o,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),P=new $(t),f=P.computeInsertionRange(o,C,e),h=P.computeCacheRange(o,C);return d&&_.add({completion:C,range:h,textBeforeCursor:T(o,e)}),x([{insertText:C,range:f}])}}catch(a){if(Ee(a))return x([]);l?l(a):M("Cannot provide completion",a);}return x([])},Ee=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,pe=be;var O=new WeakMap,v=null,Me=(t,e,o)=>{v&&v.deregister();let n=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};O.set(e,i),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let r=O.get(e);if(!r)return M("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(),O.delete(e),v=null;},trigger:()=>ve(e)};return v=d,d}catch(r){return o.onError?o.onError(r):q(r),{deregister:()=>{n.forEach(s=>s.dispose()),O.delete(e),v=null;},trigger:()=>{}}}},ve=t=>{let e=O.get(t);if(!e){M("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};
45
45
 
46
46
  export { W as Copilot, Me as registerCompletion };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "monacopilot",
3
- "version": "0.16.7",
3
+ "version": "0.16.9",
4
4
  "description": "AI auto-completion plugin for Monaco Editor",
5
5
  "main": "./build/index.js",
6
6
  "module": "./build/index.mjs",