monacopilot 0.15.2 → 0.15.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 +28 -45
- package/build/index.mjs +27 -44
- package/package.json +1 -1
package/build/index.js
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
4
|
-
`),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(
|
|
3
|
+
var K=["groq","openai","anthropic","google"],J={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-mini":"o1-mini","gemini-1.5-flash-8b":"gemini-1.5-flash-8b","gemini-1.5-flash":"gemini-1.5-flash","gemini-1.5-pro":"gemini-1.5-pro"},U={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},Z="anthropic",Q="claude-3-5-haiku",O={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models"},M=.1;var T=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,W=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
|
|
4
|
+
`),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(l=>l==="")?`
|
|
5
5
|
`.repeat(e):s.join(`
|
|
6
6
|
`)}let i=r.slice(0,e);return i.every(s=>s==="")?`
|
|
7
7
|
`.repeat(e):i.join(`
|
|
8
8
|
`)};var I=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],A=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ee=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),h=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),L=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var te=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok){let s=`
|
|
9
|
-
`+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},
|
|
9
|
+
`+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},ge=(t,e)=>te(t,"GET",e),he=(t,e,o)=>te(t,"POST",{...o,body:e}),w={GET:ge,POST:he};var oe=(t,e)=>{let o=A(t,e).trim(),r=ee(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var D=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,l)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=l,o=setTimeout(()=>{s(t(...i)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var fe=t=>t?.length?t.map(({path:e,content:o})=>`
|
|
10
10
|
<related_file>
|
|
11
11
|
<path>${e}</path>
|
|
12
12
|
<content>
|
|
@@ -16,56 +16,39 @@ ${o}
|
|
|
16
16
|
</content>
|
|
17
17
|
</related_file>`.trim()).join(`
|
|
18
18
|
|
|
19
|
-
`):"",re=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:
|
|
19
|
+
`):"",re=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:l}}=t,a=T([n,...e].filter(p=>typeof p=="string"&&!!p)),c=`You are an expert ${a?`${a} `:""}AI code completion assistant. Generate precise, contextually-aware code completions by:
|
|
20
20
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
- Completion mode: ${a}
|
|
21
|
+
1. Analyzing code context, patterns and conventions
|
|
22
|
+
2. Determining appropriate completions based on mode and context
|
|
23
|
+
3. Ensuring proper formatting and style consistency
|
|
24
|
+
4. Respect the monaco editor's inline suggest subwordSmart mode
|
|
26
25
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
5. Preserve proper spacing and indentation:
|
|
33
|
-
- Add spaces between tokens for readability
|
|
34
|
-
- Match existing indentation patterns
|
|
35
|
-
- Use appropriate newlines for multi-line completions
|
|
36
|
-
6. Follow ${a} mode requirements:
|
|
37
|
-
${a==="continue"?"- Continue writing code naturally from cursor position":a==="insert"?"- Insert precisely fitting code between before/after cursor segments":"- Complete the current code block or structure"}
|
|
38
|
-
7. Respect Monaco editor's subwordSmart inline suggestion behavior
|
|
39
|
-
8. Ensure completions are syntactically correct and contextually appropriate
|
|
40
|
-
9. Consider and maintain consistency with any provided related files
|
|
26
|
+
Context:
|
|
27
|
+
- File: ${o||"current file"}
|
|
28
|
+
- Language: ${n||"detected from context"}
|
|
29
|
+
- Mode: ${l}
|
|
30
|
+
- Technologies: ${a||"inferred from context"}
|
|
41
31
|
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
32
|
+
Guidelines:
|
|
33
|
+
- Maintain consistent style and patterns
|
|
34
|
+
- Consider related files and context
|
|
35
|
+
- Follow mode-specific behavior (${l}):
|
|
36
|
+
${l==="continue"?"- Continue code naturally from cursor":l==="insert"?"- Insert precisely between segments":"- Complete current code block"}`,d=`Context:
|
|
37
|
+
1. Related Files:
|
|
38
|
+
${fe(r)}
|
|
45
39
|
|
|
46
|
-
2.
|
|
47
|
-
Output: " b, c" (note the spaces around parameters)
|
|
48
|
-
|
|
49
|
-
3. Input:
|
|
50
|
-
{
|
|
51
|
-
name: "John",
|
|
52
|
-
<cursor>
|
|
53
|
-
}
|
|
54
|
-
Output: "age: 30,
|
|
55
|
-
city: 'New York'" (note indentation)
|
|
56
|
-
|
|
57
|
-
Analyze all context carefully before generating completions. Ensure high relevance and accuracy.`,c=`${fe(r)}
|
|
58
|
-
|
|
59
|
-
Current code with cursor position:
|
|
40
|
+
2. Code State:
|
|
60
41
|
\`\`\`
|
|
61
42
|
${i}<cursor>${s}
|
|
62
|
-
|
|
43
|
+
\`\`\`
|
|
44
|
+
|
|
45
|
+
Generate appropriate code completion at <cursor> position (Output only code without any comments or explanations):`;return {system:c,user:d}};var ne={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var Pe={createEndpoint:()=>O.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:F(t),...!o&&{temperature:M},messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},ye={createEndpoint:()=>O.groq,createRequestBody:(t,e)=>({model:F(t),temperature:M,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Re={createEndpoint:()=>O.anthropic,createRequestBody:(t,e)=>({model:F(t),temperature:M,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ne[t]}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},xe={createEndpoint:(t,e)=>`${O.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:F(t),system_instruction:{parts:{text:e.system}},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},S={openai:Pe,groq:ye,anthropic:Re,google:xe},ie=(t,e,o)=>S[o].createEndpoint(t,e),se=(t,e,o)=>S[e].createRequestBody(t,o),ae=(t,e)=>S[e].createHeaders(t),le=(t,e)=>S[e].parseCompletion(t),F=t=>J[t];var Oe="\x1B[91m",pe="\x1B[93m",z="\x1B[0m",G="\x1B[1m",y=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${Oe}${G}[MONACOPILOT ERROR] ${e}${z}`;return console.error(o),{message:e}},de=t=>{console.warn(`${pe}${G}[MONACOPILOT WARN] ${t}${z}`);};var B=(t,e,o)=>console.warn(`${pe}${G}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${z}`);var Y=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??Z,this.model=o.model??Q,this.validateInputs();}validateInputs(){if(!K.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${T(K)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!U[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${T(U[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},l=this.generatePrompt(n,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 r=re(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=ie(this.model,this.apiKey,this.provider),r,n=ae(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let i=this.model.config(this.apiKey,e);o=i.endpoint??o,r=i.body??{},n={...n,...i.headers};}else r=se(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return w.POST(e,o,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&B("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return {completion:le(e,this.provider),raw:e}}handleCompletionError(e){return {error:y(e).message,completion:null}}};var N=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
|
|
63
46
|
`).slice(1,-1).join(`
|
|
64
47
|
`);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
65
48
|
|
|
66
|
-
`),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !oe(this.cursorPos,this.mdl)}};var
|
|
67
|
-
`),s=i.length-1,
|
|
49
|
+
`),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !oe(this.cursorPos,this.mdl)}};var _=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 C=class C{constructor(){this.cache=new _(C.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return h(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:l,endLineNumber:a,endColumn:c}=n,{lineNumber:d,column:p}=o,m=d===s&&p===l;if(s===a)return m||i.startsWith(r)&&d===s&&p>=l-C.LOOK_AROUND&&p<=c+C.LOOK_AROUND;let u=i.startsWith(r)&&d>=s&&d<=a&&(d===s&&p>=l-C.LOOK_AROUND||d===a&&p<=c+C.LOOK_AROUND||d>s&&d<a);return m||u}};C.MAX_CACHE_SIZE=10,C.LOOK_AROUND=10;var k=C;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,r){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=I(e,r),i=o[0];if(!n||i===n)return this.calculateRangeWithoutOverlap(e,o);let s=r.getOffsetAt(e),l=h(e,r),a=L(e,r);if(s>=r.getValue().length||!a.length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let c=this.getSuffixOverlapLength(o,l),d=this.computeMaxOverlapLength(o,a),p=c>0?r.getPositionAt(s-c):e,m=s+d,u=r.getPositionAt(m);return new this.monaco.Range(p.lineNumber,p.column,u.lineNumber,u.column)}calculateRangeWithoutOverlap(e,o){let r=e.lineNumber,n=e.column,i=o.split(`
|
|
50
|
+
`),s=i.length-1,l=r+s,a=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,l,a)}computeMaxOverlapLength(e,o){let r=this.getPrefixOverlapLength(e,o),n=this.getSuffixPrefixOverlapLength(e,o),i=Math.max(r,n);return i===0&&(i=this.getInternalOverlapLength(e,o)),i}getSuffixOverlapLength(e,o){let r=Math.min(e.length,o.length),n=0;for(let i=1;i<=r;i++)e.substring(0,i)===o.slice(-i)&&(n=i);return n}getPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=0;n<r;n++)if(e[n]!==o[n])return n;return r}getSuffixPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=r;n>0;n--)if(e.slice(-n)===o.slice(0,n))return n;return 0}getInternalOverlapLength(e,o){for(let r=1;r<e.length;r++)if(o.startsWith(e.substring(r)))return e.length-r;return 0}};var Te="application/json",ce=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await w.POST(e,o,{headers:{"Content-Type":Te},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},me=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:l}=o,a=Ee(t,e),d=!!s?.length?3:2,p=l?Math.floor(l/d):void 0,m=(P,g,V)=>{let b=P(t,e);return g?W(b,g,V):b},u=(P,g)=>!P||!g?P:P.map(({content:V,...b})=>({...b,content:W(V,g)})),j=m(h,p,{from:"end"}),v=m(L,p),x=u(s,p);return {filename:r,language:n,technologies:i,relatedFiles:x,textBeforeCursor:j,textAfterCursor:v,cursorPosition:t,editorState:{completionMode:a}}},Ee=(t,e)=>{let o=I(t,e),r=A(t,e);return o?"insert":r.trim()?"complete":"continue"};var f=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var X={onTyping:300,onIdle:600,onDemand:0},be=t=>({onTyping:D(t,X.onTyping),onIdle:D(t,X.onIdle),onDemand:D(t,X.onDemand)}),H=new k,Me=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:l="onIdle",endpoint:a,enableCaching:c=!0,onError:d,requestHandler:p}=s;if(!new q(o,e).shouldProvideCompletions())return f([]);if(c){let m=H.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(m.length>0)return i(),f(m)}if(r.isCancellationRequested||n)return f([]);try{let u=be(p??ce)[l];r.onCancellationRequested(()=>{u.cancel();});let j=me({pos:o,mdl:e,options:s}),{completion:v}=await u({endpoint:a,body:{completionMetadata:j}});if(v){let x=N.create(v).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),g=new $(t).computeInsertionRange(o,x,e);return c&&H.add({completion:x,range:g,textBeforeCursor:h(o,e)}),i(),f([{insertText:x,range:g}])}}catch(m){if(Ie(m))return f([]);d?d(m):y(m);}return f([])},Ie=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,ue=Me;var R=new WeakMap,E=null,Ce=(t,e,o)=>{E&&E.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};R.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,c,d,p)=>{let m=R.get(e);if(!(!m||o.trigger==="onDemand"&&!m.isManualTrigger))return ue({monaco:t,mdl:a,pos:c,token:p,isCompletionAccepted:m.isCompletionAccepted,onShowCompletion:()=>{m.isCompletionVisible=!0,m.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(a=>{let c=R.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;});r.push(s);let l={deregister:()=>{r.forEach(a=>a.dispose()),H.clear(),R.delete(e),E=null;},trigger:()=>Ae(e)};return E=l,l}catch(i){return o.onError?o.onError(i):y(i),{deregister:()=>{r.forEach(s=>s.dispose()),R.delete(e),E=null;},trigger:()=>{}}}},Ae=t=>{let e=R.get(t);if(!e){de("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},Le=(...t)=>(B("registerCopilot","registerCompletion"),Ce(...t));
|
|
68
51
|
|
|
69
|
-
exports.Copilot =
|
|
70
|
-
exports.registerCompletion =
|
|
52
|
+
exports.Copilot = Y;
|
|
53
|
+
exports.registerCompletion = Ce;
|
|
71
54
|
exports.registerCopilot = Le;
|
package/build/index.mjs
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
var
|
|
2
|
-
`),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(
|
|
1
|
+
var K=["groq","openai","anthropic","google"],J={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-mini":"o1-mini","gemini-1.5-flash-8b":"gemini-1.5-flash-8b","gemini-1.5-flash":"gemini-1.5-flash","gemini-1.5-pro":"gemini-1.5-pro"},U={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},Z="anthropic",Q="claude-3-5-haiku",O={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models"},M=.1;var T=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,W=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
|
|
2
|
+
`),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(l=>l==="")?`
|
|
3
3
|
`.repeat(e):s.join(`
|
|
4
4
|
`)}let i=r.slice(0,e);return i.every(s=>s==="")?`
|
|
5
5
|
`.repeat(e):i.join(`
|
|
6
6
|
`)};var I=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1],A=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ee=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),h=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),L=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var te=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok){let s=`
|
|
7
|
-
`+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},
|
|
7
|
+
`+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},ge=(t,e)=>te(t,"GET",e),he=(t,e,o)=>te(t,"POST",{...o,body:e}),w={GET:ge,POST:he};var oe=(t,e)=>{let o=A(t,e).trim(),r=ee(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var D=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,l)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=l,o=setTimeout(()=>{s(t(...i)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var fe=t=>t?.length?t.map(({path:e,content:o})=>`
|
|
8
8
|
<related_file>
|
|
9
9
|
<path>${e}</path>
|
|
10
10
|
<content>
|
|
@@ -14,54 +14,37 @@ ${o}
|
|
|
14
14
|
</content>
|
|
15
15
|
</related_file>`.trim()).join(`
|
|
16
16
|
|
|
17
|
-
`):"",re=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:
|
|
17
|
+
`):"",re=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n,textBeforeCursor:i="",textAfterCursor:s="",editorState:{completionMode:l}}=t,a=T([n,...e].filter(p=>typeof p=="string"&&!!p)),c=`You are an expert ${a?`${a} `:""}AI code completion assistant. Generate precise, contextually-aware code completions by:
|
|
18
18
|
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
- Completion mode: ${a}
|
|
19
|
+
1. Analyzing code context, patterns and conventions
|
|
20
|
+
2. Determining appropriate completions based on mode and context
|
|
21
|
+
3. Ensuring proper formatting and style consistency
|
|
22
|
+
4. Respect the monaco editor's inline suggest subwordSmart mode
|
|
24
23
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
5. Preserve proper spacing and indentation:
|
|
31
|
-
- Add spaces between tokens for readability
|
|
32
|
-
- Match existing indentation patterns
|
|
33
|
-
- Use appropriate newlines for multi-line completions
|
|
34
|
-
6. Follow ${a} mode requirements:
|
|
35
|
-
${a==="continue"?"- Continue writing code naturally from cursor position":a==="insert"?"- Insert precisely fitting code between before/after cursor segments":"- Complete the current code block or structure"}
|
|
36
|
-
7. Respect Monaco editor's subwordSmart inline suggestion behavior
|
|
37
|
-
8. Ensure completions are syntactically correct and contextually appropriate
|
|
38
|
-
9. Consider and maintain consistency with any provided related files
|
|
24
|
+
Context:
|
|
25
|
+
- File: ${o||"current file"}
|
|
26
|
+
- Language: ${n||"detected from context"}
|
|
27
|
+
- Mode: ${l}
|
|
28
|
+
- Technologies: ${a||"inferred from context"}
|
|
39
29
|
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
30
|
+
Guidelines:
|
|
31
|
+
- Maintain consistent style and patterns
|
|
32
|
+
- Consider related files and context
|
|
33
|
+
- Follow mode-specific behavior (${l}):
|
|
34
|
+
${l==="continue"?"- Continue code naturally from cursor":l==="insert"?"- Insert precisely between segments":"- Complete current code block"}`,d=`Context:
|
|
35
|
+
1. Related Files:
|
|
36
|
+
${fe(r)}
|
|
43
37
|
|
|
44
|
-
2.
|
|
45
|
-
Output: " b, c" (note the spaces around parameters)
|
|
46
|
-
|
|
47
|
-
3. Input:
|
|
48
|
-
{
|
|
49
|
-
name: "John",
|
|
50
|
-
<cursor>
|
|
51
|
-
}
|
|
52
|
-
Output: "age: 30,
|
|
53
|
-
city: 'New York'" (note indentation)
|
|
54
|
-
|
|
55
|
-
Analyze all context carefully before generating completions. Ensure high relevance and accuracy.`,c=`${fe(r)}
|
|
56
|
-
|
|
57
|
-
Current code with cursor position:
|
|
38
|
+
2. Code State:
|
|
58
39
|
\`\`\`
|
|
59
40
|
${i}<cursor>${s}
|
|
60
|
-
|
|
41
|
+
\`\`\`
|
|
42
|
+
|
|
43
|
+
Generate appropriate code completion at <cursor> position (Output only code without any comments or explanations):`;return {system:c,user:d}};var ne={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var Pe={createEndpoint:()=>O.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:F(t),...!o&&{temperature:M},messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},ye={createEndpoint:()=>O.groq,createRequestBody:(t,e)=>({model:F(t),temperature:M,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Re={createEndpoint:()=>O.anthropic,createRequestBody:(t,e)=>({model:F(t),temperature:M,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ne[t]}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{if(!t.content||!Array.isArray(t.content)||!t.content.length)return null;let e=t.content[0];return !e||typeof e!="object"?null:"text"in e&&typeof e.text=="string"?e.text:null}},xe={createEndpoint:(t,e)=>`${O.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:F(t),system_instruction:{parts:{text:e.system}},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},S={openai:Pe,groq:ye,anthropic:Re,google:xe},ie=(t,e,o)=>S[o].createEndpoint(t,e),se=(t,e,o)=>S[e].createRequestBody(t,o),ae=(t,e)=>S[e].createHeaders(t),le=(t,e)=>S[e].parseCompletion(t),F=t=>J[t];var Oe="\x1B[91m",pe="\x1B[93m",z="\x1B[0m",G="\x1B[1m",y=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${Oe}${G}[MONACOPILOT ERROR] ${e}${z}`;return console.error(o),{message:e}},de=t=>{console.warn(`${pe}${G}[MONACOPILOT WARN] ${t}${z}`);};var B=(t,e,o)=>console.warn(`${pe}${G}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${z}`);var Y=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??Z,this.model=o.model??Q,this.validateInputs();}validateInputs(){if(!K.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${T(K)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!U[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${T(U[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},l=this.generatePrompt(n,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 r=re(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=ie(this.model,this.apiKey,this.provider),r,n=ae(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let i=this.model.config(this.apiKey,e);o=i.endpoint??o,r=i.body??{},n={...n,...i.headers};}else r=se(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return w.POST(e,o,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&B("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return {completion:le(e,this.provider),raw:e}}handleCompletionError(e){return {error:y(e).message,completion:null}}};var N=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
|
|
61
44
|
`).slice(1,-1).join(`
|
|
62
45
|
`);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
63
46
|
|
|
64
|
-
`),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !oe(this.cursorPos,this.mdl)}};var
|
|
65
|
-
`),s=i.length-1,
|
|
47
|
+
`),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !oe(this.cursorPos,this.mdl)}};var _=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 C=class C{constructor(){this.cache=new _(C.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return h(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:l,endLineNumber:a,endColumn:c}=n,{lineNumber:d,column:p}=o,m=d===s&&p===l;if(s===a)return m||i.startsWith(r)&&d===s&&p>=l-C.LOOK_AROUND&&p<=c+C.LOOK_AROUND;let u=i.startsWith(r)&&d>=s&&d<=a&&(d===s&&p>=l-C.LOOK_AROUND||d===a&&p<=c+C.LOOK_AROUND||d>s&&d<a);return m||u}};C.MAX_CACHE_SIZE=10,C.LOOK_AROUND=10;var k=C;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,r){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=I(e,r),i=o[0];if(!n||i===n)return this.calculateRangeWithoutOverlap(e,o);let s=r.getOffsetAt(e),l=h(e,r),a=L(e,r);if(s>=r.getValue().length||!a.length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let c=this.getSuffixOverlapLength(o,l),d=this.computeMaxOverlapLength(o,a),p=c>0?r.getPositionAt(s-c):e,m=s+d,u=r.getPositionAt(m);return new this.monaco.Range(p.lineNumber,p.column,u.lineNumber,u.column)}calculateRangeWithoutOverlap(e,o){let r=e.lineNumber,n=e.column,i=o.split(`
|
|
48
|
+
`),s=i.length-1,l=r+s,a=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,l,a)}computeMaxOverlapLength(e,o){let r=this.getPrefixOverlapLength(e,o),n=this.getSuffixPrefixOverlapLength(e,o),i=Math.max(r,n);return i===0&&(i=this.getInternalOverlapLength(e,o)),i}getSuffixOverlapLength(e,o){let r=Math.min(e.length,o.length),n=0;for(let i=1;i<=r;i++)e.substring(0,i)===o.slice(-i)&&(n=i);return n}getPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=0;n<r;n++)if(e[n]!==o[n])return n;return r}getSuffixPrefixOverlapLength(e,o){let r=Math.min(e.length,o.length);for(let n=r;n>0;n--)if(e.slice(-n)===o.slice(0,n))return n;return 0}getInternalOverlapLength(e,o){for(let r=1;r<e.length;r++)if(o.startsWith(e.substring(r)))return e.length-r;return 0}};var Te="application/json",ce=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await w.POST(e,o,{headers:{"Content-Type":Te},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},me=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:l}=o,a=Ee(t,e),d=!!s?.length?3:2,p=l?Math.floor(l/d):void 0,m=(P,g,V)=>{let b=P(t,e);return g?W(b,g,V):b},u=(P,g)=>!P||!g?P:P.map(({content:V,...b})=>({...b,content:W(V,g)})),j=m(h,p,{from:"end"}),v=m(L,p),x=u(s,p);return {filename:r,language:n,technologies:i,relatedFiles:x,textBeforeCursor:j,textAfterCursor:v,cursorPosition:t,editorState:{completionMode:a}}},Ee=(t,e)=>{let o=I(t,e),r=A(t,e);return o?"insert":r.trim()?"complete":"continue"};var f=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var X={onTyping:300,onIdle:600,onDemand:0},be=t=>({onTyping:D(t,X.onTyping),onIdle:D(t,X.onIdle),onDemand:D(t,X.onDemand)}),H=new k,Me=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:l="onIdle",endpoint:a,enableCaching:c=!0,onError:d,requestHandler:p}=s;if(!new q(o,e).shouldProvideCompletions())return f([]);if(c){let m=H.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(m.length>0)return i(),f(m)}if(r.isCancellationRequested||n)return f([]);try{let u=be(p??ce)[l];r.onCancellationRequested(()=>{u.cancel();});let j=me({pos:o,mdl:e,options:s}),{completion:v}=await u({endpoint:a,body:{completionMetadata:j}});if(v){let x=N.create(v).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),g=new $(t).computeInsertionRange(o,x,e);return c&&H.add({completion:x,range:g,textBeforeCursor:h(o,e)}),i(),f([{insertText:x,range:g}])}}catch(m){if(Ie(m))return f([]);d?d(m):y(m);}return f([])},Ie=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,ue=Me;var R=new WeakMap,E=null,Ce=(t,e,o)=>{E&&E.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};R.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,c,d,p)=>{let m=R.get(e);if(!(!m||o.trigger==="onDemand"&&!m.isManualTrigger))return ue({monaco:t,mdl:a,pos:c,token:p,isCompletionAccepted:m.isCompletionAccepted,onShowCompletion:()=>{m.isCompletionVisible=!0,m.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(a=>{let c=R.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;});r.push(s);let l={deregister:()=>{r.forEach(a=>a.dispose()),H.clear(),R.delete(e),E=null;},trigger:()=>Ae(e)};return E=l,l}catch(i){return o.onError?o.onError(i):y(i),{deregister:()=>{r.forEach(s=>s.dispose()),R.delete(e),E=null;},trigger:()=>{}}}},Ae=t=>{let e=R.get(t);if(!e){de("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},Le=(...t)=>(B("registerCopilot","registerCompletion"),Ce(...t));
|
|
66
49
|
|
|
67
|
-
export {
|
|
50
|
+
export { Y as Copilot, Ce as registerCompletion, Le as registerCopilot };
|