monacopilot 0.12.3 → 0.12.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -17,10 +17,11 @@
17
17
  - [API Handler](#api-handler)
18
18
  - [Register Completion with the Monaco Editor](#register-completion-with-the-monaco-editor)
19
19
  - [Register Completion Options](#register-completion-options)
20
- - [Get Completions in Real-Time](#get-completions-in-real-time)
21
- - [Manually Trigger Completions](#manually-trigger-completions)
22
- - [Trigger Completions with a Keyboard Shortcut](#trigger-completions-with-a-keyboard-shortcut)
23
- - [Trigger Completions with an Editor Action](#trigger-completions-with-an-editor-action)
20
+ - [Trigger Mode](#trigger-mode)
21
+ - [Get Completions in Real-Time](#get-completions-in-real-time)
22
+ - [Manually Trigger Completions](#manually-trigger-completions)
23
+ - [Trigger Completions with a Keyboard Shortcut](#trigger-completions-with-a-keyboard-shortcut)
24
+ - [Trigger Completions with an Editor Action](#trigger-completions-with-an-editor-action)
24
25
  - [Multi-File Context](#multi-file-context)
25
26
  - [Filename](#filename)
26
27
  - [Completions for Specific Technologies](#completions-for-specific-technologies)
@@ -147,7 +148,7 @@ registerCompletion(monaco, editor, {
147
148
 
148
149
  ## Register Completion Options
149
150
 
150
- ### Get Completions in Real-Time
151
+ ### Trigger Mode
151
152
 
152
153
  The `trigger` option determines when the completion service provides code completions. You can choose between receiving suggestions/completions in real-time as you type or after a brief pause.
153
154
 
@@ -167,12 +168,10 @@ registerCompletion(monaco, editor, {
167
168
 
168
169
  > **Note:** If you prefer real-time completions, you can set the `trigger` option to `'onTyping'`. This may increase the number of requests made to the provider and the cost. This should not be too costly since most small models are very inexpensive.
169
170
 
170
- ### Manually Trigger Completions
171
+ #### Manually Trigger Completions
171
172
 
172
173
  If you prefer not to trigger completions automatically (e.g., on typing or on idle), you can trigger completions manually. This is useful in scenarios where you want to control when completions are provided, such as through a button click or a keyboard shortcut.
173
174
 
174
- #### Usage
175
-
176
175
  ```javascript
177
176
  const completion = registerCompletion(monaco, editor, {
178
177
  trigger: 'onDemand',
@@ -183,7 +182,7 @@ completion.trigger();
183
182
 
184
183
  To set up manual triggering, configure the `trigger` option to `'onDemand'`. This disables automatic completions, allowing you to call the `completion.trigger()` method explicitly when needed.
185
184
 
186
- #### Trigger Completions with a Keyboard Shortcut
185
+ ##### Trigger Completions with a Keyboard Shortcut
187
186
 
188
187
  You can set up completions to trigger when the `Ctrl+Shift+Space` keyboard shortcut is pressed.
189
188
 
@@ -200,7 +199,7 @@ monaco.editor.addCommand(
200
199
  );
201
200
  ```
202
201
 
203
- #### Trigger Completions with an Editor Action
202
+ ##### Trigger Completions with an Editor Action
204
203
 
205
204
  You can add a custom editor action to trigger completions manually.
206
205
 
@@ -415,7 +414,7 @@ There are other providers and models available. Here is a list:
415
414
  | --------- | ------------------------------------------------------------------------- |
416
415
  | Groq | `llama-3-70b` |
417
416
  | OpenAI | `gpt-4o`, `gpt-4o-mini`, `o1-preview`, `o1-mini` |
418
- | Anthropic | `claude-3-5-Sonnet`, `claude-3-opus`, `claude-3-sonnet`, `claude-3-haiku` |
417
+ | Anthropic | `claude-3-5-sonnet`, `claude-3-opus`, `claude-3-sonnet`, `claude-3-haiku` |
419
418
 
420
419
  ### Custom Model
421
420
 
package/build/index.js CHANGED
@@ -1,15 +1,16 @@
1
- "use strict";var $=Object.defineProperty;var he=Object.getOwnPropertyDescriptor;var fe=Object.getOwnPropertyNames;var Pe=Object.prototype.hasOwnProperty;var ye=(t,e)=>{for(var o in e)$(t,o,{get:e[o],enumerable:!0})},Re=(t,e,o,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of fe(e))!Pe.call(t,n)&&n!==o&&$(t,n,{get:()=>e[n],enumerable:!(r=he(e,n))||r.enumerable});return t};var Te=t=>Re($({},"__esModule",{value:!0}),t);var qe={};ye(qe,{Copilot:()=>D,registerCompletion:()=>Y,registerCopilot:()=>ge});module.exports=Te(qe);var q=["groq","openai","anthropic"],G={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-opus":"claude-3-opus-20240229","claude-3-sonnet":"claude-3-sonnet-20240229","claude-3-haiku":"claude-3-haiku-20240307","o1-preview":"o1-preview","o1-mini":"o1-mini"},H={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-preview","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-opus","claude-3-haiku","claude-3-sonnet"]},X="llama-3-70b",z="groq",J={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages"},v=.1;var Z={"claude-3-5-sonnet":8192,"claude-3-opus":4096,"claude-3-haiku":4096,"claude-3-sonnet":4096};var xe={createRequestBody:(t,e)=>{let r=t==="o1-preview"||t==="o1-mini"?[{role:"user",content:e.user}]:[{role:"system",content:e.system},{role:"user",content:e.user}];return{model:V(t),temperature:v,messages:r}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Ee={createRequestBody:(t,e)=>({model:V(t),temperature:v,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Me={createRequestBody:(t,e)=>({model:V(t),temperature:v,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:Oe(t)}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>!t.content||typeof t.content!="string"?null:t.content},_={openai:xe,groq:Ee,anthropic:Me},Q=(t,e,o)=>_[e].createRequestBody(t,o),ee=(t,e)=>_[e].createHeaders(t),te=(t,e)=>_[e].parseCompletion(t),V=t=>G[t],oe=t=>J[t],Oe=t=>Z[t]||4096;var m=class m{constructor(){}static getInstance(){return m.instance}logError(e){let o,r;e instanceof Error?(o=e.message,r=e.stack):typeof e=="string"?o=e:o="An unknown error occurred";let n=`${m.RED}${m.BOLD}[MONACOPILOT ERROR] ${o}${m.RESET}`;return console.error(n),r&&console.error(`${m.RED}[MONACOPILOT ERROR] Stack trace:${m.RESET}
2
- ${r}`),{message:o,stack:r}}warn(e){console.warn(`${m.YELLOW}${m.BOLD}[MONACOPILOT WARN] ${e}${m.RESET}`)}log(e){console.log(`${m.BOLD}[MONACOPILOT] ${e}${m.RESET}`)}};m.instance=new m,m.RED="\x1B[31m",m.YELLOW="\x1B[33m",m.RESET="\x1B[0m",m.BOLD="\x1B[1m";var j=m,h=j.getInstance();var I=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,d)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=d,o=setTimeout(()=>{s(t(...i)),r=null},e)});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null)},n},E=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`;var U=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var A=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),re=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),P=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),ne=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())}),W=(t,e,o={})=>{if(e<=0)return"";let r=t.split(`
1
+ "use strict";var _=Object.defineProperty;var Re=Object.getOwnPropertyDescriptor;var xe=Object.getOwnPropertyNames;var Te=Object.prototype.hasOwnProperty;var Ee=(t,e)=>{for(var o in e)_(t,o,{get:e[o],enumerable:!0})},Me=(t,e,o,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of xe(e))!Te.call(t,n)&&n!==o&&_(t,n,{get:()=>e[n],enumerable:!(r=Re(e,n))||r.enumerable});return t};var Oe=t=>Me(_({},"__esModule",{value:!0}),t);var je={};Ee(je,{Copilot:()=>D,registerCompletion:()=>G,registerCopilot:()=>ye});module.exports=Oe(je);var q=["groq","openai","anthropic"],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-opus":"claude-3-opus-20240229","claude-3-sonnet":"claude-3-sonnet-20240229","claude-3-haiku":"claude-3-haiku-20240307","o1-preview":"o1-preview","o1-mini":"o1-mini"},H={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-preview","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-opus","claude-3-haiku","claude-3-sonnet"]},z="llama-3-70b",J="groq",Z={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages"},b=.1;var Q={"claude-3-5-sonnet":8192,"claude-3-opus":4096,"claude-3-haiku":4096,"claude-3-sonnet":4096};var be={createRequestBody:(t,e)=>{let r=t==="o1-preview"||t==="o1-mini"?[{role:"user",content:e.user}]:[{role:"system",content:e.system},{role:"user",content:e.user}];return{model:j(t),temperature:b,messages:r}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},ve={createRequestBody:(t,e)=>({model:j(t),temperature:b,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},Ie={createRequestBody:(t,e)=>({model:j(t),temperature:b,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:Ae(t)}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>!t.content||typeof t.content!="string"?null:t.content},V={openai:be,groq:ve,anthropic:Ie},ee=(t,e,o)=>V[e].createRequestBody(t,o),te=(t,e)=>V[e].createHeaders(t),oe=(t,e)=>V[e].parseCompletion(t),j=t=>X[t],re=t=>Z[t],Ae=t=>Q[t]||4096;var ne="\x1B[91m",ie="\x1B[93m",v="\x1B[0m",U="\x1B[1m",h=t=>{let e,o;t instanceof Error?(e=t.message,o=t.stack):typeof t=="string"?e=t:e="An unknown error occurred";let r=`${ne}${U}[MONACOPILOT ERROR] ${e}${v}`;return console.error(o?`${r}
2
+ ${ne}Stack trace:${v}
3
+ ${o}`:r),{message:e,stack:o}},I=t=>{console.warn(`${ie}${U}[MONACOPILOT DEPRECATED] ${t}${v}`)},se=t=>{console.warn(`${ie}${U}[MONACOPILOT WARN] ${t}${v}`)};var A=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,d)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=d,o=setTimeout(()=>{s(t(...i)),r=null},e)});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null)},n},T=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`;var W=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var w=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ae=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),f=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),le=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())}),K=(t,e,o={})=>{if(e<=0)return"";let r=t.split(`
3
4
  `),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(d=>d==="")?`
4
5
  `.repeat(e):s.join(`
5
6
  `)}let i=r.slice(0,e);return i.every(s=>s==="")?`
6
7
  `.repeat(e):i.join(`
7
- `)};var ie=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok)throw new Error(`${i.statusText||o.fallbackError||"Network error"}`);return i.json()},be=(t,e)=>ie(t,"GET",e),ve=(t,e,o)=>ie(t,"POST",{...o,body:e}),w={GET:be,POST:ve};var se=(t,e)=>{let o=A(t,e).trim(),r=re(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var Ie=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n}=t,i=E([n,...e].filter(c=>typeof c=="string"&&!!c)),s=`You are an expert ${i?`${i} `:""}developer assistant.`,d="Your task is to provide precise and contextually relevant code completions, modifications, or generations",a=o?`for the file '${o}'`:"",l=r&&r.length>0?"Consider the context of the current and related files provided.":"",u="Ensure that your responses integrate seamlessly with the existing code and maintain consistency with the project's style and conventions.",C="Before providing the completion or modification, think through the problem step-by-step, considering best practices and any potential edge cases.",p=n?`Pay special attention to ${n}-specific syntax and best practices.`:"";return`${s}
8
+ `)};var pe=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok)throw new Error(`${i.statusText||o.fallbackError||"Network error"}`);return i.json()},we=(t,e)=>pe(t,"GET",e),Le=(t,e,o)=>pe(t,"POST",{...o,body:e}),L={GET:we,POST:Le};var ce=(t,e)=>{let o=w(t,e).trim(),r=ae(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var De=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n}=t,i=T([n,...e].filter(c=>typeof c=="string"&&!!c)),s=`You are an expert ${i?`${i} `:""}developer assistant.`,d="Your task is to provide precise and contextually relevant code completions, modifications, or generations",a=o?`for the file '${o}'`:"",l=r&&r.length>0?"Consider the context of the current and related files provided.":"",m="Ensure that your responses integrate seamlessly with the existing code and maintain consistency with the project's style and conventions.",u="Before providing the completion or modification, think through the problem step-by-step, considering best practices and any potential edge cases.",p=n?`Pay special attention to ${n}-specific syntax and best practices.`:"";return`${s}
8
9
  ${d} ${a}.
9
- ${u}
10
+ ${m}
10
11
  ${l}
11
12
  ${p}
12
- ${C}`.trim()},Ae=t=>t?.length?t.map(({path:e,content:o})=>`
13
+ ${u}`.trim()},Se=t=>t?.length?t.map(({path:e,content:o})=>`
13
14
  <related_file>
14
15
  <path>${e}</path>
15
16
  <content>
@@ -19,19 +20,19 @@ ${o}
19
20
  </content>
20
21
  </related_file>
21
22
  `.trim()).join(`
22
- `):"",we=(t="",e)=>{let{relatedFiles:o}=e,r=o?Ae(o):"";return`
23
+ `):"",ke=(t="",e)=>{let{relatedFiles:o}=e,r=o?Se(o):"";return`
23
24
  <task>
24
25
  <instructions>
25
26
  ${t.trim()}
26
27
  </instructions>
27
28
  ${r}
28
29
  </task>
29
- `.trim()},ae=(t,e)=>({system:Ie(e),user:we(t,e)});var le="<cursor>",De=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r}}=t,n=`<code_file>
30
- ${e}${le}${o}
30
+ `.trim()},de=(t,e)=>({system:De(e),user:ke(t,e)});var me="<cursor>",Fe=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r}}=t,n=`<code_file>
31
+ ${e}${me}${o}
31
32
  </code_file>`,s=`
32
33
  You are an AI coding assistant. Your task is to provide code completions based on the current cursor position in the code.
33
34
 
34
- Below is the code file with a special token '${le}' indicating the current cursor position.
35
+ Below is the code file with a special token '${me}' indicating the current cursor position.
35
36
 
36
37
  ${n}
37
38
 
@@ -51,8 +52,8 @@ Depending on the completion mode, adjust your completion accordingly:
51
52
  ${{continue:"-- Continue writing the code from the current cursor location.",insert:"-- Insert the appropriate code snippet at the cursor point.",complete:"-- Supply the necessary code to finish the ongoing statement or block."}[r]||""}
52
53
 
53
54
  Remember to output **only** the code that should be inserted at the cursor, without any additional formatting or explanations.
54
- `.trim();return ae(s,t)},pe=De;var D=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??z,this.model=o.model??X,this.validateInputs()}validateInputs(){if(!q.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${E(q)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!H[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${E(H[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},d=this.generatePrompt(n,s),{endpoint:a,requestBody:l,headers:u}=this.prepareRequestDetails(d);try{let C=await this.sendCompletionRequest(a,l,{...u,...i});return this.processCompletionResponse(C)}catch(C){return this.handleCompletionError(C)}}generatePrompt(e,o){let r=pe(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=oe(this.provider),r,n=ee(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let i=this.model.config(this.apiKey,e);o=i.endpoint??o,r=i.body??{},n={...n,...i.headers}}else r=Q(this.model,this.provider,e);return{endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return w.POST(e,o,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return"completion"in o&&h.warn("The `completion` property in `transformResponse` function is deprecated. Please use `text` instead."),{completion:o.text??o.completion??null}}else return{completion:te(e,this.provider)}}handleCompletionError(e){return{error:h.logError(e).message,completion:null}}};var L=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
55
+ `.trim();return de(s,t)},ue=Fe;var D=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??J,this.model=o.model??z,this.validateInputs()}validateInputs(){if(!q.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${T(q)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!H[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${T(H[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},d=this.generatePrompt(n,s),{endpoint:a,requestBody:l,headers:m}=this.prepareRequestDetails(d);try{let u=await this.sendCompletionRequest(a,l,{...m,...i});return this.processCompletionResponse(u)}catch(u){return this.handleCompletionError(u)}}generatePrompt(e,o){let r=ue(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=re(this.provider),r,n=te(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=ee(this.model,this.provider,e);return{endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return L.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&&I("The `completion` property in `transformResponse` function is deprecated. Please use `text` instead."),{completion:o.text??o.completion??null}}else return{completion:oe(e,this.provider)}}handleCompletionError(e){return{error:h(e).message,completion:null}}};var S=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
55
56
  `).slice(1,-1).join(`
56
57
  `);r=r.replace(i,s)}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
57
58
 
58
- `),this}build(){return this.formattedCompletion}};var S=class{constructor(e,o){this.cursorPos=e,this.mdl=o}shouldProvideCompletions(){return!se(this.cursorPos,this.mdl)}};var k=class k{constructor(){this.cache=[]}get(e,o){return this.cache.filter(r=>this.isValidCacheItem(r,e,o))}add(e){let o=[...this.cache.slice(-(k.MAX_CACHE_SIZE-1)),e];this.cache=o}clear(){this.cache=[]}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return P(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:d,endColumn:a}=n,{lineNumber:l,column:u}=o,C=l===s&&u===d,p=i.startsWith(r)&&l===s&&u>=d-r.length&&u<=a+r.length;return C||p}};k.MAX_CACHE_SIZE=10;var B=k;var Le="application/json",ce=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await w.POST(e,o,{headers:{"Content-Type":Le},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return{completion:r}},de=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:d}=o,a=Se(t,e),u=!!s?.length?3:2,C=d?Math.floor(d/u):void 0,p=(f,x,N)=>{let b=f(t,e);return x?W(b,x,N):b},g=(f,x)=>!f||!x?f:f.map(({content:N,...b})=>({...b,content:W(N,x)})),c=p(P,C,{from:"end"}),O=p(ne,C),T=g(s,C);return{filename:r,language:n,technologies:i,relatedFiles:T,textBeforeCursor:c,textAfterCursor:O,cursorPosition:t,editorState:{completionMode:a}}},Se=(t,e)=>{let o=U(t,e),r=A(t,e);return o?"insert":r.trim()?"complete":"continue"};var me=(t,e,o,r)=>{if(!r)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=o.getOffsetAt(e),i=o.getValue().substring(n),s=0,d=0,a=0,l=r.length,u=i.length;if(n>=o.getValue().length)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(u===0)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);let C=Math.min(l,u);for(let c=0;c<C&&r[c]===i[c];c++)s++;for(let c=1;c<=C;c++)r.slice(-c)===i.slice(0,c)&&(d=c);if(a=Math.max(s,d),a===0){for(let c=1;c<l;c++)if(i.startsWith(r.substring(c))){a=l-c;break}}let p=n+a,g=o.getPositionAt(p);return new t.Range(e.lineNumber,e.column,g.lineNumber,g.column)},ue=t=>L.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),y=t=>({items:t,enableForwardStability:!0});var K={onTyping:300,onIdle:600,onDemand:0},ke=t=>({onTyping:I(t,K.onTyping),onIdle:I(t,K.onIdle),onDemand:I(t,K.onDemand)}),F=new B,Fe=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:d="onIdle",endpoint:a,enableCaching:l=!0,onError:u,requestHandler:C}=s;if(!new S(o,e).shouldProvideCompletions())return y([]);if(l){let p=F.get(o,e).map(g=>({insertText:g.completion,range:g.range}));if(p.length>0)return i(),y(p)}if(r.isCancellationRequested||n)return y([]);try{let g=ke(C??ce)[d];r.onCancellationRequested(()=>{g.cancel()});let c=de({pos:o,mdl:e,options:s}),{completion:O}=await g({endpoint:a,body:{completionMetadata:c}});if(O){let T=ue(O),f=me(t,o,e,T);return l&&F.add({completion:T,range:f,textBeforeCursor:P(o,e)}),i(),y([{insertText:T,range:f}])}}catch(p){u?u(p):Ne(p)||h.logError(p)}return y([])},Ne=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,Ce=Fe;var R=new WeakMap,M=null,Y=(t,e,o)=>{M&&M.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};R.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,l,u,C)=>{let p=R.get(e);if(!(!p||o.trigger==="onDemand"&&!p.isManualTrigger))return Ce({monaco:t,mdl:a,pos:l,token:C,isCompletionAccepted:p.isCompletionAccepted,onShowCompletion:()=>{p.isCompletionVisible=!0,p.isManualTrigger=!1},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(a=>{let l=R.get(e);if(!l)return;let u=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;l.isCompletionVisible&&u?(l.isCompletionAccepted=!0,l.isCompletionVisible=!1):l.isCompletionAccepted=!1});r.push(s);let d={deregister:()=>{r.forEach(a=>a.dispose()),F.clear(),R.delete(e),M=null},trigger:()=>$e(e)};return M=d,d}catch(i){return o.onError?o.onError(i):h.logError(i),{deregister:()=>{r.forEach(s=>s.dispose()),R.delete(e),M=null},trigger:()=>{}}}},$e=t=>{let e=R.get(t);if(!e){h.warn("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{})},ge=(...t)=>(h.warn("The `registerCopilot` function is deprecated. Use `registerCompletion` instead."),Y(...t));0&&(module.exports={Copilot,registerCompletion,registerCopilot});
59
+ `),this}build(){return this.formattedCompletion}};var k=class{constructor(e,o){this.cursorPos=e,this.mdl=o}shouldProvideCompletions(){return!ce(this.cursorPos,this.mdl)}};var B=class B{constructor(){this.cache=[]}get(e,o){return this.cache.filter(r=>this.isValidCacheItem(r,e,o))}add(e){let o=[...this.cache.slice(-(B.MAX_CACHE_SIZE-1)),e];this.cache=o}clear(){this.cache=[]}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return f(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:d,endColumn:a}=n,{lineNumber:l,column:m}=o,u=l===s&&m===d,p=i.startsWith(r)&&l===s&&m>=d-r.length&&m<=a+r.length;return u||p}};B.MAX_CACHE_SIZE=10;var F=B;var Be="application/json",Ce=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await L.POST(e,o,{headers:{"Content-Type":Be},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return{completion:r}},ge=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:d}=o,a=$e(t,e),m=!!s?.length?3:2,u=d?Math.floor(d/m):void 0,p=(g,x,N)=>{let O=g(t,e);return x?K(O,x,N):O},C=(g,x)=>!g||!x?g:g.map(({content:N,...O})=>({...O,content:K(N,x)})),c=p(f,u,{from:"end"}),M=p(le,u),R=C(s,u);return{filename:r,language:n,technologies:i,relatedFiles:R,textBeforeCursor:c,textAfterCursor:M,cursorPosition:t,editorState:{completionMode:a}}},$e=(t,e)=>{let o=W(t,e),r=w(t,e);return o?"insert":r.trim()?"complete":"continue"};var he=(t,e,o,r)=>{if(!r)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=o.getOffsetAt(e),i=o.getValue().substring(n),s=0,d=0,a=0,l=r.length,m=i.length;if(n>=o.getValue().length)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(m===0)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);let u=Math.min(l,m);for(let c=0;c<u&&r[c]===i[c];c++)s++;for(let c=1;c<=u;c++)r.slice(-c)===i.slice(0,c)&&(d=c);if(a=Math.max(s,d),a===0){for(let c=1;c<l;c++)if(i.startsWith(r.substring(c))){a=l-c;break}}let p=n+a,C=o.getPositionAt(p);return new t.Range(e.lineNumber,e.column,C.lineNumber,C.column)},fe=t=>S.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),P=t=>({items:t,enableForwardStability:!0});var Y={onTyping:300,onIdle:600,onDemand:0},_e=t=>({onTyping:A(t,Y.onTyping),onIdle:A(t,Y.onIdle),onDemand:A(t,Y.onDemand)}),$=new F,qe=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:d="onIdle",endpoint:a,enableCaching:l=!0,onError:m,requestHandler:u}=s;if(!new k(o,e).shouldProvideCompletions())return P([]);if(l){let p=$.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(p.length>0)return i(),P(p)}if(r.isCancellationRequested||n)return P([]);try{let C=_e(u??Ce)[d];r.onCancellationRequested(()=>{C.cancel()});let c=ge({pos:o,mdl:e,options:s}),{completion:M}=await C({endpoint:a,body:{completionMetadata:c}});if(M){let R=fe(M),g=he(t,o,e,R);return l&&$.add({completion:R,range:g,textBeforeCursor:f(o,e)}),i(),P([{insertText:R,range:g}])}}catch(p){m?m(p):He(p)||h(p)}return P([])},He=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,Pe=qe;var y=new WeakMap,E=null,G=(t,e,o)=>{E&&E.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};y.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,l,m,u)=>{let p=y.get(e);if(!(!p||o.trigger==="onDemand"&&!p.isManualTrigger))return Pe({monaco:t,mdl:a,pos:l,token:u,isCompletionAccepted:p.isCompletionAccepted,onShowCompletion:()=>{p.isCompletionVisible=!0,p.isManualTrigger=!1},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(a=>{let l=y.get(e);if(!l)return;let m=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;l.isCompletionVisible&&m?(l.isCompletionAccepted=!0,l.isCompletionVisible=!1):l.isCompletionAccepted=!1});r.push(s);let d={deregister:()=>{r.forEach(a=>a.dispose()),$.clear(),y.delete(e),E=null},trigger:()=>Ve(e)};return E=d,d}catch(i){return o.onError?o.onError(i):h(i),{deregister:()=>{r.forEach(s=>s.dispose()),y.delete(e),E=null},trigger:()=>{}}}},Ve=t=>{let e=y.get(t);if(!e){se("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{})},ye=(...t)=>(I("The `registerCopilot` function is deprecated. Use `registerCompletion` instead."),G(...t));0&&(module.exports={Copilot,registerCompletion,registerCopilot});
package/build/index.mjs CHANGED
@@ -1,15 +1,16 @@
1
- var N=["groq","openai","anthropic"],K={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-opus":"claude-3-opus-20240229","claude-3-sonnet":"claude-3-sonnet-20240229","claude-3-haiku":"claude-3-haiku-20240307","o1-preview":"o1-preview","o1-mini":"o1-mini"},$={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-preview","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-opus","claude-3-haiku","claude-3-sonnet"]},Y="llama-3-70b",G="groq",X={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages"},v=.1;var z={"claude-3-5-sonnet":8192,"claude-3-opus":4096,"claude-3-haiku":4096,"claude-3-sonnet":4096};var Ce={createRequestBody:(t,e)=>{let r=t==="o1-preview"||t==="o1-mini"?[{role:"user",content:e.user}]:[{role:"system",content:e.system},{role:"user",content:e.user}];return{model:H(t),temperature:v,messages:r}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},ge={createRequestBody:(t,e)=>({model:H(t),temperature:v,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},he={createRequestBody:(t,e)=>({model:H(t),temperature:v,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:fe(t)}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>!t.content||typeof t.content!="string"?null:t.content},q={openai:Ce,groq:ge,anthropic:he},J=(t,e,o)=>q[e].createRequestBody(t,o),Z=(t,e)=>q[e].createHeaders(t),Q=(t,e)=>q[e].parseCompletion(t),H=t=>K[t],ee=t=>X[t],fe=t=>z[t]||4096;var m=class m{constructor(){}static getInstance(){return m.instance}logError(e){let o,r;e instanceof Error?(o=e.message,r=e.stack):typeof e=="string"?o=e:o="An unknown error occurred";let n=`${m.RED}${m.BOLD}[MONACOPILOT ERROR] ${o}${m.RESET}`;return console.error(n),r&&console.error(`${m.RED}[MONACOPILOT ERROR] Stack trace:${m.RESET}
2
- ${r}`),{message:o,stack:r}}warn(e){console.warn(`${m.YELLOW}${m.BOLD}[MONACOPILOT WARN] ${e}${m.RESET}`)}log(e){console.log(`${m.BOLD}[MONACOPILOT] ${e}${m.RESET}`)}};m.instance=new m,m.RED="\x1B[31m",m.YELLOW="\x1B[33m",m.RESET="\x1B[0m",m.BOLD="\x1B[1m";var _=m,h=_.getInstance();var I=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,d)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=d,o=setTimeout(()=>{s(t(...i)),r=null},e)});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null)},n},E=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`;var V=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var A=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),te=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),P=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),oe=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())}),j=(t,e,o={})=>{if(e<=0)return"";let r=t.split(`
3
- `),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(d=>d==="")?`
1
+ var N=["groq","openai","anthropic"],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-opus":"claude-3-opus-20240229","claude-3-sonnet":"claude-3-sonnet-20240229","claude-3-haiku":"claude-3-haiku-20240307","o1-preview":"o1-preview","o1-mini":"o1-mini"},_={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-preview","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-opus","claude-3-haiku","claude-3-sonnet"]},G="llama-3-70b",X="groq",z={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages"},b=.1;var J={"claude-3-5-sonnet":8192,"claude-3-opus":4096,"claude-3-haiku":4096,"claude-3-sonnet":4096};var Pe={createRequestBody:(t,e)=>{let r=t==="o1-preview"||t==="o1-mini"?[{role:"user",content:e.user}]:[{role:"system",content:e.system},{role:"user",content:e.user}];return{model:H(t),temperature:b,messages:r}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},ye={createRequestBody:(t,e)=>({model:H(t),temperature:b,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={createRequestBody:(t,e)=>({model:H(t),temperature:b,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:xe(t)}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>!t.content||typeof t.content!="string"?null:t.content},q={openai:Pe,groq:ye,anthropic:Re},Z=(t,e,o)=>q[e].createRequestBody(t,o),Q=(t,e)=>q[e].createHeaders(t),ee=(t,e)=>q[e].parseCompletion(t),H=t=>Y[t],te=t=>z[t],xe=t=>J[t]||4096;var oe="\x1B[91m",re="\x1B[93m",v="\x1B[0m",V="\x1B[1m",h=t=>{let e,o;t instanceof Error?(e=t.message,o=t.stack):typeof t=="string"?e=t:e="An unknown error occurred";let r=`${oe}${V}[MONACOPILOT ERROR] ${e}${v}`;return console.error(o?`${r}
2
+ ${oe}Stack trace:${v}
3
+ ${o}`:r),{message:e,stack:o}},I=t=>{console.warn(`${re}${V}[MONACOPILOT DEPRECATED] ${t}${v}`)},ne=t=>{console.warn(`${re}${V}[MONACOPILOT WARN] ${t}${v}`)};var A=(t,e)=>{let o=null,r=null,i=(...n)=>new Promise((s,d)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=d,o=setTimeout(()=>{s(t(...n)),r=null},e)});return i.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null)},i},T=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`;var j=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var w=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ie=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),f=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),se=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())}),U=(t,e,o={})=>{if(e<=0)return"";let r=t.split(`
4
+ `),i=r.length;if(e>=i)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(d=>d==="")?`
4
5
  `.repeat(e):s.join(`
5
- `)}let i=r.slice(0,e);return i.every(s=>s==="")?`
6
- `.repeat(e):i.join(`
7
- `)};var re=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok)throw new Error(`${i.statusText||o.fallbackError||"Network error"}`);return i.json()},Pe=(t,e)=>re(t,"GET",e),ye=(t,e,o)=>re(t,"POST",{...o,body:e}),w={GET:Pe,POST:ye};var ne=(t,e)=>{let o=A(t,e).trim(),r=te(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var Re=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n}=t,i=E([n,...e].filter(c=>typeof c=="string"&&!!c)),s=`You are an expert ${i?`${i} `:""}developer assistant.`,d="Your task is to provide precise and contextually relevant code completions, modifications, or generations",a=o?`for the file '${o}'`:"",l=r&&r.length>0?"Consider the context of the current and related files provided.":"",u="Ensure that your responses integrate seamlessly with the existing code and maintain consistency with the project's style and conventions.",C="Before providing the completion or modification, think through the problem step-by-step, considering best practices and any potential edge cases.",p=n?`Pay special attention to ${n}-specific syntax and best practices.`:"";return`${s}
6
+ `)}let n=r.slice(0,e);return n.every(s=>s==="")?`
7
+ `.repeat(e):n.join(`
8
+ `)};var ae=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},i=e==="POST"&&o.body?JSON.stringify(o.body):void 0,n=await fetch(t,{method:e,headers:r,body:i,signal:o.signal});if(!n.ok)throw new Error(`${n.statusText||o.fallbackError||"Network error"}`);return n.json()},Te=(t,e)=>ae(t,"GET",e),Ee=(t,e,o)=>ae(t,"POST",{...o,body:e}),L={GET:Te,POST:Ee};var le=(t,e)=>{let o=w(t,e).trim(),r=ie(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var Me=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:i}=t,n=T([i,...e].filter(c=>typeof c=="string"&&!!c)),s=`You are an expert ${n?`${n} `:""}developer assistant.`,d="Your task is to provide precise and contextually relevant code completions, modifications, or generations",a=o?`for the file '${o}'`:"",l=r&&r.length>0?"Consider the context of the current and related files provided.":"",m="Ensure that your responses integrate seamlessly with the existing code and maintain consistency with the project's style and conventions.",u="Before providing the completion or modification, think through the problem step-by-step, considering best practices and any potential edge cases.",p=i?`Pay special attention to ${i}-specific syntax and best practices.`:"";return`${s}
8
9
  ${d} ${a}.
9
- ${u}
10
+ ${m}
10
11
  ${l}
11
12
  ${p}
12
- ${C}`.trim()},Te=t=>t?.length?t.map(({path:e,content:o})=>`
13
+ ${u}`.trim()},Oe=t=>t?.length?t.map(({path:e,content:o})=>`
13
14
  <related_file>
14
15
  <path>${e}</path>
15
16
  <content>
@@ -19,21 +20,21 @@ ${o}
19
20
  </content>
20
21
  </related_file>
21
22
  `.trim()).join(`
22
- `):"",xe=(t="",e)=>{let{relatedFiles:o}=e,r=o?Te(o):"";return`
23
+ `):"",be=(t="",e)=>{let{relatedFiles:o}=e,r=o?Oe(o):"";return`
23
24
  <task>
24
25
  <instructions>
25
26
  ${t.trim()}
26
27
  </instructions>
27
28
  ${r}
28
29
  </task>
29
- `.trim()},ie=(t,e)=>({system:Re(e),user:xe(t,e)});var se="<cursor>",Ee=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r}}=t,n=`<code_file>
30
- ${e}${se}${o}
30
+ `.trim()},pe=(t,e)=>({system:Me(e),user:be(t,e)});var ce="<cursor>",ve=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r}}=t,i=`<code_file>
31
+ ${e}${ce}${o}
31
32
  </code_file>`,s=`
32
33
  You are an AI coding assistant. Your task is to provide code completions based on the current cursor position in the code.
33
34
 
34
- Below is the code file with a special token '${se}' indicating the current cursor position.
35
+ Below is the code file with a special token '${ce}' indicating the current cursor position.
35
36
 
36
- ${n}
37
+ ${i}
37
38
 
38
39
  Please provide the code that should be inserted at the cursor position, following these guidelines:
39
40
 
@@ -51,8 +52,8 @@ Depending on the completion mode, adjust your completion accordingly:
51
52
  ${{continue:"-- Continue writing the code from the current cursor location.",insert:"-- Insert the appropriate code snippet at the cursor point.",complete:"-- Supply the necessary code to finish the ongoing statement or block."}[r]||""}
52
53
 
53
54
  Remember to output **only** the code that should be inserted at the cursor, without any additional formatting or explanations.
54
- `.trim();return ie(s,t)},ae=Ee;var U=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??G,this.model=o.model??Y,this.validateInputs()}validateInputs(){if(!N.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${E(N)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!$[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${E($[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},d=this.generatePrompt(n,s),{endpoint:a,requestBody:l,headers:u}=this.prepareRequestDetails(d);try{let C=await this.sendCompletionRequest(a,l,{...u,...i});return this.processCompletionResponse(C)}catch(C){return this.handleCompletionError(C)}}generatePrompt(e,o){let r=ae(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=ee(this.provider),r,n=Z(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let i=this.model.config(this.apiKey,e);o=i.endpoint??o,r=i.body??{},n={...n,...i.headers}}else r=J(this.model,this.provider,e);return{endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return w.POST(e,o,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return"completion"in o&&h.warn("The `completion` property in `transformResponse` function is deprecated. Please use `text` instead."),{completion:o.text??o.completion??null}}else return{completion:Q(e,this.provider)}}handleCompletionError(e){return{error:h.logError(e).message,completion:null}}};var D=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
55
+ `.trim();return pe(s,t)},de=ve;var W=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??X,this.model=o.model??G,this.validateInputs()}validateInputs(){if(!N.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${T(N)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!_[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${T(_[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:i}=o,{headers:n={},customPrompt:s}=r??{},d=this.generatePrompt(i,s),{endpoint:a,requestBody:l,headers:m}=this.prepareRequestDetails(d);try{let u=await this.sendCompletionRequest(a,l,{...m,...n});return this.processCompletionResponse(u)}catch(u){return this.handleCompletionError(u)}}generatePrompt(e,o){let r=de(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=te(this.provider),r,i=Q(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let n=this.model.config(this.apiKey,e);o=n.endpoint??o,r=n.body??{},i={...i,...n.headers}}else r=Z(this.model,this.provider,e);return{endpoint:o,requestBody:r,headers:i}}async sendCompletionRequest(e,o,r){return L.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&&I("The `completion` property in `transformResponse` function is deprecated. Please use `text` instead."),{completion:o.text??o.completion??null}}else return{completion:ee(e,this.provider)}}handleCompletionError(e){return{error:h(e).message,completion:null}}};var D=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,i;for(;(i=o.exec(e))!==null;){let n=i[0],s=n.split(`
55
56
  `).slice(1,-1).join(`
56
- `);r=r.replace(i,s)}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
57
+ `);r=r.replace(n,s)}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
57
58
 
58
- `),this}build(){return this.formattedCompletion}};var L=class{constructor(e,o){this.cursorPos=e,this.mdl=o}shouldProvideCompletions(){return!ne(this.cursorPos,this.mdl)}};var B=class B{constructor(){this.cache=[]}get(e,o){return this.cache.filter(r=>this.isValidCacheItem(r,e,o))}add(e){let o=[...this.cache.slice(-(B.MAX_CACHE_SIZE-1)),e];this.cache=o}clear(){this.cache=[]}isValidCacheItem(e,o,r){let n=r.getValueInRange(e.range);return P(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:d,endColumn:a}=n,{lineNumber:l,column:u}=o,C=l===s&&u===d,p=i.startsWith(r)&&l===s&&u>=d-r.length&&u<=a+r.length;return C||p}};B.MAX_CACHE_SIZE=10;var S=B;var Me="application/json",le=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await w.POST(e,o,{headers:{"Content-Type":Me},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return{completion:r}},pe=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:d}=o,a=Oe(t,e),u=!!s?.length?3:2,C=d?Math.floor(d/u):void 0,p=(f,x,F)=>{let b=f(t,e);return x?j(b,x,F):b},g=(f,x)=>!f||!x?f:f.map(({content:F,...b})=>({...b,content:j(F,x)})),c=p(P,C,{from:"end"}),O=p(oe,C),T=g(s,C);return{filename:r,language:n,technologies:i,relatedFiles:T,textBeforeCursor:c,textAfterCursor:O,cursorPosition:t,editorState:{completionMode:a}}},Oe=(t,e)=>{let o=V(t,e),r=A(t,e);return o?"insert":r.trim()?"complete":"continue"};var ce=(t,e,o,r)=>{if(!r)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=o.getOffsetAt(e),i=o.getValue().substring(n),s=0,d=0,a=0,l=r.length,u=i.length;if(n>=o.getValue().length)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(u===0)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);let C=Math.min(l,u);for(let c=0;c<C&&r[c]===i[c];c++)s++;for(let c=1;c<=C;c++)r.slice(-c)===i.slice(0,c)&&(d=c);if(a=Math.max(s,d),a===0){for(let c=1;c<l;c++)if(i.startsWith(r.substring(c))){a=l-c;break}}let p=n+a,g=o.getPositionAt(p);return new t.Range(e.lineNumber,e.column,g.lineNumber,g.column)},de=t=>D.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),y=t=>({items:t,enableForwardStability:!0});var W={onTyping:300,onIdle:600,onDemand:0},ve=t=>({onTyping:I(t,W.onTyping),onIdle:I(t,W.onIdle),onDemand:I(t,W.onDemand)}),k=new S,Ie=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:d="onIdle",endpoint:a,enableCaching:l=!0,onError:u,requestHandler:C}=s;if(!new L(o,e).shouldProvideCompletions())return y([]);if(l){let p=k.get(o,e).map(g=>({insertText:g.completion,range:g.range}));if(p.length>0)return i(),y(p)}if(r.isCancellationRequested||n)return y([]);try{let g=ve(C??le)[d];r.onCancellationRequested(()=>{g.cancel()});let c=pe({pos:o,mdl:e,options:s}),{completion:O}=await g({endpoint:a,body:{completionMetadata:c}});if(O){let T=de(O),f=ce(t,o,e,T);return l&&k.add({completion:T,range:f,textBeforeCursor:P(o,e)}),i(),y([{insertText:T,range:f}])}}catch(p){u?u(p):Ae(p)||h.logError(p)}return y([])},Ae=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,me=Ie;var R=new WeakMap,M=null,ue=(t,e,o)=>{M&&M.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};R.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,l,u,C)=>{let p=R.get(e);if(!(!p||o.trigger==="onDemand"&&!p.isManualTrigger))return me({monaco:t,mdl:a,pos:l,token:C,isCompletionAccepted:p.isCompletionAccepted,onShowCompletion:()=>{p.isCompletionVisible=!0,p.isManualTrigger=!1},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(a=>{let l=R.get(e);if(!l)return;let u=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;l.isCompletionVisible&&u?(l.isCompletionAccepted=!0,l.isCompletionVisible=!1):l.isCompletionAccepted=!1});r.push(s);let d={deregister:()=>{r.forEach(a=>a.dispose()),k.clear(),R.delete(e),M=null},trigger:()=>we(e)};return M=d,d}catch(i){return o.onError?o.onError(i):h.logError(i),{deregister:()=>{r.forEach(s=>s.dispose()),R.delete(e),M=null},trigger:()=>{}}}},we=t=>{let e=R.get(t);if(!e){h.warn("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{})},De=(...t)=>(h.warn("The `registerCopilot` function is deprecated. Use `registerCompletion` instead."),ue(...t));export{U as Copilot,ue as registerCompletion,De as registerCopilot};
59
+ `),this}build(){return this.formattedCompletion}};var S=class{constructor(e,o){this.cursorPos=e,this.mdl=o}shouldProvideCompletions(){return!le(this.cursorPos,this.mdl)}};var F=class F{constructor(){this.cache=[]}get(e,o){return this.cache.filter(r=>this.isValidCacheItem(r,e,o))}add(e){let o=[...this.cache.slice(-(F.MAX_CACHE_SIZE-1)),e];this.cache=o}clear(){this.cache=[]}isValidCacheItem(e,o,r){let i=r.getValueInRange(e.range);return f(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,i)}isPositionValid(e,o,r){let{range:i,completion:n}=e,{startLineNumber:s,startColumn:d,endColumn:a}=i,{lineNumber:l,column:m}=o,u=l===s&&m===d,p=n.startsWith(r)&&l===s&&m>=d-r.length&&m<=a+r.length;return u||p}};F.MAX_CACHE_SIZE=10;var k=F;var Ie="application/json",me=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:i}=await L.POST(e,o,{headers:{"Content-Type":Ie},fallbackError:"Error while fetching completion item"});if(i)throw new Error(i);return{completion:r}},ue=({pos:t,mdl:e,options:o})=>{let{filename:r,language:i,technologies:n,relatedFiles:s,maxContextLines:d}=o,a=Ae(t,e),m=!!s?.length?3:2,u=d?Math.floor(d/m):void 0,p=(g,x,$)=>{let O=g(t,e);return x?U(O,x,$):O},C=(g,x)=>!g||!x?g:g.map(({content:$,...O})=>({...O,content:U($,x)})),c=p(f,u,{from:"end"}),M=p(se,u),R=C(s,u);return{filename:r,language:i,technologies:n,relatedFiles:R,textBeforeCursor:c,textAfterCursor:M,cursorPosition:t,editorState:{completionMode:a}}},Ae=(t,e)=>{let o=j(t,e),r=w(t,e);return o?"insert":r.trim()?"complete":"continue"};var Ce=(t,e,o,r)=>{if(!r)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);let i=o.getOffsetAt(e),n=o.getValue().substring(i),s=0,d=0,a=0,l=r.length,m=n.length;if(i>=o.getValue().length)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(m===0)return new t.Range(e.lineNumber,e.column,e.lineNumber,e.column);let u=Math.min(l,m);for(let c=0;c<u&&r[c]===n[c];c++)s++;for(let c=1;c<=u;c++)r.slice(-c)===n.slice(0,c)&&(d=c);if(a=Math.max(s,d),a===0){for(let c=1;c<l;c++)if(n.startsWith(r.substring(c))){a=l-c;break}}let p=i+a,C=o.getPositionAt(p);return new t.Range(e.lineNumber,e.column,C.lineNumber,C.column)},ge=t=>D.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),P=t=>({items:t,enableForwardStability:!0});var K={onTyping:300,onIdle:600,onDemand:0},Le=t=>({onTyping:A(t,K.onTyping),onIdle:A(t,K.onIdle),onDemand:A(t,K.onDemand)}),B=new k,De=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:i,onShowCompletion:n,options:s})=>{let{trigger:d="onIdle",endpoint:a,enableCaching:l=!0,onError:m,requestHandler:u}=s;if(!new S(o,e).shouldProvideCompletions())return P([]);if(l){let p=B.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(p.length>0)return n(),P(p)}if(r.isCancellationRequested||i)return P([]);try{let C=Le(u??me)[d];r.onCancellationRequested(()=>{C.cancel()});let c=ue({pos:o,mdl:e,options:s}),{completion:M}=await C({endpoint:a,body:{completionMetadata:c}});if(M){let R=ge(M),g=Ce(t,o,e,R);return l&&B.add({completion:R,range:g,textBeforeCursor:f(o,e)}),n(),P([{insertText:R,range:g}])}}catch(p){m?m(p):Se(p)||h(p)}return P([])},Se=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,he=De;var y=new WeakMap,E=null,fe=(t,e,o)=>{E&&E.deregister();let r=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};y.set(e,i),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let n=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(a,l,m,u)=>{let p=y.get(e);if(!(!p||o.trigger==="onDemand"&&!p.isManualTrigger))return he({monaco:t,mdl:a,pos:l,token:u,isCompletionAccepted:p.isCompletionAccepted,onShowCompletion:()=>{p.isCompletionVisible=!0,p.isManualTrigger=!1},options:o})},freeInlineCompletions:()=>{}});r.push(n);let s=e.onKeyDown(a=>{let l=y.get(e);if(!l)return;let m=a.keyCode===t.KeyCode.Tab||a.keyCode===t.KeyCode.RightArrow&&a.metaKey;l.isCompletionVisible&&m?(l.isCompletionAccepted=!0,l.isCompletionVisible=!1):l.isCompletionAccepted=!1});r.push(s);let d={deregister:()=>{r.forEach(a=>a.dispose()),B.clear(),y.delete(e),E=null},trigger:()=>ke(e)};return E=d,d}catch(n){return o.onError?o.onError(n):h(n),{deregister:()=>{r.forEach(s=>s.dispose()),y.delete(e),E=null},trigger:()=>{}}}},ke=t=>{let e=y.get(t);if(!e){ne("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{})},Fe=(...t)=>(I("The `registerCopilot` function is deprecated. Use `registerCompletion` instead."),fe(...t));export{W as Copilot,fe as registerCompletion,Fe as registerCopilot};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "monacopilot",
3
- "version": "0.12.3",
3
+ "version": "0.12.5",
4
4
  "description": "AI auto-completion plugin for Monaco Editor",
5
5
  "main": "./build/index.js",
6
6
  "module": "./build/index.mjs",