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 +2 -2
- package/build/index.d.mts +1 -1
- package/build/index.d.ts +1 -1
- package/build/index.js +53 -124
- package/build/index.mjs +52 -123
- package/package.json +1 -1
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-
|
|
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-
|
|
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-
|
|
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
|
|
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
|
|
9
|
-
`+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},
|
|
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
|
-
<
|
|
12
|
+
<content>
|
|
18
13
|
\`\`\`
|
|
19
14
|
${o}
|
|
20
15
|
\`\`\`
|
|
21
|
-
</
|
|
16
|
+
</content>
|
|
22
17
|
</related_file>`.trim()).join(`
|
|
23
18
|
|
|
24
|
-
`):"",
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
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 !
|
|
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 =
|
|
142
|
-
exports.registerCopilot =
|
|
70
|
+
exports.registerCompletion = ge;
|
|
71
|
+
exports.registerCopilot = Le;
|
package/build/index.mjs
CHANGED
|
@@ -1,138 +1,67 @@
|
|
|
1
|
-
var
|
|
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
|
|
7
|
-
`+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},
|
|
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
|
-
<
|
|
10
|
+
<content>
|
|
16
11
|
\`\`\`
|
|
17
12
|
${o}
|
|
18
13
|
\`\`\`
|
|
19
|
-
</
|
|
14
|
+
</content>
|
|
20
15
|
</related_file>`.trim()).join(`
|
|
21
16
|
|
|
22
|
-
`):"",
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
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 !
|
|
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,
|
|
67
|
+
export { G as Copilot, ge as registerCompletion, Le as registerCopilot };
|