monacopilot 0.18.0 → 0.18.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/build/index.d.mts +12 -13
- package/build/index.d.ts +12 -13
- package/build/index.js +17 -17
- package/build/index.mjs +17 -17
- package/package.json +1 -1
package/build/index.d.mts
CHANGED
|
@@ -229,8 +229,9 @@ interface CompletionRegistration {
|
|
|
229
229
|
*/
|
|
230
230
|
trigger: () => void;
|
|
231
231
|
/**
|
|
232
|
-
* Deregisters the completion
|
|
233
|
-
* This should be called when the
|
|
232
|
+
* Deregisters the completion provider and cleans up all associated resources.
|
|
233
|
+
* This should be called when unmounting the editor or when completion features
|
|
234
|
+
* are no longer needed to prevent memory leaks and ensure proper cleanup.
|
|
234
235
|
*/
|
|
235
236
|
deregister: () => void;
|
|
236
237
|
}
|
|
@@ -332,13 +333,20 @@ interface FetchCompletionItemParams {
|
|
|
332
333
|
body: CompletionRequestBody;
|
|
333
334
|
}
|
|
334
335
|
|
|
336
|
+
/**
|
|
337
|
+
* Registers completion functionality with the Monaco editor.
|
|
338
|
+
* @param monaco - The Monaco instance.
|
|
339
|
+
* @param editor - The editor instance.
|
|
340
|
+
* @param options - Options for the completion.
|
|
341
|
+
* @returns A CompletionRegistration object with deregister and trigger methods.
|
|
342
|
+
*/
|
|
343
|
+
declare const registerCompletion: (monaco: Monaco, editor: StandaloneCodeEditor, options: RegisterCompletionOptions) => CompletionRegistration;
|
|
344
|
+
|
|
335
345
|
declare class Copilot {
|
|
336
346
|
private readonly apiKey;
|
|
337
347
|
private provider;
|
|
338
348
|
private model;
|
|
339
349
|
constructor(apiKey: string, options: CopilotOptions);
|
|
340
|
-
private validateParams;
|
|
341
|
-
private validateInputs;
|
|
342
350
|
complete(request: CompletionRequest): Promise<CompletionResponse>;
|
|
343
351
|
private generatePrompt;
|
|
344
352
|
private prepareRequestDetails;
|
|
@@ -347,13 +355,4 @@ declare class Copilot {
|
|
|
347
355
|
private handleCompletionError;
|
|
348
356
|
}
|
|
349
357
|
|
|
350
|
-
/**
|
|
351
|
-
* Registers completion functionality with the Monaco editor.
|
|
352
|
-
* @param monaco - The Monaco instance.
|
|
353
|
-
* @param editor - The editor instance.
|
|
354
|
-
* @param options - Options for the completion.
|
|
355
|
-
* @returns A CompletionRegistration object with deregister and trigger methods.
|
|
356
|
-
*/
|
|
357
|
-
declare const registerCompletion: (monaco: Monaco, editor: StandaloneCodeEditor, options: RegisterCompletionOptions) => CompletionRegistration;
|
|
358
|
-
|
|
359
358
|
export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type CopilotOptions, type CustomCopilotModel, type CustomCopilotModelConfig, type CustomCopilotModelTransformResponse, type DeepSeekChatCompletion, type GroqChatCompletion, type GroqModel, type Model, type Monaco, type OpenAIChatCompletion, type OpenAIModel, type Provider, type RegisterCompletionOptions, type StandaloneCodeEditor, registerCompletion };
|
package/build/index.d.ts
CHANGED
|
@@ -229,8 +229,9 @@ interface CompletionRegistration {
|
|
|
229
229
|
*/
|
|
230
230
|
trigger: () => void;
|
|
231
231
|
/**
|
|
232
|
-
* Deregisters the completion
|
|
233
|
-
* This should be called when the
|
|
232
|
+
* Deregisters the completion provider and cleans up all associated resources.
|
|
233
|
+
* This should be called when unmounting the editor or when completion features
|
|
234
|
+
* are no longer needed to prevent memory leaks and ensure proper cleanup.
|
|
234
235
|
*/
|
|
235
236
|
deregister: () => void;
|
|
236
237
|
}
|
|
@@ -332,13 +333,20 @@ interface FetchCompletionItemParams {
|
|
|
332
333
|
body: CompletionRequestBody;
|
|
333
334
|
}
|
|
334
335
|
|
|
336
|
+
/**
|
|
337
|
+
* Registers completion functionality with the Monaco editor.
|
|
338
|
+
* @param monaco - The Monaco instance.
|
|
339
|
+
* @param editor - The editor instance.
|
|
340
|
+
* @param options - Options for the completion.
|
|
341
|
+
* @returns A CompletionRegistration object with deregister and trigger methods.
|
|
342
|
+
*/
|
|
343
|
+
declare const registerCompletion: (monaco: Monaco, editor: StandaloneCodeEditor, options: RegisterCompletionOptions) => CompletionRegistration;
|
|
344
|
+
|
|
335
345
|
declare class Copilot {
|
|
336
346
|
private readonly apiKey;
|
|
337
347
|
private provider;
|
|
338
348
|
private model;
|
|
339
349
|
constructor(apiKey: string, options: CopilotOptions);
|
|
340
|
-
private validateParams;
|
|
341
|
-
private validateInputs;
|
|
342
350
|
complete(request: CompletionRequest): Promise<CompletionResponse>;
|
|
343
351
|
private generatePrompt;
|
|
344
352
|
private prepareRequestDetails;
|
|
@@ -347,13 +355,4 @@ declare class Copilot {
|
|
|
347
355
|
private handleCompletionError;
|
|
348
356
|
}
|
|
349
357
|
|
|
350
|
-
/**
|
|
351
|
-
* Registers completion functionality with the Monaco editor.
|
|
352
|
-
* @param monaco - The Monaco instance.
|
|
353
|
-
* @param editor - The editor instance.
|
|
354
|
-
* @param options - Options for the completion.
|
|
355
|
-
* @returns A CompletionRegistration object with deregister and trigger methods.
|
|
356
|
-
*/
|
|
357
|
-
declare const registerCompletion: (monaco: Monaco, editor: StandaloneCodeEditor, options: RegisterCompletionOptions) => CompletionRegistration;
|
|
358
|
-
|
|
359
358
|
export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type CopilotOptions, type CustomCopilotModel, type CustomCopilotModelConfig, type CustomCopilotModelTransformResponse, type DeepSeekChatCompletion, type GroqChatCompletion, type GroqModel, type Model, type Monaco, type OpenAIChatCompletion, type OpenAIModel, type Provider, type RegisterCompletionOptions, type StandaloneCodeEditor, registerCompletion };
|
package/build/index.js
CHANGED
|
@@ -1,12 +1,21 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var ve="\x1B[91m",re="\x1B[93m",W="\x1B[0m",G="\x1B[1m",ne=o=>o instanceof Error?o.message:typeof o=="string"?o:"An unknown error occurred",S=o=>{let e=ne(o),t=`${ve}${G}[MONACOPILOT ERROR] ${e}${W}`;return console.error(t),{message:e}},v=(o,e)=>{console.warn(`${re}${G}[MONACOPILOT WARN] ${o}${e?`
|
|
4
|
+
${ne(e)}`:""}${W}`);};var ie=(o,e,t)=>console.warn(`${re}${G}[MONACOPILOT DEPRECATED] "${o}" is deprecated${` in ${t}`}. Please use "${e}" instead. It will be removed in a future version.${W}`);var w=class{constructor(e,t,r){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=t,this.textBeforeCursorInLine=r;}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}indentByColumn(){let e=this.formattedCompletion.split(`
|
|
5
|
+
`);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let t=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
|
|
6
|
+
`+e.slice(1).map(r=>t+r).join(`
|
|
7
|
+
`),this}removeMarkdownCodeBlocks(e){let t=/```[\s\S]*?```/g,r=e,n;for(;(n=t.exec(e))!==null;){let i=n[0],s=i.split(`
|
|
8
|
+
`).slice(1,-1).join(`
|
|
9
|
+
`);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
10
|
+
|
|
11
|
+
`),this}build(){return this.formattedCompletion}};var L=class{constructor(e){this.monaco=e;}computeInsertionRange(e,t,r){if(!t)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=r.getOffsetAt(e),i=r.getValue().substring(0,n),s=r.getValue().substring(n),l=0,p=0,d=0,c=0,a=t.length,u=i.length,f=s.length;if(n>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(f===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let x=Math.min(a,u);for(let m=1;m<=x;m++){let b=t.substring(0,m),be=i.slice(-m);b===be&&(c=m);}let C=Math.min(a,f);for(let m=0;m<C&&t[m]===s[m];m++)l++;for(let m=1;m<=C;m++)t.slice(-m)===s.slice(0,m)&&(p=m);if(d=Math.max(l,p),d===0){for(let m=1;m<a;m++)if(s.startsWith(t.substring(m))){d=a-m;break}}let T=c>0?r.getPositionAt(n-c):e,R=n+d,h=r.getPositionAt(R);return new this.monaco.Range(T.lineNumber,T.column,h.lineNumber,h.column)}computeCacheRange(e,t){let r=e.lineNumber,n=e.column,i=t.split(`
|
|
12
|
+
`),s=i.length-1,l=r+s,p=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,l,p)}};var se=(o,e)=>e.getLineContent(o.lineNumber)[o.column-1];var ae=(o,e)=>e.getLineContent(o.lineNumber).slice(0,o.column-1),O=(o,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:o.lineNumber,endColumn:o.column}),X=(o,e)=>e.getValueInRange({startLineNumber:o.lineNumber,startColumn:o.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var N=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let t;return this.size===this.capacity&&(t=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,t}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 B=class B{constructor(){this.cache=new N(B.MAX_CACHE_SIZE);}get(e,t){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,t))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,t,r){let n=r.getValueInRange(e.range),i=O(t,r);return i.length<e.textBeforeCursor.length||!i.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,t,n)}isPositionValid(e,t,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:l,endLineNumber:p,endColumn:d}=n,{lineNumber:c,column:a}=t;if(!i.startsWith(r))return !1;let u=c===s&&a===l;if(s===p)return u||c===s&&a>=l&&a<=d;let f=c>s&&c<p?!0:c===s&&a>=l||c===p&&a<=d;return u||f}};B.MAX_CACHE_SIZE=10;var _=B;var A=o=>!o||o.length===0?"":o.length===1?o[0]:`${o.slice(0,-1).join(", ")} and ${o.slice(-1)}`,le=o=>o.charAt(0).toUpperCase()+o.slice(1),Y=(o,e,t={})=>{if(e<=0)return "";let r=o.split(`
|
|
4
13
|
`),n=r.length;if(e>=n)return o;if(t.from==="end"){let s=r.slice(-e);return s.every(l=>l==="")?`
|
|
5
14
|
`.repeat(e):s.join(`
|
|
6
15
|
`)}let i=r.slice(0,e);return i.every(s=>s==="")?`
|
|
7
16
|
`.repeat(e):i.join(`
|
|
8
|
-
`)};var
|
|
9
|
-
${JSON.stringify(d,null,2)}`:"",a=t.fallbackError||"Network request failed";throw new Error(`${a} (${p.status})${c}`)}return p.json()},
|
|
17
|
+
`)};var pe=async(o,e,t={})=>{let r=t.timeout??3e4,n=AbortSignal.timeout(r),i=t.signal?AbortSignal.any([n,t.signal]):n,s={"Content-Type":"application/json",...t.headers},l=e==="POST"&&t.body?JSON.stringify(t.body):void 0,p=await fetch(o,{method:e,headers:s,body:l,signal:i});if(!p.ok){let d=await p.json().catch(()=>null),c=d?`
|
|
18
|
+
${JSON.stringify(d,null,2)}`:"",a=t.fallbackError||"Network request failed";throw new Error(`${a} (${p.status})${c}`)}return p.json()},Oe=(o,e)=>pe(o,"GET",e),Ie=(o,e,t)=>pe(o,"POST",{...t,body:e}),F={GET:Oe,POST:Ie};var q=(o,e=600,t=200)=>{let r=null,n=0,i=null,s=null,l=!1,p=(...d)=>{if(l)return Promise.resolve(void 0);i=d;let c=Date.now(),a=c-n;n=c,r&&(clearTimeout(r),r=null);let u=a<t?e:t;return s=new Promise((f,x)=>{r=setTimeout(async()=>{l=!0;try{if(i){let C=await o(...i);f(C);}else f(void 0);}catch(C){x(C);}finally{l=!1,r=null,i=null;}},u);}),s};return p.cancel=()=>{r&&(clearTimeout(r),r=null),i=null;},p};var Ae="application/json",me=async o=>{let{endpoint:e,body:t}=o,{completion:r,error:n}=await F.POST(e,t,{headers:{"Content-Type":Ae},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},ce=({pos:o,mdl:e,options:t})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:l}=t,p=ke(o,e),c=!!s?.length?3:2,a=l?Math.floor(l/c):void 0,u=(R,h,m)=>{let b=R(o,e);return h?Y(b,h,m):b},f=(R,h)=>!R||!h?R:R.map(({content:m,...b})=>({...b,content:Y(m,h)})),x=u(O,a,{from:"end"}),C=u(X,a),T=f(s,a);return {filename:r,language:n,technologies:i,relatedFiles:T,textBeforeCursor:x,textAfterCursor:C,cursorPosition:o,editorState:{completionMode:p}}},ke=(o,e)=>{let t=se(o,e),r=X(o,e);return t?"insert":r.trim()?"complete":"continue"};var I=o=>({items:o,enableForwardStability:!0,suppressSuggestions:!0});var Se=o=>({onTyping:q(o,600,200),onIdle:q(o,600,400),onDemand:q(o,0,0)}),$=new _,de=async({monaco:o,mdl:e,pos:t,token:r,isCompletionAccepted:n,options:i})=>{let{trigger:s="onIdle",endpoint:l,enableCaching:p=!0,onError:d,requestHandler:c}=i;if(p){let a=$.get(t,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return I(a)}if(r.isCancellationRequested||n)return I([]);try{let u=Se(c??me)[s];r.onCancellationRequested(()=>{u.cancel();});let f=ce({pos:t,mdl:e,options:i}),{completion:x}=await u({endpoint:l,body:{completionMetadata:f}});if(x){let C=new w(x,t.column,ae(t,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),T=new L(o),R=T.computeInsertionRange(t,C,e),h=T.computeCacheRange(t,C);return p&&$.add({completion:C,range:h,textBeforeCursor:O(t,e)}),I([{insertText:C,range:R}])}}catch(a){if(we(a))return I([]);d?d(a):v("Cannot provide completion",a);}return I([])},we=o=>typeof o=="string"?o==="Cancelled"||o==="AbortError":o instanceof Error?o.message==="Cancelled"||o.name==="AbortError":!1;var J=new WeakMap,k=o=>J.get(o),ue=(o,e)=>{J.set(o,e);},Z=o=>{J.delete(o);},Ce=()=>({isCompletionAccepted:!1,isCompletionVisible:!1,isExplicitlyTriggered:!1,hasRejectedCurrentCompletion:!1});var ge=(o,e,t)=>{let r=k(e);return r?o.languages.registerInlineCompletionsProvider(t.language,{provideInlineCompletions:(n,i,s,l)=>{if(!(t.trigger==="onDemand"&&!r.isExplicitlyTriggered))return de({monaco:o,mdl:n,pos:i,token:l,isCompletionAccepted:r.isCompletionAccepted,options:t})},handleItemDidShow:(n,i,s)=>{r.isExplicitlyTriggered=!1,r.hasRejectedCurrentCompletion=!1,!r.isCompletionAccepted&&(r.isCompletionVisible=!0,t.onCompletionShown?.(s,i.range));},freeInlineCompletions:()=>{}}):null},fe=o=>{let e=k(o);if(!e){v("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isExplicitlyTriggered=!0,o.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};var Le={TAB:(o,e)=>e.keyCode===o.KeyCode.Tab,CMD_RIGHT_ARROW:(o,e)=>e.keyCode===o.KeyCode.RightArrow&&e.metaKey},Q=class{constructor(e,t,r){this.monaco=e;this.state=t;this.options=r;}handleKeyEvent(e){let t={monaco:this.monaco,event:e,state:this.state,options:this.options};this.handleCompletionAcceptance(t),this.handleCompletionRejection(t);}handleCompletionAcceptance(e){return e.state.isCompletionVisible&&this.isAcceptanceKey(e.event)?(e.options.onCompletionAccepted?.(),e.state.isCompletionAccepted=!0,e.state.isCompletionVisible=!1,!0):(e.state.isCompletionAccepted=!1,!1)}handleCompletionRejection(e){return this.shouldRejectCompletion(e)?(e.options.onCompletionRejected?.(),e.state.hasRejectedCurrentCompletion=!0,!0):!1}shouldRejectCompletion(e){return e.state.isCompletionVisible&&!e.state.hasRejectedCurrentCompletion&&!e.state.isCompletionAccepted&&!this.isAcceptanceKey(e.event)}isAcceptanceKey(e){return Object.values(Le).some(t=>t(this.monaco,e))}},he=(o,e,t,r)=>{let n=new Q(o,t,r);return e.onKeyDown(i=>n.handleKeyEvent(i))};var D=null,Ne=(o,e,t)=>{D&&D.deregister();let r=[];ue(e,Ce()),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let n=k(e);if(!n)return v("Completion is not registered properly. State not found."),_e();let i=ge(o,e,t);i&&r.push(i);let s=he(o,e,n,t);r.push(s);let l={deregister:()=>{r.forEach(p=>p.dispose()),$.clear(),Z(e),D=null;},trigger:()=>fe(e)};return D=l,l}catch(n){return t.onError?t.onError(n):S(n),{deregister:()=>{r.forEach(i=>i.dispose()),Z(e),D=null;},trigger:()=>{}}}},_e=()=>({deregister:()=>{},trigger:()=>{}});var Be=o=>!o||o.length===0?"":o.map(({path:e,content:t})=>`
|
|
10
19
|
<related_file>
|
|
11
20
|
<filePath>${e}</filePath>
|
|
12
21
|
<fileContent>
|
|
@@ -16,7 +25,7 @@ ${t}
|
|
|
16
25
|
</fileContent>
|
|
17
26
|
</related_file>`.trim()).join(`
|
|
18
27
|
|
|
19
|
-
`),
|
|
28
|
+
`),Pe=o=>{let{technologies:e=[],filename:t,relatedFiles:r,language:n,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:l}}=o,p=A([n,...e].filter(a=>typeof a=="string"&&!!a)),d=`
|
|
20
29
|
You are an expert code completion assistant.
|
|
21
30
|
|
|
22
31
|
**Context:**
|
|
@@ -25,25 +34,16 @@ Language: ${n||"Undetermined"}
|
|
|
25
34
|
Mode: ${l}
|
|
26
35
|
Stack: ${p||"None"}`,c=`
|
|
27
36
|
**Related Files:**
|
|
28
|
-
${
|
|
37
|
+
${Be(r)}
|
|
29
38
|
|
|
30
39
|
**Source:**
|
|
31
40
|
\`\`\`
|
|
32
41
|
${i}<cursor>${s}
|
|
33
42
|
\`\`\`
|
|
34
43
|
|
|
35
|
-
${
|
|
36
|
-
|
|
37
|
-
Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:d,user:c}};var G=["groq","openai","anthropic","google","deepseek"],P={"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",v3:"deepseek-chat"},J={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"],deepseek:["v3"]},E={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models",deepseek:"https://api.deepseek.com/beta/completions"};var g=class{};var L=class extends g{createEndpoint(){return E.anthropic}createRequestBody(e,t){return {model:P[e],temperature:.1,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}}parseCompletion(e){let t=e.content?.[0];return t&&"text"in t?t.text:null}};var N=class extends g{createEndpoint(){return E.deepseek}createRequestBody(e,t,r){return {model:P[e],prompt:r.textBeforeCursor,suffix:r.textAfterCursor,temperature:.1,max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return typeof e.choices?.[0]?.text=="string"?e.choices[0].text:null}};var _=class extends g{createEndpoint(e,t){return `${E.google}/${P[e]}:generateContent?key=${t}`}createRequestBody(e,t){return {systemInstruction:{role:"system",parts:[{text:t.system}]},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{role:"user",parts:[{text:t.user}]}]}}createHeaders(){return {"Content-Type":"application/json"}}parseCompletion(e){return e.candidates?.[0]?.content?.parts?.[0]?.text??null}};var B=class extends g{createEndpoint(){return E.groq}createRequestBody(e,t){return {model:P[e],temperature:.1,max_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var F=class extends g{createEndpoint(){return E.openai}createRequestBody(e,t){let r=e==="o1-mini";return {model:P[e],...!r&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var q={openai:new F,groq:new B,anthropic:new L,google:new _,deepseek:new N},ae=(o,e,t)=>q[t].createEndpoint(o,e),le=(o,e,t,r)=>q[e].createRequestBody(o,t,r),pe=(o,e)=>q[e].createHeaders(o),me=(o,e)=>q[e].parseCompletion(o);var Oe="\x1B[91m",ce="\x1B[93m",Y="\x1B[0m",Z="\x1B[1m",de=o=>o instanceof Error?o.message:typeof o=="string"?o:"An unknown error occurred",$=o=>{let e=de(o),t=`${Oe}${Z}[MONACOPILOT ERROR] ${e}${Y}`;return console.error(t),{message:e}},O=(o,e)=>{console.warn(`${ce}${Z}[MONACOPILOT WARN] ${o}${e?`
|
|
38
|
-
${de(e)}`:""}${Y}`);};var ue=(o,e,t)=>console.warn(`${ce}${Z}[MONACOPILOT DEPRECATED] "${o}" is deprecated${` in ${t}`}. Please use "${e}" instead. It will be removed in a future version.${Y}`);var Q=class{constructor(e,t){this.validateParams(e,t),this.apiKey=e,this.provider=t.provider,this.model=t.model,this.validateInputs();}validateParams(e,t){if(!e)throw new Error("Please provide an API key.");if(!t||typeof t=="object"&&Object.keys(t).length===0)throw new Error("Please provide options.")}validateInputs(){if(typeof this.model=="object"){if(this.provider!==void 0)throw new Error("Provider should not be specified when using a custom model.");if(!("config"in this.model)||!("transformResponse"in this.model))throw new Error("Please ensure both config and transformResponse are provided for custom model.");return}if(!this.provider||!G.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${k(G)}`);if(typeof this.model=="string"&&!J[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${k(J[this.provider])}`)}async complete(e){let{body:t,options:r}=e,{completionMetadata:n}=t,{headers:i={},customPrompt:s}=r??{},l=this.generatePrompt(n,s),{endpoint:p,requestBody:d,headers:c}=this.prepareRequestDetails(l,n);try{let a=await this.sendCompletionRequest(p,d,{...c,...i});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,t){let r=se(e);return t?{...r,...t(e)}:r}prepareRequestDetails(e,t){if(typeof this.model=="object"&&"config"in this.model){let r=this.model.config(this.apiKey,e),n=r.endpoint,i=r.body??{},s=r.headers??{};return {endpoint:n,requestBody:i,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let r=ae(this.model,this.apiKey,this.provider),n=pe(this.apiKey,this.provider),i=le(this.model,this.provider,e,t);return {endpoint:r,requestBody:i,headers:n}}}async sendCompletionRequest(e,t,r){return S.POST(e,t,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let t=this.model.transformResponse(e);return "completion"in t&&ue("completion","text","Copilot.options.model.transformResponse"),{completion:t.text??t.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:me(e,this.provider),raw:e}}}handleCompletionError(e){return {error:$(e).message,completion:null}}};var j=class{constructor(e,t,r){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=t,this.textBeforeCursorInLine=r;}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}indentByColumn(){let e=this.formattedCompletion.split(`
|
|
39
|
-
`);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let t=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
|
|
40
|
-
`+e.slice(1).map(r=>t+r).join(`
|
|
41
|
-
`),this}removeMarkdownCodeBlocks(e){let t=/```[\s\S]*?```/g,r=e,n;for(;(n=t.exec(e))!==null;){let i=n[0],s=i.split(`
|
|
42
|
-
`).slice(1,-1).join(`
|
|
43
|
-
`);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
44
|
+
${le(l)} the code at <cursor>.
|
|
44
45
|
|
|
45
|
-
|
|
46
|
-
`),s=i.length-1,l=r+s,p=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,l,p)}};var Ie="application/json",fe=async o=>{let{endpoint:e,body:t}=o,{completion:r,error:n}=await S.POST(e,t,{headers:{"Content-Type":Ie},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},he=({pos:o,mdl:e,options:t})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:l}=t,p=ke(o,e),c=!!s?.length?3:2,a=l?Math.floor(l/c):void 0,u=(R,h,m)=>{let b=R(o,e);return h?W(b,h,m):b},f=(R,h)=>!R||!h?R:R.map(({content:m,...b})=>({...b,content:W(m,h)})),M=u(v,a,{from:"end"}),C=u(X,a),T=f(s,a);return {filename:r,language:n,technologies:i,relatedFiles:T,textBeforeCursor:M,textAfterCursor:C,cursorPosition:o,editorState:{completionMode:p}}},ke=(o,e)=>{let t=re(o,e),r=X(o,e);return t?"insert":r.trim()?"complete":"continue"};var I=o=>({items:o,enableForwardStability:!0,suppressSuggestions:!0});var De=o=>({onTyping:w(o,600,200),onIdle:w(o,600,400),onDemand:w(o,0,0)}),z=new K,Pe=async({monaco:o,mdl:e,pos:t,token:r,isCompletionAccepted:n,options:i})=>{let{trigger:s="onIdle",endpoint:l,enableCaching:p=!0,onError:d,requestHandler:c}=i;if(p){let a=z.get(t,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return I(a)}if(r.isCancellationRequested||n)return I([]);try{let u=De(c??fe)[s];r.onCancellationRequested(()=>{u.cancel();});let f=he({pos:t,mdl:e,options:i}),{completion:M}=await u({endpoint:l,body:{completionMetadata:f}});if(M){let C=new j(M,t.column,ne(t,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),T=new U(o),R=T.computeInsertionRange(t,C,e),h=T.computeCacheRange(t,C);return p&&z.add({completion:C,range:h,textBeforeCursor:v(t,e)}),I([{insertText:C,range:R}])}}catch(a){if(Se(a))return I([]);d?d(a):O("Cannot provide completion",a);}return I([])},Se=o=>typeof o=="string"?o==="Cancelled"||o==="AbortError":o instanceof Error?o.message==="Cancelled"||o.name==="AbortError":!1;var Ee=(o,e,t)=>{let r=A(e);return r?o.languages.registerInlineCompletionsProvider(t.language,{provideInlineCompletions:(n,i,s,l)=>{if(!(t.trigger==="onDemand"&&!r.isExplicitlyTriggered))return Pe({monaco:o,mdl:n,pos:i,token:l,isCompletionAccepted:r.isCompletionAccepted,options:t})},handleItemDidShow:(n,i,s)=>{r.hasRejectedCurrentCompletion=!1,!r.isCompletionAccepted&&(r.isCompletionVisible=!0,t.onCompletionShown?.(s,i.range));},freeInlineCompletions:()=>{}}):null},Re=o=>{let e=A(o);if(!e){O("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isExplicitlyTriggered=!0,o.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};var ye=(o,e,t,r)=>(t.isExplicitlyTriggered=!1,e.onKeyDown(n=>{we({monaco:o,event:n,state:t,options:r}),Le({monaco:o,event:n,state:t,options:r});})),we=({monaco:o,event:e,state:t,options:r})=>t.isCompletionVisible&&xe(o,e)?(r.onCompletionAccepted?.(),t.isCompletionAccepted=!0,t.isCompletionVisible=!1,!0):(t.isCompletionAccepted=!1,!1),Le=({monaco:o,event:e,state:t,options:r})=>{let n=!xe(o,e);return t.isCompletionVisible&&!t.hasRejectedCurrentCompletion&&!t.isCompletionAccepted&&n?(r.onCompletionRejected?.(),t.hasRejectedCurrentCompletion=!0,!0):!1},xe=(o,e)=>e.keyCode===o.KeyCode.Tab||e.keyCode===o.KeyCode.RightArrow&&e.metaKey;var D=null,Ne=(o,e,t)=>{D&&D.deregister();let r=[];Ce(e,ge()),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let n=A(e);if(!n)return O("Completion is not registered properly. State not found."),_e();let i=Ee(o,e,t);i&&r.push(i);let s=ye(o,e,n,t);r.push(s);let l={deregister:()=>{r.forEach(p=>p.dispose()),z.clear(),te(e),D=null;},trigger:()=>Re(e)};return D=l,l}catch(n){return t.onError?t.onError(n):$(n),{deregister:()=>{r.forEach(i=>i.dispose()),te(e),D=null;},trigger:()=>{}}}},_e=()=>({deregister:()=>{},trigger:()=>{}});
|
|
46
|
+
Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:d,user:c}};var ee=["groq","openai","anthropic","google","deepseek"],P={"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",v3:"deepseek-chat"},te={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"],deepseek:["v3"]},E={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models",deepseek:"https://api.deepseek.com/beta/completions"};var g=class{};var j=class extends g{createEndpoint(){return E.anthropic}createRequestBody(e,t){return {model:P[e],temperature:.1,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}}parseCompletion(e){let t=e.content?.[0];return t&&"text"in t?t.text:null}};var H=class extends g{createEndpoint(){return E.deepseek}createRequestBody(e,t,r){return {model:P[e],prompt:r.textBeforeCursor,suffix:r.textAfterCursor,temperature:.1,max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return typeof e.choices?.[0]?.text=="string"?e.choices[0].text:null}};var K=class extends g{createEndpoint(e,t){return `${E.google}/${P[e]}:generateContent?key=${t}`}createRequestBody(e,t){return {systemInstruction:{role:"system",parts:[{text:t.system}]},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{role:"user",parts:[{text:t.user}]}]}}createHeaders(){return {"Content-Type":"application/json"}}parseCompletion(e){return e.candidates?.[0]?.content?.parts?.[0]?.text??null}};var V=class extends g{createEndpoint(){return E.groq}createRequestBody(e,t){return {model:P[e],temperature:.1,max_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var U=class extends g{createEndpoint(){return E.openai}createRequestBody(e,t){let r=e==="o1-mini";return {model:P[e],...!r&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var z={openai:new U,groq:new V,anthropic:new j,google:new K,deepseek:new H},Ee=(o,e,t)=>z[t].createEndpoint(o,e),Re=(o,e,t,r)=>z[e].createRequestBody(o,t,r),ye=(o,e)=>z[e].createHeaders(o),Me=(o,e)=>z[e].parseCompletion(o);var xe=(o,e)=>{if(!o)throw new Error("Please provide an API key.");if(!e||typeof e=="object"&&Object.keys(e).length===0)throw new Error("Please provide options.")},Te=(o,e)=>{if(typeof o=="object"){if(e!==void 0)throw new Error("Provider should not be specified when using a custom model.");if(!("config"in o)||!("transformResponse"in o))throw new Error("Please ensure both config and transformResponse are provided for custom model.");return}if(!e||!ee.includes(e))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${A(ee)}`);if(typeof o=="string"&&!te[e].includes(o))throw new Error(`Model "${o}" is not supported by the "${e}" provider. Supported models: ${A(te[e])}`)};var oe=class{constructor(e,t){xe(e,t),this.apiKey=e,this.provider=t.provider,this.model=t.model,Te(this.model,this.provider);}async complete(e){let{body:t,options:r}=e,{completionMetadata:n}=t,{headers:i={},customPrompt:s}=r??{},l=this.generatePrompt(n,s),{endpoint:p,requestBody:d,headers:c}=this.prepareRequestDetails(l,n);try{let a=await this.sendCompletionRequest(p,d,{...c,...i});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,t){let r=Pe(e);return t?{...r,...t(e)}:r}prepareRequestDetails(e,t){if(typeof this.model=="object"&&"config"in this.model){let r=this.model.config(this.apiKey,e),n=r.endpoint,i=r.body??{},s=r.headers??{};return {endpoint:n,requestBody:i,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let r=Ee(this.model,this.apiKey,this.provider),n=ye(this.apiKey,this.provider),i=Re(this.model,this.provider,e,t);return {endpoint:r,requestBody:i,headers:n}}}async sendCompletionRequest(e,t,r){return F.POST(e,t,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let t=this.model.transformResponse(e);return "completion"in t&&ie("completion","text","Copilot.options.model.transformResponse"),{completion:t.text??t.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:Me(e,this.provider),raw:e}}}handleCompletionError(e){return {error:S(e).message,completion:null}}};
|
|
47
47
|
|
|
48
|
-
exports.Copilot =
|
|
48
|
+
exports.Copilot = oe;
|
|
49
49
|
exports.registerCompletion = Ne;
|
package/build/index.mjs
CHANGED
|
@@ -1,10 +1,19 @@
|
|
|
1
|
-
var
|
|
1
|
+
var ve="\x1B[91m",re="\x1B[93m",W="\x1B[0m",G="\x1B[1m",ne=o=>o instanceof Error?o.message:typeof o=="string"?o:"An unknown error occurred",S=o=>{let e=ne(o),t=`${ve}${G}[MONACOPILOT ERROR] ${e}${W}`;return console.error(t),{message:e}},v=(o,e)=>{console.warn(`${re}${G}[MONACOPILOT WARN] ${o}${e?`
|
|
2
|
+
${ne(e)}`:""}${W}`);};var ie=(o,e,t)=>console.warn(`${re}${G}[MONACOPILOT DEPRECATED] "${o}" is deprecated${` in ${t}`}. Please use "${e}" instead. It will be removed in a future version.${W}`);var w=class{constructor(e,t,r){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=t,this.textBeforeCursorInLine=r;}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}indentByColumn(){let e=this.formattedCompletion.split(`
|
|
3
|
+
`);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let t=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
|
|
4
|
+
`+e.slice(1).map(r=>t+r).join(`
|
|
5
|
+
`),this}removeMarkdownCodeBlocks(e){let t=/```[\s\S]*?```/g,r=e,n;for(;(n=t.exec(e))!==null;){let i=n[0],s=i.split(`
|
|
6
|
+
`).slice(1,-1).join(`
|
|
7
|
+
`);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
8
|
+
|
|
9
|
+
`),this}build(){return this.formattedCompletion}};var L=class{constructor(e){this.monaco=e;}computeInsertionRange(e,t,r){if(!t)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=r.getOffsetAt(e),i=r.getValue().substring(0,n),s=r.getValue().substring(n),l=0,p=0,d=0,c=0,a=t.length,u=i.length,f=s.length;if(n>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(f===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let x=Math.min(a,u);for(let m=1;m<=x;m++){let b=t.substring(0,m),be=i.slice(-m);b===be&&(c=m);}let C=Math.min(a,f);for(let m=0;m<C&&t[m]===s[m];m++)l++;for(let m=1;m<=C;m++)t.slice(-m)===s.slice(0,m)&&(p=m);if(d=Math.max(l,p),d===0){for(let m=1;m<a;m++)if(s.startsWith(t.substring(m))){d=a-m;break}}let T=c>0?r.getPositionAt(n-c):e,R=n+d,h=r.getPositionAt(R);return new this.monaco.Range(T.lineNumber,T.column,h.lineNumber,h.column)}computeCacheRange(e,t){let r=e.lineNumber,n=e.column,i=t.split(`
|
|
10
|
+
`),s=i.length-1,l=r+s,p=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,l,p)}};var se=(o,e)=>e.getLineContent(o.lineNumber)[o.column-1];var ae=(o,e)=>e.getLineContent(o.lineNumber).slice(0,o.column-1),O=(o,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:o.lineNumber,endColumn:o.column}),X=(o,e)=>e.getValueInRange({startLineNumber:o.lineNumber,startColumn:o.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var N=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let t;return this.size===this.capacity&&(t=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,t}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 B=class B{constructor(){this.cache=new N(B.MAX_CACHE_SIZE);}get(e,t){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,t))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,t,r){let n=r.getValueInRange(e.range),i=O(t,r);return i.length<e.textBeforeCursor.length||!i.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,t,n)}isPositionValid(e,t,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:l,endLineNumber:p,endColumn:d}=n,{lineNumber:c,column:a}=t;if(!i.startsWith(r))return !1;let u=c===s&&a===l;if(s===p)return u||c===s&&a>=l&&a<=d;let f=c>s&&c<p?!0:c===s&&a>=l||c===p&&a<=d;return u||f}};B.MAX_CACHE_SIZE=10;var _=B;var A=o=>!o||o.length===0?"":o.length===1?o[0]:`${o.slice(0,-1).join(", ")} and ${o.slice(-1)}`,le=o=>o.charAt(0).toUpperCase()+o.slice(1),Y=(o,e,t={})=>{if(e<=0)return "";let r=o.split(`
|
|
2
11
|
`),n=r.length;if(e>=n)return o;if(t.from==="end"){let s=r.slice(-e);return s.every(l=>l==="")?`
|
|
3
12
|
`.repeat(e):s.join(`
|
|
4
13
|
`)}let i=r.slice(0,e);return i.every(s=>s==="")?`
|
|
5
14
|
`.repeat(e):i.join(`
|
|
6
|
-
`)};var
|
|
7
|
-
${JSON.stringify(d,null,2)}`:"",a=t.fallbackError||"Network request failed";throw new Error(`${a} (${p.status})${c}`)}return p.json()},
|
|
15
|
+
`)};var pe=async(o,e,t={})=>{let r=t.timeout??3e4,n=AbortSignal.timeout(r),i=t.signal?AbortSignal.any([n,t.signal]):n,s={"Content-Type":"application/json",...t.headers},l=e==="POST"&&t.body?JSON.stringify(t.body):void 0,p=await fetch(o,{method:e,headers:s,body:l,signal:i});if(!p.ok){let d=await p.json().catch(()=>null),c=d?`
|
|
16
|
+
${JSON.stringify(d,null,2)}`:"",a=t.fallbackError||"Network request failed";throw new Error(`${a} (${p.status})${c}`)}return p.json()},Oe=(o,e)=>pe(o,"GET",e),Ie=(o,e,t)=>pe(o,"POST",{...t,body:e}),F={GET:Oe,POST:Ie};var q=(o,e=600,t=200)=>{let r=null,n=0,i=null,s=null,l=!1,p=(...d)=>{if(l)return Promise.resolve(void 0);i=d;let c=Date.now(),a=c-n;n=c,r&&(clearTimeout(r),r=null);let u=a<t?e:t;return s=new Promise((f,x)=>{r=setTimeout(async()=>{l=!0;try{if(i){let C=await o(...i);f(C);}else f(void 0);}catch(C){x(C);}finally{l=!1,r=null,i=null;}},u);}),s};return p.cancel=()=>{r&&(clearTimeout(r),r=null),i=null;},p};var Ae="application/json",me=async o=>{let{endpoint:e,body:t}=o,{completion:r,error:n}=await F.POST(e,t,{headers:{"Content-Type":Ae},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},ce=({pos:o,mdl:e,options:t})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:l}=t,p=ke(o,e),c=!!s?.length?3:2,a=l?Math.floor(l/c):void 0,u=(R,h,m)=>{let b=R(o,e);return h?Y(b,h,m):b},f=(R,h)=>!R||!h?R:R.map(({content:m,...b})=>({...b,content:Y(m,h)})),x=u(O,a,{from:"end"}),C=u(X,a),T=f(s,a);return {filename:r,language:n,technologies:i,relatedFiles:T,textBeforeCursor:x,textAfterCursor:C,cursorPosition:o,editorState:{completionMode:p}}},ke=(o,e)=>{let t=se(o,e),r=X(o,e);return t?"insert":r.trim()?"complete":"continue"};var I=o=>({items:o,enableForwardStability:!0,suppressSuggestions:!0});var Se=o=>({onTyping:q(o,600,200),onIdle:q(o,600,400),onDemand:q(o,0,0)}),$=new _,de=async({monaco:o,mdl:e,pos:t,token:r,isCompletionAccepted:n,options:i})=>{let{trigger:s="onIdle",endpoint:l,enableCaching:p=!0,onError:d,requestHandler:c}=i;if(p){let a=$.get(t,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return I(a)}if(r.isCancellationRequested||n)return I([]);try{let u=Se(c??me)[s];r.onCancellationRequested(()=>{u.cancel();});let f=ce({pos:t,mdl:e,options:i}),{completion:x}=await u({endpoint:l,body:{completionMetadata:f}});if(x){let C=new w(x,t.column,ae(t,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),T=new L(o),R=T.computeInsertionRange(t,C,e),h=T.computeCacheRange(t,C);return p&&$.add({completion:C,range:h,textBeforeCursor:O(t,e)}),I([{insertText:C,range:R}])}}catch(a){if(we(a))return I([]);d?d(a):v("Cannot provide completion",a);}return I([])},we=o=>typeof o=="string"?o==="Cancelled"||o==="AbortError":o instanceof Error?o.message==="Cancelled"||o.name==="AbortError":!1;var J=new WeakMap,k=o=>J.get(o),ue=(o,e)=>{J.set(o,e);},Z=o=>{J.delete(o);},Ce=()=>({isCompletionAccepted:!1,isCompletionVisible:!1,isExplicitlyTriggered:!1,hasRejectedCurrentCompletion:!1});var ge=(o,e,t)=>{let r=k(e);return r?o.languages.registerInlineCompletionsProvider(t.language,{provideInlineCompletions:(n,i,s,l)=>{if(!(t.trigger==="onDemand"&&!r.isExplicitlyTriggered))return de({monaco:o,mdl:n,pos:i,token:l,isCompletionAccepted:r.isCompletionAccepted,options:t})},handleItemDidShow:(n,i,s)=>{r.isExplicitlyTriggered=!1,r.hasRejectedCurrentCompletion=!1,!r.isCompletionAccepted&&(r.isCompletionVisible=!0,t.onCompletionShown?.(s,i.range));},freeInlineCompletions:()=>{}}):null},fe=o=>{let e=k(o);if(!e){v("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isExplicitlyTriggered=!0,o.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};var Le={TAB:(o,e)=>e.keyCode===o.KeyCode.Tab,CMD_RIGHT_ARROW:(o,e)=>e.keyCode===o.KeyCode.RightArrow&&e.metaKey},Q=class{constructor(e,t,r){this.monaco=e;this.state=t;this.options=r;}handleKeyEvent(e){let t={monaco:this.monaco,event:e,state:this.state,options:this.options};this.handleCompletionAcceptance(t),this.handleCompletionRejection(t);}handleCompletionAcceptance(e){return e.state.isCompletionVisible&&this.isAcceptanceKey(e.event)?(e.options.onCompletionAccepted?.(),e.state.isCompletionAccepted=!0,e.state.isCompletionVisible=!1,!0):(e.state.isCompletionAccepted=!1,!1)}handleCompletionRejection(e){return this.shouldRejectCompletion(e)?(e.options.onCompletionRejected?.(),e.state.hasRejectedCurrentCompletion=!0,!0):!1}shouldRejectCompletion(e){return e.state.isCompletionVisible&&!e.state.hasRejectedCurrentCompletion&&!e.state.isCompletionAccepted&&!this.isAcceptanceKey(e.event)}isAcceptanceKey(e){return Object.values(Le).some(t=>t(this.monaco,e))}},he=(o,e,t,r)=>{let n=new Q(o,t,r);return e.onKeyDown(i=>n.handleKeyEvent(i))};var D=null,Ne=(o,e,t)=>{D&&D.deregister();let r=[];ue(e,Ce()),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let n=k(e);if(!n)return v("Completion is not registered properly. State not found."),_e();let i=ge(o,e,t);i&&r.push(i);let s=he(o,e,n,t);r.push(s);let l={deregister:()=>{r.forEach(p=>p.dispose()),$.clear(),Z(e),D=null;},trigger:()=>fe(e)};return D=l,l}catch(n){return t.onError?t.onError(n):S(n),{deregister:()=>{r.forEach(i=>i.dispose()),Z(e),D=null;},trigger:()=>{}}}},_e=()=>({deregister:()=>{},trigger:()=>{}});var Be=o=>!o||o.length===0?"":o.map(({path:e,content:t})=>`
|
|
8
17
|
<related_file>
|
|
9
18
|
<filePath>${e}</filePath>
|
|
10
19
|
<fileContent>
|
|
@@ -14,7 +23,7 @@ ${t}
|
|
|
14
23
|
</fileContent>
|
|
15
24
|
</related_file>`.trim()).join(`
|
|
16
25
|
|
|
17
|
-
`),
|
|
26
|
+
`),Pe=o=>{let{technologies:e=[],filename:t,relatedFiles:r,language:n,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:l}}=o,p=A([n,...e].filter(a=>typeof a=="string"&&!!a)),d=`
|
|
18
27
|
You are an expert code completion assistant.
|
|
19
28
|
|
|
20
29
|
**Context:**
|
|
@@ -23,24 +32,15 @@ Language: ${n||"Undetermined"}
|
|
|
23
32
|
Mode: ${l}
|
|
24
33
|
Stack: ${p||"None"}`,c=`
|
|
25
34
|
**Related Files:**
|
|
26
|
-
${
|
|
35
|
+
${Be(r)}
|
|
27
36
|
|
|
28
37
|
**Source:**
|
|
29
38
|
\`\`\`
|
|
30
39
|
${i}<cursor>${s}
|
|
31
40
|
\`\`\`
|
|
32
41
|
|
|
33
|
-
${
|
|
34
|
-
|
|
35
|
-
Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:d,user:c}};var G=["groq","openai","anthropic","google","deepseek"],P={"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",v3:"deepseek-chat"},J={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"],deepseek:["v3"]},E={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models",deepseek:"https://api.deepseek.com/beta/completions"};var g=class{};var L=class extends g{createEndpoint(){return E.anthropic}createRequestBody(e,t){return {model:P[e],temperature:.1,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}}parseCompletion(e){let t=e.content?.[0];return t&&"text"in t?t.text:null}};var N=class extends g{createEndpoint(){return E.deepseek}createRequestBody(e,t,r){return {model:P[e],prompt:r.textBeforeCursor,suffix:r.textAfterCursor,temperature:.1,max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return typeof e.choices?.[0]?.text=="string"?e.choices[0].text:null}};var _=class extends g{createEndpoint(e,t){return `${E.google}/${P[e]}:generateContent?key=${t}`}createRequestBody(e,t){return {systemInstruction:{role:"system",parts:[{text:t.system}]},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{role:"user",parts:[{text:t.user}]}]}}createHeaders(){return {"Content-Type":"application/json"}}parseCompletion(e){return e.candidates?.[0]?.content?.parts?.[0]?.text??null}};var B=class extends g{createEndpoint(){return E.groq}createRequestBody(e,t){return {model:P[e],temperature:.1,max_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var F=class extends g{createEndpoint(){return E.openai}createRequestBody(e,t){let r=e==="o1-mini";return {model:P[e],...!r&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var q={openai:new F,groq:new B,anthropic:new L,google:new _,deepseek:new N},ae=(o,e,t)=>q[t].createEndpoint(o,e),le=(o,e,t,r)=>q[e].createRequestBody(o,t,r),pe=(o,e)=>q[e].createHeaders(o),me=(o,e)=>q[e].parseCompletion(o);var Oe="\x1B[91m",ce="\x1B[93m",Y="\x1B[0m",Z="\x1B[1m",de=o=>o instanceof Error?o.message:typeof o=="string"?o:"An unknown error occurred",$=o=>{let e=de(o),t=`${Oe}${Z}[MONACOPILOT ERROR] ${e}${Y}`;return console.error(t),{message:e}},O=(o,e)=>{console.warn(`${ce}${Z}[MONACOPILOT WARN] ${o}${e?`
|
|
36
|
-
${de(e)}`:""}${Y}`);};var ue=(o,e,t)=>console.warn(`${ce}${Z}[MONACOPILOT DEPRECATED] "${o}" is deprecated${` in ${t}`}. Please use "${e}" instead. It will be removed in a future version.${Y}`);var Q=class{constructor(e,t){this.validateParams(e,t),this.apiKey=e,this.provider=t.provider,this.model=t.model,this.validateInputs();}validateParams(e,t){if(!e)throw new Error("Please provide an API key.");if(!t||typeof t=="object"&&Object.keys(t).length===0)throw new Error("Please provide options.")}validateInputs(){if(typeof this.model=="object"){if(this.provider!==void 0)throw new Error("Provider should not be specified when using a custom model.");if(!("config"in this.model)||!("transformResponse"in this.model))throw new Error("Please ensure both config and transformResponse are provided for custom model.");return}if(!this.provider||!G.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${k(G)}`);if(typeof this.model=="string"&&!J[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${k(J[this.provider])}`)}async complete(e){let{body:t,options:r}=e,{completionMetadata:n}=t,{headers:i={},customPrompt:s}=r??{},l=this.generatePrompt(n,s),{endpoint:p,requestBody:d,headers:c}=this.prepareRequestDetails(l,n);try{let a=await this.sendCompletionRequest(p,d,{...c,...i});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,t){let r=se(e);return t?{...r,...t(e)}:r}prepareRequestDetails(e,t){if(typeof this.model=="object"&&"config"in this.model){let r=this.model.config(this.apiKey,e),n=r.endpoint,i=r.body??{},s=r.headers??{};return {endpoint:n,requestBody:i,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let r=ae(this.model,this.apiKey,this.provider),n=pe(this.apiKey,this.provider),i=le(this.model,this.provider,e,t);return {endpoint:r,requestBody:i,headers:n}}}async sendCompletionRequest(e,t,r){return S.POST(e,t,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let t=this.model.transformResponse(e);return "completion"in t&&ue("completion","text","Copilot.options.model.transformResponse"),{completion:t.text??t.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:me(e,this.provider),raw:e}}}handleCompletionError(e){return {error:$(e).message,completion:null}}};var j=class{constructor(e,t,r){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=t,this.textBeforeCursorInLine=r;}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}indentByColumn(){let e=this.formattedCompletion.split(`
|
|
37
|
-
`);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let t=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
|
|
38
|
-
`+e.slice(1).map(r=>t+r).join(`
|
|
39
|
-
`),this}removeMarkdownCodeBlocks(e){let t=/```[\s\S]*?```/g,r=e,n;for(;(n=t.exec(e))!==null;){let i=n[0],s=i.split(`
|
|
40
|
-
`).slice(1,-1).join(`
|
|
41
|
-
`);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
42
|
+
${le(l)} the code at <cursor>.
|
|
42
43
|
|
|
43
|
-
|
|
44
|
-
`),s=i.length-1,l=r+s,p=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,l,p)}};var Ie="application/json",fe=async o=>{let{endpoint:e,body:t}=o,{completion:r,error:n}=await S.POST(e,t,{headers:{"Content-Type":Ie},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},he=({pos:o,mdl:e,options:t})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:l}=t,p=ke(o,e),c=!!s?.length?3:2,a=l?Math.floor(l/c):void 0,u=(R,h,m)=>{let b=R(o,e);return h?W(b,h,m):b},f=(R,h)=>!R||!h?R:R.map(({content:m,...b})=>({...b,content:W(m,h)})),M=u(v,a,{from:"end"}),C=u(X,a),T=f(s,a);return {filename:r,language:n,technologies:i,relatedFiles:T,textBeforeCursor:M,textAfterCursor:C,cursorPosition:o,editorState:{completionMode:p}}},ke=(o,e)=>{let t=re(o,e),r=X(o,e);return t?"insert":r.trim()?"complete":"continue"};var I=o=>({items:o,enableForwardStability:!0,suppressSuggestions:!0});var De=o=>({onTyping:w(o,600,200),onIdle:w(o,600,400),onDemand:w(o,0,0)}),z=new K,Pe=async({monaco:o,mdl:e,pos:t,token:r,isCompletionAccepted:n,options:i})=>{let{trigger:s="onIdle",endpoint:l,enableCaching:p=!0,onError:d,requestHandler:c}=i;if(p){let a=z.get(t,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return I(a)}if(r.isCancellationRequested||n)return I([]);try{let u=De(c??fe)[s];r.onCancellationRequested(()=>{u.cancel();});let f=he({pos:t,mdl:e,options:i}),{completion:M}=await u({endpoint:l,body:{completionMetadata:f}});if(M){let C=new j(M,t.column,ne(t,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),T=new U(o),R=T.computeInsertionRange(t,C,e),h=T.computeCacheRange(t,C);return p&&z.add({completion:C,range:h,textBeforeCursor:v(t,e)}),I([{insertText:C,range:R}])}}catch(a){if(Se(a))return I([]);d?d(a):O("Cannot provide completion",a);}return I([])},Se=o=>typeof o=="string"?o==="Cancelled"||o==="AbortError":o instanceof Error?o.message==="Cancelled"||o.name==="AbortError":!1;var Ee=(o,e,t)=>{let r=A(e);return r?o.languages.registerInlineCompletionsProvider(t.language,{provideInlineCompletions:(n,i,s,l)=>{if(!(t.trigger==="onDemand"&&!r.isExplicitlyTriggered))return Pe({monaco:o,mdl:n,pos:i,token:l,isCompletionAccepted:r.isCompletionAccepted,options:t})},handleItemDidShow:(n,i,s)=>{r.hasRejectedCurrentCompletion=!1,!r.isCompletionAccepted&&(r.isCompletionVisible=!0,t.onCompletionShown?.(s,i.range));},freeInlineCompletions:()=>{}}):null},Re=o=>{let e=A(o);if(!e){O("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isExplicitlyTriggered=!0,o.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};var ye=(o,e,t,r)=>(t.isExplicitlyTriggered=!1,e.onKeyDown(n=>{we({monaco:o,event:n,state:t,options:r}),Le({monaco:o,event:n,state:t,options:r});})),we=({monaco:o,event:e,state:t,options:r})=>t.isCompletionVisible&&xe(o,e)?(r.onCompletionAccepted?.(),t.isCompletionAccepted=!0,t.isCompletionVisible=!1,!0):(t.isCompletionAccepted=!1,!1),Le=({monaco:o,event:e,state:t,options:r})=>{let n=!xe(o,e);return t.isCompletionVisible&&!t.hasRejectedCurrentCompletion&&!t.isCompletionAccepted&&n?(r.onCompletionRejected?.(),t.hasRejectedCurrentCompletion=!0,!0):!1},xe=(o,e)=>e.keyCode===o.KeyCode.Tab||e.keyCode===o.KeyCode.RightArrow&&e.metaKey;var D=null,Ne=(o,e,t)=>{D&&D.deregister();let r=[];Ce(e,ge()),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let n=A(e);if(!n)return O("Completion is not registered properly. State not found."),_e();let i=Ee(o,e,t);i&&r.push(i);let s=ye(o,e,n,t);r.push(s);let l={deregister:()=>{r.forEach(p=>p.dispose()),z.clear(),te(e),D=null;},trigger:()=>Re(e)};return D=l,l}catch(n){return t.onError?t.onError(n):$(n),{deregister:()=>{r.forEach(i=>i.dispose()),te(e),D=null;},trigger:()=>{}}}},_e=()=>({deregister:()=>{},trigger:()=>{}});
|
|
44
|
+
Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:d,user:c}};var ee=["groq","openai","anthropic","google","deepseek"],P={"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",v3:"deepseek-chat"},te={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"],deepseek:["v3"]},E={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models",deepseek:"https://api.deepseek.com/beta/completions"};var g=class{};var j=class extends g{createEndpoint(){return E.anthropic}createRequestBody(e,t){return {model:P[e],temperature:.1,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}}parseCompletion(e){let t=e.content?.[0];return t&&"text"in t?t.text:null}};var H=class extends g{createEndpoint(){return E.deepseek}createRequestBody(e,t,r){return {model:P[e],prompt:r.textBeforeCursor,suffix:r.textAfterCursor,temperature:.1,max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return typeof e.choices?.[0]?.text=="string"?e.choices[0].text:null}};var K=class extends g{createEndpoint(e,t){return `${E.google}/${P[e]}:generateContent?key=${t}`}createRequestBody(e,t){return {systemInstruction:{role:"system",parts:[{text:t.system}]},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{role:"user",parts:[{text:t.user}]}]}}createHeaders(){return {"Content-Type":"application/json"}}parseCompletion(e){return e.candidates?.[0]?.content?.parts?.[0]?.text??null}};var V=class extends g{createEndpoint(){return E.groq}createRequestBody(e,t){return {model:P[e],temperature:.1,max_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var U=class extends g{createEndpoint(){return E.openai}createRequestBody(e,t){let r=e==="o1-mini";return {model:P[e],...!r&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var z={openai:new U,groq:new V,anthropic:new j,google:new K,deepseek:new H},Ee=(o,e,t)=>z[t].createEndpoint(o,e),Re=(o,e,t,r)=>z[e].createRequestBody(o,t,r),ye=(o,e)=>z[e].createHeaders(o),Me=(o,e)=>z[e].parseCompletion(o);var xe=(o,e)=>{if(!o)throw new Error("Please provide an API key.");if(!e||typeof e=="object"&&Object.keys(e).length===0)throw new Error("Please provide options.")},Te=(o,e)=>{if(typeof o=="object"){if(e!==void 0)throw new Error("Provider should not be specified when using a custom model.");if(!("config"in o)||!("transformResponse"in o))throw new Error("Please ensure both config and transformResponse are provided for custom model.");return}if(!e||!ee.includes(e))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${A(ee)}`);if(typeof o=="string"&&!te[e].includes(o))throw new Error(`Model "${o}" is not supported by the "${e}" provider. Supported models: ${A(te[e])}`)};var oe=class{constructor(e,t){xe(e,t),this.apiKey=e,this.provider=t.provider,this.model=t.model,Te(this.model,this.provider);}async complete(e){let{body:t,options:r}=e,{completionMetadata:n}=t,{headers:i={},customPrompt:s}=r??{},l=this.generatePrompt(n,s),{endpoint:p,requestBody:d,headers:c}=this.prepareRequestDetails(l,n);try{let a=await this.sendCompletionRequest(p,d,{...c,...i});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,t){let r=Pe(e);return t?{...r,...t(e)}:r}prepareRequestDetails(e,t){if(typeof this.model=="object"&&"config"in this.model){let r=this.model.config(this.apiKey,e),n=r.endpoint,i=r.body??{},s=r.headers??{};return {endpoint:n,requestBody:i,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let r=Ee(this.model,this.apiKey,this.provider),n=ye(this.apiKey,this.provider),i=Re(this.model,this.provider,e,t);return {endpoint:r,requestBody:i,headers:n}}}async sendCompletionRequest(e,t,r){return F.POST(e,t,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let t=this.model.transformResponse(e);return "completion"in t&&ie("completion","text","Copilot.options.model.transformResponse"),{completion:t.text??t.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:Me(e,this.provider),raw:e}}}handleCompletionError(e){return {error:S(e).message,completion:null}}};
|
|
45
45
|
|
|
46
|
-
export {
|
|
46
|
+
export { oe as Copilot, Ne as registerCompletion };
|