monacopilot 0.11.8 → 0.12.0
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 +10 -0
- package/build/index.d.mts +6 -0
- package/build/index.d.ts +6 -0
- package/build/index.js +52 -40
- package/build/index.mjs +52 -40
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -279,6 +279,16 @@ registerCompletion(monaco, editor, {
|
|
|
279
279
|
|
|
280
280
|
> **Note:** If you're using `Groq` as your provider, it's recommended to set `maxContextLines` to `60` or less due to its low rate limits and lack of pay-as-you-go pricing. However, `Groq` is expected to offer pay-as-you-go pricing in the near future.
|
|
281
281
|
|
|
282
|
+
### Caching Completions
|
|
283
|
+
|
|
284
|
+
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:
|
|
285
|
+
|
|
286
|
+
```javascript
|
|
287
|
+
registerCompletion(monaco, editor, {
|
|
288
|
+
enableCaching: false,
|
|
289
|
+
});
|
|
290
|
+
```
|
|
291
|
+
|
|
282
292
|
### Handling Errors
|
|
283
293
|
|
|
284
294
|
You can handle errors that occur during completion requests by providing an `onError` function when calling `registerCompletion`. This allows you to customize error handling and logging based on your application's needs.
|
package/build/index.d.mts
CHANGED
|
@@ -158,6 +158,12 @@ interface RegisterCompletionOptions {
|
|
|
158
158
|
* since `Groq` does not implement pay-as-you-go pricing and has only low rate limits.
|
|
159
159
|
*/
|
|
160
160
|
maxContextLines?: number;
|
|
161
|
+
/**
|
|
162
|
+
* Determines if completions should be cached.
|
|
163
|
+
* Enabling caching can enhance performance by reusing previous results when the cursor position and context remain the same while editing.
|
|
164
|
+
* @default true
|
|
165
|
+
*/
|
|
166
|
+
enableCaching?: boolean;
|
|
161
167
|
/**
|
|
162
168
|
* Callback function that is called when an error occurs during the completion request.
|
|
163
169
|
* This function allows you to handle errors gracefully and provide appropriate feedback to the user.
|
package/build/index.d.ts
CHANGED
|
@@ -158,6 +158,12 @@ interface RegisterCompletionOptions {
|
|
|
158
158
|
* since `Groq` does not implement pay-as-you-go pricing and has only low rate limits.
|
|
159
159
|
*/
|
|
160
160
|
maxContextLines?: number;
|
|
161
|
+
/**
|
|
162
|
+
* Determines if completions should be cached.
|
|
163
|
+
* Enabling caching can enhance performance by reusing previous results when the cursor position and context remain the same while editing.
|
|
164
|
+
* @default true
|
|
165
|
+
*/
|
|
166
|
+
enableCaching?: boolean;
|
|
161
167
|
/**
|
|
162
168
|
* Callback function that is called when an error occurs during the completion request.
|
|
163
169
|
* This function allows you to handle errors gracefully and provide appropriate feedback to the user.
|
package/build/index.js
CHANGED
|
@@ -1,46 +1,58 @@
|
|
|
1
|
-
"use strict";var
|
|
2
|
-
`),
|
|
3
|
-
|
|
4
|
-
`)
|
|
5
|
-
`.repeat(
|
|
6
|
-
`)}
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
</
|
|
20
|
-
`,c=`
|
|
21
|
-
<context>
|
|
22
|
-
<current_file path="${t}">
|
|
23
|
-
<code>
|
|
24
|
-
${o}${Te}${r}
|
|
25
|
-
</code>
|
|
26
|
-
</current_file>
|
|
27
|
-
</context>
|
|
28
|
-
`,u=n?.map(({path:l,content:C})=>`
|
|
29
|
-
<related_file path="${l}">
|
|
30
|
-
<code>
|
|
31
|
-
${C}
|
|
32
|
-
</code>
|
|
1
|
+
"use strict";var $=Object.defineProperty;var fe=Object.getOwnPropertyDescriptor;var Pe=Object.getOwnPropertyNames;var ye=Object.prototype.hasOwnProperty;var Re=(t,e)=>{for(var o in e)$(t,o,{get:e[o],enumerable:!0})},Te=(t,e,o,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of Pe(e))!ye.call(t,n)&&n!==o&&$(t,n,{get:()=>e[n],enumerable:!(r=fe(e,n))||r.enumerable});return t};var Ee=t=>Te($({},"__esModule",{value:!0}),t);var He={};Re(He,{Copilot:()=>L,registerCompletion:()=>Y,registerCopilot:()=>he});module.exports=Ee(He);var q=["groq","openai","anthropic"],G={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3.5-sonnet":"claude-3.5-sonnet-20240620","claude-3-opus":"claude-3-opus-20240229","claude-3-sonnet":"claude-3-sonnet-20240229","claude-3-haiku":"claude-3-haiku-20240307","o1-preview":"o1-preview","o1-mini":"o1-mini"},H={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-preview","o1-mini"],anthropic:["claude-3.5-sonnet","claude-3-opus","claude-3-haiku","claude-3-sonnet"]},X="llama-3-70b",z="groq",J={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages"},b=.1;var Z={"claude-3.5-sonnet":8192,"claude-3-opus":4096,"claude-3-haiku":4096,"claude-3-sonnet":4096};var xe={createRequestBody:(t,e)=>{let r=t==="o1-preview"||t==="o1-mini"?[{role:"user",content:e.user}]:[{role:"system",content:e.system},{role:"user",content:e.user}];return{model:j(t),temperature:b,messages:r}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Me={createRequestBody:(t,e)=>({model:j(t),temperature:b,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},Oe={createRequestBody:(t,e)=>({model:j(t),temperature:b,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:be(t)}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>!t.content||typeof t.content!="string"?null:t.content},_={openai:xe,groq:Me,anthropic:Oe},Q=(t,e,o)=>_[e].createRequestBody(t,o),ee=(t,e)=>_[e].createHeaders(t),te=(t,e)=>_[e].parseCompletion(t),j=t=>G[t],oe=t=>J[t],be=t=>Z[t]||4096;var l=class l{constructor(){}static getInstance(){return l.instance}logError(e){let o,r;e instanceof Error?(o=e.message,r=e.stack):typeof e=="string"?o=e:o="An unknown error occurred";let n=`${l.RED}${l.BOLD}[MONACOPILOT ERROR] ${o}${l.RESET}`;return console.error(n),r&&console.error(`${l.RED}[MONACOPILOT ERROR] Stack trace:${l.RESET}
|
|
2
|
+
${r}`),{message:o,stack:r}}warn(e){console.warn(`${l.YELLOW}${l.BOLD}[MONACOPILOT WARN] ${e}${l.RESET}`)}log(e){console.log(`${l.BOLD}[MONACOPILOT] ${e}${l.RESET}`)}};l.instance=new l,l.RED="\x1B[31m",l.YELLOW="\x1B[33m",l.RESET="\x1B[0m",l.BOLD="\x1B[1m";var U=l,h=U.getInstance();var v=(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},E=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`;var V=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],re=t=>{let e=t.split(`
|
|
3
|
+
`);return e[e.length-1].length+1},I=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),y=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),ne=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),ie=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())}),W=(t,e,o={})=>{if(e<=0)return"";let r=t.split(`
|
|
4
|
+
`),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(a=>a==="")?`
|
|
5
|
+
`.repeat(e):s.join(`
|
|
6
|
+
`)}let i=r.slice(0,e);return i.every(s=>s==="")?`
|
|
7
|
+
`.repeat(e):i.join(`
|
|
8
|
+
`)};var se=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)throw new Error(`${i.statusText||o.fallbackError||"Network error"}`);return i.json()},ve=(t,e)=>se(t,"GET",e),Ie=(t,e,o)=>se(t,"POST",{...o,body:e}),A={GET:ve,POST:Ie};var ae=(t,e)=>{let o=I(t,e).trim(),r=y(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var Ae=t=>{let{technologies:e,filename:o,relatedFiles:r}=t,n=E(e),i=`You are an expert ${n?`${n} `:""}developer assistant.`,s="Your task is to provide precise and contextually relevant code completions, modifications, or generations",a=o?`for the file '${o}'`:"",p=r&&r.length>0?"Consider the context of the current and related files provided.":"";return`${i}
|
|
9
|
+
${s} ${a}.
|
|
10
|
+
Ensure that your responses integrate seamlessly with the existing code and maintain consistency with the project's style and conventions.
|
|
11
|
+
${p}
|
|
12
|
+
Before providing the completion or modification, think through the problem step-by-step, considering best practices and any potential edge cases.`.trim()},Le=t=>t?.length?t.map(({path:e,content:o})=>`
|
|
13
|
+
<related_file>
|
|
14
|
+
<path>${e}</path>
|
|
15
|
+
<content>
|
|
16
|
+
\`\`\`
|
|
17
|
+
${o}
|
|
18
|
+
\`\`\`
|
|
19
|
+
</content>
|
|
33
20
|
</related_file>
|
|
34
|
-
|
|
35
|
-
`)
|
|
21
|
+
`.trim()).join(`
|
|
22
|
+
`):"",De=(t="",e)=>{let{relatedFiles:o}=e,r=o?Le(o):"";return`
|
|
36
23
|
<task>
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
24
|
+
<instructions>
|
|
25
|
+
${t.trim()}
|
|
26
|
+
</instructions>
|
|
27
|
+
${r}
|
|
40
28
|
</task>
|
|
41
|
-
|
|
42
|
-
${
|
|
29
|
+
`.trim()},le=(t,e)=>({system:Ae(e),user:De(t,e)});var pe="<cursor>",we=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r}}=t,n=`<code_file>
|
|
30
|
+
${e}${pe}${o}
|
|
31
|
+
</code_file>`,s=`
|
|
32
|
+
You are an AI coding assistant. Your task is to provide code completions based on the current cursor position in the code.
|
|
33
|
+
|
|
34
|
+
Below is the code file with a special token '${pe}' indicating the current cursor position.
|
|
35
|
+
|
|
36
|
+
${n}
|
|
37
|
+
|
|
38
|
+
Please provide the code that should be inserted at the cursor position, following these guidelines:
|
|
39
|
+
|
|
40
|
+
- Carefully analyze the code context before and after the cursor to understand what code is needed.
|
|
41
|
+
- Follow best practices and maintain a consistent coding style with the existing code.
|
|
42
|
+
- Ensure the generated code integrates smoothly with the existing codebase.
|
|
43
|
+
- Do **not** include any code that is before the cursor in your response.
|
|
44
|
+
- Do **not** include any explanations, comments, or placeholders.
|
|
45
|
+
- Avoid wrapping your completion with markdown code blocks (\`\`\` or \`).
|
|
46
|
+
- Provide **only** the necessary code to be inserted at the cursor location.
|
|
47
|
+
|
|
48
|
+
Depending on the completion mode, adjust your completion accordingly:
|
|
49
|
+
|
|
50
|
+
- **Completion Mode**: ${r}
|
|
51
|
+
${{continue:"-- Continue writing the code from the current cursor location.",insert:"-- Insert the appropriate code snippet at the cursor point.",complete:"-- Supply the necessary code to finish the ongoing statement or block."}[r]||""}
|
|
52
|
+
|
|
53
|
+
Remember to output **only** the code that should be inserted at the cursor, without any additional formatting or explanations.
|
|
54
|
+
`.trim();return le(s,t)},ce=we;var L=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??X,this.validateInputs()}validateInputs(){if(!q.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${E(q)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!H[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${E(H[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:p,requestBody:c,headers:d}=this.prepareRequestDetails(a);try{let m=await this.sendCompletionRequest(p,c,{...d,...i});return this.processCompletionResponse(m)}catch(m){return this.handleCompletionError(m)}}generatePrompt(e,o){let r=ce(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=oe(this.provider),r,n=ee(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=Q(this.model,this.provider,e);return{endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return A.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&&h.warn("The `completion` property in `transformResponse` function is deprecated. Please use `text` instead."),{completion:o.text??o.completion}}else return{completion:te(e,this.provider)}}handleCompletionError(e){return{error:h.logError(e).message,completion:null}}};var D=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(`
|
|
43
55
|
`).slice(1,-1).join(`
|
|
44
56
|
`);r=r.replace(i,s)}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
45
57
|
|
|
46
|
-
`),this}build(){return this.formattedCompletion}};var w=class{constructor(
|
|
58
|
+
`),this}build(){return this.formattedCompletion}};var w=class{constructor(e,o){this.cursorPos=e,this.mdl=o}shouldProvideCompletions(){return!ae(this.cursorPos,this.mdl)}};var B=class B{constructor(){this.cache=[]}get(e,o){return this.cache.filter(r=>this.isValidCacheItem(r,e,o))}add(e){let o=[...this.cache.slice(-(B.MAX_CACHE_SIZE-1)),e];this.cache=o}clear(){this.cache=[]}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return y(o,r).startsWith(e.textBeforeCursorInLine)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:a,endColumn:p}=n,{lineNumber:c,column:d}=o,m=c===s&&d===a,u=i.startsWith(r)&&c===s&&d>=a-r.length&&d<=p+r.length;return m||u}};B.MAX_CACHE_SIZE=10;var S=B;var Se="application/json",de=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await A.POST(e,o,{headers:{"Content-Type":Se},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,p=Be(t,e),d=!!s?.length?3:2,m=a?Math.floor(a/d):void 0,u=(g,f,N)=>{let O=g(t,e);return f?W(O,f,N):O},C=(g,f)=>!g||!f?g:g.map(({content:N,...O})=>({...O,content:W(N,f)})),P=u(ne,m,{from:"end"}),k=u(ie,m),M=C(s,m);return{filename:r,language:n,technologies:i,relatedFiles:M,textBeforeCursor:P,textAfterCursor:k,cursorPosition:t,editorState:{completionMode:p}}},Be=(t,e)=>{let o=V(t,e),r=I(t,e);return o?"insert":r.trim()?"complete":"continue"};var ue=(t,e,o)=>{let r=o.match(/\n/g)?.length||0,n=e.lineNumber+r,i=re(o),s=r===0?e.column+i:i;return new t.Range(e.lineNumber,e.column,n,s)},Ce=t=>D.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),R=t=>({items:t,enableForwardStability:!0});var K={onTyping:300,onIdle:600,onDemand:0},ke=t=>({onTyping:v(t,K.onTyping),onIdle:v(t,K.onIdle),onDemand:v(t,K.onDemand)}),F=new S,Ne=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:a="onIdle",endpoint:p,enableCaching:c=!0,onError:d,requestHandler:m}=s,u=a==="onDemand"?!1:c;if(!new w(o,e).shouldProvideCompletions())return R([]);if(u){let C=F.get(o,e).map(P=>({insertText:P.completion,range:P.range}));if(C.length>0)return i(),R(C)}if(r.isCancellationRequested||n)return R([]);try{let P=ke(m??de)[a];r.onCancellationRequested(()=>{P.cancel()});let k=me({pos:o,mdl:e,options:s}),{completion:M}=await P({endpoint:p,body:{completionMetadata:k}});if(M){let g=Ce(M),f=ue(t,o,g);return u&&F.add({completion:g,range:f,textBeforeCursorInLine:y(o,e)}),i(),R([{insertText:g,range:f}])}}catch(C){d?d(C):$e(C)||h.logError(C)}return R([])},$e=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,ge=Ne;var T=new WeakMap,x=null,Y=(t,e,o)=>{x&&x.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};T.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(p,c,d,m)=>{let u=T.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return ge({monaco:t,mdl:p,pos:c,token:m,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(p=>{let c=T.get(e);if(!c)return;let d=p.keyCode===t.KeyCode.Tab||p.keyCode===t.KeyCode.RightArrow&&p.metaKey;c.isCompletionVisible&&d?(c.isCompletionAccepted=!0,c.isCompletionVisible=!1):c.isCompletionAccepted=!1});r.push(s);let a={deregister:()=>{r.forEach(p=>p.dispose()),F.clear(),T.delete(e),x=null},trigger:()=>qe(e)};return x=a,a}catch(i){return o.onError?o.onError(i):h.logError(i),{deregister:()=>{r.forEach(s=>s.dispose()),T.delete(e),x=null},trigger:()=>{}}}},qe=t=>{let e=T.get(t);if(!e){h.warn("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{})},he=(...t)=>(h.warn("The `registerCopilot` function is deprecated. Use `registerCompletion` instead."),Y(...t));0&&(module.exports={Copilot,registerCompletion,registerCopilot});
|
package/build/index.mjs
CHANGED
|
@@ -1,46 +1,58 @@
|
|
|
1
|
-
var
|
|
2
|
-
`),
|
|
3
|
-
|
|
4
|
-
`)
|
|
5
|
-
`.repeat(
|
|
6
|
-
`)}
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
</
|
|
20
|
-
`,c=`
|
|
21
|
-
<context>
|
|
22
|
-
<current_file path="${t}">
|
|
23
|
-
<code>
|
|
24
|
-
${o}${Ce}${r}
|
|
25
|
-
</code>
|
|
26
|
-
</current_file>
|
|
27
|
-
</context>
|
|
28
|
-
`,u=n?.map(({path:l,content:C})=>`
|
|
29
|
-
<related_file path="${l}">
|
|
30
|
-
<code>
|
|
31
|
-
${C}
|
|
32
|
-
</code>
|
|
1
|
+
var N=["groq","openai","anthropic"],K={"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-20240620","claude-3-opus":"claude-3-opus-20240229","claude-3-sonnet":"claude-3-sonnet-20240229","claude-3-haiku":"claude-3-haiku-20240307","o1-preview":"o1-preview","o1-mini":"o1-mini"},$={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-preview","o1-mini"],anthropic:["claude-3.5-sonnet","claude-3-opus","claude-3-haiku","claude-3-sonnet"]},Y="llama-3-70b",G="groq",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"},b=.1;var z={"claude-3.5-sonnet":8192,"claude-3-opus":4096,"claude-3-haiku":4096,"claude-3-sonnet":4096};var ge={createRequestBody:(t,e)=>{let r=t==="o1-preview"||t==="o1-mini"?[{role:"user",content:e.user}]:[{role:"system",content:e.system},{role:"user",content:e.user}];return{model:H(t),temperature:b,messages:r}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},he={createRequestBody:(t,e)=>({model:H(t),temperature:b,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},fe={createRequestBody:(t,e)=>({model:H(t),temperature:b,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:Pe(t)}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>!t.content||typeof t.content!="string"?null:t.content},q={openai:ge,groq:he,anthropic:fe},J=(t,e,o)=>q[e].createRequestBody(t,o),Z=(t,e)=>q[e].createHeaders(t),Q=(t,e)=>q[e].parseCompletion(t),H=t=>K[t],ee=t=>X[t],Pe=t=>z[t]||4096;var l=class l{constructor(){}static getInstance(){return l.instance}logError(e){let o,r;e instanceof Error?(o=e.message,r=e.stack):typeof e=="string"?o=e:o="An unknown error occurred";let n=`${l.RED}${l.BOLD}[MONACOPILOT ERROR] ${o}${l.RESET}`;return console.error(n),r&&console.error(`${l.RED}[MONACOPILOT ERROR] Stack trace:${l.RESET}
|
|
2
|
+
${r}`),{message:o,stack:r}}warn(e){console.warn(`${l.YELLOW}${l.BOLD}[MONACOPILOT WARN] ${e}${l.RESET}`)}log(e){console.log(`${l.BOLD}[MONACOPILOT] ${e}${l.RESET}`)}};l.instance=new l,l.RED="\x1B[31m",l.YELLOW="\x1B[33m",l.RESET="\x1B[0m",l.BOLD="\x1B[1m";var _=l,h=_.getInstance();var v=(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},E=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`;var j=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],te=t=>{let e=t.split(`
|
|
3
|
+
`);return e[e.length-1].length+1},I=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),y=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),oe=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),re=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())}),U=(t,e,o={})=>{if(e<=0)return"";let r=t.split(`
|
|
4
|
+
`),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(a=>a==="")?`
|
|
5
|
+
`.repeat(e):s.join(`
|
|
6
|
+
`)}let i=r.slice(0,e);return i.every(s=>s==="")?`
|
|
7
|
+
`.repeat(e):i.join(`
|
|
8
|
+
`)};var ne=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)throw new Error(`${i.statusText||o.fallbackError||"Network error"}`);return i.json()},ye=(t,e)=>ne(t,"GET",e),Re=(t,e,o)=>ne(t,"POST",{...o,body:e}),A={GET:ye,POST:Re};var ie=(t,e)=>{let o=I(t,e).trim(),r=y(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var Te=t=>{let{technologies:e,filename:o,relatedFiles:r}=t,n=E(e),i=`You are an expert ${n?`${n} `:""}developer assistant.`,s="Your task is to provide precise and contextually relevant code completions, modifications, or generations",a=o?`for the file '${o}'`:"",p=r&&r.length>0?"Consider the context of the current and related files provided.":"";return`${i}
|
|
9
|
+
${s} ${a}.
|
|
10
|
+
Ensure that your responses integrate seamlessly with the existing code and maintain consistency with the project's style and conventions.
|
|
11
|
+
${p}
|
|
12
|
+
Before providing the completion or modification, think through the problem step-by-step, considering best practices and any potential edge cases.`.trim()},Ee=t=>t?.length?t.map(({path:e,content:o})=>`
|
|
13
|
+
<related_file>
|
|
14
|
+
<path>${e}</path>
|
|
15
|
+
<content>
|
|
16
|
+
\`\`\`
|
|
17
|
+
${o}
|
|
18
|
+
\`\`\`
|
|
19
|
+
</content>
|
|
33
20
|
</related_file>
|
|
34
|
-
|
|
35
|
-
`)
|
|
21
|
+
`.trim()).join(`
|
|
22
|
+
`):"",xe=(t="",e)=>{let{relatedFiles:o}=e,r=o?Ee(o):"";return`
|
|
36
23
|
<task>
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
24
|
+
<instructions>
|
|
25
|
+
${t.trim()}
|
|
26
|
+
</instructions>
|
|
27
|
+
${r}
|
|
40
28
|
</task>
|
|
41
|
-
|
|
42
|
-
${
|
|
29
|
+
`.trim()},se=(t,e)=>({system:Te(e),user:xe(t,e)});var ae="<cursor>",Me=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r}}=t,n=`<code_file>
|
|
30
|
+
${e}${ae}${o}
|
|
31
|
+
</code_file>`,s=`
|
|
32
|
+
You are an AI coding assistant. Your task is to provide code completions based on the current cursor position in the code.
|
|
33
|
+
|
|
34
|
+
Below is the code file with a special token '${ae}' indicating the current cursor position.
|
|
35
|
+
|
|
36
|
+
${n}
|
|
37
|
+
|
|
38
|
+
Please provide the code that should be inserted at the cursor position, following these guidelines:
|
|
39
|
+
|
|
40
|
+
- Carefully analyze the code context before and after the cursor to understand what code is needed.
|
|
41
|
+
- Follow best practices and maintain a consistent coding style with the existing code.
|
|
42
|
+
- Ensure the generated code integrates smoothly with the existing codebase.
|
|
43
|
+
- Do **not** include any code that is before the cursor in your response.
|
|
44
|
+
- Do **not** include any explanations, comments, or placeholders.
|
|
45
|
+
- Avoid wrapping your completion with markdown code blocks (\`\`\` or \`).
|
|
46
|
+
- Provide **only** the necessary code to be inserted at the cursor location.
|
|
47
|
+
|
|
48
|
+
Depending on the completion mode, adjust your completion accordingly:
|
|
49
|
+
|
|
50
|
+
- **Completion Mode**: ${r}
|
|
51
|
+
${{continue:"-- Continue writing the code from the current cursor location.",insert:"-- Insert the appropriate code snippet at the cursor point.",complete:"-- Supply the necessary code to finish the ongoing statement or block."}[r]||""}
|
|
52
|
+
|
|
53
|
+
Remember to output **only** the code that should be inserted at the cursor, without any additional formatting or explanations.
|
|
54
|
+
`.trim();return se(s,t)},le=Me;var V=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??G,this.model=o.model??Y,this.validateInputs()}validateInputs(){if(!N.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${E(N)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!$[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${E($[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:p,requestBody:c,headers:d}=this.prepareRequestDetails(a);try{let m=await this.sendCompletionRequest(p,c,{...d,...i});return this.processCompletionResponse(m)}catch(m){return this.handleCompletionError(m)}}generatePrompt(e,o){let r=le(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=ee(this.provider),r,n=Z(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=J(this.model,this.provider,e);return{endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return A.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&&h.warn("The `completion` property in `transformResponse` function is deprecated. Please use `text` instead."),{completion:o.text??o.completion}}else return{completion:Q(e,this.provider)}}handleCompletionError(e){return{error:h.logError(e).message,completion:null}}};var L=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(`
|
|
43
55
|
`).slice(1,-1).join(`
|
|
44
56
|
`);r=r.replace(i,s)}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
45
57
|
|
|
46
|
-
`),this}build(){return this.formattedCompletion}};var
|
|
58
|
+
`),this}build(){return this.formattedCompletion}};var D=class{constructor(e,o){this.cursorPos=e,this.mdl=o}shouldProvideCompletions(){return!ie(this.cursorPos,this.mdl)}};var S=class S{constructor(){this.cache=[]}get(e,o){return this.cache.filter(r=>this.isValidCacheItem(r,e,o))}add(e){let o=[...this.cache.slice(-(S.MAX_CACHE_SIZE-1)),e];this.cache=o}clear(){this.cache=[]}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return y(o,r).startsWith(e.textBeforeCursorInLine)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:a,endColumn:p}=n,{lineNumber:c,column:d}=o,m=c===s&&d===a,u=i.startsWith(r)&&c===s&&d>=a-r.length&&d<=p+r.length;return m||u}};S.MAX_CACHE_SIZE=10;var w=S;var Oe="application/json",pe=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await A.POST(e,o,{headers:{"Content-Type":Oe},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,p=be(t,e),d=!!s?.length?3:2,m=a?Math.floor(a/d):void 0,u=(g,f,k)=>{let O=g(t,e);return f?U(O,f,k):O},C=(g,f)=>!g||!f?g:g.map(({content:k,...O})=>({...O,content:U(k,f)})),P=u(oe,m,{from:"end"}),F=u(re,m),M=C(s,m);return{filename:r,language:n,technologies:i,relatedFiles:M,textBeforeCursor:P,textAfterCursor:F,cursorPosition:t,editorState:{completionMode:p}}},be=(t,e)=>{let o=j(t,e),r=I(t,e);return o?"insert":r.trim()?"complete":"continue"};var de=(t,e,o)=>{let r=o.match(/\n/g)?.length||0,n=e.lineNumber+r,i=te(o),s=r===0?e.column+i:i;return new t.Range(e.lineNumber,e.column,n,s)},me=t=>L.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),R=t=>({items:t,enableForwardStability:!0});var W={onTyping:300,onIdle:600,onDemand:0},Ie=t=>({onTyping:v(t,W.onTyping),onIdle:v(t,W.onIdle),onDemand:v(t,W.onDemand)}),B=new w,Ae=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:a="onIdle",endpoint:p,enableCaching:c=!0,onError:d,requestHandler:m}=s,u=a==="onDemand"?!1:c;if(!new D(o,e).shouldProvideCompletions())return R([]);if(u){let C=B.get(o,e).map(P=>({insertText:P.completion,range:P.range}));if(C.length>0)return i(),R(C)}if(r.isCancellationRequested||n)return R([]);try{let P=Ie(m??pe)[a];r.onCancellationRequested(()=>{P.cancel()});let F=ce({pos:o,mdl:e,options:s}),{completion:M}=await P({endpoint:p,body:{completionMetadata:F}});if(M){let g=me(M),f=de(t,o,g);return u&&B.add({completion:g,range:f,textBeforeCursorInLine:y(o,e)}),i(),R([{insertText:g,range:f}])}}catch(C){d?d(C):Le(C)||h.logError(C)}return R([])},Le=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,ue=Ae;var T=new WeakMap,x=null,Ce=(t,e,o)=>{x&&x.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};T.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(p,c,d,m)=>{let u=T.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return ue({monaco:t,mdl:p,pos:c,token:m,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(p=>{let c=T.get(e);if(!c)return;let d=p.keyCode===t.KeyCode.Tab||p.keyCode===t.KeyCode.RightArrow&&p.metaKey;c.isCompletionVisible&&d?(c.isCompletionAccepted=!0,c.isCompletionVisible=!1):c.isCompletionAccepted=!1});r.push(s);let a={deregister:()=>{r.forEach(p=>p.dispose()),B.clear(),T.delete(e),x=null},trigger:()=>De(e)};return x=a,a}catch(i){return o.onError?o.onError(i):h.logError(i),{deregister:()=>{r.forEach(s=>s.dispose()),T.delete(e),x=null},trigger:()=>{}}}},De=t=>{let e=T.get(t);if(!e){h.warn("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{})},we=(...t)=>(h.warn("The `registerCopilot` function is deprecated. Use `registerCompletion` instead."),Ce(...t));export{V as Copilot,Ce as registerCompletion,we as registerCopilot};
|