monacopilot 1.2.1 → 1.2.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.global.js +9 -11
- package/package.json +2 -2
package/dist/index.global.js
CHANGED
|
@@ -1,26 +1,24 @@
|
|
|
1
|
-
var monacopilot=(function(exports){'use strict';var de
|
|
2
|
-
|
|
3
|
-
`;var $=["mistral"],ue={codestral:"codestral-latest"},U={mistral:["codestral"]},Ce={mistral:"https://api.mistral.ai/v1/fim/completions"},ge=class{},fe=class extends ge{createEndpoint(){return Ce.mistral}createRequestBody(t,e,o){return {model:ue[t],prompt:`${e.context}
|
|
1
|
+
var monacopilot=(function(exports){'use strict';var $=["mistral"],de={codestral:"codestral-latest"},j={mistral:["codestral"]},ue={mistral:"https://api.mistral.ai/v1/fim/completions"},Ce=class{},ge=class extends Ce{createEndpoint(){return ue.mistral}createRequestBody(t,e,o){return {model:de[t],prompt:`${e.context}
|
|
4
2
|
${e.instruction}
|
|
5
|
-
${o.textBeforeCursor}`,suffix:o.textAfterCursor,stream:false,top_p:.1,temperature:.1,max_tokens:256
|
|
6
|
-
${V(e)}`:""}${S}`);},
|
|
3
|
+
${o.textBeforeCursor}`,suffix:o.textAfterCursor,stream:false,top_p:.1,temperature:.1,max_tokens:256}}createHeaders(t){return {"Content-Type":"application/json",Authorization:`Bearer ${t}`}}parseCompletion(t){let e=t.choices?.[0]?.message.content;return e?Array.isArray(e)?e.filter(o=>"text"in o).map(o=>o.text).join(""):e:null}},P={mistral:new ge},fe=(t,e,o)=>P[o].createEndpoint(t,e),he=(t,e,o,r)=>P[e].createRequestBody(t,o,r),Ee=(t,e)=>P[e].createHeaders(t),ye=(t,e)=>P[e].parseCompletion(t),S="\x1B[0m",F="\x1B[1m",V=t=>t instanceof Error?t.message:typeof t=="string"?t:"An unknown error occurred",Re=t=>{let e=V(t),o=`${F}[MONACOPILOT ERROR] ${e}${S}`;return console.error(o),{message:e}},xe=(t,e)=>{console.warn(`${F}[MONACOPILOT WARN] ${t}${e?`
|
|
4
|
+
${V(e)}`:""}${S}`);},ve=(t,e,o)=>console.warn(`${F}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${S}`),f={report:Re,warn:xe,warnDeprecated:ve},Pe=async(t,e={},o=2e4)=>{let r=new AbortController,{signal:n}=r,i=setTimeout(()=>{r.abort();},o);try{return await fetch(t,{...e,signal:n})}catch(s){throw s instanceof DOMException&&s.name==="AbortError"?new Error(`Request timed out after ${o}ms`):s}finally{clearTimeout(i);}},U=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,Te=(t,e)=>{if(!t&&typeof e.model!="function")throw new Error(e.provider?`Please provide the ${e.provider} API key.`:"Please provide an API key.");if(!e||typeof e=="object"&&Object.keys(e).length===0)throw new Error('Please provide required Copilot options, such as "model" and "provider".')},be=(t,e)=>{if(typeof t=="function"&&e!==void 0)throw new Error("Provider should not be specified when using a custom model.");if(typeof t!="function"&&(!e||!$.includes(e)))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${U($)}`);if(typeof t=="string"&&e!==void 0&&!j[e].includes(t))throw new Error(`Model "${t}" is not supported by the "${e}" provider. Supported models: ${U(j[e])}`)},K={params:Te,inputs:be},H=class{constructor(t,e){K.params(t,e),this.apiKey=t??"",this.provider=e.provider,this.model=e.model,K.inputs(this.model,this.provider);}generatePrompt(t,e){let o=this.getDefaultPrompt(t);return e?{...o,...e(t)}:o}async makeAIRequest(t,e={}){try{let o=this.generatePrompt(t,e.customPrompt);if(this.isCustomModel())return this.model(o);{let{customHeaders:r={}}=e,n=await this.prepareRequest(o,t),i=await this.sendRequest(n.endpoint,n.requestBody,{...n.headers,...r});return this.processResponse(i)}}catch(o){return this.handleError(o)}}async prepareRequest(t,e){if(!this.provider)throw new Error("Provider is required for non-custom models");return {endpoint:fe(this.model,this.apiKey,this.provider),headers:Ee(this.apiKey,this.provider),requestBody:he(this.model,this.provider,t,e)}}processResponse(t){if(!this.provider)throw new Error("Provider is required for non-custom models");return {text:ye(t,this.provider),raw:t}}isCustomModel(){return typeof this.model=="function"}async sendRequest(t,e,o){let r=await Pe(t,{method:"POST",headers:{"Content-Type":"application/json",...o},body:JSON.stringify(e)});if(!r.ok)throw new Error(await r.text());return r.json()}handleError(t){return {text:null,error:f.report(t).message}}};var W=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`;var N=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
|
|
7
5
|
`),n=r.length;if(e>=n)return t;if(o.truncateDirection==="keepEnd"){let s=r.slice(-e);return s.every(a=>a==="")?`
|
|
8
6
|
`.repeat(e):s.join(`
|
|
9
7
|
`)}let i=r.slice(0,e);return i.every(s=>s==="")?`
|
|
10
8
|
`.repeat(e):i.join(`
|
|
11
|
-
`)};var
|
|
9
|
+
`)};var Oe="<|developer_cursor_is_here|>",z=t=>({instruction:Me(),context:Ie(t),fileContent:Le(t)}),Me=()=>"Provide concise and readable code completions that are syntactically and logically accurate, and seamlessly integrate with the existing context. Output only the raw code to be inserted at the cursor location without any additional text, comments, or text before or after the cursor.",Ie=t=>{let{technologies:e=[],filename:o,relatedFiles:r=[],language:n}=t,i=W([n,...e].filter(p=>!!p)),s=r.length===0?"":r.map(({path:p,content:l})=>`### ${p}
|
|
12
10
|
${l}`).join(`
|
|
13
11
|
|
|
14
12
|
`),a=[i?`Technology stack: ${i}`:"",`File: ${o||"unknown"}`].filter(Boolean).join(`
|
|
15
13
|
`);return `${s?`${s}
|
|
16
14
|
|
|
17
|
-
`:""}${a}`},
|
|
15
|
+
`:""}${a}`},Le=t=>{let{textBeforeCursor:e,textAfterCursor:o}=t;return `**Current code:**
|
|
18
16
|
\`\`\`
|
|
19
|
-
${e}${
|
|
20
|
-
\`\`\``};var T=class extends H{async complete(e){let{body:o,options:r}=e,{customPrompt:n,headers:i}=r??{},{completionMetadata:s}=o,{text:a,raw:p,error:l}=await this.makeAIRequest(s,{customPrompt:n,customHeaders:i});return {completion:a,raw:p,error:l}}getDefaultPrompt(e){return z(e)}};var X=100,Y=true,b="onIdle",J=true,
|
|
21
|
-
${l}`;}if(!(s.trim().includes(n)||n.includes(s.trim())))return false;let p=r.getValueInRange(e.range);return this.isPartialMatch(p,e.completion)?this.isPositionValid(e,o):false}isPartialMatch(e,o){let r=e.trim(),n=o.trim();return n.startsWith(r)||r.startsWith(n)}isPositionValid(e,o){let{range:r}=e,{startLineNumber:n,startColumn:i,endLineNumber:s,endColumn:a}=r,{lineNumber:p,column:l}=o;return p<n||p>s?false:n===s?l>=i-1&&l<=a+1:p===n?l>=i-1:p===s?l<=a+1:true}};
|
|
17
|
+
${e}${Oe}${o}
|
|
18
|
+
\`\`\``};var T=class extends H{async complete(e){let{body:o,options:r}=e,{customPrompt:n,headers:i}=r??{},{completionMetadata:s}=o,{text:a,raw:p,error:l}=await this.makeAIRequest(s,{customPrompt:n,customHeaders:i});return {completion:a,raw:p,error:l}}getDefaultPrompt(e){return z(e)}};var X=100,Y=true,b="onIdle",J=true,Z=120,Q=400,ee=0;var h=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),te=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())}),oe=t=>t.getValue();var O=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 I=class I{constructor(){this.cache=new O(I.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,o))}add(e){e.completion.trim()&&this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,r){let n=e.textBeforeCursor.trim(),i=h(o,r),s=i,a=r.getLineContent(o.lineNumber);if(o.column===a.length+1&&o.lineNumber<r.getLineCount()){let l=r.getLineContent(o.lineNumber+1);s=`${i}
|
|
19
|
+
${l}`;}if(!(s.trim().includes(n)||n.includes(s.trim())))return false;let p=r.getValueInRange(e.range);return this.isPartialMatch(p,e.completion)?this.isPositionValid(e,o):false}isPartialMatch(e,o){let r=e.trim(),n=o.trim();return n.startsWith(r)||r.startsWith(n)}isPositionValid(e,o){let{range:r}=e,{startLineNumber:n,startColumn:i,endLineNumber:s,endColumn:a}=r,{lineNumber:p,column:l}=o;return p<n||p>s?false:n===s?l>=i-1&&l<=a+1:p===n?l>=i-1:p===s?l<=a+1:true}};I.MAX_CACHE_SIZE=20;var M=I;var L=class{constructor(e){this.formattedCompletion="";this.formattedCompletion=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=e.split(`
|
|
22
20
|
`),r=[],n=false;for(let i=0;i<o.length;i++){let s=o[i],a=s.trim().startsWith("```");if(a&&!n){n=true;continue}if(a&&n){n=false;continue}r.push(s);}return r.join(`
|
|
23
21
|
`)}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
24
22
|
|
|
25
23
|
`),this}build(){return this.formattedCompletion}};var A=class{findOverlaps(e,o,r){if(!e)return {startOverlapLength:0,maxOverlapLength:0};let n=e.length,i=o.length,s=r.length,a=0,p=0,l=0,d=Math.min(n,i);for(let m=1;m<=d;m++){let u=e.substring(0,m),C=o.slice(-m);u===C&&(l=m);}let c=Math.min(n,s);for(let m=0;m<c&&e[m]===r[m];m++)a++;for(let m=1;m<=c;m++)e.slice(-m)===r.slice(0,m)&&(p=m);let g=Math.max(a,p);if(g===0){for(let m=1;m<n;m++)if(r.startsWith(e.substring(m))){g=n-m;break}}return {startOverlapLength:l,maxOverlapLength:g}}};var w=class{constructor(e){this.monaco=e;this.textOverlapCalculator=new A;}computeInsertionRange(e,o,r){if(!o)return this.createEmptyRange(e);let n=r.getOffsetAt(e),i=r.getValue().substring(0,n),s=r.getValue().substring(n);if(n>=r.getValue().length)return this.createEmptyRange(e);if(s.length===0)return this.createEmptyRange(e);let{startOverlapLength:a,maxOverlapLength:p}=this.textOverlapCalculator.findOverlaps(o,i,s),l=a>0?r.getPositionAt(n-a):e,d=n+p,c=r.getPositionAt(d);return new this.monaco.Range(l.lineNumber,l.column,c.lineNumber,c.column)}computeCacheRange(e,o){let r=e.lineNumber,n=e.column,i=o.split(`
|
|
26
|
-
`),s=i.length-1,a=r+s,p=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,a,p)}createEmptyRange(e){return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column)}};var re=async t=>{let{endpoint:e,body:o}=t,r=await fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(o)});if(!r.ok)throw new Error(`Error while fetching completion item: ${r.statusText}`);let{completion:n,error:i}=await r.json();return {completion:n,error:i}},ne=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:a=X}=o,l=s&&s.length>0?3:2,d=a?Math.floor(a/l):void 0,c=(y,R,_)=>{let v=y(t,e);return R?N(v,R,_):v},g=(y,R)=>!y||!R?y:y.map(({content:_,...v})=>({...v,content:N(_,R)})),m=c(h,d,{truncateDirection:"keepEnd"}),u=c(te,d,{truncateDirection:"keepStart"}),C=g(s,d);return {filename:r,language:n,technologies:i,relatedFiles:C,textBeforeCursor:m,textAfterCursor:u,cursorPosition:t}};var ie=(t,e=300)=>{let o=null,r=null,n=(...i)=>{if(r)return r.args=i,r.promise;let s,a,p=new Promise((l,d)=>{s=l,a=d;});return r={args:i,promise:p,resolve:s,reject:a},o&&(clearTimeout(o),o=null),o=setTimeout(async()=>{let l=r;if(l){r=null,o=null;try{let d=await t(...l.args);l.resolve(d);}catch(d){l.reject(d);}}},e),p};return n.cancel=()=>{o&&(clearTimeout(o),o=null),r&&(r.reject(new Error("Cancelled")),r=null);},n};var se=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":false;var E=t=>({items:t,enableForwardStability:true});var D=new
|
|
24
|
+
`),s=i.length-1,a=r+s,p=s===0?n+i[0].length:i[s].length+1;return new this.monaco.Range(r,n,a,p)}createEmptyRange(e){return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column)}};var re=async t=>{let{endpoint:e,body:o}=t,r=await fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(o)});if(!r.ok)throw new Error(`Error while fetching completion item: ${r.statusText}`);let{completion:n,error:i}=await r.json();return {completion:n,error:i}},ne=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:a=X}=o,l=s&&s.length>0?3:2,d=a?Math.floor(a/l):void 0,c=(y,R,_)=>{let v=y(t,e);return R?N(v,R,_):v},g=(y,R)=>!y||!R?y:y.map(({content:_,...v})=>({...v,content:N(_,R)})),m=c(h,d,{truncateDirection:"keepEnd"}),u=c(te,d,{truncateDirection:"keepStart"}),C=g(s,d);return {filename:r,language:n,technologies:i,relatedFiles:C,textBeforeCursor:m,textAfterCursor:u,cursorPosition:t}};var ie=(t,e=300)=>{let o=null,r=null,n=(...i)=>{if(r)return r.args=i,r.promise;let s,a,p=new Promise((l,d)=>{s=l,a=d;});return r={args:i,promise:p,resolve:s,reject:a},o&&(clearTimeout(o),o=null),o=setTimeout(async()=>{let l=r;if(l){r=null,o=null;try{let d=await t(...l.args);l.resolve(d);}catch(d){l.reject(d);}}},e),p};return n.cancel=()=>{o&&(clearTimeout(o),o=null),r&&(r.reject(new Error("Cancelled")),r=null);},n};var se=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":false;var E=t=>({items:t,enableForwardStability:true});var D=new M,ae=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,options:i})=>{let{trigger:s=b,enableCaching:a=Y,allowFollowUpCompletions:p=J,onError:l,requestHandler:d}=i;if(a&&!n){let c=D.get(o,e).map(g=>({insertText:g.completion,range:g.range}));if(c.length>0)return E(c)}if(r.isCancellationRequested||!p&&n)return E([]);try{let c=ie(async u=>{i.onCompletionRequested?.(u);let C;if(d)C=await d(u);else if(i.endpoint)C=await re({endpoint:i.endpoint,...u});else throw new Error('No endpoint specified for completion request. Please set the "endpoint" option in registerCompletion, or provide a custom requestHandler.');if(C.error)throw new Error(C.error);return i.onCompletionRequestFinished?.(u,C),C},{onTyping:Z,onIdle:Q,onDemand:ee}[s]);r.onCancellationRequested(()=>{c.cancel();});let g=ne({pos:o,mdl:e,options:i}),{completion:m}=await c({body:{completionMetadata:g}});if(m){let u=new L(m).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),C=new w(t);return a&&D.add({completion:u,range:C.computeCacheRange(o,u),textBeforeCursor:h(o,e)}),E([{insertText:u,range:C.computeInsertionRange(o,u,e)}])}}catch(c){if(se(c))return E([]);l?l(c):f.warn("Cannot provide completion",c);}return E([])};var k=new WeakMap,x=t=>k.get(t),le=(t,e)=>{k.set(t,e);},q=t=>{k.delete(t);},pe=()=>({isCompletionAccepted:false,isCompletionVisible:false,isExplicitlyTriggered:false,hasRejectedCurrentCompletion:false});var me=(t,e,o)=>{let r=x(e);return r?t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(n,i,s,a)=>{if(!(o.trigger==="onDemand"&&!r.isExplicitlyTriggered||o.triggerIf&&!o.triggerIf({text:oe(e),position:i,triggerType:o.trigger??b})))return ae({monaco:t,mdl:n,pos:i,token:a,isCompletionAccepted:r.isCompletionAccepted,options:o})},handleItemDidShow:(n,i,s)=>{r.isExplicitlyTriggered=false,r.hasRejectedCurrentCompletion=false,!r.isCompletionAccepted&&(r.isCompletionVisible=true,o.onCompletionShown?.(s,i.range));},freeInlineCompletions:()=>{}}):null};var Ae={TAB:(t,e)=>e.keyCode===t.KeyCode.Tab,CMD_RIGHT_ARROW:(t,e)=>e.keyCode===t.KeyCode.RightArrow&&e.metaKey},B=class{constructor(e,o,r){this.monaco=e;this.state=o;this.options=r;}handleKeyEvent(e){let o={monaco:this.monaco,event:e,state:this.state,options:this.options};this.handleCompletionAcceptance(o),this.handleCompletionRejection(o);}handleCompletionAcceptance(e){return e.state.isCompletionVisible&&this.isAcceptanceKey(e.event)?(e.options.onCompletionAccepted?.(),e.state.isCompletionAccepted=true,e.state.isCompletionVisible=false,true):(e.state.isCompletionAccepted=false,false)}handleCompletionRejection(e){return this.shouldRejectCompletion(e)?(e.options.onCompletionRejected?.(),e.state.hasRejectedCurrentCompletion=true,true):false}shouldRejectCompletion(e){return e.state.isCompletionVisible&&!e.state.hasRejectedCurrentCompletion&&!e.state.isCompletionAccepted&&!this.isAcceptanceKey(e.event)}isAcceptanceKey(e){return Object.values(Ae).some(o=>o(this.monaco,e))}},ce=(t,e,o,r)=>{let n=new B(t,o,r);return e.onKeyDown(i=>n.handleKeyEvent(i))};var we=(t,e,o)=>{let r=[];le(e,pe()),e.updateOptions({inlineSuggest:{enabled:true}});try{let n=x(e);if(!n)return f.warn("Completion is not registered properly. State not found."),_e();let i=me(t,e,o);i&&r.push(i);let s=ce(t,e,n,o);return r.push(s),{deregister:()=>{for(let p of r)p.dispose();D.clear(),q(e);},trigger:()=>De(e)}}catch(n){return o.onError?o.onError(n):f.report(n),{deregister:()=>{for(let i of r)i.dispose();q(e);},trigger:()=>{}}}},De=t=>{let e=x(t);if(!e){f.warn("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isExplicitlyTriggered=true,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});},_e=()=>({deregister:()=>{},trigger:()=>{}});var kt=T;exports.CompletionCopilot=T;exports.Copilot=kt;exports.registerCompletion=we;return exports;})({});
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "monacopilot",
|
|
3
|
-
"version": "1.2.
|
|
3
|
+
"version": "1.2.2",
|
|
4
4
|
"description": "AI auto-completion plugin for Monaco Editor",
|
|
5
5
|
"main": "./dist/index.js",
|
|
6
6
|
"module": "./dist/index.mjs",
|
|
@@ -37,7 +37,7 @@
|
|
|
37
37
|
"license": "MIT",
|
|
38
38
|
"author": "Arshad Yaseen <m@arshadyaseen.com> (https://arshadyaseen.com)",
|
|
39
39
|
"dependencies": {
|
|
40
|
-
"@monacopilot/core": "1.2.
|
|
40
|
+
"@monacopilot/core": "1.2.2"
|
|
41
41
|
},
|
|
42
42
|
"peerDependencies": {
|
|
43
43
|
"monaco-editor": ">=0.41.0"
|