monacopilot 0.15.0 → 0.15.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -288,7 +288,7 @@ registerCompletion(monaco, editor, {
288
288
 
289
289
  ### Caching Completions
290
290
 
291
- Monacopilot caches completions by default. It uses a FIFO (First In First Out) strategy, reusing cached completions when the context and cursor position match while editing. To disable caching:
291
+ Monacopilot caches completions by default. It uses a FIFO (First In First Out) strategy, reusing cached completions when the context and cursor position match while editing (default: `true`). To disable caching:
292
292
 
293
293
  ```javascript
294
294
  registerCompletion(monaco, editor, {
@@ -422,7 +422,7 @@ There are other providers and models available. Here is a list:
422
422
  | Provider | Models |
423
423
  | --------- | ----------------------------------------------------------- |
424
424
  | Groq | `llama-3-70b` |
425
- | OpenAI | `gpt-4o`, `gpt-4o-mini`, `o1-preview`, `o1-mini` |
425
+ | OpenAI | `gpt-4o`, `gpt-4o-mini`, `o1-mini (beta model)` |
426
426
  | Anthropic | `claude-3-5-sonnet`, `claude-3-haiku`, `claude-3-5-haiku` |
427
427
  | Google | `gemini-1.5-pro`, `gemini-1.5-flash`, `gemini-1.5-flash-8b` |
428
428
 
package/build/index.d.mts CHANGED
@@ -7,7 +7,7 @@ import * as monaco_editor from 'monaco-editor';
7
7
  /**
8
8
  * Models available for OpenAI provider.
9
9
  */
10
- type OpenAIModel = 'gpt-4o' | 'gpt-4o-mini' | 'o1-preview' | 'o1-mini';
10
+ type OpenAIModel = 'gpt-4o' | 'gpt-4o-mini' | 'o1-mini';
11
11
  /**
12
12
  * Models available for Groq provider.
13
13
  */
package/build/index.d.ts CHANGED
@@ -7,7 +7,7 @@ import * as monaco_editor from 'monaco-editor';
7
7
  /**
8
8
  * Models available for OpenAI provider.
9
9
  */
10
- type OpenAIModel = 'gpt-4o' | 'gpt-4o-mini' | 'o1-preview' | 'o1-mini';
10
+ type OpenAIModel = 'gpt-4o' | 'gpt-4o-mini' | 'o1-mini';
11
11
  /**
12
12
  * Models available for Groq provider.
13
13
  */
package/build/index.js CHANGED
@@ -1,142 +1,71 @@
1
1
  'use strict';
2
2
 
3
- var j=["groq","openai","anthropic","google"],J={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-preview":"o1-preview","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"},U={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-preview","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},Z="anthropic",Q="claude-3-5-haiku",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"},A=.1;var ee={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var xe={createEndpoint:()=>b.openai,createRequestBody:(t,e)=>{let o=t==="o1-preview"||t==="o1-mini",r=o?[{role:"user",content:e.user}]:[{role:"system",content:e.system},{role:"user",content:e.user}];return {model:N(t),...!o&&{temperature:A},messages:r}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Pe={createEndpoint:()=>b.groq,createRequestBody:(t,e)=>({model:N(t),temperature:A,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Re={createEndpoint:()=>b.anthropic,createRequestBody:(t,e)=>({model:N(t),temperature:A,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ee[t]}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},Oe={createEndpoint:(t,e)=>`${b.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:N(t),system_instruction:{parts:{text:e.system}},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},L={openai:xe,groq:Pe,anthropic:Re,google:Oe},te=(t,e,o)=>L[o].createEndpoint(t,e),oe=(t,e,o)=>L[e].createRequestBody(t,o),re=(t,e)=>L[e].createHeaders(t),ne=(t,e)=>L[e].parseCompletion(t),N=t=>J[t];var Te="\x1B[91m",ie="\x1B[93m",K="\x1B[0m",W="\x1B[1m",O=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${Te}${W}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},se=t=>{console.warn(`${ie}${W}[MONACOPILOT WARN] ${t}${K}`);};var w=(t,e,o)=>console.warn(`${ie}${W}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${K}`);var v=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`;var z=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var _=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ae=(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}),D=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())}),Y=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
3
+ var U=["groq","openai","anthropic","google"],J={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-mini":"o1-mini","gemini-1.5-flash-8b":"gemini-1.5-flash-8b","gemini-1.5-flash":"gemini-1.5-flash","gemini-1.5-pro":"gemini-1.5-pro"},K={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},Z="anthropic",Q="claude-3-5-haiku",x={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models"},M=.1;var T=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,W=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
4
4
  `),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(a=>a==="")?`
5
5
  `.repeat(e):s.join(`
6
6
  `)}let i=r.slice(0,e);return i.every(s=>s==="")?`
7
7
  `.repeat(e):i.join(`
8
- `)};var le=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok){let s=`
9
- `+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},Ee=(t,e)=>le(t,"GET",e),Me=(t,e,o)=>le(t,"POST",{...o,body:e}),S={GET:Ee,POST:Me};var ce=(t,e)=>{let o=_(t,e).trim(),r=ae(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var B=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,a)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=a,o=setTimeout(()=>{s(t(...i)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var be=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n}=t,i=v([n,...e].filter(a=>typeof a=="string"&&!!a));return [`You are an expert ${i?`${i} `:""}developer assistant specialized in precise code completion and generation.`,`Your primary task is to provide accurate, context-aware code completions that seamlessly integrate with existing codebases${o?` in '${o}'`:""}.`,`You must:
10
- - Generate only the exact code required
11
- - Maintain strict adherence to provided instructions
12
- - Follow established code patterns and conventions
13
- - Consider the full context before generating code`,r?.length?"Analyze and incorporate context from all provided related files to ensure consistent and appropriate code generation.":"",n?`Apply ${n}-specific best practices, idioms, and syntax conventions in all generated code.`:""].filter(Boolean).join(`
14
- `)},ve=t=>t?.length?t.map(({path:e,content:o})=>`
8
+ `)};var I=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],A=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ee=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),h=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),L=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var te=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok){let s=`
9
+ `+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},Ce=(t,e)=>te(t,"GET",e),he=(t,e,o)=>te(t,"POST",{...o,body:e}),w={GET:Ce,POST:he};var oe=(t,e)=>{let o=A(t,e).trim(),r=ee(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var D=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,a)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=a,o=setTimeout(()=>{s(t(...i)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var fe=t=>t?.length?t.map(({path:e,content:o})=>`
15
10
  <related_file>
16
11
  <path>${e}</path>
17
- <content_context>
12
+ <content>
18
13
  \`\`\`
19
14
  ${o}
20
15
  \`\`\`
21
- </content_context>
16
+ </content>
22
17
  </related_file>`.trim()).join(`
23
18
 
24
- `):"",Ie=(t="",e)=>{let{relatedFiles:o}=e;return `
25
- <task_context>
26
- <primary_instructions>
27
- ${t.trim()}
28
- </primary_instructions>
29
- ${o?.length?`
30
- <reference_files>
31
- ${ve(o)}
32
- </reference_files>`:""}
33
- </task_context>`.trim()},pe=(t,e)=>({system:be(e),user:Ie(t,e)});var de="<cursor>",Ae=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r},language:n}=t,i=`<code_file>
34
- ${e}${de}${o}
35
- </code_file>`,a=`
36
- <instructions>
37
- <context>
38
- Below is a ${n||"code"} file with the token '${de}' marking the exact cursor position where code completion is needed.
39
-
40
- ${i}
41
- </context>
42
-
43
- <critical_rules>
44
- 1. NEVER REPEAT ANY TEXT THAT APPEARS BEFORE THE CURSOR
45
- 2. Start your completion EXACTLY from the cursor position
46
- 3. If user types 'const ' and cursor is after it, DO NOT include 'const ' in your completion
47
- 4. ONLY provide the remaining part of the code that should appear after the cursor
48
- 5. Violation of these rules will cause code duplication and syntax errors
49
- </critical_rules>
50
-
51
- <primary_objectives>
52
- 1. Generate code that is syntactically correct and follows ${n||"the language"}'s best practices
53
- 2. Ensure seamless integration with existing code structure
54
- 3. Maintain consistent naming conventions and coding style
55
- 4. Provide only the exact code needed at the cursor position
56
- </primary_objectives>
57
-
58
- <strict_requirements>
59
- - Output MUST contain only the NEW code to be inserted at cursor position
60
- - NEVER repeat any code that appears before the cursor position
61
- - DO NOT include any code that appears before the cursor
62
- - DO NOT include explanatory comments or documentation
63
- - DO NOT wrap output in markdown code blocks
64
- - DO NOT include placeholder text or TODO comments
65
- - AVOID generating code beyond the immediate logical completion
66
- </strict_requirements>
67
-
68
- <completion_mode>
69
- Active Mode: ${r}
70
- Specific Instructions: ${{continue:"-- Analyze the code structure and continue writing from the cursor position, maintaining logical flow.",insert:"-- Insert a precise, contextually appropriate code snippet at the cursor position while preserving surrounding code integrity.",complete:"-- Complete the current statement or block with syntactically correct and logically coherent code."}[r]||""}
71
- </completion_mode>
72
-
73
- <code_analysis_steps>
74
- 1. Analyze the code context before and after the cursor
75
- 2. Identify the current scope and available variables/functions
76
- 3. Determine the logical flow and required completion
77
- 4. Remove any duplicate text that appears before cursor
78
- 5. Verify completion starts exactly at cursor position
79
- </code_analysis_steps>
80
-
81
- <examples>
82
- <example>
83
- Context: "const <cursor>"
84
- CORRECT COMPLETION: "myVariable = 42"
85
- INCORRECT COMPLETION: "const myVariable = 42"
86
- </example>
87
-
88
- <example>
89
- Context: "function hello<cursor>"
90
- CORRECT COMPLETION: "(name: string) {\\n return 'Hello ' + name;\\n}"
91
- INCORRECT COMPLETION: "function hello(name: string) {\\n return 'Hello ' + name;\\n}"
92
- </example>
93
-
94
- <example>
95
- Context: "const randomNumber = Math.floor(Math.ran<cursor>00);"
96
- CORRECT COMPLETION: "dom() * 1"
97
- INCORRECT COMPLETION: "Math.random() * 1"
98
- </example>
99
-
100
- <example>
101
- Context: "const result = 'Hello' + ' W<cursor>';"
102
- CORRECT COMPLETION: "orld"
103
- INCORRECT COMPLETION: "orld';"
104
- </example>
105
-
106
- <example>
107
- Context: "function isPalindrome(<cursor>)"
108
- CORRECT COMPLETION: "str) {
109
- return str === str.split('').reverse().join('');
110
- }"
111
- INCORRECT COMPLETION: "(str) {
112
- return str === str.split('').reverse().join('');
113
- }"
114
- </example>
115
- </examples>
116
-
117
- <error_prevention>
118
- - Verify that generated code doesn't introduce syntax errors
119
- - Ensure variable and function references are valid in the current scope
120
- - Check for proper bracket and parenthesis matching
121
- - Maintain consistent indentation with surrounding code
122
- - Respect language-specific type safety requirements
123
- - NEVER duplicate text that appears before cursor
124
- </error_prevention>
125
-
126
- <final_validation>
127
- Before providing the completion:
128
- 1. Confirm the output contains ONLY the new code after cursor position
129
- 2. Double-check no text before cursor is duplicated
130
- 3. Verify it fits seamlessly at the cursor position
131
- 4. Ensure it follows the active completion mode requirements
132
- 5. Check for consistency with existing code style
133
- </final_validation>
134
- </instructions>`.trim();return pe(a,t)},me=Ae;var G=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??Z,this.model=o.model??Q,this.validateInputs();}validateInputs(){if(!j.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${v(j)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!U[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${v(U[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},a=this.generatePrompt(n,s),{endpoint:d,requestBody:m,headers:c}=this.prepareRequestDetails(a);try{let p=await this.sendCompletionRequest(d,m,{...c,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let r=me(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=te(this.model,this.apiKey,this.provider),r,n=re(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let i=this.model.config(this.apiKey,e);o=i.endpoint??o,r=i.body??{},n={...n,...i.headers};}else r=oe(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return S.POST(e,o,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&w("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return {completion:ne(e,this.provider),raw:e}}handleCompletionError(e){return {error:O(e).message,completion:null}}};var k=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
19
+ `):"",re=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:a}}=t,l=T([n,...e].filter(p=>typeof p=="string"&&!!p)),d=`You are an expert ${l?`${l} `:""}AI code completion assistant specialized in generating precise, contextually-aware code completions.
20
+
21
+ ROLE AND CONTEXT:
22
+ - You complete code exactly where the <cursor> placeholder is located in the provided code
23
+ - You are working in file: ${o||"current file"}
24
+ - Primary language: ${n||"detected from context"}
25
+ - Completion mode: ${a}
26
+
27
+ CRITICAL COMPLETION RULES:
28
+ 1. Generate ONLY the exact code needed at cursor position - no explanations, no comments
29
+ 2. NEVER repeat any code that appears before <cursor>
30
+ 3. Start completion EXACTLY at cursor position
31
+ 4. Maintain consistent code style and patterns with surrounding code
32
+ 5. Preserve proper spacing and indentation:
33
+ - Add spaces between tokens for readability
34
+ - Match existing indentation patterns
35
+ - Use appropriate newlines for multi-line completions
36
+ 6. Follow ${a} mode requirements:
37
+ ${a==="continue"?"- Continue writing code naturally from cursor position":a==="insert"?"- Insert precisely fitting code between before/after cursor segments":"- Complete the current code block or structure"}
38
+ 7. Respect Monaco editor's subwordSmart inline suggestion behavior
39
+ 8. Ensure completions are syntactically correct and contextually appropriate
40
+ 9. Consider and maintain consistency with any provided related files
41
+
42
+ COMPLETION SPACING AND INDENTATION EXAMPLES:
43
+ 1. Input: "console.log('Hello<cursor>');"
44
+ Output: " World" (note the leading space)
45
+
46
+ 2. Input: "function calc(a,<cursor>)"
47
+ Output: " b, c" (note the spaces around parameters)
48
+
49
+ 3. Input:
50
+ {
51
+ name: "John",
52
+ <cursor>
53
+ }
54
+ Output: "age: 30,
55
+ city: 'New York'" (note indentation)
56
+
57
+ Analyze all context carefully before generating completions. Ensure high relevance and accuracy.`,c=`${fe(r)}
58
+
59
+ Current code with cursor position:
60
+ \`\`\`
61
+ ${i}<cursor>${s}
62
+ \`\`\``;return {system:d,user:c}};var ne={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var Pe={createEndpoint:()=>x.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:S(t),...!o&&{temperature:M},messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},ye={createEndpoint:()=>x.groq,createRequestBody:(t,e)=>({model:S(t),temperature:M,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Re={createEndpoint:()=>x.anthropic,createRequestBody:(t,e)=>({model:S(t),temperature:M,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ne[t]}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},Oe={createEndpoint:(t,e)=>`${x.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:S(t),system_instruction:{parts:{text:e.system}},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},N={openai:Pe,groq:ye,anthropic:Re,google:Oe},ie=(t,e,o)=>N[o].createEndpoint(t,e),se=(t,e,o)=>N[e].createRequestBody(t,o),ae=(t,e)=>N[e].createHeaders(t),le=(t,e)=>N[e].parseCompletion(t),S=t=>J[t];var xe="\x1B[91m",pe="\x1B[93m",z="\x1B[0m",Y="\x1B[1m",y=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${xe}${Y}[MONACOPILOT ERROR] ${e}${z}`;return console.error(o),{message:e}},ce=t=>{console.warn(`${pe}${Y}[MONACOPILOT WARN] ${t}${z}`);};var B=(t,e,o)=>console.warn(`${pe}${Y}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${z}`);var G=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??Z,this.model=o.model??Q,this.validateInputs();}validateInputs(){if(!U.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${T(U)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!K[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${T(K[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},a=this.generatePrompt(n,s),{endpoint:l,requestBody:d,headers:c}=this.prepareRequestDetails(a);try{let p=await this.sendCompletionRequest(l,d,{...c,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let r=re(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=ie(this.model,this.apiKey,this.provider),r,n=ae(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let i=this.model.config(this.apiKey,e);o=i.endpoint??o,r=i.body??{},n={...n,...i.headers};}else r=se(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return w.POST(e,o,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&B("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return {completion:le(e,this.provider),raw:e}}handleCompletionError(e){return {error:y(e).message,completion:null}}};var F=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
135
63
  `).slice(1,-1).join(`
136
64
  `);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
137
65
 
138
- `),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !ce(this.cursorPos,this.mdl)}};var F=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 h=class h{constructor(){this.cache=new F(h.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return T(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:a,endLineNumber:d,endColumn:m}=n,{lineNumber:c,column:p}=o,u=c===s&&p===a;if(s===d)return u||i.startsWith(r)&&c===s&&p>=a-h.LOOK_AROUND&&p<=m+h.LOOK_AROUND;let C=i.startsWith(r)&&c>=s&&c<=d&&(c===s&&p>=a-h.LOOK_AROUND||c===d&&p<=m+h.LOOK_AROUND||c>s&&c<d);return u||C}};h.MAX_CACHE_SIZE=10,h.LOOK_AROUND=3;var $=h;var H=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,r){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=r.getOffsetAt(e),i=r.getValue().substring(0,n),s=r.getValue().substring(n),a=0,d=0,m=0,c=0,p=o.length,u=i.length,C=s.length;if(n>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(C===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let M=Math.min(p,u);for(let l=1;l<=M;l++){let R=o.substring(0,l),ye=i.slice(-l);R===ye&&(c=l);}let x=Math.min(p,C);for(let l=0;l<x&&o[l]===s[l];l++)a++;for(let l=1;l<=x;l++)o.slice(-l)===s.slice(0,l)&&(d=l);if(m=Math.max(a,d),m===0){for(let l=1;l<p;l++)if(s.startsWith(o.substring(l))){m=p-l;break}}let f=c>0?r.getPositionAt(n-c):e,y=n+m,g=r.getPositionAt(y);return new this.monaco.Range(f.lineNumber,f.column,g.lineNumber,g.column)}};var Le="application/json",ue=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await S.POST(e,o,{headers:{"Content-Type":Le},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},Ce=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:a}=o,d=Ne(t,e),c=!!s?.length?3:2,p=a?Math.floor(a/c):void 0,u=(y,g,l)=>{let R=y(t,e);return g?Y(R,g,l):R},C=(y,g)=>!y||!g?y:y.map(({content:l,...R})=>({...R,content:Y(l,g)})),M=u(T,p,{from:"end"}),x=u(D,p),f=C(s,p);return {filename:r,language:n,technologies:i,relatedFiles:f,textBeforeCursor:M,textAfterCursor:x,cursorPosition:t,editorState:{completionMode:d}}},Ne=(t,e)=>{let o=z(t,e),r=_(t,e);return o?"insert":r.trim()?"complete":"continue"};var ge=t=>k.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),P=t=>({items:t,enableForwardStability:!0});var X={onTyping:300,onIdle:600,onDemand:0},_e=t=>({onTyping:B(t,X.onTyping),onIdle:B(t,X.onIdle),onDemand:B(t,X.onDemand)}),V=new $,De=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:a="onIdle",endpoint:d,enableCaching:m=!0,onError:c,requestHandler:p}=s;if(!new q(o,e).shouldProvideCompletions())return P([]);if(m){let u=V.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return i(),P(u)}if(r.isCancellationRequested||n)return P([]);try{let C=_e(p??ue)[a];r.onCancellationRequested(()=>{C.cancel();});let M=Ce({pos:o,mdl:e,options:s}),{completion:x}=await C({endpoint:d,body:{completionMetadata:M}});if(x){let f=ge(x),g=new H(t).computeInsertionRange(o,f,e);return m&&V.add({completion:f,range:g,textBeforeCursor:T(o,e),textAfterCursor:D(o,e),cachePos:o}),i(),P([{insertText:f,range:g}])}}catch(u){if(Se(u))return P([]);c?c(u):O(u);}return P([])},Se=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,he=De;var E=new WeakMap,I=null,fe=(t,e,o)=>{I&&I.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};E.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(d,m,c,p)=>{let u=E.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return he({monaco:t,mdl:d,pos:m,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(d=>{let m=E.get(e);if(!m)return;let c=d.keyCode===t.KeyCode.Tab||d.keyCode===t.KeyCode.RightArrow&&d.metaKey;m.isCompletionVisible&&c?(m.isCompletionAccepted=!0,m.isCompletionVisible=!1):m.isCompletionAccepted=!1;});r.push(s);let a={deregister:()=>{r.forEach(d=>d.dispose()),V.clear(),E.delete(e),I=null;},trigger:()=>Be(e)};return I=a,a}catch(i){return o.onError?o.onError(i):O(i),{deregister:()=>{r.forEach(s=>s.dispose()),E.delete(e),I=null;},trigger:()=>{}}}},Be=t=>{let e=E.get(t);if(!e){se("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},ke=(...t)=>(w("registerCopilot","registerCompletion"),fe(...t));
66
+ `),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !oe(this.cursorPos,this.mdl)}};var k=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let o;return this.size===this.capacity&&(o=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,o}dequeue(){if(this.size===0)return;let e=this.buffer[this.head];return this.buffer[this.head]=void 0,this.head=(this.head+1)%this.capacity,this.size--,e}getAll(){return this.buffer.filter(e=>e!==void 0)}clear(){this.buffer=new Array(this.capacity),this.head=0,this.tail=0,this.size=0;}getSize(){return this.size}isEmpty(){return this.size===0}isFull(){return this.size===this.capacity}};var g=class g{constructor(){this.cache=new k(g.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return h(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:a,endLineNumber:l,endColumn:d}=n,{lineNumber:c,column:p}=o,m=c===s&&p===a;if(s===l)return m||i.startsWith(r)&&c===s&&p>=a-g.LOOK_AROUND&&p<=d+g.LOOK_AROUND;let u=i.startsWith(r)&&c>=s&&c<=l&&(c===s&&p>=a-g.LOOK_AROUND||c===l&&p<=d+g.LOOK_AROUND||c>s&&c<l);return m||u}};g.MAX_CACHE_SIZE=10,g.LOOK_AROUND=10;var _=g;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,r){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=I(e,r),i=o[0];if(!n||i===n)return this.calculateRangeWithoutOverlap(e,o);let s=r.getOffsetAt(e),a=h(e,r),l=L(e,r);if(s>=r.getValue().length||!l.length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let d=this.getSuffixOverlapLength(o,a),c=this.computeMaxOverlapLength(o,l),p=d>0?r.getPositionAt(s-d):e,m=s+c,u=r.getPositionAt(m);return new this.monaco.Range(p.lineNumber,p.column,u.lineNumber,u.column)}calculateRangeWithoutOverlap(e,o){let r=e.lineNumber,n=e.column,i=o.split(`
67
+ `),s=i.length-1,a=r+s,l=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,a,l)}computeMaxOverlapLength(e,o){let r=this.getPrefixOverlapLength(e,o),n=this.getSuffixPrefixOverlapLength(e,o),i=Math.max(r,n);return i===0&&(i=this.getInternalOverlapLength(e,o)),i}getSuffixOverlapLength(e,o){let r=Math.min(e.length,o.length),n=0;for(let i=1;i<=r;i++)e.substring(0,i)===o.slice(-i)&&(n=i);return n}getPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=0;n<r;n++)if(e[n]!==o[n])return n;return r}getSuffixPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=r;n>0;n--)if(e.slice(-n)===o.slice(0,n))return n;return 0}getInternalOverlapLength(e,o){for(let r=1;r<e.length;r++)if(o.startsWith(e.substring(r)))return e.length-r;return 0}};var Te="application/json",de=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await w.POST(e,o,{headers:{"Content-Type":Te},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},me=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:a}=o,l=Ee(t,e),c=!!s?.length?3:2,p=a?Math.floor(a/c):void 0,m=(P,C,j)=>{let b=P(t,e);return C?W(b,C,j):b},u=(P,C)=>!P||!C?P:P.map(({content:j,...b})=>({...b,content:W(j,C)})),V=m(h,p,{from:"end"}),v=m(L,p),O=u(s,p);return {filename:r,language:n,technologies:i,relatedFiles:O,textBeforeCursor:V,textAfterCursor:v,cursorPosition:t,editorState:{completionMode:l}}},Ee=(t,e)=>{let o=I(t,e),r=A(t,e);return o?"insert":r.trim()?"complete":"continue"};var f=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var X={onTyping:300,onIdle:600,onDemand:0},be=t=>({onTyping:D(t,X.onTyping),onIdle:D(t,X.onIdle),onDemand:D(t,X.onDemand)}),H=new _,Me=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:a="onIdle",endpoint:l,enableCaching:d=!0,onError:c,requestHandler:p}=s;if(!new q(o,e).shouldProvideCompletions())return f([]);if(d){let m=H.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(m.length>0)return i(),f(m)}if(r.isCancellationRequested||n)return f([]);try{let u=be(p??de)[a];r.onCancellationRequested(()=>{u.cancel();});let V=me({pos:o,mdl:e,options:s}),{completion:v}=await u({endpoint:l,body:{completionMetadata:V}});if(v){let O=F.create(v).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),C=new $(t).computeInsertionRange(o,O,e);return d&&H.add({completion:O,range:C,textBeforeCursor:h(o,e)}),i(),f([{insertText:O,range:C}])}}catch(m){if(Ie(m))return f([]);c?c(m):y(m);}return f([])},Ie=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,ue=Me;var R=new WeakMap,E=null,ge=(t,e,o)=>{E&&E.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};R.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(l,d,c,p)=>{let m=R.get(e);if(!(!m||o.trigger==="onDemand"&&!m.isManualTrigger))return ue({monaco:t,mdl:l,pos:d,token:p,isCompletionAccepted:m.isCompletionAccepted,onShowCompletion:()=>{m.isCompletionVisible=!0,m.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(l=>{let d=R.get(e);if(!d)return;let c=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;d.isCompletionVisible&&c?(d.isCompletionAccepted=!0,d.isCompletionVisible=!1):d.isCompletionAccepted=!1;});r.push(s);let a={deregister:()=>{r.forEach(l=>l.dispose()),H.clear(),R.delete(e),E=null;},trigger:()=>Ae(e)};return E=a,a}catch(i){return o.onError?o.onError(i):y(i),{deregister:()=>{r.forEach(s=>s.dispose()),R.delete(e),E=null;},trigger:()=>{}}}},Ae=t=>{let e=R.get(t);if(!e){ce("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},Le=(...t)=>(B("registerCopilot","registerCompletion"),ge(...t));
139
68
 
140
69
  exports.Copilot = G;
141
- exports.registerCompletion = fe;
142
- exports.registerCopilot = ke;
70
+ exports.registerCompletion = ge;
71
+ exports.registerCopilot = Le;
package/build/index.mjs CHANGED
@@ -1,138 +1,67 @@
1
- var j=["groq","openai","anthropic","google"],J={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-preview":"o1-preview","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"},U={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-preview","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},Z="anthropic",Q="claude-3-5-haiku",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"},A=.1;var ee={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var xe={createEndpoint:()=>b.openai,createRequestBody:(t,e)=>{let o=t==="o1-preview"||t==="o1-mini",r=o?[{role:"user",content:e.user}]:[{role:"system",content:e.system},{role:"user",content:e.user}];return {model:N(t),...!o&&{temperature:A},messages:r}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Pe={createEndpoint:()=>b.groq,createRequestBody:(t,e)=>({model:N(t),temperature:A,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Re={createEndpoint:()=>b.anthropic,createRequestBody:(t,e)=>({model:N(t),temperature:A,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ee[t]}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},Oe={createEndpoint:(t,e)=>`${b.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:N(t),system_instruction:{parts:{text:e.system}},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},L={openai:xe,groq:Pe,anthropic:Re,google:Oe},te=(t,e,o)=>L[o].createEndpoint(t,e),oe=(t,e,o)=>L[e].createRequestBody(t,o),re=(t,e)=>L[e].createHeaders(t),ne=(t,e)=>L[e].parseCompletion(t),N=t=>J[t];var Te="\x1B[91m",ie="\x1B[93m",K="\x1B[0m",W="\x1B[1m",O=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${Te}${W}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},se=t=>{console.warn(`${ie}${W}[MONACOPILOT WARN] ${t}${K}`);};var w=(t,e,o)=>console.warn(`${ie}${W}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${K}`);var v=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`;var z=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var _=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ae=(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}),D=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())}),Y=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
1
+ var U=["groq","openai","anthropic","google"],J={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-mini":"o1-mini","gemini-1.5-flash-8b":"gemini-1.5-flash-8b","gemini-1.5-flash":"gemini-1.5-flash","gemini-1.5-pro":"gemini-1.5-pro"},K={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},Z="anthropic",Q="claude-3-5-haiku",x={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models"},M=.1;var T=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,W=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
2
2
  `),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(a=>a==="")?`
3
3
  `.repeat(e):s.join(`
4
4
  `)}let i=r.slice(0,e);return i.every(s=>s==="")?`
5
5
  `.repeat(e):i.join(`
6
- `)};var le=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok){let s=`
7
- `+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},Ee=(t,e)=>le(t,"GET",e),Me=(t,e,o)=>le(t,"POST",{...o,body:e}),S={GET:Ee,POST:Me};var ce=(t,e)=>{let o=_(t,e).trim(),r=ae(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var B=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,a)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=a,o=setTimeout(()=>{s(t(...i)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var be=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n}=t,i=v([n,...e].filter(a=>typeof a=="string"&&!!a));return [`You are an expert ${i?`${i} `:""}developer assistant specialized in precise code completion and generation.`,`Your primary task is to provide accurate, context-aware code completions that seamlessly integrate with existing codebases${o?` in '${o}'`:""}.`,`You must:
8
- - Generate only the exact code required
9
- - Maintain strict adherence to provided instructions
10
- - Follow established code patterns and conventions
11
- - Consider the full context before generating code`,r?.length?"Analyze and incorporate context from all provided related files to ensure consistent and appropriate code generation.":"",n?`Apply ${n}-specific best practices, idioms, and syntax conventions in all generated code.`:""].filter(Boolean).join(`
12
- `)},ve=t=>t?.length?t.map(({path:e,content:o})=>`
6
+ `)};var I=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],A=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ee=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),h=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),L=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var te=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok){let s=`
7
+ `+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},Ce=(t,e)=>te(t,"GET",e),he=(t,e,o)=>te(t,"POST",{...o,body:e}),w={GET:Ce,POST:he};var oe=(t,e)=>{let o=A(t,e).trim(),r=ee(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var D=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,a)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=a,o=setTimeout(()=>{s(t(...i)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var fe=t=>t?.length?t.map(({path:e,content:o})=>`
13
8
  <related_file>
14
9
  <path>${e}</path>
15
- <content_context>
10
+ <content>
16
11
  \`\`\`
17
12
  ${o}
18
13
  \`\`\`
19
- </content_context>
14
+ </content>
20
15
  </related_file>`.trim()).join(`
21
16
 
22
- `):"",Ie=(t="",e)=>{let{relatedFiles:o}=e;return `
23
- <task_context>
24
- <primary_instructions>
25
- ${t.trim()}
26
- </primary_instructions>
27
- ${o?.length?`
28
- <reference_files>
29
- ${ve(o)}
30
- </reference_files>`:""}
31
- </task_context>`.trim()},pe=(t,e)=>({system:be(e),user:Ie(t,e)});var de="<cursor>",Ae=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r},language:n}=t,i=`<code_file>
32
- ${e}${de}${o}
33
- </code_file>`,a=`
34
- <instructions>
35
- <context>
36
- Below is a ${n||"code"} file with the token '${de}' marking the exact cursor position where code completion is needed.
37
-
38
- ${i}
39
- </context>
40
-
41
- <critical_rules>
42
- 1. NEVER REPEAT ANY TEXT THAT APPEARS BEFORE THE CURSOR
43
- 2. Start your completion EXACTLY from the cursor position
44
- 3. If user types 'const ' and cursor is after it, DO NOT include 'const ' in your completion
45
- 4. ONLY provide the remaining part of the code that should appear after the cursor
46
- 5. Violation of these rules will cause code duplication and syntax errors
47
- </critical_rules>
48
-
49
- <primary_objectives>
50
- 1. Generate code that is syntactically correct and follows ${n||"the language"}'s best practices
51
- 2. Ensure seamless integration with existing code structure
52
- 3. Maintain consistent naming conventions and coding style
53
- 4. Provide only the exact code needed at the cursor position
54
- </primary_objectives>
55
-
56
- <strict_requirements>
57
- - Output MUST contain only the NEW code to be inserted at cursor position
58
- - NEVER repeat any code that appears before the cursor position
59
- - DO NOT include any code that appears before the cursor
60
- - DO NOT include explanatory comments or documentation
61
- - DO NOT wrap output in markdown code blocks
62
- - DO NOT include placeholder text or TODO comments
63
- - AVOID generating code beyond the immediate logical completion
64
- </strict_requirements>
65
-
66
- <completion_mode>
67
- Active Mode: ${r}
68
- Specific Instructions: ${{continue:"-- Analyze the code structure and continue writing from the cursor position, maintaining logical flow.",insert:"-- Insert a precise, contextually appropriate code snippet at the cursor position while preserving surrounding code integrity.",complete:"-- Complete the current statement or block with syntactically correct and logically coherent code."}[r]||""}
69
- </completion_mode>
70
-
71
- <code_analysis_steps>
72
- 1. Analyze the code context before and after the cursor
73
- 2. Identify the current scope and available variables/functions
74
- 3. Determine the logical flow and required completion
75
- 4. Remove any duplicate text that appears before cursor
76
- 5. Verify completion starts exactly at cursor position
77
- </code_analysis_steps>
78
-
79
- <examples>
80
- <example>
81
- Context: "const <cursor>"
82
- CORRECT COMPLETION: "myVariable = 42"
83
- INCORRECT COMPLETION: "const myVariable = 42"
84
- </example>
85
-
86
- <example>
87
- Context: "function hello<cursor>"
88
- CORRECT COMPLETION: "(name: string) {\\n return 'Hello ' + name;\\n}"
89
- INCORRECT COMPLETION: "function hello(name: string) {\\n return 'Hello ' + name;\\n}"
90
- </example>
91
-
92
- <example>
93
- Context: "const randomNumber = Math.floor(Math.ran<cursor>00);"
94
- CORRECT COMPLETION: "dom() * 1"
95
- INCORRECT COMPLETION: "Math.random() * 1"
96
- </example>
97
-
98
- <example>
99
- Context: "const result = 'Hello' + ' W<cursor>';"
100
- CORRECT COMPLETION: "orld"
101
- INCORRECT COMPLETION: "orld';"
102
- </example>
103
-
104
- <example>
105
- Context: "function isPalindrome(<cursor>)"
106
- CORRECT COMPLETION: "str) {
107
- return str === str.split('').reverse().join('');
108
- }"
109
- INCORRECT COMPLETION: "(str) {
110
- return str === str.split('').reverse().join('');
111
- }"
112
- </example>
113
- </examples>
114
-
115
- <error_prevention>
116
- - Verify that generated code doesn't introduce syntax errors
117
- - Ensure variable and function references are valid in the current scope
118
- - Check for proper bracket and parenthesis matching
119
- - Maintain consistent indentation with surrounding code
120
- - Respect language-specific type safety requirements
121
- - NEVER duplicate text that appears before cursor
122
- </error_prevention>
123
-
124
- <final_validation>
125
- Before providing the completion:
126
- 1. Confirm the output contains ONLY the new code after cursor position
127
- 2. Double-check no text before cursor is duplicated
128
- 3. Verify it fits seamlessly at the cursor position
129
- 4. Ensure it follows the active completion mode requirements
130
- 5. Check for consistency with existing code style
131
- </final_validation>
132
- </instructions>`.trim();return pe(a,t)},me=Ae;var G=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??Z,this.model=o.model??Q,this.validateInputs();}validateInputs(){if(!j.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${v(j)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!U[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${v(U[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},a=this.generatePrompt(n,s),{endpoint:d,requestBody:m,headers:c}=this.prepareRequestDetails(a);try{let p=await this.sendCompletionRequest(d,m,{...c,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let r=me(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=te(this.model,this.apiKey,this.provider),r,n=re(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let i=this.model.config(this.apiKey,e);o=i.endpoint??o,r=i.body??{},n={...n,...i.headers};}else r=oe(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return S.POST(e,o,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&w("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return {completion:ne(e,this.provider),raw:e}}handleCompletionError(e){return {error:O(e).message,completion:null}}};var k=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
17
+ `):"",re=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:a}}=t,l=T([n,...e].filter(p=>typeof p=="string"&&!!p)),d=`You are an expert ${l?`${l} `:""}AI code completion assistant specialized in generating precise, contextually-aware code completions.
18
+
19
+ ROLE AND CONTEXT:
20
+ - You complete code exactly where the <cursor> placeholder is located in the provided code
21
+ - You are working in file: ${o||"current file"}
22
+ - Primary language: ${n||"detected from context"}
23
+ - Completion mode: ${a}
24
+
25
+ CRITICAL COMPLETION RULES:
26
+ 1. Generate ONLY the exact code needed at cursor position - no explanations, no comments
27
+ 2. NEVER repeat any code that appears before <cursor>
28
+ 3. Start completion EXACTLY at cursor position
29
+ 4. Maintain consistent code style and patterns with surrounding code
30
+ 5. Preserve proper spacing and indentation:
31
+ - Add spaces between tokens for readability
32
+ - Match existing indentation patterns
33
+ - Use appropriate newlines for multi-line completions
34
+ 6. Follow ${a} mode requirements:
35
+ ${a==="continue"?"- Continue writing code naturally from cursor position":a==="insert"?"- Insert precisely fitting code between before/after cursor segments":"- Complete the current code block or structure"}
36
+ 7. Respect Monaco editor's subwordSmart inline suggestion behavior
37
+ 8. Ensure completions are syntactically correct and contextually appropriate
38
+ 9. Consider and maintain consistency with any provided related files
39
+
40
+ COMPLETION SPACING AND INDENTATION EXAMPLES:
41
+ 1. Input: "console.log('Hello<cursor>');"
42
+ Output: " World" (note the leading space)
43
+
44
+ 2. Input: "function calc(a,<cursor>)"
45
+ Output: " b, c" (note the spaces around parameters)
46
+
47
+ 3. Input:
48
+ {
49
+ name: "John",
50
+ <cursor>
51
+ }
52
+ Output: "age: 30,
53
+ city: 'New York'" (note indentation)
54
+
55
+ Analyze all context carefully before generating completions. Ensure high relevance and accuracy.`,c=`${fe(r)}
56
+
57
+ Current code with cursor position:
58
+ \`\`\`
59
+ ${i}<cursor>${s}
60
+ \`\`\``;return {system:d,user:c}};var ne={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var Pe={createEndpoint:()=>x.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:S(t),...!o&&{temperature:M},messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},ye={createEndpoint:()=>x.groq,createRequestBody:(t,e)=>({model:S(t),temperature:M,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Re={createEndpoint:()=>x.anthropic,createRequestBody:(t,e)=>({model:S(t),temperature:M,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ne[t]}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},Oe={createEndpoint:(t,e)=>`${x.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:S(t),system_instruction:{parts:{text:e.system}},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},N={openai:Pe,groq:ye,anthropic:Re,google:Oe},ie=(t,e,o)=>N[o].createEndpoint(t,e),se=(t,e,o)=>N[e].createRequestBody(t,o),ae=(t,e)=>N[e].createHeaders(t),le=(t,e)=>N[e].parseCompletion(t),S=t=>J[t];var xe="\x1B[91m",pe="\x1B[93m",z="\x1B[0m",Y="\x1B[1m",y=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${xe}${Y}[MONACOPILOT ERROR] ${e}${z}`;return console.error(o),{message:e}},ce=t=>{console.warn(`${pe}${Y}[MONACOPILOT WARN] ${t}${z}`);};var B=(t,e,o)=>console.warn(`${pe}${Y}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${z}`);var G=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??Z,this.model=o.model??Q,this.validateInputs();}validateInputs(){if(!U.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${T(U)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!K[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${T(K[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},a=this.generatePrompt(n,s),{endpoint:l,requestBody:d,headers:c}=this.prepareRequestDetails(a);try{let p=await this.sendCompletionRequest(l,d,{...c,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let r=re(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=ie(this.model,this.apiKey,this.provider),r,n=ae(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let i=this.model.config(this.apiKey,e);o=i.endpoint??o,r=i.body??{},n={...n,...i.headers};}else r=se(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return w.POST(e,o,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&B("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return {completion:le(e,this.provider),raw:e}}handleCompletionError(e){return {error:y(e).message,completion:null}}};var F=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
133
61
  `).slice(1,-1).join(`
134
62
  `);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
135
63
 
136
- `),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !ce(this.cursorPos,this.mdl)}};var F=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 h=class h{constructor(){this.cache=new F(h.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return T(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:a,endLineNumber:d,endColumn:m}=n,{lineNumber:c,column:p}=o,u=c===s&&p===a;if(s===d)return u||i.startsWith(r)&&c===s&&p>=a-h.LOOK_AROUND&&p<=m+h.LOOK_AROUND;let C=i.startsWith(r)&&c>=s&&c<=d&&(c===s&&p>=a-h.LOOK_AROUND||c===d&&p<=m+h.LOOK_AROUND||c>s&&c<d);return u||C}};h.MAX_CACHE_SIZE=10,h.LOOK_AROUND=3;var $=h;var H=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,r){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=r.getOffsetAt(e),i=r.getValue().substring(0,n),s=r.getValue().substring(n),a=0,d=0,m=0,c=0,p=o.length,u=i.length,C=s.length;if(n>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(C===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let M=Math.min(p,u);for(let l=1;l<=M;l++){let R=o.substring(0,l),ye=i.slice(-l);R===ye&&(c=l);}let x=Math.min(p,C);for(let l=0;l<x&&o[l]===s[l];l++)a++;for(let l=1;l<=x;l++)o.slice(-l)===s.slice(0,l)&&(d=l);if(m=Math.max(a,d),m===0){for(let l=1;l<p;l++)if(s.startsWith(o.substring(l))){m=p-l;break}}let f=c>0?r.getPositionAt(n-c):e,y=n+m,g=r.getPositionAt(y);return new this.monaco.Range(f.lineNumber,f.column,g.lineNumber,g.column)}};var Le="application/json",ue=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await S.POST(e,o,{headers:{"Content-Type":Le},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},Ce=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:a}=o,d=Ne(t,e),c=!!s?.length?3:2,p=a?Math.floor(a/c):void 0,u=(y,g,l)=>{let R=y(t,e);return g?Y(R,g,l):R},C=(y,g)=>!y||!g?y:y.map(({content:l,...R})=>({...R,content:Y(l,g)})),M=u(T,p,{from:"end"}),x=u(D,p),f=C(s,p);return {filename:r,language:n,technologies:i,relatedFiles:f,textBeforeCursor:M,textAfterCursor:x,cursorPosition:t,editorState:{completionMode:d}}},Ne=(t,e)=>{let o=z(t,e),r=_(t,e);return o?"insert":r.trim()?"complete":"continue"};var ge=t=>k.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),P=t=>({items:t,enableForwardStability:!0});var X={onTyping:300,onIdle:600,onDemand:0},_e=t=>({onTyping:B(t,X.onTyping),onIdle:B(t,X.onIdle),onDemand:B(t,X.onDemand)}),V=new $,De=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:a="onIdle",endpoint:d,enableCaching:m=!0,onError:c,requestHandler:p}=s;if(!new q(o,e).shouldProvideCompletions())return P([]);if(m){let u=V.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return i(),P(u)}if(r.isCancellationRequested||n)return P([]);try{let C=_e(p??ue)[a];r.onCancellationRequested(()=>{C.cancel();});let M=Ce({pos:o,mdl:e,options:s}),{completion:x}=await C({endpoint:d,body:{completionMetadata:M}});if(x){let f=ge(x),g=new H(t).computeInsertionRange(o,f,e);return m&&V.add({completion:f,range:g,textBeforeCursor:T(o,e),textAfterCursor:D(o,e),cachePos:o}),i(),P([{insertText:f,range:g}])}}catch(u){if(Se(u))return P([]);c?c(u):O(u);}return P([])},Se=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,he=De;var E=new WeakMap,I=null,fe=(t,e,o)=>{I&&I.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};E.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(d,m,c,p)=>{let u=E.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return he({monaco:t,mdl:d,pos:m,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(d=>{let m=E.get(e);if(!m)return;let c=d.keyCode===t.KeyCode.Tab||d.keyCode===t.KeyCode.RightArrow&&d.metaKey;m.isCompletionVisible&&c?(m.isCompletionAccepted=!0,m.isCompletionVisible=!1):m.isCompletionAccepted=!1;});r.push(s);let a={deregister:()=>{r.forEach(d=>d.dispose()),V.clear(),E.delete(e),I=null;},trigger:()=>Be(e)};return I=a,a}catch(i){return o.onError?o.onError(i):O(i),{deregister:()=>{r.forEach(s=>s.dispose()),E.delete(e),I=null;},trigger:()=>{}}}},Be=t=>{let e=E.get(t);if(!e){se("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},ke=(...t)=>(w("registerCopilot","registerCompletion"),fe(...t));
64
+ `),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !oe(this.cursorPos,this.mdl)}};var k=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let o;return this.size===this.capacity&&(o=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,o}dequeue(){if(this.size===0)return;let e=this.buffer[this.head];return this.buffer[this.head]=void 0,this.head=(this.head+1)%this.capacity,this.size--,e}getAll(){return this.buffer.filter(e=>e!==void 0)}clear(){this.buffer=new Array(this.capacity),this.head=0,this.tail=0,this.size=0;}getSize(){return this.size}isEmpty(){return this.size===0}isFull(){return this.size===this.capacity}};var g=class g{constructor(){this.cache=new k(g.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return h(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:a,endLineNumber:l,endColumn:d}=n,{lineNumber:c,column:p}=o,m=c===s&&p===a;if(s===l)return m||i.startsWith(r)&&c===s&&p>=a-g.LOOK_AROUND&&p<=d+g.LOOK_AROUND;let u=i.startsWith(r)&&c>=s&&c<=l&&(c===s&&p>=a-g.LOOK_AROUND||c===l&&p<=d+g.LOOK_AROUND||c>s&&c<l);return m||u}};g.MAX_CACHE_SIZE=10,g.LOOK_AROUND=10;var _=g;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,r){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=I(e,r),i=o[0];if(!n||i===n)return this.calculateRangeWithoutOverlap(e,o);let s=r.getOffsetAt(e),a=h(e,r),l=L(e,r);if(s>=r.getValue().length||!l.length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let d=this.getSuffixOverlapLength(o,a),c=this.computeMaxOverlapLength(o,l),p=d>0?r.getPositionAt(s-d):e,m=s+c,u=r.getPositionAt(m);return new this.monaco.Range(p.lineNumber,p.column,u.lineNumber,u.column)}calculateRangeWithoutOverlap(e,o){let r=e.lineNumber,n=e.column,i=o.split(`
65
+ `),s=i.length-1,a=r+s,l=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,a,l)}computeMaxOverlapLength(e,o){let r=this.getPrefixOverlapLength(e,o),n=this.getSuffixPrefixOverlapLength(e,o),i=Math.max(r,n);return i===0&&(i=this.getInternalOverlapLength(e,o)),i}getSuffixOverlapLength(e,o){let r=Math.min(e.length,o.length),n=0;for(let i=1;i<=r;i++)e.substring(0,i)===o.slice(-i)&&(n=i);return n}getPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=0;n<r;n++)if(e[n]!==o[n])return n;return r}getSuffixPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=r;n>0;n--)if(e.slice(-n)===o.slice(0,n))return n;return 0}getInternalOverlapLength(e,o){for(let r=1;r<e.length;r++)if(o.startsWith(e.substring(r)))return e.length-r;return 0}};var Te="application/json",de=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await w.POST(e,o,{headers:{"Content-Type":Te},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},me=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:a}=o,l=Ee(t,e),c=!!s?.length?3:2,p=a?Math.floor(a/c):void 0,m=(P,C,j)=>{let b=P(t,e);return C?W(b,C,j):b},u=(P,C)=>!P||!C?P:P.map(({content:j,...b})=>({...b,content:W(j,C)})),V=m(h,p,{from:"end"}),v=m(L,p),O=u(s,p);return {filename:r,language:n,technologies:i,relatedFiles:O,textBeforeCursor:V,textAfterCursor:v,cursorPosition:t,editorState:{completionMode:l}}},Ee=(t,e)=>{let o=I(t,e),r=A(t,e);return o?"insert":r.trim()?"complete":"continue"};var f=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var X={onTyping:300,onIdle:600,onDemand:0},be=t=>({onTyping:D(t,X.onTyping),onIdle:D(t,X.onIdle),onDemand:D(t,X.onDemand)}),H=new _,Me=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:a="onIdle",endpoint:l,enableCaching:d=!0,onError:c,requestHandler:p}=s;if(!new q(o,e).shouldProvideCompletions())return f([]);if(d){let m=H.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(m.length>0)return i(),f(m)}if(r.isCancellationRequested||n)return f([]);try{let u=be(p??de)[a];r.onCancellationRequested(()=>{u.cancel();});let V=me({pos:o,mdl:e,options:s}),{completion:v}=await u({endpoint:l,body:{completionMetadata:V}});if(v){let O=F.create(v).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),C=new $(t).computeInsertionRange(o,O,e);return d&&H.add({completion:O,range:C,textBeforeCursor:h(o,e)}),i(),f([{insertText:O,range:C}])}}catch(m){if(Ie(m))return f([]);c?c(m):y(m);}return f([])},Ie=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,ue=Me;var R=new WeakMap,E=null,ge=(t,e,o)=>{E&&E.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};R.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(l,d,c,p)=>{let m=R.get(e);if(!(!m||o.trigger==="onDemand"&&!m.isManualTrigger))return ue({monaco:t,mdl:l,pos:d,token:p,isCompletionAccepted:m.isCompletionAccepted,onShowCompletion:()=>{m.isCompletionVisible=!0,m.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(l=>{let d=R.get(e);if(!d)return;let c=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;d.isCompletionVisible&&c?(d.isCompletionAccepted=!0,d.isCompletionVisible=!1):d.isCompletionAccepted=!1;});r.push(s);let a={deregister:()=>{r.forEach(l=>l.dispose()),H.clear(),R.delete(e),E=null;},trigger:()=>Ae(e)};return E=a,a}catch(i){return o.onError?o.onError(i):y(i),{deregister:()=>{r.forEach(s=>s.dispose()),R.delete(e),E=null;},trigger:()=>{}}}},Ae=t=>{let e=R.get(t);if(!e){ce("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},Le=(...t)=>(B("registerCopilot","registerCompletion"),ge(...t));
137
66
 
138
- export { G as Copilot, fe as registerCompletion, ke as registerCopilot };
67
+ export { G as Copilot, ge as registerCompletion, Le as registerCopilot };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "monacopilot",
3
- "version": "0.15.0",
3
+ "version": "0.15.2",
4
4
  "description": "AI auto-completion plugin for Monaco Editor",
5
5
  "main": "./build/index.js",
6
6
  "module": "./build/index.mjs",