monacopilot 0.12.1 → 0.12.3
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 +2 -2
- package/build/index.d.ts +2 -2
- package/build/index.js +14 -14
- package/build/index.mjs +14 -14
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -80,7 +80,7 @@ app.post('/complete', async (req, res) => {
|
|
|
80
80
|
});
|
|
81
81
|
|
|
82
82
|
if (error) {
|
|
83
|
-
//
|
|
83
|
+
// Handle error if needed
|
|
84
84
|
// ...
|
|
85
85
|
res.status(500).json({completion: null, error});
|
|
86
86
|
}
|
|
@@ -415,7 +415,7 @@ There are other providers and models available. Here is a list:
|
|
|
415
415
|
| --------- | ------------------------------------------------------------------------- |
|
|
416
416
|
| Groq | `llama-3-70b` |
|
|
417
417
|
| OpenAI | `gpt-4o`, `gpt-4o-mini`, `o1-preview`, `o1-mini` |
|
|
418
|
-
| Anthropic | `claude-3
|
|
418
|
+
| Anthropic | `claude-3-5-Sonnet`, `claude-3-opus`, `claude-3-sonnet`, `claude-3-haiku` |
|
|
419
419
|
|
|
420
420
|
### Custom Model
|
|
421
421
|
|
package/build/index.d.mts
CHANGED
|
@@ -3,7 +3,7 @@ import * as monaco_editor from 'monaco-editor';
|
|
|
3
3
|
|
|
4
4
|
type OpenAIModel = 'gpt-4o' | 'gpt-4o-mini' | 'o1-preview' | 'o1-mini';
|
|
5
5
|
type GroqModel = 'llama-3-70b';
|
|
6
|
-
type AnthropicModel = 'claude-3
|
|
6
|
+
type AnthropicModel = 'claude-3-5-sonnet' | 'claude-3-opus' | 'claude-3-haiku' | 'claude-3-sonnet';
|
|
7
7
|
type CopilotModel = OpenAIModel | GroqModel | AnthropicModel;
|
|
8
8
|
type CopilotProvider = 'openai' | 'groq' | 'anthropic';
|
|
9
9
|
type PromptData = {
|
|
@@ -81,7 +81,7 @@ type CustomCopilotModelTransformResponse = (response: unknown) => {
|
|
|
81
81
|
/**
|
|
82
82
|
* @deprecated Use `text` instead. This property will be removed in a future version.
|
|
83
83
|
*/
|
|
84
|
-
completion
|
|
84
|
+
completion?: string | null;
|
|
85
85
|
};
|
|
86
86
|
|
|
87
87
|
type Monaco = typeof monaco;
|
package/build/index.d.ts
CHANGED
|
@@ -3,7 +3,7 @@ import * as monaco_editor from 'monaco-editor';
|
|
|
3
3
|
|
|
4
4
|
type OpenAIModel = 'gpt-4o' | 'gpt-4o-mini' | 'o1-preview' | 'o1-mini';
|
|
5
5
|
type GroqModel = 'llama-3-70b';
|
|
6
|
-
type AnthropicModel = 'claude-3
|
|
6
|
+
type AnthropicModel = 'claude-3-5-sonnet' | 'claude-3-opus' | 'claude-3-haiku' | 'claude-3-sonnet';
|
|
7
7
|
type CopilotModel = OpenAIModel | GroqModel | AnthropicModel;
|
|
8
8
|
type CopilotProvider = 'openai' | 'groq' | 'anthropic';
|
|
9
9
|
type PromptData = {
|
|
@@ -81,7 +81,7 @@ type CustomCopilotModelTransformResponse = (response: unknown) => {
|
|
|
81
81
|
/**
|
|
82
82
|
* @deprecated Use `text` instead. This property will be removed in a future version.
|
|
83
83
|
*/
|
|
84
|
-
completion
|
|
84
|
+
completion?: string | null;
|
|
85
85
|
};
|
|
86
86
|
|
|
87
87
|
type Monaco = typeof monaco;
|
package/build/index.js
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
"use strict";var $=Object.defineProperty;var
|
|
2
|
-
${r}`),{message:o,stack:r}}warn(e){console.warn(`${
|
|
3
|
-
`)
|
|
4
|
-
`),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(a=>a==="")?`
|
|
1
|
+
"use strict";var $=Object.defineProperty;var he=Object.getOwnPropertyDescriptor;var fe=Object.getOwnPropertyNames;var Pe=Object.prototype.hasOwnProperty;var ye=(t,e)=>{for(var o in e)$(t,o,{get:e[o],enumerable:!0})},Re=(t,e,o,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of fe(e))!Pe.call(t,n)&&n!==o&&$(t,n,{get:()=>e[n],enumerable:!(r=he(e,n))||r.enumerable});return t};var Te=t=>Re($({},"__esModule",{value:!0}),t);var qe={};ye(qe,{Copilot:()=>D,registerCompletion:()=>Y,registerCopilot:()=>ge});module.exports=Te(qe);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-20241022","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"},v=.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:V(t),temperature:v,messages:r}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Ee={createRequestBody:(t,e)=>({model:V(t),temperature:v,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},Me={createRequestBody:(t,e)=>({model:V(t),temperature:v,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:Oe(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:Ee,anthropic:Me},Q=(t,e,o)=>_[e].createRequestBody(t,o),ee=(t,e)=>_[e].createHeaders(t),te=(t,e)=>_[e].parseCompletion(t),V=t=>G[t],oe=t=>J[t],Oe=t=>Z[t]||4096;var m=class m{constructor(){}static getInstance(){return m.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=`${m.RED}${m.BOLD}[MONACOPILOT ERROR] ${o}${m.RESET}`;return console.error(n),r&&console.error(`${m.RED}[MONACOPILOT ERROR] Stack trace:${m.RESET}
|
|
2
|
+
${r}`),{message:o,stack:r}}warn(e){console.warn(`${m.YELLOW}${m.BOLD}[MONACOPILOT WARN] ${e}${m.RESET}`)}log(e){console.log(`${m.BOLD}[MONACOPILOT] ${e}${m.RESET}`)}};m.instance=new m,m.RED="\x1B[31m",m.YELLOW="\x1B[33m",m.RESET="\x1B[0m",m.BOLD="\x1B[1m";var j=m,h=j.getInstance();var I=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,d)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=d,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 U=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var A=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),re=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),P=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),ne=(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(`
|
|
3
|
+
`),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(d=>d==="")?`
|
|
5
4
|
`.repeat(e):s.join(`
|
|
6
5
|
`)}let i=r.slice(0,e);return i.every(s=>s==="")?`
|
|
7
6
|
`.repeat(e):i.join(`
|
|
8
|
-
`)};var
|
|
9
|
-
${
|
|
10
|
-
|
|
7
|
+
`)};var ie=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()},be=(t,e)=>ie(t,"GET",e),ve=(t,e,o)=>ie(t,"POST",{...o,body:e}),w={GET:be,POST:ve};var se=(t,e)=>{let o=A(t,e).trim(),r=re(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var Ie=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n}=t,i=E([n,...e].filter(c=>typeof c=="string"&&!!c)),s=`You are an expert ${i?`${i} `:""}developer assistant.`,d="Your task is to provide precise and contextually relevant code completions, modifications, or generations",a=o?`for the file '${o}'`:"",l=r&&r.length>0?"Consider the context of the current and related files provided.":"",u="Ensure that your responses integrate seamlessly with the existing code and maintain consistency with the project's style and conventions.",C="Before providing the completion or modification, think through the problem step-by-step, considering best practices and any potential edge cases.",p=n?`Pay special attention to ${n}-specific syntax and best practices.`:"";return`${s}
|
|
8
|
+
${d} ${a}.
|
|
9
|
+
${u}
|
|
10
|
+
${l}
|
|
11
11
|
${p}
|
|
12
|
-
|
|
12
|
+
${C}`.trim()},Ae=t=>t?.length?t.map(({path:e,content:o})=>`
|
|
13
13
|
<related_file>
|
|
14
14
|
<path>${e}</path>
|
|
15
15
|
<content>
|
|
@@ -19,19 +19,19 @@ ${o}
|
|
|
19
19
|
</content>
|
|
20
20
|
</related_file>
|
|
21
21
|
`.trim()).join(`
|
|
22
|
-
`):"",
|
|
22
|
+
`):"",we=(t="",e)=>{let{relatedFiles:o}=e,r=o?Ae(o):"";return`
|
|
23
23
|
<task>
|
|
24
24
|
<instructions>
|
|
25
25
|
${t.trim()}
|
|
26
26
|
</instructions>
|
|
27
27
|
${r}
|
|
28
28
|
</task>
|
|
29
|
-
`.trim()},
|
|
30
|
-
${e}${
|
|
29
|
+
`.trim()},ae=(t,e)=>({system:Ie(e),user:we(t,e)});var le="<cursor>",De=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r}}=t,n=`<code_file>
|
|
30
|
+
${e}${le}${o}
|
|
31
31
|
</code_file>`,s=`
|
|
32
32
|
You are an AI coding assistant. Your task is to provide code completions based on the current cursor position in the code.
|
|
33
33
|
|
|
34
|
-
Below is the code file with a special token '${
|
|
34
|
+
Below is the code file with a special token '${le}' indicating the current cursor position.
|
|
35
35
|
|
|
36
36
|
${n}
|
|
37
37
|
|
|
@@ -51,8 +51,8 @@ Depending on the completion mode, adjust your completion accordingly:
|
|
|
51
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
52
|
|
|
53
53
|
Remember to output **only** the code that should be inserted at the cursor, without any additional formatting or explanations.
|
|
54
|
-
`.trim();return
|
|
54
|
+
`.trim();return ae(s,t)},pe=De;var D=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??{},d=this.generatePrompt(n,s),{endpoint:a,requestBody:l,headers:u}=this.prepareRequestDetails(d);try{let C=await this.sendCompletionRequest(a,l,{...u,...i});return this.processCompletionResponse(C)}catch(C){return this.handleCompletionError(C)}}generatePrompt(e,o){let r=pe(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 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&&h.warn("The `completion` property in `transformResponse` function is deprecated. Please use `text` instead."),{completion:o.text??o.completion??null}}else return{completion:te(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(`
|
|
55
55
|
`).slice(1,-1).join(`
|
|
56
56
|
`);r=r.replace(i,s)}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
57
57
|
|
|
58
|
-
`),this}build(){return this.formattedCompletion}};var
|
|
58
|
+
`),this}build(){return this.formattedCompletion}};var S=class{constructor(e,o){this.cursorPos=e,this.mdl=o}shouldProvideCompletions(){return!se(this.cursorPos,this.mdl)}};var k=class k{constructor(){this.cache=[]}get(e,o){return this.cache.filter(r=>this.isValidCacheItem(r,e,o))}add(e){let o=[...this.cache.slice(-(k.MAX_CACHE_SIZE-1)),e];this.cache=o}clear(){this.cache=[]}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return P(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:d,endColumn:a}=n,{lineNumber:l,column:u}=o,C=l===s&&u===d,p=i.startsWith(r)&&l===s&&u>=d-r.length&&u<=a+r.length;return C||p}};k.MAX_CACHE_SIZE=10;var B=k;var Le="application/json",ce=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await w.POST(e,o,{headers:{"Content-Type":Le},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return{completion:r}},de=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:d}=o,a=Se(t,e),u=!!s?.length?3:2,C=d?Math.floor(d/u):void 0,p=(f,x,N)=>{let b=f(t,e);return x?W(b,x,N):b},g=(f,x)=>!f||!x?f:f.map(({content:N,...b})=>({...b,content:W(N,x)})),c=p(P,C,{from:"end"}),O=p(ne,C),T=g(s,C);return{filename:r,language:n,technologies:i,relatedFiles:T,textBeforeCursor:c,textAfterCursor:O,cursorPosition:t,editorState:{completionMode:a}}},Se=(t,e)=>{let o=U(t,e),r=A(t,e);return o?"insert":r.trim()?"complete":"continue"};var me=(t,e,o,r)=>{if(!r)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=o.getOffsetAt(e),i=o.getValue().substring(n),s=0,d=0,a=0,l=r.length,u=i.length;if(n>=o.getValue().length)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(u===0)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);let C=Math.min(l,u);for(let c=0;c<C&&r[c]===i[c];c++)s++;for(let c=1;c<=C;c++)r.slice(-c)===i.slice(0,c)&&(d=c);if(a=Math.max(s,d),a===0){for(let c=1;c<l;c++)if(i.startsWith(r.substring(c))){a=l-c;break}}let p=n+a,g=o.getPositionAt(p);return new t.Range(e.lineNumber,e.column,g.lineNumber,g.column)},ue=t=>L.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),y=t=>({items:t,enableForwardStability:!0});var K={onTyping:300,onIdle:600,onDemand:0},ke=t=>({onTyping:I(t,K.onTyping),onIdle:I(t,K.onIdle),onDemand:I(t,K.onDemand)}),F=new B,Fe=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:d="onIdle",endpoint:a,enableCaching:l=!0,onError:u,requestHandler:C}=s;if(!new S(o,e).shouldProvideCompletions())return y([]);if(l){let p=F.get(o,e).map(g=>({insertText:g.completion,range:g.range}));if(p.length>0)return i(),y(p)}if(r.isCancellationRequested||n)return y([]);try{let g=ke(C??ce)[d];r.onCancellationRequested(()=>{g.cancel()});let c=de({pos:o,mdl:e,options:s}),{completion:O}=await g({endpoint:a,body:{completionMetadata:c}});if(O){let T=ue(O),f=me(t,o,e,T);return l&&F.add({completion:T,range:f,textBeforeCursor:P(o,e)}),i(),y([{insertText:T,range:f}])}}catch(p){u?u(p):Ne(p)||h.logError(p)}return y([])},Ne=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,Ce=Fe;var R=new WeakMap,M=null,Y=(t,e,o)=>{M&&M.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:(a,l,u,C)=>{let p=R.get(e);if(!(!p||o.trigger==="onDemand"&&!p.isManualTrigger))return Ce({monaco:t,mdl:a,pos:l,token:C,isCompletionAccepted:p.isCompletionAccepted,onShowCompletion:()=>{p.isCompletionVisible=!0,p.isManualTrigger=!1},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(a=>{let l=R.get(e);if(!l)return;let u=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;l.isCompletionVisible&&u?(l.isCompletionAccepted=!0,l.isCompletionVisible=!1):l.isCompletionAccepted=!1});r.push(s);let d={deregister:()=>{r.forEach(a=>a.dispose()),F.clear(),R.delete(e),M=null},trigger:()=>$e(e)};return M=d,d}catch(i){return o.onError?o.onError(i):h.logError(i),{deregister:()=>{r.forEach(s=>s.dispose()),R.delete(e),M=null},trigger:()=>{}}}},$e=t=>{let e=R.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",{})},ge=(...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,15 +1,15 @@
|
|
|
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
|
|
2
|
-
${r}`),{message:o,stack:r}}warn(e){console.warn(`${
|
|
3
|
-
`)
|
|
4
|
-
`),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(a=>a==="")?`
|
|
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-20241022","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"},v=.1;var z={"claude-3-5-sonnet":8192,"claude-3-opus":4096,"claude-3-haiku":4096,"claude-3-sonnet":4096};var Ce={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:v,messages:r}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},ge={createRequestBody:(t,e)=>({model:H(t),temperature:v,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},he={createRequestBody:(t,e)=>({model:H(t),temperature:v,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:fe(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:Ce,groq:ge,anthropic:he},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],fe=t=>z[t]||4096;var m=class m{constructor(){}static getInstance(){return m.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=`${m.RED}${m.BOLD}[MONACOPILOT ERROR] ${o}${m.RESET}`;return console.error(n),r&&console.error(`${m.RED}[MONACOPILOT ERROR] Stack trace:${m.RESET}
|
|
2
|
+
${r}`),{message:o,stack:r}}warn(e){console.warn(`${m.YELLOW}${m.BOLD}[MONACOPILOT WARN] ${e}${m.RESET}`)}log(e){console.log(`${m.BOLD}[MONACOPILOT] ${e}${m.RESET}`)}};m.instance=new m,m.RED="\x1B[31m",m.YELLOW="\x1B[33m",m.RESET="\x1B[0m",m.BOLD="\x1B[1m";var _=m,h=_.getInstance();var I=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,d)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=d,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];var A=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),te=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),P=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),oe=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())}),j=(t,e,o={})=>{if(e<=0)return"";let r=t.split(`
|
|
3
|
+
`),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(d=>d==="")?`
|
|
5
4
|
`.repeat(e):s.join(`
|
|
6
5
|
`)}let i=r.slice(0,e);return i.every(s=>s==="")?`
|
|
7
6
|
`.repeat(e):i.join(`
|
|
8
|
-
`)};var
|
|
9
|
-
${
|
|
10
|
-
|
|
7
|
+
`)};var re=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()},Pe=(t,e)=>re(t,"GET",e),ye=(t,e,o)=>re(t,"POST",{...o,body:e}),w={GET:Pe,POST:ye};var ne=(t,e)=>{let o=A(t,e).trim(),r=te(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var Re=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n}=t,i=E([n,...e].filter(c=>typeof c=="string"&&!!c)),s=`You are an expert ${i?`${i} `:""}developer assistant.`,d="Your task is to provide precise and contextually relevant code completions, modifications, or generations",a=o?`for the file '${o}'`:"",l=r&&r.length>0?"Consider the context of the current and related files provided.":"",u="Ensure that your responses integrate seamlessly with the existing code and maintain consistency with the project's style and conventions.",C="Before providing the completion or modification, think through the problem step-by-step, considering best practices and any potential edge cases.",p=n?`Pay special attention to ${n}-specific syntax and best practices.`:"";return`${s}
|
|
8
|
+
${d} ${a}.
|
|
9
|
+
${u}
|
|
10
|
+
${l}
|
|
11
11
|
${p}
|
|
12
|
-
|
|
12
|
+
${C}`.trim()},Te=t=>t?.length?t.map(({path:e,content:o})=>`
|
|
13
13
|
<related_file>
|
|
14
14
|
<path>${e}</path>
|
|
15
15
|
<content>
|
|
@@ -19,19 +19,19 @@ ${o}
|
|
|
19
19
|
</content>
|
|
20
20
|
</related_file>
|
|
21
21
|
`.trim()).join(`
|
|
22
|
-
`):"",xe=(t="",e)=>{let{relatedFiles:o}=e,r=o?
|
|
22
|
+
`):"",xe=(t="",e)=>{let{relatedFiles:o}=e,r=o?Te(o):"";return`
|
|
23
23
|
<task>
|
|
24
24
|
<instructions>
|
|
25
25
|
${t.trim()}
|
|
26
26
|
</instructions>
|
|
27
27
|
${r}
|
|
28
28
|
</task>
|
|
29
|
-
`.trim()},
|
|
30
|
-
${e}${
|
|
29
|
+
`.trim()},ie=(t,e)=>({system:Re(e),user:xe(t,e)});var se="<cursor>",Ee=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r}}=t,n=`<code_file>
|
|
30
|
+
${e}${se}${o}
|
|
31
31
|
</code_file>`,s=`
|
|
32
32
|
You are an AI coding assistant. Your task is to provide code completions based on the current cursor position in the code.
|
|
33
33
|
|
|
34
|
-
Below is the code file with a special token '${
|
|
34
|
+
Below is the code file with a special token '${se}' indicating the current cursor position.
|
|
35
35
|
|
|
36
36
|
${n}
|
|
37
37
|
|
|
@@ -51,8 +51,8 @@ Depending on the completion mode, adjust your completion accordingly:
|
|
|
51
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
52
|
|
|
53
53
|
Remember to output **only** the code that should be inserted at the cursor, without any additional formatting or explanations.
|
|
54
|
-
`.trim();return
|
|
54
|
+
`.trim();return ie(s,t)},ae=Ee;var U=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??{},d=this.generatePrompt(n,s),{endpoint:a,requestBody:l,headers:u}=this.prepareRequestDetails(d);try{let C=await this.sendCompletionRequest(a,l,{...u,...i});return this.processCompletionResponse(C)}catch(C){return this.handleCompletionError(C)}}generatePrompt(e,o){let r=ae(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 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&&h.warn("The `completion` property in `transformResponse` function is deprecated. Please use `text` instead."),{completion:o.text??o.completion??null}}else return{completion:Q(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(`
|
|
55
55
|
`).slice(1,-1).join(`
|
|
56
56
|
`);r=r.replace(i,s)}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
57
57
|
|
|
58
|
-
`),this}build(){return this.formattedCompletion}};var
|
|
58
|
+
`),this}build(){return this.formattedCompletion}};var L=class{constructor(e,o){this.cursorPos=e,this.mdl=o}shouldProvideCompletions(){return!ne(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 P(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:d,endColumn:a}=n,{lineNumber:l,column:u}=o,C=l===s&&u===d,p=i.startsWith(r)&&l===s&&u>=d-r.length&&u<=a+r.length;return C||p}};B.MAX_CACHE_SIZE=10;var S=B;var Me="application/json",le=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await w.POST(e,o,{headers:{"Content-Type":Me},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return{completion:r}},pe=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:d}=o,a=Oe(t,e),u=!!s?.length?3:2,C=d?Math.floor(d/u):void 0,p=(f,x,F)=>{let b=f(t,e);return x?j(b,x,F):b},g=(f,x)=>!f||!x?f:f.map(({content:F,...b})=>({...b,content:j(F,x)})),c=p(P,C,{from:"end"}),O=p(oe,C),T=g(s,C);return{filename:r,language:n,technologies:i,relatedFiles:T,textBeforeCursor:c,textAfterCursor:O,cursorPosition:t,editorState:{completionMode:a}}},Oe=(t,e)=>{let o=V(t,e),r=A(t,e);return o?"insert":r.trim()?"complete":"continue"};var ce=(t,e,o,r)=>{if(!r)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=o.getOffsetAt(e),i=o.getValue().substring(n),s=0,d=0,a=0,l=r.length,u=i.length;if(n>=o.getValue().length)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(u===0)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);let C=Math.min(l,u);for(let c=0;c<C&&r[c]===i[c];c++)s++;for(let c=1;c<=C;c++)r.slice(-c)===i.slice(0,c)&&(d=c);if(a=Math.max(s,d),a===0){for(let c=1;c<l;c++)if(i.startsWith(r.substring(c))){a=l-c;break}}let p=n+a,g=o.getPositionAt(p);return new t.Range(e.lineNumber,e.column,g.lineNumber,g.column)},de=t=>D.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),y=t=>({items:t,enableForwardStability:!0});var W={onTyping:300,onIdle:600,onDemand:0},ve=t=>({onTyping:I(t,W.onTyping),onIdle:I(t,W.onIdle),onDemand:I(t,W.onDemand)}),k=new S,Ie=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:d="onIdle",endpoint:a,enableCaching:l=!0,onError:u,requestHandler:C}=s;if(!new L(o,e).shouldProvideCompletions())return y([]);if(l){let p=k.get(o,e).map(g=>({insertText:g.completion,range:g.range}));if(p.length>0)return i(),y(p)}if(r.isCancellationRequested||n)return y([]);try{let g=ve(C??le)[d];r.onCancellationRequested(()=>{g.cancel()});let c=pe({pos:o,mdl:e,options:s}),{completion:O}=await g({endpoint:a,body:{completionMetadata:c}});if(O){let T=de(O),f=ce(t,o,e,T);return l&&k.add({completion:T,range:f,textBeforeCursor:P(o,e)}),i(),y([{insertText:T,range:f}])}}catch(p){u?u(p):Ae(p)||h.logError(p)}return y([])},Ae=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,me=Ie;var R=new WeakMap,M=null,ue=(t,e,o)=>{M&&M.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:(a,l,u,C)=>{let p=R.get(e);if(!(!p||o.trigger==="onDemand"&&!p.isManualTrigger))return me({monaco:t,mdl:a,pos:l,token:C,isCompletionAccepted:p.isCompletionAccepted,onShowCompletion:()=>{p.isCompletionVisible=!0,p.isManualTrigger=!1},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(a=>{let l=R.get(e);if(!l)return;let u=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;l.isCompletionVisible&&u?(l.isCompletionAccepted=!0,l.isCompletionVisible=!1):l.isCompletionAccepted=!1});r.push(s);let d={deregister:()=>{r.forEach(a=>a.dispose()),k.clear(),R.delete(e),M=null},trigger:()=>we(e)};return M=d,d}catch(i){return o.onError?o.onError(i):h.logError(i),{deregister:()=>{r.forEach(s=>s.dispose()),R.delete(e),M=null},trigger:()=>{}}}},we=t=>{let e=R.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",{})},De=(...t)=>(h.warn("The `registerCopilot` function is deprecated. Use `registerCompletion` instead."),ue(...t));export{U as Copilot,ue as registerCompletion,De as registerCopilot};
|