monacopilot 0.16.2 → 0.16.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/build/index.js CHANGED
@@ -1,12 +1,12 @@
1
1
  'use strict';
2
2
 
3
- var j=["groq","openai","anthropic","google"],Y={"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"},V={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"]},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"};var M=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,J=t=>t.charAt(0).toUpperCase()+t.slice(1),z=(t,e,o={})=>{if(e<=0)return "";let n=t.split(`
4
- `),r=n.length;if(e>=r)return t;if(o.from==="end"){let s=n.slice(-e);return s.every(c=>c==="")?`
3
+ var j=["groq","openai","anthropic","google"],X={"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"},V={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"]},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"};var M=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,J=t=>t.charAt(0).toUpperCase()+t.slice(1),z=(t,e,o={})=>{if(e<=0)return "";let n=t.split(`
4
+ `),r=n.length;if(e>=r)return t;if(o.from==="end"){let s=n.slice(-e);return s.every(l=>l==="")?`
5
5
  `.repeat(e):s.join(`
6
6
  `)}let i=n.slice(0,e);return i.every(s=>s==="")?`
7
7
  `.repeat(e):i.join(`
8
- `)};var Z=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var T=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),K=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var Q=async(t,e,o={})=>{let n=o.timeout??3e4,r=AbortSignal.timeout(n),i=o.signal?AbortSignal.any([r,o.signal]):r,s={"Content-Type":"application/json",...o.headers},c=e==="POST"&&o.body?JSON.stringify(o.body):void 0,a=await fetch(t,{method:e,headers:s,body:c,signal:i});if(!a.ok){let l=await a.json().catch(()=>null),d=l?`
9
- ${JSON.stringify(l,null,2)}`:"",p=o.fallbackError||"Network request failed";throw new Error(`${p} (${a.status})${d}`)}return a.json()},de=(t,e)=>Q(t,"GET",e),ue=(t,e,o)=>Q(t,"POST",{...o,body:e}),O={GET:de,POST:ue};var I=(t,e=600,o=200)=>{let n=null,r=0,i=null,s=null,c=(...a)=>{i=a;let l=Date.now(),d=l-r;r=l,n&&(clearTimeout(n),n=null);let p=d<o?e:o;return s=new Promise((u,C)=>{n=setTimeout(async()=>{try{if(i){let f=await t(...i);u(f);}}catch(f){C(f);}finally{n=null,i=null;}},p);}),s};return c.cancel=()=>{n&&(clearTimeout(n),n=null),i=null;},c};var Ce=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
8
+ `)};var Y=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var T=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),K=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var Z=async(t,e,o={})=>{let n=o.timeout??3e4,r=AbortSignal.timeout(n),i=o.signal?AbortSignal.any([r,o.signal]):r,s={"Content-Type":"application/json",...o.headers},l=e==="POST"&&o.body?JSON.stringify(o.body):void 0,a=await fetch(t,{method:e,headers:s,body:l,signal:i});if(!a.ok){let c=await a.json().catch(()=>null),d=c?`
9
+ ${JSON.stringify(c,null,2)}`:"",p=o.fallbackError||"Network request failed";throw new Error(`${p} (${a.status})${d}`)}return a.json()},de=(t,e)=>Z(t,"GET",e),me=(t,e,o)=>Z(t,"POST",{...o,body:e}),O={GET:de,POST:me};var I=(t,e=600,o=200)=>{let n=null,r=0,i=null,s=null,l=!1,a=(...c)=>{if(l)return Promise.resolve(void 0);i=c;let d=Date.now(),p=d-r;r=d,n&&(clearTimeout(n),n=null);let u=p<o?e:o;return s=new Promise((C,P)=>{n=setTimeout(async()=>{l=!0;try{if(i){let g=await t(...i);C(g);}else C(void 0);}catch(g){P(g);}finally{l=!1,n=null,i=null;}},u);}),s};return a.cancel=()=>{n&&(clearTimeout(n),n=null),i=null;},a};var ue=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
10
10
  <related_file>
11
11
  <filePath>${e}</filePath>
12
12
  <fileContent>
@@ -16,32 +16,32 @@ ${o}
16
16
  </fileContent>
17
17
  </related_file>`.trim()).join(`
18
18
 
19
- `),ee=t=>{let{technologies:e=[],filename:o,relatedFiles:n,language:r,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:c}}=t,a=M([r,...e].filter(p=>typeof p=="string"&&!!p)),l=`
19
+ `),Q=t=>{let{technologies:e=[],filename:o,relatedFiles:n,language:r,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:l}}=t,a=M([r,...e].filter(p=>typeof p=="string"&&!!p)),c=`
20
20
  You are an expert code completion assistant.
21
21
 
22
22
  **Context:**
23
23
  File: ${o||"Untitled"}
24
24
  Language: ${r||"Undetermined"}
25
- Mode: ${c}
25
+ Mode: ${l}
26
26
  Stack: ${a||"None"}`,d=`
27
27
  **Related Files:**
28
- ${Ce(n)}
28
+ ${ue(n)}
29
29
 
30
30
  **Source:**
