monacopilot 0.13.1 → 0.14.0
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 +16 -19
- package/build/index.d.mts +2 -2
- package/build/index.d.ts +2 -2
- package/build/index.js +7 -7
- package/build/index.mjs +4 -4
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -72,9 +72,9 @@ import {Copilot} from 'monacopilot';
|
|
|
72
72
|
|
|
73
73
|
const app = express();
|
|
74
74
|
const port = process.env.PORT || 3000;
|
|
75
|
-
const copilot = new Copilot(process.env.
|
|
76
|
-
provider: '
|
|
77
|
-
model: '
|
|
75
|
+
const copilot = new Copilot(process.env.ANTHROPIC_API_KEY!, {
|
|
76
|
+
provider: 'anthropic',
|
|
77
|
+
model: 'claude-3-5-haiku',
|
|
78
78
|
});
|
|
79
79
|
|
|
80
80
|
app.use(express.json());
|
|
@@ -87,7 +87,7 @@ app.post('/complete', async (req, res) => {
|
|
|
87
87
|
// Process raw LLM response if needed
|
|
88
88
|
// `raw` can be undefined if an error occurred, which happens when `error` is present
|
|
89
89
|
if (raw) {
|
|
90
|
-
calculateCost(raw.usage.
|
|
90
|
+
calculateCost(raw.usage.input_tokens);
|
|
91
91
|
}
|
|
92
92
|
|
|
93
93
|
// Handle errors if present
|
|
@@ -145,9 +145,6 @@ registerCompletion(monaco, editor, {
|
|
|
145
145
|
endpoint: 'https://api.example.com/complete',
|
|
146
146
|
// The language of the editor.
|
|
147
147
|
language: 'javascript',
|
|
148
|
-
// If you are using Groq as your provider, it's recommended to set `maxContextLines` to `60` or less.
|
|
149
|
-
// This is because Groq has low rate limits and doesn't offer pay-as-you-go pricing.
|
|
150
|
-
maxContextLines: 60,
|
|
151
148
|
});
|
|
152
149
|
```
|
|
153
150
|
|
|
@@ -168,11 +165,11 @@ registerCompletion(monaco, editor, {
|
|
|
168
165
|
});
|
|
169
166
|
```
|
|
170
167
|
|
|
171
|
-
| Trigger | Description | Notes
|
|
172
|
-
| -------------------- | --------------------------------------------------- |
|
|
173
|
-
| `'onIdle'` (default) | Provides completions after a brief pause in typing. | This approach is less resource-intensive, as it only initiates a request when the editor is idle.
|
|
174
|
-
| `'onTyping'` | Provides completions in real-time as you type. | Best suited for models with low response latency, such as Groq models. This trigger mode initiates additional background requests to deliver real-time suggestions, a method known as predictive caching. |
|
|
175
|
-
| `'onDemand'` | Does not provide completions automatically. | Completions are triggered manually using the `trigger` function from the `registerCompletion` return. This allows for precise control over when completions are provided.
|
|
168
|
+
| Trigger | Description | Notes |
|
|
169
|
+
| -------------------- | --------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
170
|
+
| `'onIdle'` (default) | Provides completions after a brief pause in typing. | This approach is less resource-intensive, as it only initiates a request when the editor is idle. |
|
|
171
|
+
| `'onTyping'` | Provides completions in real-time as you type. | Best suited for models with low response latency, such as Groq models or Claude 3-5 Haiku. This trigger mode initiates additional background requests to deliver real-time suggestions, a method known as predictive caching. |
|
|
172
|
+
| `'onDemand'` | Does not provide completions automatically. | Completions are triggered manually using the `trigger` function from the `registerCompletion` return. This allows for precise control over when completions are provided. |
|
|
176
173
|
|
|
177
174
|
[OnTyping Demo](https://github.com/user-attachments/assets/22c2ce44-334c-4963-b853-01b890b8e39f)
|
|
178
175
|
|
|
@@ -416,17 +413,17 @@ const copilot = new Copilot(process.env.OPENAI_API_KEY, {
|
|
|
416
413
|
});
|
|
417
414
|
```
|
|
418
415
|
|
|
419
|
-
The default provider is `
|
|
416
|
+
The default provider is `anthropic`, and the default model is `claude-3-5-haiku`.
|
|
420
417
|
|
|
421
|
-
> **Tip:** Even though the default provider and model are `
|
|
418
|
+
> **Tip:** Even though the default provider and model are `anthropic` and `claude-3-5-haiku`, it's always recommended to specify a provider and model when using Monacopilot. This ensures your code remains consistent even if the default settings change in future updates.
|
|
422
419
|
|
|
423
420
|
There are other providers and models available. Here is a list:
|
|
424
421
|
|
|
425
|
-
| Provider | Models
|
|
426
|
-
| --------- |
|
|
427
|
-
| Groq | `llama-3-70b`
|
|
428
|
-
| OpenAI | `gpt-4o`, `gpt-4o-mini`, `o1-preview`, `o1-mini`
|
|
429
|
-
| Anthropic | `claude-3-5-sonnet`, `claude-3-
|
|
422
|
+
| Provider | Models |
|
|
423
|
+
| --------- | --------------------------------------------------------- |
|
|
424
|
+
| Groq | `llama-3-70b` |
|
|
425
|
+
| OpenAI | `gpt-4o`, `gpt-4o-mini`, `o1-preview`, `o1-mini` |
|
|
426
|
+
| Anthropic | `claude-3-5-sonnet`, `claude-3-haiku`, `claude-3-5-haiku` |
|
|
430
427
|
|
|
431
428
|
### Custom Model
|
|
432
429
|
|
package/build/index.d.mts
CHANGED
|
@@ -6,7 +6,7 @@ import * as monaco_editor from 'monaco-editor';
|
|
|
6
6
|
|
|
7
7
|
type OpenAIModel = 'gpt-4o' | 'gpt-4o-mini' | 'o1-preview' | 'o1-mini';
|
|
8
8
|
type GroqModel = 'llama-3-70b';
|
|
9
|
-
type AnthropicModel = 'claude-3-5-sonnet' | 'claude-3-
|
|
9
|
+
type AnthropicModel = 'claude-3-5-sonnet' | 'claude-3-5-haiku' | 'claude-3-haiku';
|
|
10
10
|
type CopilotModel = OpenAIModel | GroqModel | AnthropicModel;
|
|
11
11
|
type CopilotProvider = 'openai' | 'groq' | 'anthropic';
|
|
12
12
|
type OpenAIChatCompletion = ChatCompletion;
|
|
@@ -28,7 +28,7 @@ interface CopilotOptions {
|
|
|
28
28
|
/**
|
|
29
29
|
* The model to use for copilot LLM requests.
|
|
30
30
|
* This can be either:
|
|
31
|
-
* 1. A predefined model name (e.g. 'claude-3-
|
|
31
|
+
* 1. A predefined model name (e.g. 'claude-3-5-haiku'): Use this option if you want to use a model that is built into Monacopilot.
|
|
32
32
|
* If you choose this option, also set the `provider` property to the corresponding provider of the model.
|
|
33
33
|
* 2. A custom model configuration object: Use this option if you want to use a LLM from a third-party service or your own custom model.
|
|
34
34
|
*
|
package/build/index.d.ts
CHANGED
|
@@ -6,7 +6,7 @@ import * as monaco_editor from 'monaco-editor';
|
|
|
6
6
|
|
|
7
7
|
type OpenAIModel = 'gpt-4o' | 'gpt-4o-mini' | 'o1-preview' | 'o1-mini';
|
|
8
8
|
type GroqModel = 'llama-3-70b';
|
|
9
|
-
type AnthropicModel = 'claude-3-5-sonnet' | 'claude-3-
|
|
9
|
+
type AnthropicModel = 'claude-3-5-sonnet' | 'claude-3-5-haiku' | 'claude-3-haiku';
|
|
10
10
|
type CopilotModel = OpenAIModel | GroqModel | AnthropicModel;
|
|
11
11
|
type CopilotProvider = 'openai' | 'groq' | 'anthropic';
|
|
12
12
|
type OpenAIChatCompletion = ChatCompletion;
|
|
@@ -28,7 +28,7 @@ interface CopilotOptions {
|
|
|
28
28
|
/**
|
|
29
29
|
* The model to use for copilot LLM requests.
|
|
30
30
|
* This can be either:
|
|
31
|
-
* 1. A predefined model name (e.g. 'claude-3-
|
|
31
|
+
* 1. A predefined model name (e.g. 'claude-3-5-haiku'): Use this option if you want to use a model that is built into Monacopilot.
|
|
32
32
|
* If you choose this option, also set the `provider` property to the corresponding provider of the model.
|
|
33
33
|
* 2. A custom model configuration object: Use this option if you want to use a LLM from a third-party service or your own custom model.
|
|
34
34
|
*
|
package/build/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var q=Object.defineProperty;var Re=Object.getOwnPropertyDescriptor;var Te=Object.getOwnPropertyNames;var Me=Object.prototype.hasOwnProperty;var be=(t,e)=>{for(var o in e)q(t,o,{get:e[o],enumerable:!0})},Ee=(t,e,o,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of Te(e))!Me.call(t,n)&&n!==o&&q(t,n,{get:()=>e[n],enumerable:!(r=Re(e,n))||r.enumerable});return t};var Oe=t=>Ee(q({},"__esModule",{value:!0}),t);var Ue={};be(Ue,{Copilot:()=>D,registerCompletion:()=>G,registerCopilot:()=>xe});module.exports=Oe(Ue);var H=["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-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-preview":"o1-preview","o1-mini":"o1-mini"},j={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-preview","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"]},J="anthropic",Z="claude-3-5-haiku",Q={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages"},O=.1;var ee={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var ve={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:U(t),temperature:O,messages:r}},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:U(t),temperature:O,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},Ae={createRequestBody:(t,e)=>({model:U(t),temperature:O,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:we(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}},V={openai:ve,groq:Ie,anthropic:Ae},te=(t,e,o)=>V[e].createRequestBody(t,o),oe=(t,e)=>V[e].createHeaders(t),re=(t,e)=>V[e].parseCompletion(t),U=t=>X[t],ne=t=>Q[t],we=t=>ee[t]||4096;var ie="\x1B[91m",se="\x1B[93m",v="\x1B[0m",W="\x1B[1m",f=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=`${ie}${W}[MONACOPILOT ERROR] ${e}${v}`;return console.error(o?`${r}
|
|
2
2
|
${ie}Stack trace:${v}
|
|
3
|
-
${o}`:r),{message:e,stack:o}},ae=t=>{console.warn(`${se}${W}[MONACOPILOT WARN] ${t}${v}`)};var I=(t,e,o)=>console.warn(`${se}${W}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${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 z=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var w=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),le=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),
|
|
3
|
+
${o}`:r),{message:e,stack:o}},ae=t=>{console.warn(`${se}${W}[MONACOPILOT WARN] ${t}${v}`)};var I=(t,e,o)=>console.warn(`${se}${W}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${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 z=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var w=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),le=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),y=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),pe=(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(`
|
|
4
4
|
`),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(d=>d==="")?`
|
|
5
5
|
`.repeat(e):s.join(`
|
|
6
6
|
`)}let i=r.slice(0,e);return i.every(s=>s==="")?`
|
|
@@ -10,7 +10,7 @@ ${d} ${a}.
|
|
|
10
10
|
${m}
|
|
11
11
|
${l}
|
|
12
12
|
${p}
|
|
13
|
-
${u}`.trim()},
|
|
13
|
+
${u}`.trim()},ke=t=>t?.length?t.map(({path:e,content:o})=>`
|
|
14
14
|
<related_file>
|
|
15
15
|
<path>${e}</path>
|
|
16
16
|
<content>
|
|
@@ -20,14 +20,14 @@ ${o}
|
|
|
20
20
|
</content>
|
|
21
21
|
</related_file>
|
|
22
22
|
`.trim()).join(`
|
|
23
|
-
`):"",
|
|
23
|
+
`):"",Fe=(t="",e)=>{let{relatedFiles:o}=e,r=o?ke(o):"";return`
|
|
24
24
|
<task>
|
|
25
25
|
<instructions>
|
|
26
26
|
${t.trim()}
|
|
27
27
|
</instructions>
|
|
28
28
|
${r}
|
|
29
29
|
</task>
|
|
30
|
-
`.trim()},me=(t,e)=>({system:Se(e),user:
|
|
30
|
+
`.trim()},me=(t,e)=>({system:Se(e),user:Fe(t,e)});var ue="<cursor>",Be=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r}}=t,n=`<code_file>
|
|
31
31
|
${e}${ue}${o}
|
|
32
32
|
</code_file>`,s=`
|
|
33
33
|
You are an expert coding assistant. Your task is to provide code completions based on the current cursor position in the code.
|
|
@@ -52,8 +52,8 @@ Depending on the completion mode, adjust your completion accordingly:
|
|
|
52
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]||""}
|
|
53
53
|
|
|
54
54
|
Remember to output **only** the code that should be inserted at the cursor, without any additional formatting or explanations.
|
|
55
|
-
`.trim();return me(s,t)},Ce=Be;var D=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??
|
|
55
|
+
`.trim();return me(s,t)},Ce=Be;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(!H.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${T(H)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!j[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${T(j[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=Ce(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=ne(this.provider),r,n=oe(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=te(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("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return{completion:re(e,this.provider),raw:e}}handleCompletionError(e){return{error:f(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(`
|
|
56
56
|
`).slice(1,-1).join(`
|
|
57
57
|
`);r=r.replace(i,s)}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
58
58
|
|
|
59
|
-
`),this}build(){return this.formattedCompletion}};var
|
|
59
|
+
`),this}build(){return this.formattedCompletion}};var k=class{constructor(e,o){this.cursorPos=e,this.mdl=o}shouldProvideCompletions(){return!de(this.cursorPos,this.mdl)}};var F=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e)}enqueue(e){let o;return this.size===this.capacity&&(o=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,o}dequeue(){if(this.size===0)return;let e=this.buffer[this.head];return this.buffer[this.head]=void 0,this.head=(this.head+1)%this.capacity,this.size--,e}getAll(){return this.buffer.filter(e=>e!==void 0)}clear(){this.buffer=new Array(this.capacity),this.head=0,this.tail=0,this.size=0}getSize(){return this.size}isEmpty(){return this.size===0}isFull(){return this.size===this.capacity}};var $=class ${constructor(){this.cache=new F($.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 y(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}};$.MAX_CACHE_SIZE=10;var B=$;var $e="application/json",ge=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await L.POST(e,o,{headers:{"Content-Type":$e},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return{completion:r}},he=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:d}=o,a=Ne(t,e),m=!!s?.length?3:2,u=d?Math.floor(d/m):void 0,p=(g,R,_)=>{let E=g(t,e);return R?K(E,R,_):E},C=(g,R)=>!g||!R?g:g.map(({content:_,...E})=>({...E,content:K(_,R)})),c=p(y,u,{from:"end"}),b=p(pe,u),x=C(s,u);return{filename:r,language:n,technologies:i,relatedFiles:x,textBeforeCursor:c,textAfterCursor:b,cursorPosition:t,editorState:{completionMode:a}}},Ne=(t,e)=>{let o=z(t,e),r=w(t,e);return o?"insert":r.trim()?"complete":"continue"};var fe=(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)},ye=t=>S.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),h=t=>({items:t,enableForwardStability:!0});var Y={onTyping:300,onIdle:600,onDemand:0},qe=t=>({onTyping:A(t,Y.onTyping),onIdle:A(t,Y.onIdle),onDemand:A(t,Y.onDemand)}),N=new B,He=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 h([]);if(l){let p=N.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(p.length>0)return i(),h(p)}if(r.isCancellationRequested||n)return h([]);try{let C=qe(u??ge)[d];r.onCancellationRequested(()=>{C.cancel()});let c=he({pos:o,mdl:e,options:s}),{completion:b}=await C({endpoint:a,body:{completionMetadata:c}});if(b){let x=ye(b),g=fe(t,o,e,x);return l&&N.add({completion:x,range:g,textBeforeCursor:y(o,e)}),i(),h([{insertText:x,range:g}])}}catch(p){if(je(p))return h([]);m?m(p):f(p)}return h([])},je=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,Pe=He;var P=new WeakMap,M=null,G=(t,e,o)=>{M&&M.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};P.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=P.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=P.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()),N.clear(),P.delete(e),M=null},trigger:()=>Ve(e)};return M=d,d}catch(i){return o.onError?o.onError(i):f(i),{deregister:()=>{r.forEach(s=>s.dispose()),P.delete(e),M=null},trigger:()=>{}}}},Ve=t=>{let e=P.get(t);if(!e){ae("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{})},xe=(...t)=>(I("registerCopilot","registerCompletion"),G(...t));0&&(module.exports={Copilot,registerCompletion,registerCopilot});
|
package/build/index.mjs
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
var
|
|
1
|
+
var _=["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-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-preview":"o1-preview","o1-mini":"o1-mini"},q={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-preview","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"]},G="anthropic",X="claude-3-5-haiku",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"},O=.1;var Z={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":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:j(t),temperature:O,messages:r}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},xe={createRequestBody:(t,e)=>({model:j(t),temperature:O,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:j(t),temperature:O,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:Te(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}},H={openai:Pe,groq:xe,anthropic:Re},Q=(t,e,o)=>H[e].createRequestBody(t,o),ee=(t,e)=>H[e].createHeaders(t),te=(t,e)=>H[e].parseCompletion(t),j=t=>Y[t],oe=t=>J[t],Te=t=>Z[t]||4096;var re="\x1B[91m",ne="\x1B[93m",v="\x1B[0m",V="\x1B[1m",f=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=`${re}${V}[MONACOPILOT ERROR] ${e}${v}`;return console.error(o?`${r}
|
|
2
2
|
${re}Stack trace:${v}
|
|
3
|
-
${o}`:r),{message:e,stack:o}},ie=t=>{console.warn(`${ne}${
|
|
3
|
+
${o}`:r),{message:e,stack:o}},ie=t=>{console.warn(`${ne}${V}[MONACOPILOT WARN] ${t}${v}`)};var I=(t,e,o)=>console.warn(`${ne}${V}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${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 U=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var w=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),se=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),y=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),ae=(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(`
|
|
4
4
|
`),i=r.length;if(e>=i)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(d=>d==="")?`
|
|
5
5
|
`.repeat(e):s.join(`
|
|
6
6
|
`)}let n=r.slice(0,e);return n.every(s=>s==="")?`
|
|
@@ -52,8 +52,8 @@ Depending on the completion mode, adjust your completion accordingly:
|
|
|
52
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]||""}
|
|
53
53
|
|
|
54
54
|
Remember to output **only** the code that should be inserted at the cursor, without any additional formatting or explanations.
|
|
55
|
-
`.trim();return ce(s,t)},me=Ie;var z=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??
|
|
55
|
+
`.trim();return ce(s,t)},me=Ie;var z=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??X,this.validateInputs()}validateInputs(){if(!_.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${T(_)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!q[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${T(q[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=me(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=oe(this.provider),r,i=ee(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=Q(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("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return{completion:te(e,this.provider),raw:e}}handleCompletionError(e){return{error:f(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(`
|
|
56
56
|
`).slice(1,-1).join(`
|
|
57
57
|
`);r=r.replace(n,s)}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
58
58
|
|
|
59
|
-
`),this}build(){return this.formattedCompletion}};var S=class{constructor(e,o){this.cursorPos=e,this.mdl=o}shouldProvideCompletions(){return!pe(this.cursorPos,this.mdl)}};var
|
|
59
|
+
`),this}build(){return this.formattedCompletion}};var S=class{constructor(e,o){this.cursorPos=e,this.mdl=o}shouldProvideCompletions(){return!pe(this.cursorPos,this.mdl)}};var k=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 B=class B{constructor(){this.cache=new k(B.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 i=r.getValueInRange(e.range);return y(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}};B.MAX_CACHE_SIZE=10;var F=B;var Ae="application/json",ue=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:i}=await L.POST(e,o,{headers:{"Content-Type":Ae},fallbackError:"Error while fetching completion item"});if(i)throw new Error(i);return{completion:r}},Ce=({pos:t,mdl:e,options:o})=>{let{filename:r,language:i,technologies:n,relatedFiles:s,maxContextLines:d}=o,a=we(t,e),m=!!s?.length?3:2,u=d?Math.floor(d/m):void 0,p=(g,R,N)=>{let E=g(t,e);return R?W(E,R,N):E},C=(g,R)=>!g||!R?g:g.map(({content:N,...E})=>({...E,content:W(N,R)})),c=p(y,u,{from:"end"}),b=p(ae,u),x=C(s,u);return{filename:r,language:i,technologies:n,relatedFiles:x,textBeforeCursor:c,textAfterCursor:b,cursorPosition:t,editorState:{completionMode:a}}},we=(t,e)=>{let o=U(t,e),r=w(t,e);return o?"insert":r.trim()?"complete":"continue"};var ge=(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)},he=t=>D.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),h=t=>({items:t,enableForwardStability:!0});var K={onTyping:300,onIdle:600,onDemand:0},De=t=>({onTyping:A(t,K.onTyping),onIdle:A(t,K.onIdle),onDemand:A(t,K.onDemand)}),$=new F,Se=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 h([]);if(l){let p=$.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(p.length>0)return n(),h(p)}if(r.isCancellationRequested||i)return h([]);try{let C=De(u??ue)[d];r.onCancellationRequested(()=>{C.cancel()});let c=Ce({pos:o,mdl:e,options:s}),{completion:b}=await C({endpoint:a,body:{completionMetadata:c}});if(b){let x=he(b),g=ge(t,o,e,x);return l&&$.add({completion:x,range:g,textBeforeCursor:y(o,e)}),n(),h([{insertText:x,range:g}])}}catch(p){if(ke(p))return h([]);m?m(p):f(p)}return h([])},ke=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,fe=Se;var P=new WeakMap,M=null,ye=(t,e,o)=>{M&&M.deregister();let r=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};P.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=P.get(e);if(!(!p||o.trigger==="onDemand"&&!p.isManualTrigger))return fe({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=P.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(),P.delete(e),M=null},trigger:()=>Fe(e)};return M=d,d}catch(n){return o.onError?o.onError(n):f(n),{deregister:()=>{r.forEach(s=>s.dispose()),P.delete(e),M=null},trigger:()=>{}}}},Fe=t=>{let e=P.get(t);if(!e){ie("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{})},Be=(...t)=>(I("registerCopilot","registerCompletion"),ye(...t));export{z as Copilot,ye as registerCompletion,Be as registerCopilot};
|