31
31
  \`\`\`
32
32
  ${i}<cursor>${s}
33
33
  \`\`\`
34
34
 
35
- ${J(c)} the code at <cursor>.
35
+ ${J(l)} the code at <cursor>.
36
36
 
37
- Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:l,user:d}};var ge={createEndpoint:()=>E.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:S(t),...!o&&{temperature:.1},max_completion_tokens:500,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={createEndpoint:()=>E.groq,createRequestBody:(t,e)=>({model:S(t),temperature:.1,max_tokens:500,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},fe={createEndpoint:()=>E.anthropic,createRequestBody:(t,e)=>({model:S(t),temperature:.1,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:500}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},ye={createEndpoint:(t,e)=>`${E.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:S(t),system_instruction:{parts:{text:e.system}},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},L={openai:ge,groq:he,anthropic:fe,google:ye},te=(t,e,o)=>L[o].createEndpoint(t,e),oe=(t,e,o)=>L[e].createRequestBody(t,o),ne=(t,e)=>L[e].createHeaders(t),re=(t,e)=>L[e].parseCompletion(t),S=t=>Y[t];var Pe="\x1B[91m",ie="\x1B[93m",U="\x1B[0m",W="\x1B[1m",se=t=>t instanceof Error?t.message:typeof t=="string"?t:"An unknown error occurred",q=t=>{let e=se(t),o=`${Pe}${W}[MONACOPILOT ERROR] ${e}${U}`;return console.error(o),{message:e}},D=(t,e)=>{console.warn(`${ie}${W}[MONACOPILOT WARN] ${t}${e?`
38
- ${se(e)}`:""}${U}`);};var F=(t,e,o)=>console.warn(`${ie}${W}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${U}`);var G=class{constructor(e,o){this.validateParams(e,o),this.apiKey=e,this.provider=o.provider,this.model=o.model,this.validateInputs();}validateParams(e,o){if(!e)throw new Error("Please provide an API key.");if(!o||typeof o=="object"&&Object.keys(o).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||!j.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${M(j)}`);if(typeof this.model=="string"&&!V[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${M(V[this.provider])}`)}async complete(e){let{body:o,options:n}=e,{completionMetadata:r}=o,{headers:i={},customPrompt:s}=n??{},c=this.generatePrompt(r,s),{endpoint:a,requestBody:l,headers:d}=this.prepareRequestDetails(c);try{let p=await this.sendCompletionRequest(a,l,{...d,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let n=ee(e);return o?{...n,...o(e)}:n}prepareRequestDetails(e){if(typeof this.model=="object"&&"config"in this.model){let o=this.model.config(this.apiKey,e),n=o.endpoint,r=o.body??{},i=o.headers??{};return {endpoint:n,requestBody:r,headers:i}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let o=te(this.model,this.apiKey,this.provider),n=ne(this.apiKey,this.provider),r=oe(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}}async sendCompletionRequest(e,o,n){return O.POST(e,o,{headers:n})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&F("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:re(e,this.provider),raw:e}}}handleCompletionError(e){return {error:q(e).message,completion:null}}};var k=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,n=e,r;for(;(r=o.exec(e))!==null;){let i=r[0],s=i.split(`
37
+ Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:c,user:d}};var Ce={createEndpoint:()=>E.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:S(t),...!o&&{temperature:.1},max_completion_tokens:500,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},ge={createEndpoint:()=>E.groq,createRequestBody:(t,e)=>({model:S(t),temperature:.1,max_tokens:500,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={createEndpoint:()=>E.anthropic,createRequestBody:(t,e)=>({model:S(t),temperature:.1,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:500}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},fe={createEndpoint:(t,e)=>`${E.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:S(t),system_instruction:{parts:{text:e.system}},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},L={openai:Ce,groq:ge,anthropic:he,google:fe},ee=(t,e,o)=>L[o].createEndpoint(t,e),te=(t,e,o)=>L[e].createRequestBody(t,o),oe=(t,e)=>L[e].createHeaders(t),ne=(t,e)=>L[e].parseCompletion(t),S=t=>X[t];var ye="\x1B[91m",re="\x1B[93m",U="\x1B[0m",W="\x1B[1m",ie=t=>t instanceof Error?t.message:typeof t=="string"?t:"An unknown error occurred",q=t=>{let e=ie(t),o=`${ye}${W}[MONACOPILOT ERROR] ${e}${U}`;return console.error(o),{message:e}},F=(t,e)=>{console.warn(`${re}${W}[MONACOPILOT WARN] ${t}${e?`
38
+ ${ie(e)}`:""}${U}`);};var k=(t,e,o)=>console.warn(`${re}${W}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${U}`);var G=class{constructor(e,o){this.validateParams(e,o),this.apiKey=e,this.provider=o.provider,this.model=o.model,this.validateInputs();}validateParams(e,o){if(!e)throw new Error("Please provide an API key.");if(!o||typeof o=="object"&&Object.keys(o).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||!j.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${M(j)}`);if(typeof this.model=="string"&&!V[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${M(V[this.provider])}`)}async complete(e){let{body:o,options:n}=e,{completionMetadata:r}=o,{headers:i={},customPrompt:s}=n??{},l=this.generatePrompt(r,s),{endpoint:a,requestBody:c,headers:d}=this.prepareRequestDetails(l);try{let p=await this.sendCompletionRequest(a,c,{...d,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let n=Q(e);return o?{...n,...o(e)}:n}prepareRequestDetails(e){if(typeof this.model=="object"&&"config"in this.model){let o=this.model.config(this.apiKey,e),n=o.endpoint,r=o.body??{},i=o.headers??{};return {endpoint:n,requestBody:r,headers:i}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let o=ee(this.model,this.apiKey,this.provider),n=oe(this.apiKey,this.provider),r=te(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}}async sendCompletionRequest(e,o,n){return O.POST(e,o,{headers:n})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&k("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:ne(e,this.provider),raw:e}}}handleCompletionError(e){return {error:q(e).message,completion:null}}};var B=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,n=e,r;for(;(r=o.exec(e))!==null;){let i=r[0],s=i.split(`
39
39
  `).slice(1,-1).join(`
40
40
  `);n=n.replace(i,s);}return n.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
41
41
 
42
- `),this}build(){return this.formattedCompletion}};var B=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let o;return this.size===this.capacity&&(o=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,o}dequeue(){if(this.size===0)return;let e=this.buffer[this.head];return this.buffer[this.head]=void 0,this.head=(this.head+1)%this.capacity,this.size--,e}getAll(){return this.buffer.filter(e=>e!==void 0)}clear(){this.buffer=new Array(this.capacity),this.head=0,this.tail=0,this.size=0;}getSize(){return this.size}isEmpty(){return this.size===0}isFull(){return this.size===this.capacity}};var $=class ${constructor(){this.cache=new B($.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(n=>this.isValidCacheItem(n,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,n){let r=n.getValueInRange(e.range),i=T(o,n);return i.length<e.textBeforeCursor.length||!i.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,o,r)}isPositionValid(e,o,n){let{range:r,completion:i}=e,{startLineNumber:s,startColumn:c,endLineNumber:a,endColumn:l}=r,{lineNumber:d,column:p}=o;if(!i.startsWith(n))return !1;let u=d===s&&p===c;if(s===a)return u||d===s&&p>=c&&p<=l;let C=d>s&&d<a?!0:d===s&&p>=c||d===a&&p<=l;return u||C}};$.MAX_CACHE_SIZE=10;var N=$;var _=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,n){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let r=n.getOffsetAt(e),i=n.getValue().substring(0,r),s=n.getValue().substring(r),c=0,a=0,l=0,d=0,p=o.length,u=i.length,C=s.length;if(r>=n.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(C===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let f=Math.min(p,u);for(let m=1;m<=f;m++){let R=o.substring(0,m),me=i.slice(-m);R===me&&(d=m);}let P=Math.min(p,C);for(let m=0;m<P&&o[m]===s[m];m++)c++;for(let m=1;m<=P;m++)o.slice(-m)===s.slice(0,m)&&(a=m);if(l=Math.max(c,a),l===0){for(let m=1;m<p;m++)if(s.startsWith(o.substring(m))){l=p-m;break}}let y=d>0?n.getPositionAt(r-d):e,g=r+l,h=n.getPositionAt(g);return new this.monaco.Range(y.lineNumber,y.column,h.lineNumber,h.column)}computeCacheRange(e,o){let n=e.lineNumber,r=e.column,i=o.split(`
43
- `),s=i.length-1,c=n+s,a=s===0?r+i[0].length:i[s].length+1;return new this.monaco.Range(n,r,c,a)}};var Re="application/json",ae=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:r}=await O.POST(e,o,{headers:{"Content-Type":Re},fallbackError:"Error while fetching completion item"});if(r)throw new Error(r);return {completion:n}},le=({pos:t,mdl:e,options:o})=>{let{filename:n,language:r,technologies:i,relatedFiles:s,maxContextLines:c}=o,a=Te(t,e),d=!!s?.length?3:2,p=c?Math.floor(c/d):void 0,u=(g,h,m)=>{let R=g(t,e);return h?z(R,h,m):R},C=(g,h)=>!g||!h?g:g.map(({content:m,...R})=>({...R,content:z(m,h)})),f=u(T,p,{from:"end"}),P=u(K,p),y=C(s,p);return {filename:n,language:r,technologies:i,relatedFiles:y,textBeforeCursor:f,textAfterCursor:P,cursorPosition:t,editorState:{completionMode:a}}},Te=(t,e)=>{let o=Z(t,e),n=K(t,e);return o?"insert":n.trim()?"complete":"continue"};var b=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var X={onTyping:200,onIdle:600,onDemand:0},xe=t=>({onTyping:I(t,X.onTyping),onIdle:I(t,X.onIdle),onDemand:I(t,X.onDemand)}),H=new N,Ee=async({monaco:t,mdl:e,pos:o,token:n,isCompletionAccepted:r,onShowCompletion:i,options:s})=>{let{trigger:c="onIdle",endpoint:a,enableCaching:l=!0,onError:d,requestHandler:p}=s;if(l){let u=H.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return i(),b(u)}if(n.isCancellationRequested||r)return b([]);try{let C=xe(p??ae)[c];n.onCancellationRequested(()=>{C.cancel();});let f=le({pos:o,mdl:e,options:s}),{completion:P}=await C({endpoint:a,body:{completionMetadata:f}});if(P){let y=k.create(P).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),g=new _(t),h=g.computeInsertionRange(o,y,e),m=g.computeCacheRange(o,y);return l&&H.add({completion:y,range:m,textBeforeCursor:T(o,e)}),i(),b([{insertText:y,range:h}])}}catch(u){if(Me(u))return b([]);d?d(u):D("Cannot provide completion",u);}return b([])},Me=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,pe=Ee;var x=new WeakMap,v=null,ce=(t,e,o)=>{v&&v.deregister();let n=[],r={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};x.set(e,r),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,l,d,p)=>{let u=x.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return pe({monaco:t,mdl:a,pos:l,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});n.push(i);let s=e.onKeyDown(a=>{let l=x.get(e);if(!l)return;let d=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;l.isCompletionVisible&&d?(l.isCompletionAccepted=!0,l.isCompletionVisible=!1):l.isCompletionAccepted=!1;});n.push(s);let c={deregister:()=>{n.forEach(a=>a.dispose()),H.clear(),x.delete(e),v=null;},trigger:()=>ve(e)};return v=c,c}catch(i){return o.onError?o.onError(i):q(i),{deregister:()=>{n.forEach(s=>s.dispose()),x.delete(e),v=null;},trigger:()=>{}}}},ve=t=>{let e=x.get(t);if(!e){D("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},Oe=(...t)=>(F("registerCopilot","registerCompletion"),ce(...t));
42
+ `),this}build(){return this.formattedCompletion}};var D=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let o;return this.size===this.capacity&&(o=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,o}dequeue(){if(this.size===0)return;let e=this.buffer[this.head];return this.buffer[this.head]=void 0,this.head=(this.head+1)%this.capacity,this.size--,e}getAll(){return this.buffer.filter(e=>e!==void 0)}clear(){this.buffer=new Array(this.capacity),this.head=0,this.tail=0,this.size=0;}getSize(){return this.size}isEmpty(){return this.size===0}isFull(){return this.size===this.capacity}};var $=class ${constructor(){this.cache=new D($.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(n=>this.isValidCacheItem(n,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,n){let r=n.getValueInRange(e.range),i=T(o,n);return i.length<e.textBeforeCursor.length||!i.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,o,r)}isPositionValid(e,o,n){let{range:r,completion:i}=e,{startLineNumber:s,startColumn:l,endLineNumber:a,endColumn:c}=r,{lineNumber:d,column:p}=o;if(!i.startsWith(n))return !1;let u=d===s&&p===l;if(s===a)return u||d===s&&p>=l&&p<=c;let C=d>s&&d<a?!0:d===s&&p>=l||d===a&&p<=c;return u||C}};$.MAX_CACHE_SIZE=10;var N=$;var _=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,n){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let r=n.getOffsetAt(e),i=n.getValue().substring(0,r),s=n.getValue().substring(r),l=0,a=0,c=0,d=0,p=o.length,u=i.length,C=s.length;if(r>=n.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(C===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let P=Math.min(p,u);for(let m=1;m<=P;m++){let R=o.substring(0,m),ce=i.slice(-m);R===ce&&(d=m);}let g=Math.min(p,C);for(let m=0;m<g&&o[m]===s[m];m++)l++;for(let m=1;m<=g;m++)o.slice(-m)===s.slice(0,m)&&(a=m);if(c=Math.max(l,a),c===0){for(let m=1;m<p;m++)if(s.startsWith(o.substring(m))){c=p-m;break}}let y=d>0?n.getPositionAt(r-d):e,h=r+c,f=n.getPositionAt(h);return new this.monaco.Range(y.lineNumber,y.column,f.lineNumber,f.column)}computeCacheRange(e,o){let n=e.lineNumber,r=e.column,i=o.split(`
43
+ `),s=i.length-1,l=n+s,a=s===0?r+i[0].length:i[s].length+1;return new this.monaco.Range(n,r,l,a)}};var Pe="application/json",se=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:r}=await O.POST(e,o,{headers:{"Content-Type":Pe},fallbackError:"Error while fetching completion item"});if(r)throw new Error(r);return {completion:n}},ae=({pos:t,mdl:e,options:o})=>{let{filename:n,language:r,technologies:i,relatedFiles:s,maxContextLines:l}=o,a=Re(t,e),d=!!s?.length?3:2,p=l?Math.floor(l/d):void 0,u=(h,f,m)=>{let R=h(t,e);return f?z(R,f,m):R},C=(h,f)=>!h||!f?h:h.map(({content:m,...R})=>({...R,content:z(m,f)})),P=u(T,p,{from:"end"}),g=u(K,p),y=C(s,p);return {filename:n,language:r,technologies:i,relatedFiles:y,textBeforeCursor:P,textAfterCursor:g,cursorPosition:t,editorState:{completionMode:a}}},Re=(t,e)=>{let o=Y(t,e),n=K(t,e);return o?"insert":n.trim()?"complete":"continue"};var x=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var xe=t=>({onTyping:I(t,600,200),onIdle:I(t,650,250),onDemand:I(t,0,0)}),H=new N,be=async({monaco:t,mdl:e,pos:o,token:n,isCompletionAccepted:r,onShowCompletion:i,options:s})=>{let{trigger:l="onIdle",endpoint:a,enableCaching:c=!0,onError:d,requestHandler:p}=s;if(c){let u=H.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return i(),x(u)}if(n.isCancellationRequested||r)return x([]);try{let C=xe(p??se)[l];n.onCancellationRequested(()=>{C.cancel();});let P=ae({pos:o,mdl:e,options:s}),{completion:g}=await C({endpoint:a,body:{completionMetadata:P}});if(g){let y=B.create(g).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),h=new _(t),f=h.computeInsertionRange(o,y,e),m=h.computeCacheRange(o,y);return c&&H.add({completion:y,range:m,textBeforeCursor:T(o,e)}),i(),x([{insertText:y,range:f}])}}catch(u){if(Ee(u))return x([]);d?d(u):F("Cannot provide completion",u);}return x([])},Ee=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,le=be;var b=new WeakMap,v=null,pe=(t,e,o)=>{v&&v.deregister();let n=[],r={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};b.set(e,r),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,c,d,p)=>{let u=b.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return le({monaco:t,mdl:a,pos:c,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});n.push(i);let s=e.onKeyDown(a=>{let c=b.get(e);if(!c)return;let d=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;c.isCompletionVisible&&d?(c.isCompletionAccepted=!0,c.isCompletionVisible=!1):c.isCompletionAccepted=!1;});n.push(s);let l={deregister:()=>{n.forEach(a=>a.dispose()),H.clear(),b.delete(e),v=null;},trigger:()=>Me(e)};return v=l,l}catch(i){return o.onError?o.onError(i):q(i),{deregister:()=>{n.forEach(s=>s.dispose()),b.delete(e),v=null;},trigger:()=>{}}}},Me=t=>{let e=b.get(t);if(!e){F("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},ve=(...t)=>(k("registerCopilot","registerCompletion"),pe(...t));
44
44
 
45
45
  exports.Copilot = G;
46
- exports.registerCompletion = ce;
47
- exports.registerCopilot = Oe;
46
+ exports.registerCompletion = pe;
47
+ exports.registerCopilot = ve;
package/build/index.mjs CHANGED
@@ -1,10 +1,10 @@
1
- var j=["groq","openai","anthropic","google"],Y={"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"},V={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"]},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"};var M=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,J=t=>t.charAt(0).toUpperCase()+t.slice(1),z=(t,e,o={})=>{if(e<=0)return "";let n=t.split(`
2
- `),r=n.length;if(e>=r)return t;if(o.from==="end"){let s=n.slice(-e);return s.every(c=>c==="")?`
1
+ var j=["groq","openai","anthropic","google"],X={"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"},V={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"]},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"};var M=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,J=t=>t.charAt(0).toUpperCase()+t.slice(1),z=(t,e,o={})=>{if(e<=0)return "";let n=t.split(`
2
+ `),r=n.length;if(e>=r)return t;if(o.from==="end"){let s=n.slice(-e);return s.every(l=>l==="")?`
3
3
  `.repeat(e):s.join(`
4
4
  `)}let i=n.slice(0,e);return i.every(s=>s==="")?`
5
5
  `.repeat(e):i.join(`
6
- `)};var Z=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var T=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),K=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var Q=async(t,e,o={})=>{let n=o.timeout??3e4,r=AbortSignal.timeout(n),i=o.signal?AbortSignal.any([r,o.signal]):r,s={"Content-Type":"application/json",...o.headers},c=e==="POST"&&o.body?JSON.stringify(o.body):void 0,a=await fetch(t,{method:e,headers:s,body:c,signal:i});if(!a.ok){let l=await a.json().catch(()=>null),d=l?`
7
- ${JSON.stringify(l,null,2)}`:"",p=o.fallbackError||"Network request failed";throw new Error(`${p} (${a.status})${d}`)}return a.json()},de=(t,e)=>Q(t,"GET",e),ue=(t,e,o)=>Q(t,"POST",{...o,body:e}),O={GET:de,POST:ue};var I=(t,e=600,o=200)=>{let n=null,r=0,i=null,s=null,c=(...a)=>{i=a;let l=Date.now(),d=l-r;r=l,n&&(clearTimeout(n),n=null);let p=d<o?e:o;return s=new Promise((u,C)=>{n=setTimeout(async()=>{try{if(i){let f=await t(...i);u(f);}}catch(f){C(f);}finally{n=null,i=null;}},p);}),s};return c.cancel=()=>{n&&(clearTimeout(n),n=null),i=null;},c};var Ce=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
6
+ `)};var Y=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var T=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),K=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var Z=async(t,e,o={})=>{let n=o.timeout??3e4,r=AbortSignal.timeout(n),i=o.signal?AbortSignal.any([r,o.signal]):r,s={"Content-Type":"application/json",...o.headers},l=e==="POST"&&o.body?JSON.stringify(o.body):void 0,a=await fetch(t,{method:e,headers:s,body:l,signal:i});if(!a.ok){let c=await a.json().catch(()=>null),d=c?`
7
+ ${JSON.stringify(c,null,2)}`:"",p=o.fallbackError||"Network request failed";throw new Error(`${p} (${a.status})${d}`)}return a.json()},de=(t,e)=>Z(t,"GET",e),me=(t,e,o)=>Z(t,"POST",{...o,body:e}),O={GET:de,POST:me};var I=(t,e=600,o=200)=>{let n=null,r=0,i=null,s=null,l=!1,a=(...c)=>{if(l)return Promise.resolve(void 0);i=c;let d=Date.now(),p=d-r;r=d,n&&(clearTimeout(n),n=null);let u=p<o?e:o;return s=new Promise((C,P)=>{n=setTimeout(async()=>{l=!0;try{if(i){let g=await t(...i);C(g);}else C(void 0);}catch(g){P(g);}finally{l=!1,n=null,i=null;}},u);}),s};return a.cancel=()=>{n&&(clearTimeout(n),n=null),i=null;},a};var ue=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
8
8
  <related_file>
9
9
  <filePath>${e}</filePath>
10
10
  <fileContent>
@@ -14,30 +14,30 @@ ${o}
14
14
  </fileContent>
15
15
  </related_file>`.trim()).join(`
16
16
 
17
- `),ee=t=>{let{technologies:e=[],filename:o,relatedFiles:n,language:r,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:c}}=t,a=M([r,...e].filter(p=>typeof p=="string"&&!!p)),l=`
17
+ `),Q=t=>{let{technologies:e=[],filename:o,relatedFiles:n,language:r,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:l}}=t,a=M([r,...e].filter(p=>typeof p=="string"&&!!p)),c=`
18
18
  You are an expert code completion assistant.
19
19
 
20
20
  **Context:**
21
21
  File: ${o||"Untitled"}
22
22
  Language: ${r||"Undetermined"}
23
- Mode: ${c}
23
+ Mode: ${l}
24
24
  Stack: ${a||"None"}`,d=`
25
25
  **Related Files:**
26
- ${Ce(n)}
26
+ ${ue(n)}
27
27
 
28
28
  **Source:**
29
29
  \`\`\`
30
30
  ${i}<cursor>${s}
31
31
  \`\`\`
32
32
 
33
- ${J(c)} the code at <cursor>.
33
+ ${J(l)} the code at <cursor>.
34
34
 
35
- Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:l,user:d}};var ge={createEndpoint:()=>E.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:S(t),...!o&&{temperature:.1},max_completion_tokens:500,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={createEndpoint:()=>E.groq,createRequestBody:(t,e)=>({model:S(t),temperature:.1,max_tokens:500,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},fe={createEndpoint:()=>E.anthropic,createRequestBody:(t,e)=>({model:S(t),temperature:.1,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:500}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},ye={createEndpoint:(t,e)=>`${E.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:S(t),system_instruction:{parts:{text:e.system}},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},L={openai:ge,groq:he,anthropic:fe,google:ye},te=(t,e,o)=>L[o].createEndpoint(t,e),oe=(t,e,o)=>L[e].createRequestBody(t,o),ne=(t,e)=>L[e].createHeaders(t),re=(t,e)=>L[e].parseCompletion(t),S=t=>Y[t];var Pe="\x1B[91m",ie="\x1B[93m",U="\x1B[0m",W="\x1B[1m",se=t=>t instanceof Error?t.message:typeof t=="string"?t:"An unknown error occurred",q=t=>{let e=se(t),o=`${Pe}${W}[MONACOPILOT ERROR] ${e}${U}`;return console.error(o),{message:e}},D=(t,e)=>{console.warn(`${ie}${W}[MONACOPILOT WARN] ${t}${e?`
36
- ${se(e)}`:""}${U}`);};var F=(t,e,o)=>console.warn(`${ie}${W}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${U}`);var G=class{constructor(e,o){this.validateParams(e,o),this.apiKey=e,this.provider=o.provider,this.model=o.model,this.validateInputs();}validateParams(e,o){if(!e)throw new Error("Please provide an API key.");if(!o||typeof o=="object"&&Object.keys(o).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||!j.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${M(j)}`);if(typeof this.model=="string"&&!V[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${M(V[this.provider])}`)}async complete(e){let{body:o,options:n}=e,{completionMetadata:r}=o,{headers:i={},customPrompt:s}=n??{},c=this.generatePrompt(r,s),{endpoint:a,requestBody:l,headers:d}=this.prepareRequestDetails(c);try{let p=await this.sendCompletionRequest(a,l,{...d,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let n=ee(e);return o?{...n,...o(e)}:n}prepareRequestDetails(e){if(typeof this.model=="object"&&"config"in this.model){let o=this.model.config(this.apiKey,e),n=o.endpoint,r=o.body??{},i=o.headers??{};return {endpoint:n,requestBody:r,headers:i}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let o=te(this.model,this.apiKey,this.provider),n=ne(this.apiKey,this.provider),r=oe(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}}async sendCompletionRequest(e,o,n){return O.POST(e,o,{headers:n})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&F("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:re(e,this.provider),raw:e}}}handleCompletionError(e){return {error:q(e).message,completion:null}}};var k=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,n=e,r;for(;(r=o.exec(e))!==null;){let i=r[0],s=i.split(`
35
+ Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:c,user:d}};var Ce={createEndpoint:()=>E.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:S(t),...!o&&{temperature:.1},max_completion_tokens:500,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},ge={createEndpoint:()=>E.groq,createRequestBody:(t,e)=>({model:S(t),temperature:.1,max_tokens:500,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={createEndpoint:()=>E.anthropic,createRequestBody:(t,e)=>({model:S(t),temperature:.1,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:500}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},fe={createEndpoint:(t,e)=>`${E.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:S(t),system_instruction:{parts:{text:e.system}},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},L={openai:Ce,groq:ge,anthropic:he,google:fe},ee=(t,e,o)=>L[o].createEndpoint(t,e),te=(t,e,o)=>L[e].createRequestBody(t,o),oe=(t,e)=>L[e].createHeaders(t),ne=(t,e)=>L[e].parseCompletion(t),S=t=>X[t];var ye="\x1B[91m",re="\x1B[93m",U="\x1B[0m",W="\x1B[1m",ie=t=>t instanceof Error?t.message:typeof t=="string"?t:"An unknown error occurred",q=t=>{let e=ie(t),o=`${ye}${W}[MONACOPILOT ERROR] ${e}${U}`;return console.error(o),{message:e}},F=(t,e)=>{console.warn(`${re}${W}[MONACOPILOT WARN] ${t}${e?`
36
+ ${ie(e)}`:""}${U}`);};var k=(t,e,o)=>console.warn(`${re}${W}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${U}`);var G=class{constructor(e,o){this.validateParams(e,o),this.apiKey=e,this.provider=o.provider,this.model=o.model,this.validateInputs();}validateParams(e,o){if(!e)throw new Error("Please provide an API key.");if(!o||typeof o=="object"&&Object.keys(o).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||!j.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${M(j)}`);if(typeof this.model=="string"&&!V[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${M(V[this.provider])}`)}async complete(e){let{body:o,options:n}=e,{completionMetadata:r}=o,{headers:i={},customPrompt:s}=n??{},l=this.generatePrompt(r,s),{endpoint:a,requestBody:c,headers:d}=this.prepareRequestDetails(l);try{let p=await this.sendCompletionRequest(a,c,{...d,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let n=Q(e);return o?{...n,...o(e)}:n}prepareRequestDetails(e){if(typeof this.model=="object"&&"config"in this.model){let o=this.model.config(this.apiKey,e),n=o.endpoint,r=o.body??{},i=o.headers??{};return {endpoint:n,requestBody:r,headers:i}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let o=ee(this.model,this.apiKey,this.provider),n=oe(this.apiKey,this.provider),r=te(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}}async sendCompletionRequest(e,o,n){return O.POST(e,o,{headers:n})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&k("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:ne(e,this.provider),raw:e}}}handleCompletionError(e){return {error:q(e).message,completion:null}}};var B=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,n=e,r;for(;(r=o.exec(e))!==null;){let i=r[0],s=i.split(`
37
37
  `).slice(1,-1).join(`
38
38
  `);n=n.replace(i,s);}return n.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
39
39
 
40
- `),this}build(){return this.formattedCompletion}};var B=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let o;return this.size===this.capacity&&(o=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,o}dequeue(){if(this.size===0)return;let e=this.buffer[this.head];return this.buffer[this.head]=void 0,this.head=(this.head+1)%this.capacity,this.size--,e}getAll(){return this.buffer.filter(e=>e!==void 0)}clear(){this.buffer=new Array(this.capacity),this.head=0,this.tail=0,this.size=0;}getSize(){return this.size}isEmpty(){return this.size===0}isFull(){return this.size===this.capacity}};var $=class ${constructor(){this.cache=new B($.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(n=>this.isValidCacheItem(n,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,n){let r=n.getValueInRange(e.range),i=T(o,n);return i.length<e.textBeforeCursor.length||!i.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,o,r)}isPositionValid(e,o,n){let{range:r,completion:i}=e,{startLineNumber:s,startColumn:c,endLineNumber:a,endColumn:l}=r,{lineNumber:d,column:p}=o;if(!i.startsWith(n))return !1;let u=d===s&&p===c;if(s===a)return u||d===s&&p>=c&&p<=l;let C=d>s&&d<a?!0:d===s&&p>=c||d===a&&p<=l;return u||C}};$.MAX_CACHE_SIZE=10;var N=$;var _=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,n){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let r=n.getOffsetAt(e),i=n.getValue().substring(0,r),s=n.getValue().substring(r),c=0,a=0,l=0,d=0,p=o.length,u=i.length,C=s.length;if(r>=n.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(C===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let f=Math.min(p,u);for(let m=1;m<=f;m++){let R=o.substring(0,m),me=i.slice(-m);R===me&&(d=m);}let P=Math.min(p,C);for(let m=0;m<P&&o[m]===s[m];m++)c++;for(let m=1;m<=P;m++)o.slice(-m)===s.slice(0,m)&&(a=m);if(l=Math.max(c,a),l===0){for(let m=1;m<p;m++)if(s.startsWith(o.substring(m))){l=p-m;break}}let y=d>0?n.getPositionAt(r-d):e,g=r+l,h=n.getPositionAt(g);return new this.monaco.Range(y.lineNumber,y.column,h.lineNumber,h.column)}computeCacheRange(e,o){let n=e.lineNumber,r=e.column,i=o.split(`
41
- `),s=i.length-1,c=n+s,a=s===0?r+i[0].length:i[s].length+1;return new this.monaco.Range(n,r,c,a)}};var Re="application/json",ae=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:r}=await O.POST(e,o,{headers:{"Content-Type":Re},fallbackError:"Error while fetching completion item"});if(r)throw new Error(r);return {completion:n}},le=({pos:t,mdl:e,options:o})=>{let{filename:n,language:r,technologies:i,relatedFiles:s,maxContextLines:c}=o,a=Te(t,e),d=!!s?.length?3:2,p=c?Math.floor(c/d):void 0,u=(g,h,m)=>{let R=g(t,e);return h?z(R,h,m):R},C=(g,h)=>!g||!h?g:g.map(({content:m,...R})=>({...R,content:z(m,h)})),f=u(T,p,{from:"end"}),P=u(K,p),y=C(s,p);return {filename:n,language:r,technologies:i,relatedFiles:y,textBeforeCursor:f,textAfterCursor:P,cursorPosition:t,editorState:{completionMode:a}}},Te=(t,e)=>{let o=Z(t,e),n=K(t,e);return o?"insert":n.trim()?"complete":"continue"};var b=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var X={onTyping:200,onIdle:600,onDemand:0},xe=t=>({onTyping:I(t,X.onTyping),onIdle:I(t,X.onIdle),onDemand:I(t,X.onDemand)}),H=new N,Ee=async({monaco:t,mdl:e,pos:o,token:n,isCompletionAccepted:r,onShowCompletion:i,options:s})=>{let{trigger:c="onIdle",endpoint:a,enableCaching:l=!0,onError:d,requestHandler:p}=s;if(l){let u=H.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return i(),b(u)}if(n.isCancellationRequested||r)return b([]);try{let C=xe(p??ae)[c];n.onCancellationRequested(()=>{C.cancel();});let f=le({pos:o,mdl:e,options:s}),{completion:P}=await C({endpoint:a,body:{completionMetadata:f}});if(P){let y=k.create(P).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),g=new _(t),h=g.computeInsertionRange(o,y,e),m=g.computeCacheRange(o,y);return l&&H.add({completion:y,range:m,textBeforeCursor:T(o,e)}),i(),b([{insertText:y,range:h}])}}catch(u){if(Me(u))return b([]);d?d(u):D("Cannot provide completion",u);}return b([])},Me=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,pe=Ee;var x=new WeakMap,v=null,ce=(t,e,o)=>{v&&v.deregister();let n=[],r={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};x.set(e,r),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,l,d,p)=>{let u=x.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return pe({monaco:t,mdl:a,pos:l,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});n.push(i);let s=e.onKeyDown(a=>{let l=x.get(e);if(!l)return;let d=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;l.isCompletionVisible&&d?(l.isCompletionAccepted=!0,l.isCompletionVisible=!1):l.isCompletionAccepted=!1;});n.push(s);let c={deregister:()=>{n.forEach(a=>a.dispose()),H.clear(),x.delete(e),v=null;},trigger:()=>ve(e)};return v=c,c}catch(i){return o.onError?o.onError(i):q(i),{deregister:()=>{n.forEach(s=>s.dispose()),x.delete(e),v=null;},trigger:()=>{}}}},ve=t=>{let e=x.get(t);if(!e){D("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},Oe=(...t)=>(F("registerCopilot","registerCompletion"),ce(...t));
40
+ `),this}build(){return this.formattedCompletion}};var D=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let o;return this.size===this.capacity&&(o=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,o}dequeue(){if(this.size===0)return;let e=this.buffer[this.head];return this.buffer[this.head]=void 0,this.head=(this.head+1)%this.capacity,this.size--,e}getAll(){return this.buffer.filter(e=>e!==void 0)}clear(){this.buffer=new Array(this.capacity),this.head=0,this.tail=0,this.size=0;}getSize(){return this.size}isEmpty(){return this.size===0}isFull(){return this.size===this.capacity}};var $=class ${constructor(){this.cache=new D($.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(n=>this.isValidCacheItem(n,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,n){let r=n.getValueInRange(e.range),i=T(o,n);return i.length<e.textBeforeCursor.length||!i.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,o,r)}isPositionValid(e,o,n){let{range:r,completion:i}=e,{startLineNumber:s,startColumn:l,endLineNumber:a,endColumn:c}=r,{lineNumber:d,column:p}=o;if(!i.startsWith(n))return !1;let u=d===s&&p===l;if(s===a)return u||d===s&&p>=l&&p<=c;let C=d>s&&d<a?!0:d===s&&p>=l||d===a&&p<=c;return u||C}};$.MAX_CACHE_SIZE=10;var N=$;var _=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,n){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let r=n.getOffsetAt(e),i=n.getValue().substring(0,r),s=n.getValue().substring(r),l=0,a=0,c=0,d=0,p=o.length,u=i.length,C=s.length;if(r>=n.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(C===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let P=Math.min(p,u);for(let m=1;m<=P;m++){let R=o.substring(0,m),ce=i.slice(-m);R===ce&&(d=m);}let g=Math.min(p,C);for(let m=0;m<g&&o[m]===s[m];m++)l++;for(let m=1;m<=g;m++)o.slice(-m)===s.slice(0,m)&&(a=m);if(c=Math.max(l,a),c===0){for(let m=1;m<p;m++)if(s.startsWith(o.substring(m))){c=p-m;break}}let y=d>0?n.getPositionAt(r-d):e,h=r+c,f=n.getPositionAt(h);return new this.monaco.Range(y.lineNumber,y.column,f.lineNumber,f.column)}computeCacheRange(e,o){let n=e.lineNumber,r=e.column,i=o.split(`
41
+ `),s=i.length-1,l=n+s,a=s===0?r+i[0].length:i[s].length+1;return new this.monaco.Range(n,r,l,a)}};var Pe="application/json",se=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:r}=await O.POST(e,o,{headers:{"Content-Type":Pe},fallbackError:"Error while fetching completion item"});if(r)throw new Error(r);return {completion:n}},ae=({pos:t,mdl:e,options:o})=>{let{filename:n,language:r,technologies:i,relatedFiles:s,maxContextLines:l}=o,a=Re(t,e),d=!!s?.length?3:2,p=l?Math.floor(l/d):void 0,u=(h,f,m)=>{let R=h(t,e);return f?z(R,f,m):R},C=(h,f)=>!h||!f?h:h.map(({content:m,...R})=>({...R,content:z(m,f)})),P=u(T,p,{from:"end"}),g=u(K,p),y=C(s,p);return {filename:n,language:r,technologies:i,relatedFiles:y,textBeforeCursor:P,textAfterCursor:g,cursorPosition:t,editorState:{completionMode:a}}},Re=(t,e)=>{let o=Y(t,e),n=K(t,e);return o?"insert":n.trim()?"complete":"continue"};var x=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var xe=t=>({onTyping:I(t,600,200),onIdle:I(t,650,250),onDemand:I(t,0,0)}),H=new N,be=async({monaco:t,mdl:e,pos:o,token:n,isCompletionAccepted:r,onShowCompletion:i,options:s})=>{let{trigger:l="onIdle",endpoint:a,enableCaching:c=!0,onError:d,requestHandler:p}=s;if(c){let u=H.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return i(),x(u)}if(n.isCancellationRequested||r)return x([]);try{let C=xe(p??se)[l];n.onCancellationRequested(()=>{C.cancel();});let P=ae({pos:o,mdl:e,options:s}),{completion:g}=await C({endpoint:a,body:{completionMetadata:P}});if(g){let y=B.create(g).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),h=new _(t),f=h.computeInsertionRange(o,y,e),m=h.computeCacheRange(o,y);return c&&H.add({completion:y,range:m,textBeforeCursor:T(o,e)}),i(),x([{insertText:y,range:f}])}}catch(u){if(Ee(u))return x([]);d?d(u):F("Cannot provide completion",u);}return x([])},Ee=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,le=be;var b=new WeakMap,v=null,pe=(t,e,o)=>{v&&v.deregister();let n=[],r={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};b.set(e,r),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,c,d,p)=>{let u=b.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return le({monaco:t,mdl:a,pos:c,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});n.push(i);let s=e.onKeyDown(a=>{let c=b.get(e);if(!c)return;let d=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;c.isCompletionVisible&&d?(c.isCompletionAccepted=!0,c.isCompletionVisible=!1):c.isCompletionAccepted=!1;});n.push(s);let l={deregister:()=>{n.forEach(a=>a.dispose()),H.clear(),b.delete(e),v=null;},trigger:()=>Me(e)};return v=l,l}catch(i){return o.onError?o.onError(i):q(i),{deregister:()=>{n.forEach(s=>s.dispose()),b.delete(e),v=null;},trigger:()=>{}}}},Me=t=>{let e=b.get(t);if(!e){F("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},ve=(...t)=>(k("registerCopilot","registerCompletion"),pe(...t));
42
42
 
43
- export { G as Copilot, ce as registerCompletion, Oe as registerCopilot };
43
+ export { G as Copilot, pe as registerCompletion, ve as registerCopilot };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "monacopilot",
3
- "version": "0.16.2",
3
+ "version": "0.16.3",
4
4
  "description": "AI auto-completion plugin for Monaco Editor",
5
5
  "main": "./build/index.js",
6
6
  "module": "./build/index.mjs",