monacopilot 0.14.1 → 0.15.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 CHANGED
@@ -419,11 +419,12 @@ The default provider is `anthropic`, and the default model is `claude-3-5-haiku`
419
419
 
420
420
  There are other providers and models available. Here is a list:
421
421
 
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` |
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` |
427
+ | Google | `gemini-1.5-pro`, `gemini-1.5-flash`, `gemini-1.5-flash-8b` |
427
428
 
428
429
  ### Custom Model
429
430
 
package/build/index.d.mts CHANGED
@@ -4,67 +4,47 @@ import { ChatCompletion } from 'openai/resources/chat/completions';
4
4
  import * as monaco from 'monaco-editor/esm/vs/editor/editor.api';
5
5
  import * as monaco_editor from 'monaco-editor';
6
6
 
7
+ /**
8
+ * Models available for OpenAI provider.
9
+ */
7
10
  type OpenAIModel = 'gpt-4o' | 'gpt-4o-mini' | 'o1-preview' | 'o1-mini';
11
+ /**
12
+ * Models available for Groq provider.
13
+ */
8
14
  type GroqModel = 'llama-3-70b';
15
+ /**
16
+ * Models available for Anthropic provider.
17
+ */
9
18
  type AnthropicModel = 'claude-3-5-sonnet' | 'claude-3-5-haiku' | 'claude-3-haiku';
10
- type CopilotModel = OpenAIModel | GroqModel | AnthropicModel;
11
- type CopilotProvider = 'openai' | 'groq' | 'anthropic';
19
+ /**
20
+ * Models available for Google provider.
21
+ */
22
+ type GoogleModel = 'gemini-1.5-flash' | 'gemini-1.5-flash-8b' | 'gemini-1.5-pro';
23
+ /**
24
+ * Union of all predefined Copilot models.
25
+ */
26
+ type CopilotModel = OpenAIModel | GroqModel | AnthropicModel | GoogleModel;
27
+ /**
28
+ * Providers supported by Copilot.
29
+ */
30
+ type CopilotProvider = 'openai' | 'groq' | 'anthropic' | 'google';
31
+ /**
32
+ * Specific ChatCompletion types for each provider.
33
+ */
12
34
  type OpenAIChatCompletion = ChatCompletion;
13
35
  type GroqChatCompletion = ChatCompletion$1;
14
36
  type AnthropicChatCompletion = Message;
15
- type PromptData = {
16
- system: string;
17
- user: string;
18
- };
19
37
  /**
20
- * Options for configuring the Copilot instance.
38
+ * Data structure representing the prompt data.
21
39
  */
22
- interface CopilotOptions {
23
- /**
24
- * The provider to use (e.g., 'openai', 'anthropic', 'groq').
25
- * If not specified, a default provider will be used.
26
- */
27
- provider?: CopilotProvider;
28
- /**
29
- * The model to use for copilot LLM requests.
30
- * This can be either:
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
- * If you choose this option, also set the `provider` property to the corresponding provider of the model.
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
- *
35
- * If not specified, a default model will be used.
36
- */
37
- model?: CopilotModel | CustomCopilotModel;
38
- }
39
- type CustomCopilotModel = {
40
- /**
41
- * A function to configure the custom model.
42
- * This function takes the API key and the prompt data and returns the configuration for the custom model.
43
- *
44
- * @param {string} apiKey - The API key for authentication.
45
- * @param {Object} prompt - An object containing 'system' and 'user' messages generated by Monacopilot.
46
- * @returns {Object} An object that may include:
47
- * - endpoint: The URL for the custom model's API (required)
48
- * - headers: Additional HTTP headers for the API request (optional)
49
- * - body: The request body data for the custom model API (optional)
50
- */
51
- config: CustomCopilotModelConfig;
52
- /**
53
- * A function to transform the response from the custom model.
54
- * This function takes the raw response from the custom model API
55
- * and returns the model generated text or null.
56
- *
57
- * @param response - The raw response from the custom model API.
58
- * The type is 'unknown' because different APIs
59
- * may return responses in different formats.
60
- * @returns The model generated text or null if no valid text could be extracted.
61
- */
62
- transformResponse: CustomCopilotModelTransformResponse;
63
- };
64
- type CustomCopilotModelConfig = (apiKey: string, prompt: {
40
+ interface PromptData {
65
41
  system: string;
66
42
  user: string;
67
- }) => {
43
+ }
44
+ /**
45
+ * Function type for configuring a custom model.
46
+ */
47
+ type CustomCopilotModelConfig = (apiKey: string, prompt: PromptData) => {
68
48
  /**
69
49
  * The URL endpoint for the custom model's API.
70
50
  */
@@ -79,6 +59,9 @@ type CustomCopilotModelConfig = (apiKey: string, prompt: {
79
59
  */
80
60
  body?: Record<string, unknown>;
81
61
  };
62
+ /**
63
+ * Function type for transforming the response from a custom model.
64
+ */
82
65
  type CustomCopilotModelTransformResponse = (response: unknown) => {
83
66
  /**
84
67
  * The text generated by the custom model.
@@ -89,6 +72,77 @@ type CustomCopilotModelTransformResponse = (response: unknown) => {
89
72
  */
90
73
  completion?: string | null;
91
74
  };
75
+ /**
76
+ * Definition of a custom Copilot model.
77
+ */
78
+ interface CustomCopilotModel {
79
+ /**
80
+ * Function to configure the custom model.
81
+ */
82
+ config: CustomCopilotModelConfig;
83
+ /**
84
+ * Function to transform the response from the custom model.
85
+ */
86
+ transformResponse: CustomCopilotModelTransformResponse;
87
+ }
88
+ /**
89
+ * Configuration options for initializing a Copilot instance.
90
+ * The `model` property is type-safe and varies based on the specified `provider`.
91
+ */
92
+ type CopilotOptions = {
93
+ /**
94
+ * Specifies the provider for the Copilot instance.
95
+ * Supported providers include 'openai', 'anthropic', 'groq', and 'google'.
96
+ */
97
+ provider: 'openai';
98
+ /**
99
+ * Defines the model to be used for Copilot LLM (Language Model) requests.
100
+ * This must be a model from the 'openai' provider.
101
+ */
102
+ model?: OpenAIModel;
103
+ } | {
104
+ /**
105
+ * Specifies the 'groq' provider for the Copilot instance.
106
+ */
107
+ provider: 'groq';
108
+ /**
109
+ * Defines the model to be used for Copilot LLM requests.
110
+ * This must be a model from the 'groq' provider.
111
+ */
112
+ model?: GroqModel;
113
+ } | {
114
+ /**
115
+ * Specifies the 'anthropic' provider for the Copilot instance.
116
+ */
117
+ provider: 'anthropic';
118
+ /**
119
+ * Defines the model to be used for Copilot LLM requests.
120
+ * This must be a model from the 'anthropic' provider.
121
+ */
122
+ model?: AnthropicModel;
123
+ } | {
124
+ /**
125
+ * Specifies the 'google' provider for the Copilot instance.
126
+ */
127
+ provider: 'google';
128
+ /**
129
+ * Defines the model to be used for Copilot LLM requests.
130
+ * This must be a model from the 'google' provider.
131
+ */
132
+ model?: GoogleModel;
133
+ } | {
134
+ /**
135
+ * When no provider is specified, only custom models are allowed.
136
+ */
137
+ provider?: undefined;
138
+ /**
139
+ * Defines the model to be used for Copilot LLM requests.
140
+ * Must be a custom model when no provider is specified.
141
+ * For more information, refer to the documentation:
142
+ * @see https://github.com/arshad-yaseen/monacopilot?tab=readme-ov-file#custom-model
143
+ */
144
+ model?: CustomCopilotModel;
145
+ };
92
146
 
93
147
  type Monaco = typeof monaco;
94
148
  type StandaloneCodeEditor = monaco.editor.IStandaloneCodeEditor;
package/build/index.d.ts CHANGED
@@ -4,67 +4,47 @@ import { ChatCompletion } from 'openai/resources/chat/completions';
4
4
  import * as monaco from 'monaco-editor/esm/vs/editor/editor.api';
5
5
  import * as monaco_editor from 'monaco-editor';
6
6
 
7
+ /**
8
+ * Models available for OpenAI provider.
9
+ */
7
10
  type OpenAIModel = 'gpt-4o' | 'gpt-4o-mini' | 'o1-preview' | 'o1-mini';
11
+ /**
12
+ * Models available for Groq provider.
13
+ */
8
14
  type GroqModel = 'llama-3-70b';
15
+ /**
16
+ * Models available for Anthropic provider.
17
+ */
9
18
  type AnthropicModel = 'claude-3-5-sonnet' | 'claude-3-5-haiku' | 'claude-3-haiku';
10
- type CopilotModel = OpenAIModel | GroqModel | AnthropicModel;
11
- type CopilotProvider = 'openai' | 'groq' | 'anthropic';
19
+ /**
20
+ * Models available for Google provider.
21
+ */
22
+ type GoogleModel = 'gemini-1.5-flash' | 'gemini-1.5-flash-8b' | 'gemini-1.5-pro';
23
+ /**
24
+ * Union of all predefined Copilot models.
25
+ */
26
+ type CopilotModel = OpenAIModel | GroqModel | AnthropicModel | GoogleModel;
27
+ /**
28
+ * Providers supported by Copilot.
29
+ */
30
+ type CopilotProvider = 'openai' | 'groq' | 'anthropic' | 'google';
31
+ /**
32
+ * Specific ChatCompletion types for each provider.
33
+ */
12
34
  type OpenAIChatCompletion = ChatCompletion;
13
35
  type GroqChatCompletion = ChatCompletion$1;
14
36
  type AnthropicChatCompletion = Message;
15
- type PromptData = {
16
- system: string;
17
- user: string;
18
- };
19
37
  /**
20
- * Options for configuring the Copilot instance.
38
+ * Data structure representing the prompt data.
21
39
  */
22
- interface CopilotOptions {
23
- /**
24
- * The provider to use (e.g., 'openai', 'anthropic', 'groq').
25
- * If not specified, a default provider will be used.
26
- */
27
- provider?: CopilotProvider;
28
- /**
29
- * The model to use for copilot LLM requests.
30
- * This can be either:
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
- * If you choose this option, also set the `provider` property to the corresponding provider of the model.
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
- *
35
- * If not specified, a default model will be used.
36
- */
37
- model?: CopilotModel | CustomCopilotModel;
38
- }
39
- type CustomCopilotModel = {
40
- /**
41
- * A function to configure the custom model.
42
- * This function takes the API key and the prompt data and returns the configuration for the custom model.
43
- *
44
- * @param {string} apiKey - The API key for authentication.
45
- * @param {Object} prompt - An object containing 'system' and 'user' messages generated by Monacopilot.
46
- * @returns {Object} An object that may include:
47
- * - endpoint: The URL for the custom model's API (required)
48
- * - headers: Additional HTTP headers for the API request (optional)
49
- * - body: The request body data for the custom model API (optional)
50
- */
51
- config: CustomCopilotModelConfig;
52
- /**
53
- * A function to transform the response from the custom model.
54
- * This function takes the raw response from the custom model API
55
- * and returns the model generated text or null.
56
- *
57
- * @param response - The raw response from the custom model API.
58
- * The type is 'unknown' because different APIs
59
- * may return responses in different formats.
60
- * @returns The model generated text or null if no valid text could be extracted.
61
- */
62
- transformResponse: CustomCopilotModelTransformResponse;
63
- };
64
- type CustomCopilotModelConfig = (apiKey: string, prompt: {
40
+ interface PromptData {
65
41
  system: string;
66
42
  user: string;
67
- }) => {
43
+ }
44
+ /**
45
+ * Function type for configuring a custom model.
46
+ */
47
+ type CustomCopilotModelConfig = (apiKey: string, prompt: PromptData) => {
68
48
  /**
69
49
  * The URL endpoint for the custom model's API.
70
50
  */
@@ -79,6 +59,9 @@ type CustomCopilotModelConfig = (apiKey: string, prompt: {
79
59
  */
80
60
  body?: Record<string, unknown>;
81
61
  };
62
+ /**
63
+ * Function type for transforming the response from a custom model.
64
+ */
82
65
  type CustomCopilotModelTransformResponse = (response: unknown) => {
83
66
  /**
84
67
  * The text generated by the custom model.
@@ -89,6 +72,77 @@ type CustomCopilotModelTransformResponse = (response: unknown) => {
89
72
  */
90
73
  completion?: string | null;
91
74
  };
75
+ /**
76
+ * Definition of a custom Copilot model.
77
+ */
78
+ interface CustomCopilotModel {
79
+ /**
80
+ * Function to configure the custom model.
81
+ */
82
+ config: CustomCopilotModelConfig;
83
+ /**
84
+ * Function to transform the response from the custom model.
85
+ */
86
+ transformResponse: CustomCopilotModelTransformResponse;
87
+ }
88
+ /**
89
+ * Configuration options for initializing a Copilot instance.
90
+ * The `model` property is type-safe and varies based on the specified `provider`.
91
+ */
92
+ type CopilotOptions = {
93
+ /**
94
+ * Specifies the provider for the Copilot instance.
95
+ * Supported providers include 'openai', 'anthropic', 'groq', and 'google'.
96
+ */
97
+ provider: 'openai';
98
+ /**
99
+ * Defines the model to be used for Copilot LLM (Language Model) requests.
100
+ * This must be a model from the 'openai' provider.
101
+ */
102
+ model?: OpenAIModel;
103
+ } | {
104
+ /**
105
+ * Specifies the 'groq' provider for the Copilot instance.
106
+ */
107
+ provider: 'groq';
108
+ /**
109
+ * Defines the model to be used for Copilot LLM requests.
110
+ * This must be a model from the 'groq' provider.
111
+ */
112
+ model?: GroqModel;
113
+ } | {
114
+ /**
115
+ * Specifies the 'anthropic' provider for the Copilot instance.
116
+ */
117
+ provider: 'anthropic';
118
+ /**
119
+ * Defines the model to be used for Copilot LLM requests.
120
+ * This must be a model from the 'anthropic' provider.
121
+ */
122
+ model?: AnthropicModel;
123
+ } | {
124
+ /**
125
+ * Specifies the 'google' provider for the Copilot instance.
126
+ */
127
+ provider: 'google';
128
+ /**
129
+ * Defines the model to be used for Copilot LLM requests.
130
+ * This must be a model from the 'google' provider.
131
+ */
132
+ model?: GoogleModel;
133
+ } | {
134
+ /**
135
+ * When no provider is specified, only custom models are allowed.
136
+ */
137
+ provider?: undefined;
138
+ /**
139
+ * Defines the model to be used for Copilot LLM requests.
140
+ * Must be a custom model when no provider is specified.
141
+ * For more information, refer to the documentation:
142
+ * @see https://github.com/arshad-yaseen/monacopilot?tab=readme-ov-file#custom-model
143
+ */
144
+ model?: CustomCopilotModel;
145
+ };
92
146
 
93
147
  type Monaco = typeof monaco;
94
148
  type StandaloneCodeEditor = monaco.editor.IStandaloneCodeEditor;
package/build/index.js CHANGED
@@ -1,16 +1,17 @@
1
- "use strict";var $=Object.defineProperty;var Te=Object.getOwnPropertyDescriptor;var Re=Object.getOwnPropertyNames;var Me=Object.prototype.hasOwnProperty;var Oe=(t,e)=>{for(var o in e)$(t,o,{get:e[o],enumerable:!0})},be=(t,e,o,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of Re(e))!Me.call(t,n)&&n!==o&&$(t,n,{get:()=>e[n],enumerable:!(r=Te(e,n))||r.enumerable});return t};var Ee=t=>be($({},"__esModule",{value:!0}),t);var Ue={};Oe(Ue,{Copilot:()=>D,registerCompletion:()=>Y,registerCopilot:()=>xe});module.exports=Ee(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"},V={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"},E=.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:E,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:E,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:E,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}},j={openai:ve,groq:Ie,anthropic:Ae},te=(t,e,o)=>j[e].createRequestBody(t,o),oe=(t,e)=>j[e].createHeaders(t),re=(t,e)=>j[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",z="\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}${z}[MONACOPILOT ERROR] ${e}${v}`;return console.error(o?`${r}
2
- ${ie}Stack trace:${v}
3
- ${o}`:r),{message:e,stack:o}},ae=t=>{console.warn(`${se}${z}[MONACOPILOT WARN] ${t}${v}`)};var I=(t,e,o)=>console.warn(`${se}${z}[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,a)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=a,o=setTimeout(()=>{s(t(...i)),r=null},e)});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null)},n},R=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),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(`
1
+ 'use strict';
2
+
3
+ var j=["groq","openai","anthropic","google"],J={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-preview":"o1-preview","o1-mini":"o1-mini","gemini-1.5-flash-8b":"gemini-1.5-flash-8b","gemini-1.5-flash":"gemini-1.5-flash","gemini-1.5-pro":"gemini-1.5-pro"},U={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-preview","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},Z="anthropic",Q="claude-3-5-haiku",b={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models"},A=.1;var ee={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var xe={createEndpoint:()=>b.openai,createRequestBody:(t,e)=>{let o=t==="o1-preview"||t==="o1-mini",r=o?[{role:"user",content:e.user}]:[{role:"system",content:e.system},{role:"user",content:e.user}];return {model:N(t),...!o&&{temperature:A},messages:r}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Pe={createEndpoint:()=>b.groq,createRequestBody:(t,e)=>({model:N(t),temperature:A,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Re={createEndpoint:()=>b.anthropic,createRequestBody:(t,e)=>({model:N(t),temperature:A,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ee[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}},Oe={createEndpoint:(t,e)=>`${b.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:N(t),system_instruction:{parts:{text:e.system}},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},L={openai:xe,groq:Pe,anthropic:Re,google:Oe},te=(t,e,o)=>L[o].createEndpoint(t,e),oe=(t,e,o)=>L[e].createRequestBody(t,o),re=(t,e)=>L[e].createHeaders(t),ne=(t,e)=>L[e].parseCompletion(t),N=t=>J[t];var Te="\x1B[91m",ie="\x1B[93m",K="\x1B[0m",W="\x1B[1m",O=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${Te}${W}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},se=t=>{console.warn(`${ie}${W}[MONACOPILOT WARN] ${t}${K}`);};var w=(t,e,o)=>console.warn(`${ie}${W}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${K}`);var v=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 _=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ae=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),T=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),D=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())}),Y=(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(a=>a==="")?`
5
5
  `.repeat(e):s.join(`
6
6
  `)}let i=r.slice(0,e);return i.every(s=>s==="")?`
7
7
  `.repeat(e):i.join(`
8
- `)};var ce=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()},_e=(t,e)=>ce(t,"GET",e),De=(t,e,o)=>ce(t,"POST",{...o,body:e}),_={GET:_e,POST:De};var de=(t,e)=>{let o=w(t,e).trim(),r=le(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var Le=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n}=t,i=R([n,...e].filter(a=>typeof a=="string"&&!!a));return[`You are an expert ${i?`${i} `:""}developer assistant specialized in precise code completion and generation.`,`Your primary task is to provide accurate, context-aware code completions that seamlessly integrate with existing codebases${o?` in '${o}'`:""}.`,`You must:
8
+ `)};var le=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok){let s=`
9
+ `+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},Ee=(t,e)=>le(t,"GET",e),Me=(t,e,o)=>le(t,"POST",{...o,body:e}),S={GET:Ee,POST:Me};var ce=(t,e)=>{let o=_(t,e).trim(),r=ae(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var B=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,a)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=a,o=setTimeout(()=>{s(t(...i)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var be=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n}=t,i=v([n,...e].filter(a=>typeof a=="string"&&!!a));return [`You are an expert ${i?`${i} `:""}developer assistant specialized in precise code completion and generation.`,`Your primary task is to provide accurate, context-aware code completions that seamlessly integrate with existing codebases${o?` in '${o}'`:""}.`,`You must:
9
10
  - Generate only the exact code required
10
11
  - Maintain strict adherence to provided instructions
11
12
  - Follow established code patterns and conventions
12
13
  - Consider the full context before generating code`,r?.length?"Analyze and incorporate context from all provided related files to ensure consistent and appropriate code generation.":"",n?`Apply ${n}-specific best practices, idioms, and syntax conventions in all generated code.`:""].filter(Boolean).join(`
13
- `)},ke=t=>t?.length?t.map(({path:e,content:o})=>`
14
+ `)},ve=t=>t?.length?t.map(({path:e,content:o})=>`
14
15
  <related_file>
15
16
  <path>${e}</path>
16
17
  <content_context>
@@ -20,25 +21,33 @@ ${o}
20
21
  </content_context>
21
22
  </related_file>`.trim()).join(`
22
23
 
23
- `):"",Se=(t="",e)=>{let{relatedFiles:o}=e;return`
24
+ `):"",Ie=(t="",e)=>{let{relatedFiles:o}=e;return `
24
25
  <task_context>
25
26
  <primary_instructions>
26
27
  ${t.trim()}
27
28
  </primary_instructions>
28
29
  ${o?.length?`
29
30
  <reference_files>
30
- ${ke(o)}
31
+ ${ve(o)}
31
32
  </reference_files>`:""}
32
- </task_context>`.trim()},me=(t,e)=>({system:Le(e),user:Se(t,e)});var ue="<cursor>",Be=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r},language:n}=t,i=`<code_file>
33
- ${e}${ue}${o}
33
+ </task_context>`.trim()},pe=(t,e)=>({system:be(e),user:Ie(t,e)});var de="<cursor>",Ae=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r},language:n}=t,i=`<code_file>
34
+ ${e}${de}${o}
34
35
  </code_file>`,a=`
35
36
  <instructions>
36
37
  <context>
37
- Below is a ${n||"code"} file with the token '${ue}' marking the exact cursor position where code completion is needed.
38
+ Below is a ${n||"code"} file with the token '${de}' marking the exact cursor position where code completion is needed.
38
39
 
39
40
  ${i}
40
41
  </context>
41
42
 
43
+ <critical_rules>
44
+ 1. NEVER REPEAT ANY TEXT THAT APPEARS BEFORE THE CURSOR
45
+ 2. Start your completion EXACTLY from the cursor position
46
+ 3. If user types 'const ' and cursor is after it, DO NOT include 'const ' in your completion
47
+ 4. ONLY provide the remaining part of the code that should appear after the cursor
48
+ 5. Violation of these rules will cause code duplication and syntax errors
49
+ </critical_rules>
50
+
42
51
  <primary_objectives>
43
52
  1. Generate code that is syntactically correct and follows ${n||"the language"}'s best practices
44
53
  2. Ensure seamless integration with existing code structure
@@ -47,7 +56,8 @@ ${e}${ue}${o}
47
56
  </primary_objectives>
48
57
 
49
58
  <strict_requirements>
50
- - Output MUST contain only the code to be inserted at cursor position
59
+ - Output MUST contain only the NEW code to be inserted at cursor position
60
+ - NEVER repeat any code that appears before the cursor position
51
61
  - DO NOT include any code that appears before the cursor
52
62
  - DO NOT include explanatory comments or documentation
53
63
  - DO NOT wrap output in markdown code blocks
@@ -64,12 +74,44 @@ ${e}${ue}${o}
64
74
  1. Analyze the code context before and after the cursor
65
75
  2. Identify the current scope and available variables/functions
66
76
  3. Determine the logical flow and required completion
67
- 4. Verify syntax compatibility with surrounding code
68
- 5. Ensure completion maintains code integrity
77
+ 4. Remove any duplicate text that appears before cursor
78
+ 5. Verify completion starts exactly at cursor position
69
79
  </code_analysis_steps>
70
80
 
71
81
  <examples>
72
- [Previous examples section remains the same]
82
+ <example>
83
+ Context: "const <cursor>"
84
+ CORRECT COMPLETION: "myVariable = 42"
85
+ INCORRECT COMPLETION: "const myVariable = 42"
86
+ </example>
87
+
88
+ <example>
89
+ Context: "function hello<cursor>"
90
+ CORRECT COMPLETION: "(name: string) {\\n return 'Hello ' + name;\\n}"
91
+ INCORRECT COMPLETION: "function hello(name: string) {\\n return 'Hello ' + name;\\n}"
92
+ </example>
93
+
94
+ <example>
95
+ Context: "const randomNumber = Math.floor(Math.ran<cursor>00);"
96
+ CORRECT COMPLETION: "dom() * 1"
97
+ INCORRECT COMPLETION: "Math.random() * 1"
98
+ </example>
99
+
100
+ <example>
101
+ Context: "const result = 'Hello' + ' W<cursor>';"
102
+ CORRECT COMPLETION: "orld"
103
+ INCORRECT COMPLETION: "orld';"
104
+ </example>
105
+
106
+ <example>
107
+ Context: "function isPalindrome(<cursor>)"
108
+ CORRECT COMPLETION: "str) {
109
+ return str === str.split('').reverse().join('');
110
+ }"
111
+ INCORRECT COMPLETION: "(str) {
112
+ return str === str.split('').reverse().join('');
113
+ }"
114
+ </example>
73
115
  </examples>
74
116
 
75
117
  <error_prevention>
@@ -78,17 +120,23 @@ ${e}${ue}${o}
78
120
  - Check for proper bracket and parenthesis matching
79
121
  - Maintain consistent indentation with surrounding code
80
122
  - Respect language-specific type safety requirements
123
+ - NEVER duplicate text that appears before cursor
81
124
  </error_prevention>
82
125
 
83
126
  <final_validation>
84
127
  Before providing the completion:
85
- 1. Confirm the output contains ONLY the necessary code
86
- 2. Verify it fits seamlessly at the cursor position
87
- 3. Ensure it follows the active completion mode requirements
88
- 4. Check for consistency with existing code style
128
+ 1. Confirm the output contains ONLY the new code after cursor position
129
+ 2. Double-check no text before cursor is duplicated
130
+ 3. Verify it fits seamlessly at the cursor position
131
+ 4. Ensure it follows the active completion mode requirements
132
+ 5. Check for consistency with existing code style
89
133
  </final_validation>
90
- </instructions>`.trim();return me(a,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: ${R(H)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!V[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${R(V[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},a=this.generatePrompt(n,s),{endpoint:l,requestBody:p,headers:m}=this.prepareRequestDetails(a);try{let u=await this.sendCompletionRequest(l,p,{...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 _.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 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(`
134
+ </instructions>`.trim();return pe(a,t)},me=Ae;var G=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??Z,this.model=o.model??Q,this.validateInputs();}validateInputs(){if(!j.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${v(j)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!U[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${v(U[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},a=this.generatePrompt(n,s),{endpoint:d,requestBody:m,headers:c}=this.prepareRequestDetails(a);try{let p=await this.sendCompletionRequest(d,m,{...c,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let r=me(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=te(this.model,this.apiKey,this.provider),r,n=re(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=oe(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return S.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&&w("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return {completion:ne(e,this.provider),raw:e}}handleCompletionError(e){return {error:O(e).message,completion:null}}};var k=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
91
135
  `).slice(1,-1).join(`
92
- `);r=r.replace(i,s)}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
136
+ `);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
137
+
138
+ `),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !ce(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 h=class h{constructor(){this.cache=new F(h.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 T(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:a,endLineNumber:d,endColumn:m}=n,{lineNumber:c,column:p}=o,u=c===s&&p===a;if(s===d)return u||i.startsWith(r)&&c===s&&p>=a-h.LOOK_AROUND&&p<=m+h.LOOK_AROUND;let C=i.startsWith(r)&&c>=s&&c<=d&&(c===s&&p>=a-h.LOOK_AROUND||c===d&&p<=m+h.LOOK_AROUND||c>s&&c<d);return u||C}};h.MAX_CACHE_SIZE=10,h.LOOK_AROUND=3;var $=h;var H=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,r){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=r.getOffsetAt(e),i=r.getValue().substring(0,n),s=r.getValue().substring(n),a=0,d=0,m=0,c=0,p=o.length,u=i.length,C=s.length;if(n>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(C===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let M=Math.min(p,u);for(let l=1;l<=M;l++){let R=o.substring(0,l),ye=i.slice(-l);R===ye&&(c=l);}let x=Math.min(p,C);for(let l=0;l<x&&o[l]===s[l];l++)a++;for(let l=1;l<=x;l++)o.slice(-l)===s.slice(0,l)&&(d=l);if(m=Math.max(a,d),m===0){for(let l=1;l<p;l++)if(s.startsWith(o.substring(l))){m=p-l;break}}let f=c>0?r.getPositionAt(n-c):e,y=n+m,g=r.getPositionAt(y);return new this.monaco.Range(f.lineNumber,f.column,g.lineNumber,g.column)}};var Le="application/json",ue=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await S.POST(e,o,{headers:{"Content-Type":Le},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},Ce=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:a}=o,d=Ne(t,e),c=!!s?.length?3:2,p=a?Math.floor(a/c):void 0,u=(y,g,l)=>{let R=y(t,e);return g?Y(R,g,l):R},C=(y,g)=>!y||!g?y:y.map(({content:l,...R})=>({...R,content:Y(l,g)})),M=u(T,p,{from:"end"}),x=u(D,p),f=C(s,p);return {filename:r,language:n,technologies:i,relatedFiles:f,textBeforeCursor:M,textAfterCursor:x,cursorPosition:t,editorState:{completionMode:d}}},Ne=(t,e)=>{let o=z(t,e),r=_(t,e);return o?"insert":r.trim()?"complete":"continue"};var ge=t=>k.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),P=t=>({items:t,enableForwardStability:!0});var X={onTyping:300,onIdle:600,onDemand:0},_e=t=>({onTyping:B(t,X.onTyping),onIdle:B(t,X.onIdle),onDemand:B(t,X.onDemand)}),V=new $,De=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:a="onIdle",endpoint:d,enableCaching:m=!0,onError:c,requestHandler:p}=s;if(!new q(o,e).shouldProvideCompletions())return P([]);if(m){let u=V.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return i(),P(u)}if(r.isCancellationRequested||n)return P([]);try{let C=_e(p??ue)[a];r.onCancellationRequested(()=>{C.cancel();});let M=Ce({pos:o,mdl:e,options:s}),{completion:x}=await C({endpoint:d,body:{completionMetadata:M}});if(x){let f=ge(x),g=new H(t).computeInsertionRange(o,f,e);return m&&V.add({completion:f,range:g,textBeforeCursor:T(o,e),textAfterCursor:D(o,e),cachePos:o}),i(),P([{insertText:f,range:g}])}}catch(u){if(Se(u))return P([]);c?c(u):O(u);}return P([])},Se=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,he=De;var E=new WeakMap,I=null,fe=(t,e,o)=>{I&&I.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};E.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(d,m,c,p)=>{let u=E.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return he({monaco:t,mdl:d,pos:m,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(d=>{let m=E.get(e);if(!m)return;let c=d.keyCode===t.KeyCode.Tab||d.keyCode===t.KeyCode.RightArrow&&d.metaKey;m.isCompletionVisible&&c?(m.isCompletionAccepted=!0,m.isCompletionVisible=!1):m.isCompletionAccepted=!1;});r.push(s);let a={deregister:()=>{r.forEach(d=>d.dispose()),V.clear(),E.delete(e),I=null;},trigger:()=>Be(e)};return I=a,a}catch(i){return o.onError?o.onError(i):O(i),{deregister:()=>{r.forEach(s=>s.dispose()),E.delete(e),I=null;},trigger:()=>{}}}},Be=t=>{let e=E.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",{});},ke=(...t)=>(w("registerCopilot","registerCompletion"),fe(...t));
93
139
 
94
- `),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 S=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 q=class q{constructor(){this.cache=new S(q.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:a,endColumn:l}=n,{lineNumber:p,column:m}=o,u=p===s&&m===a,c=i.startsWith(r)&&p===s&&m>=a-r.length&&m<=l+r.length;return u||c}};q.MAX_CACHE_SIZE=10;var B=q;var qe="application/json",ge=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await _.POST(e,o,{headers:{"Content-Type":qe},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:a}=o,l=Fe(t,e),m=!!s?.length?3:2,u=a?Math.floor(a/m):void 0,c=(g,T,N)=>{let b=g(t,e);return T?K(b,T,N):b},C=(g,T)=>!g||!T?g:g.map(({content:N,...b})=>({...b,content:K(N,T)})),d=c(y,u,{from:"end"}),O=c(pe,u),x=C(s,u);return{filename:r,language:n,technologies:i,relatedFiles:x,textBeforeCursor:d,textAfterCursor:O,cursorPosition:t,editorState:{completionMode:l}}},Fe=(t,e)=>{let o=W(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,a=0,l=0,p=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(p,m);for(let d=0;d<u&&r[d]===i[d];d++)s++;for(let d=1;d<=u;d++)r.slice(-d)===i.slice(0,d)&&(a=d);if(l=Math.max(s,a),l===0){for(let d=1;d<p;d++)if(i.startsWith(r.substring(d))){l=p-d;break}}let c=n+l,C=o.getPositionAt(c);return new t.Range(e.lineNumber,e.column,C.lineNumber,C.column)},ye=t=>L.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),h=t=>({items:t,enableForwardStability:!0});var G={onTyping:300,onIdle:600,onDemand:0},$e=t=>({onTyping:A(t,G.onTyping),onIdle:A(t,G.onIdle),onDemand:A(t,G.onDemand)}),F=new B,He=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:a="onIdle",endpoint:l,enableCaching:p=!0,onError:m,requestHandler:u}=s;if(!new k(o,e).shouldProvideCompletions())return h([]);if(p){let c=F.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(c.length>0)return i(),h(c)}if(r.isCancellationRequested||n)return h([]);try{let C=$e(u??ge)[a];r.onCancellationRequested(()=>{C.cancel()});let d=he({pos:o,mdl:e,options:s}),{completion:O}=await C({endpoint:l,body:{completionMetadata:d}});if(O){let x=ye(O),g=fe(t,o,e,x);return p&&F.add({completion:x,range:g,textBeforeCursor:y(o,e)}),i(),h([{insertText:x,range:g}])}}catch(c){if(Ve(c))return h([]);m?m(c):f(c)}return h([])},Ve=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,Y=(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:(l,p,m,u)=>{let c=P.get(e);if(!(!c||o.trigger==="onDemand"&&!c.isManualTrigger))return Pe({monaco:t,mdl:l,pos:p,token:u,isCompletionAccepted:c.isCompletionAccepted,onShowCompletion:()=>{c.isCompletionVisible=!0,c.isManualTrigger=!1},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(l=>{let p=P.get(e);if(!p)return;let m=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;p.isCompletionVisible&&m?(p.isCompletionAccepted=!0,p.isCompletionVisible=!1):p.isCompletionAccepted=!1});r.push(s);let a={deregister:()=>{r.forEach(l=>l.dispose()),F.clear(),P.delete(e),M=null},trigger:()=>je(e)};return M=a,a}catch(i){return o.onError?o.onError(i):f(i),{deregister:()=>{r.forEach(s=>s.dispose()),P.delete(e),M=null},trigger:()=>{}}}},je=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"),Y(...t));0&&(module.exports={Copilot,registerCompletion,registerCopilot});
140
+ exports.Copilot = G;
141
+ exports.registerCompletion = fe;
142
+ exports.registerCopilot = ke;
package/build/index.mjs CHANGED
@@ -1,16 +1,15 @@
1
- var N=["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-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","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-haiku","claude-3-5-haiku"]},Y="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"},E=.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:V(t),temperature:E,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:V(t),temperature:E,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},Te={createRequestBody:(t,e)=>({model:V(t),temperature:E,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:Re(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:Te},Q=(t,e,o)=>H[e].createRequestBody(t,o),ee=(t,e)=>H[e].createHeaders(t),te=(t,e)=>H[e].parseCompletion(t),V=t=>G[t],oe=t=>J[t],Re=t=>Z[t]||4096;var re="\x1B[91m",ne="\x1B[93m",v="\x1B[0m",j="\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}${j}[MONACOPILOT ERROR] ${e}${v}`;return console.error(o?`${r}
2
- ${re}Stack trace:${v}
3
- ${o}`:r),{message:e,stack:o}},ie=t=>{console.warn(`${ne}${j}[MONACOPILOT WARN] ${t}${v}`)};var I=(t,e,o)=>console.warn(`${ne}${j}[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,a)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=a,o=setTimeout(()=>{s(t(...n)),r=null},e)});return i.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null)},i},R=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())}),z=(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(a=>a==="")?`
1
+ var j=["groq","openai","anthropic","google"],J={"llama-3-70b":"llama3-70b-8192","gpt-4o":"gpt-4o-2024-08-06","gpt-4o-mini":"gpt-4o-mini","claude-3-5-sonnet":"claude-3-5-sonnet-20241022","claude-3-haiku":"claude-3-haiku-20240307","claude-3-5-haiku":"claude-3-5-haiku-20241022","o1-preview":"o1-preview","o1-mini":"o1-mini","gemini-1.5-flash-8b":"gemini-1.5-flash-8b","gemini-1.5-flash":"gemini-1.5-flash","gemini-1.5-pro":"gemini-1.5-pro"},U={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-preview","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},Z="anthropic",Q="claude-3-5-haiku",b={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models"},A=.1;var ee={"claude-3-5-sonnet":8192,"claude-3-5-haiku":8192,"claude-3-haiku":4096};var xe={createEndpoint:()=>b.openai,createRequestBody:(t,e)=>{let o=t==="o1-preview"||t==="o1-mini",r=o?[{role:"user",content:e.user}]:[{role:"system",content:e.system},{role:"user",content:e.user}];return {model:N(t),...!o&&{temperature:A},messages:r}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Pe={createEndpoint:()=>b.groq,createRequestBody:(t,e)=>({model:N(t),temperature:A,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},Re={createEndpoint:()=>b.anthropic,createRequestBody:(t,e)=>({model:N(t),temperature:A,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:ee[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}},Oe={createEndpoint:(t,e)=>`${b.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:N(t),system_instruction:{parts:{text:e.system}},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},L={openai:xe,groq:Pe,anthropic:Re,google:Oe},te=(t,e,o)=>L[o].createEndpoint(t,e),oe=(t,e,o)=>L[e].createRequestBody(t,o),re=(t,e)=>L[e].createHeaders(t),ne=(t,e)=>L[e].parseCompletion(t),N=t=>J[t];var Te="\x1B[91m",ie="\x1B[93m",K="\x1B[0m",W="\x1B[1m",O=t=>{let e;t instanceof Error?e=t.message:typeof t=="string"?e=t:e="An unknown error occurred";let o=`${Te}${W}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},se=t=>{console.warn(`${ie}${W}[MONACOPILOT WARN] ${t}${K}`);};var w=(t,e,o)=>console.warn(`${ie}${W}[MONACOPILOT DEPRECATED] "${t}" is deprecated${o?` in ${o}`:""}. Please use "${e}" instead. It will be removed in a future version.${K}`);var v=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 _=(t,e)=>e.getLineContent(t.lineNumber).slice(t.column-1),ae=(t,e)=>e.getLineContent(t.lineNumber).slice(0,t.column-1),T=(t,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:t.lineNumber,endColumn:t.column}),D=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())}),Y=(t,e,o={})=>{if(e<=0)return "";let r=t.split(`
2
+ `),n=r.length;if(e>=n)return t;if(o.from==="end"){let s=r.slice(-e);return s.every(a=>a==="")?`
5
3
  `.repeat(e):s.join(`
6
- `)}let n=r.slice(0,e);return n.every(s=>s==="")?`
7
- `.repeat(e):n.join(`
8
- `)};var le=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()},Me=(t,e)=>le(t,"GET",e),Oe=(t,e,o)=>le(t,"POST",{...o,body:e}),_={GET:Me,POST:Oe};var pe=(t,e)=>{let o=w(t,e).trim(),r=se(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var be=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:i}=t,n=R([i,...e].filter(a=>typeof a=="string"&&!!a));return[`You are an expert ${n?`${n} `:""}developer assistant specialized in precise code completion and generation.`,`Your primary task is to provide accurate, context-aware code completions that seamlessly integrate with existing codebases${o?` in '${o}'`:""}.`,`You must:
4
+ `)}let i=r.slice(0,e);return i.every(s=>s==="")?`
5
+ `.repeat(e):i.join(`
6
+ `)};var le=async(t,e,o={})=>{let r={"Content-Type":"application/json",...o.headers},n=e==="POST"&&o.body?JSON.stringify(o.body):void 0,i=await fetch(t,{method:e,headers:r,body:n,signal:o.signal});if(!i.ok){let s=`
7
+ `+(JSON.stringify(await i.json(),null,2)||"");throw new Error(`${i.statusText||o.fallbackError||"Network error"}${s}`)}return i.json()},Ee=(t,e)=>le(t,"GET",e),Me=(t,e,o)=>le(t,"POST",{...o,body:e}),S={GET:Ee,POST:Me};var ce=(t,e)=>{let o=_(t,e).trim(),r=ae(t,e).trim();return t.column<=3&&(o!==""||r!=="")};var B=(t,e)=>{let o=null,r=null,n=(...i)=>new Promise((s,a)=>{o&&(clearTimeout(o),r&&r("Cancelled")),r=a,o=setTimeout(()=>{s(t(...i)),r=null;},e);});return n.cancel=()=>{o&&(clearTimeout(o),r&&r("Cancelled"),o=null,r=null);},n};var be=t=>{let{technologies:e=[],filename:o,relatedFiles:r,language:n}=t,i=v([n,...e].filter(a=>typeof a=="string"&&!!a));return [`You are an expert ${i?`${i} `:""}developer assistant specialized in precise code completion and generation.`,`Your primary task is to provide accurate, context-aware code completions that seamlessly integrate with existing codebases${o?` in '${o}'`:""}.`,`You must:
9
8
  - Generate only the exact code required
10
9
  - Maintain strict adherence to provided instructions
11
10
  - Follow established code patterns and conventions
12
- - Consider the full context before generating code`,r?.length?"Analyze and incorporate context from all provided related files to ensure consistent and appropriate code generation.":"",i?`Apply ${i}-specific best practices, idioms, and syntax conventions in all generated code.`:""].filter(Boolean).join(`
13
- `)},Ee=t=>t?.length?t.map(({path:e,content:o})=>`
11
+ - Consider the full context before generating code`,r?.length?"Analyze and incorporate context from all provided related files to ensure consistent and appropriate code generation.":"",n?`Apply ${n}-specific best practices, idioms, and syntax conventions in all generated code.`:""].filter(Boolean).join(`
12
+ `)},ve=t=>t?.length?t.map(({path:e,content:o})=>`
14
13
  <related_file>
15
14
  <path>${e}</path>
16
15
  <content_context>
@@ -20,34 +19,43 @@ ${o}
20
19
  </content_context>
21
20
  </related_file>`.trim()).join(`
22
21
 
23
- `):"",ve=(t="",e)=>{let{relatedFiles:o}=e;return`
22
+ `):"",Ie=(t="",e)=>{let{relatedFiles:o}=e;return `
24
23
  <task_context>
25
24
  <primary_instructions>
26
25
  ${t.trim()}
27
26
  </primary_instructions>
28
27
  ${o?.length?`
29
28
  <reference_files>
30
- ${Ee(o)}
29
+ ${ve(o)}
31
30
  </reference_files>`:""}
32
- </task_context>`.trim()},ce=(t,e)=>({system:be(e),user:ve(t,e)});var de="<cursor>",Ie=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r},language:i}=t,n=`<code_file>
31
+ </task_context>`.trim()},pe=(t,e)=>({system:be(e),user:Ie(t,e)});var de="<cursor>",Ae=t=>{let{textBeforeCursor:e="",textAfterCursor:o="",editorState:{completionMode:r},language:n}=t,i=`<code_file>
33
32
  ${e}${de}${o}
34
33
  </code_file>`,a=`
35
34
  <instructions>
36
35
  <context>
37
- Below is a ${i||"code"} file with the token '${de}' marking the exact cursor position where code completion is needed.
36
+ Below is a ${n||"code"} file with the token '${de}' marking the exact cursor position where code completion is needed.
38
37
 
39
- ${n}
38
+ ${i}
40
39
  </context>
41
40
 
41
+ <critical_rules>
42
+ 1. NEVER REPEAT ANY TEXT THAT APPEARS BEFORE THE CURSOR
43
+ 2. Start your completion EXACTLY from the cursor position
44
+ 3. If user types 'const ' and cursor is after it, DO NOT include 'const ' in your completion
45
+ 4. ONLY provide the remaining part of the code that should appear after the cursor
46
+ 5. Violation of these rules will cause code duplication and syntax errors
47
+ </critical_rules>
48
+
42
49
  <primary_objectives>
43
- 1. Generate code that is syntactically correct and follows ${i||"the language"}'s best practices
50
+ 1. Generate code that is syntactically correct and follows ${n||"the language"}'s best practices
44
51
  2. Ensure seamless integration with existing code structure
45
52
  3. Maintain consistent naming conventions and coding style
46
53
  4. Provide only the exact code needed at the cursor position
47
54
  </primary_objectives>
48
55
 
49
56
  <strict_requirements>
50
- - Output MUST contain only the code to be inserted at cursor position
57
+ - Output MUST contain only the NEW code to be inserted at cursor position
58
+ - NEVER repeat any code that appears before the cursor position
51
59
  - DO NOT include any code that appears before the cursor
52
60
  - DO NOT include explanatory comments or documentation
53
61
  - DO NOT wrap output in markdown code blocks
@@ -64,12 +72,44 @@ ${e}${de}${o}
64
72
  1. Analyze the code context before and after the cursor
65
73
  2. Identify the current scope and available variables/functions
66
74
  3. Determine the logical flow and required completion
67
- 4. Verify syntax compatibility with surrounding code
68
- 5. Ensure completion maintains code integrity
75
+ 4. Remove any duplicate text that appears before cursor
76
+ 5. Verify completion starts exactly at cursor position
69
77
  </code_analysis_steps>
70
78
 
71
79
  <examples>
72
- [Previous examples section remains the same]
80
+ <example>
81
+ Context: "const <cursor>"
82
+ CORRECT COMPLETION: "myVariable = 42"
83
+ INCORRECT COMPLETION: "const myVariable = 42"
84
+ </example>
85
+
86
+ <example>
87
+ Context: "function hello<cursor>"
88
+ CORRECT COMPLETION: "(name: string) {\\n return 'Hello ' + name;\\n}"
89
+ INCORRECT COMPLETION: "function hello(name: string) {\\n return 'Hello ' + name;\\n}"
90
+ </example>
91
+
92
+ <example>
93
+ Context: "const randomNumber = Math.floor(Math.ran<cursor>00);"
94
+ CORRECT COMPLETION: "dom() * 1"
95
+ INCORRECT COMPLETION: "Math.random() * 1"
96
+ </example>
97
+
98
+ <example>
99
+ Context: "const result = 'Hello' + ' W<cursor>';"
100
+ CORRECT COMPLETION: "orld"
101
+ INCORRECT COMPLETION: "orld';"
102
+ </example>
103
+
104
+ <example>
105
+ Context: "function isPalindrome(<cursor>)"
106
+ CORRECT COMPLETION: "str) {
107
+ return str === str.split('').reverse().join('');
108
+ }"
109
+ INCORRECT COMPLETION: "(str) {
110
+ return str === str.split('').reverse().join('');
111
+ }"
112
+ </example>
73
113
  </examples>
74
114
 
75
115
  <error_prevention>
@@ -78,17 +118,21 @@ ${e}${de}${o}
78
118
  - Check for proper bracket and parenthesis matching
79
119
  - Maintain consistent indentation with surrounding code
80
120
  - Respect language-specific type safety requirements
121
+ - NEVER duplicate text that appears before cursor
81
122
  </error_prevention>
82
123
 
83
124
  <final_validation>
84
125
  Before providing the completion:
85
- 1. Confirm the output contains ONLY the necessary code
86
- 2. Verify it fits seamlessly at the cursor position
87
- 3. Ensure it follows the active completion mode requirements
88
- 4. Check for consistency with existing code style
126
+ 1. Confirm the output contains ONLY the new code after cursor position
127
+ 2. Double-check no text before cursor is duplicated
128
+ 3. Verify it fits seamlessly at the cursor position
129
+ 4. Ensure it follows the active completion mode requirements
130
+ 5. Check for consistency with existing code style
89
131
  </final_validation>
90
- </instructions>`.trim();return ce(a,t)},me=Ie;var W=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??Y,this.model=o.model??X,this.validateInputs()}validateInputs(){if(!N.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${R(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: ${R($[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:i}=o,{headers:n={},customPrompt:s}=r??{},a=this.generatePrompt(i,s),{endpoint:l,requestBody:p,headers:m}=this.prepareRequestDetails(a);try{let u=await this.sendCompletionRequest(l,p,{...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 _.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(`
132
+ </instructions>`.trim();return pe(a,t)},me=Ae;var G=class{constructor(e,o={}){if(!e)throw new Error("Please provide an API key.");this.apiKey=e,this.provider=o.provider??Z,this.model=o.model??Q,this.validateInputs();}validateInputs(){if(!j.includes(this.provider))throw new Error(`Unsupported provider "${this.provider}". Please choose from: ${v(j)}. For custom models, provider specification is not needed.`);if(typeof this.model=="string"&&!U[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${v(U[this.provider])}`)}async complete(e){let{body:o,options:r}=e,{completionMetadata:n}=o,{headers:i={},customPrompt:s}=r??{},a=this.generatePrompt(n,s),{endpoint:d,requestBody:m,headers:c}=this.prepareRequestDetails(a);try{let p=await this.sendCompletionRequest(d,m,{...c,...i});return this.processCompletionResponse(p)}catch(p){return this.handleCompletionError(p)}}generatePrompt(e,o){let r=me(e);return o?{...r,...o(e)}:r}prepareRequestDetails(e){let o=te(this.model,this.apiKey,this.provider),r,n=re(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=oe(this.model,this.provider,e);return {endpoint:o,requestBody:r,headers:n}}async sendCompletionRequest(e,o,r){return S.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&&w("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else return {completion:ne(e,this.provider),raw:e}}handleCompletionError(e){return {error:O(e).message,completion:null}}};var k=class t{constructor(e){this.formattedCompletion="";this.formattedCompletion=e;}static create(e){return new t(e)}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,r=e,n;for(;(n=o.exec(e))!==null;){let i=n[0],s=i.split(`
91
133
  `).slice(1,-1).join(`
92
- `);r=r.replace(n,s)}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
134
+ `);r=r.replace(i,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
135
+
136
+ `),this}build(){return this.formattedCompletion}};var q=class{constructor(e,o){this.cursorPos=e,this.mdl=o;}shouldProvideCompletions(){return !ce(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 h=class h{constructor(){this.cache=new F(h.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 T(o,r).startsWith(e.textBeforeCursor)&&this.isPositionValid(e,o,n)}isPositionValid(e,o,r){let{range:n,completion:i}=e,{startLineNumber:s,startColumn:a,endLineNumber:d,endColumn:m}=n,{lineNumber:c,column:p}=o,u=c===s&&p===a;if(s===d)return u||i.startsWith(r)&&c===s&&p>=a-h.LOOK_AROUND&&p<=m+h.LOOK_AROUND;let C=i.startsWith(r)&&c>=s&&c<=d&&(c===s&&p>=a-h.LOOK_AROUND||c===d&&p<=m+h.LOOK_AROUND||c>s&&c<d);return u||C}};h.MAX_CACHE_SIZE=10,h.LOOK_AROUND=3;var $=h;var H=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,r){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let n=r.getOffsetAt(e),i=r.getValue().substring(0,n),s=r.getValue().substring(n),a=0,d=0,m=0,c=0,p=o.length,u=i.length,C=s.length;if(n>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(C===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let M=Math.min(p,u);for(let l=1;l<=M;l++){let R=o.substring(0,l),ye=i.slice(-l);R===ye&&(c=l);}let x=Math.min(p,C);for(let l=0;l<x&&o[l]===s[l];l++)a++;for(let l=1;l<=x;l++)o.slice(-l)===s.slice(0,l)&&(d=l);if(m=Math.max(a,d),m===0){for(let l=1;l<p;l++)if(s.startsWith(o.substring(l))){m=p-l;break}}let f=c>0?r.getPositionAt(n-c):e,y=n+m,g=r.getPositionAt(y);return new this.monaco.Range(f.lineNumber,f.column,g.lineNumber,g.column)}};var Le="application/json",ue=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:n}=await S.POST(e,o,{headers:{"Content-Type":Le},fallbackError:"Error while fetching completion item"});if(n)throw new Error(n);return {completion:r}},Ce=({pos:t,mdl:e,options:o})=>{let{filename:r,language:n,technologies:i,relatedFiles:s,maxContextLines:a}=o,d=Ne(t,e),c=!!s?.length?3:2,p=a?Math.floor(a/c):void 0,u=(y,g,l)=>{let R=y(t,e);return g?Y(R,g,l):R},C=(y,g)=>!y||!g?y:y.map(({content:l,...R})=>({...R,content:Y(l,g)})),M=u(T,p,{from:"end"}),x=u(D,p),f=C(s,p);return {filename:r,language:n,technologies:i,relatedFiles:f,textBeforeCursor:M,textAfterCursor:x,cursorPosition:t,editorState:{completionMode:d}}},Ne=(t,e)=>{let o=z(t,e),r=_(t,e);return o?"insert":r.trim()?"complete":"continue"};var ge=t=>k.create(t).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().build(),P=t=>({items:t,enableForwardStability:!0});var X={onTyping:300,onIdle:600,onDemand:0},_e=t=>({onTyping:B(t,X.onTyping),onIdle:B(t,X.onIdle),onDemand:B(t,X.onDemand)}),V=new $,De=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:n,onShowCompletion:i,options:s})=>{let{trigger:a="onIdle",endpoint:d,enableCaching:m=!0,onError:c,requestHandler:p}=s;if(!new q(o,e).shouldProvideCompletions())return P([]);if(m){let u=V.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(u.length>0)return i(),P(u)}if(r.isCancellationRequested||n)return P([]);try{let C=_e(p??ue)[a];r.onCancellationRequested(()=>{C.cancel();});let M=Ce({pos:o,mdl:e,options:s}),{completion:x}=await C({endpoint:d,body:{completionMetadata:M}});if(x){let f=ge(x),g=new H(t).computeInsertionRange(o,f,e);return m&&V.add({completion:f,range:g,textBeforeCursor:T(o,e),textAfterCursor:D(o,e),cachePos:o}),i(),P([{insertText:f,range:g}])}}catch(u){if(Se(u))return P([]);c?c(u):O(u);}return P([])},Se=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,he=De;var E=new WeakMap,I=null,fe=(t,e,o)=>{I&&I.deregister();let r=[],n={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};E.set(e,n),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let i=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(d,m,c,p)=>{let u=E.get(e);if(!(!u||o.trigger==="onDemand"&&!u.isManualTrigger))return he({monaco:t,mdl:d,pos:m,token:p,isCompletionAccepted:u.isCompletionAccepted,onShowCompletion:()=>{u.isCompletionVisible=!0,u.isManualTrigger=!1;},options:o})},freeInlineCompletions:()=>{}});r.push(i);let s=e.onKeyDown(d=>{let m=E.get(e);if(!m)return;let c=d.keyCode===t.KeyCode.Tab||d.keyCode===t.KeyCode.RightArrow&&d.metaKey;m.isCompletionVisible&&c?(m.isCompletionAccepted=!0,m.isCompletionVisible=!1):m.isCompletionAccepted=!1;});r.push(s);let a={deregister:()=>{r.forEach(d=>d.dispose()),V.clear(),E.delete(e),I=null;},trigger:()=>Be(e)};return I=a,a}catch(i){return o.onError?o.onError(i):O(i),{deregister:()=>{r.forEach(s=>s.dispose()),E.delete(e),I=null;},trigger:()=>{}}}},Be=t=>{let e=E.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",{});},ke=(...t)=>(w("registerCopilot","registerCompletion"),fe(...t));
93
137
 
94
- `),this}build(){return this.formattedCompletion}};var L=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:a,endColumn:l}=i,{lineNumber:p,column:m}=o,u=p===s&&m===a,c=n.startsWith(r)&&p===s&&m>=a-r.length&&m<=l+r.length;return u||c}};B.MAX_CACHE_SIZE=10;var S=B;var Ae="application/json",ue=async t=>{let{endpoint:e,body:o}=t,{completion:r,error:i}=await _.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:a}=o,l=we(t,e),m=!!s?.length?3:2,u=a?Math.floor(a/m):void 0,c=(g,T,F)=>{let b=g(t,e);return T?z(b,T,F):b},C=(g,T)=>!g||!T?g:g.map(({content:F,...b})=>({...b,content:z(F,T)})),d=c(y,u,{from:"end"}),O=c(ae,u),x=C(s,u);return{filename:r,language:i,technologies:n,relatedFiles:x,textBeforeCursor:d,textAfterCursor:O,cursorPosition:t,editorState:{completionMode:l}}},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,a=0,l=0,p=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(p,m);for(let d=0;d<u&&r[d]===n[d];d++)s++;for(let d=1;d<=u;d++)r.slice(-d)===n.slice(0,d)&&(a=d);if(l=Math.max(s,a),l===0){for(let d=1;d<p;d++)if(n.startsWith(r.substring(d))){l=p-d;break}}let c=i+l,C=o.getPositionAt(c);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)}),q=new S,Le=async({monaco:t,mdl:e,pos:o,token:r,isCompletionAccepted:i,onShowCompletion:n,options:s})=>{let{trigger:a="onIdle",endpoint:l,enableCaching:p=!0,onError:m,requestHandler:u}=s;if(!new L(o,e).shouldProvideCompletions())return h([]);if(p){let c=q.get(o,e).map(C=>({insertText:C.completion,range:C.range}));if(c.length>0)return n(),h(c)}if(r.isCancellationRequested||i)return h([]);try{let C=De(u??ue)[a];r.onCancellationRequested(()=>{C.cancel()});let d=Ce({pos:o,mdl:e,options:s}),{completion:O}=await C({endpoint:l,body:{completionMetadata:d}});if(O){let x=he(O),g=ge(t,o,e,x);return p&&q.add({completion:x,range:g,textBeforeCursor:y(o,e)}),n(),h([{insertText:x,range:g}])}}catch(c){if(ke(c))return h([]);m?m(c):f(c)}return h([])},ke=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,fe=Le;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:(l,p,m,u)=>{let c=P.get(e);if(!(!c||o.trigger==="onDemand"&&!c.isManualTrigger))return fe({monaco:t,mdl:l,pos:p,token:u,isCompletionAccepted:c.isCompletionAccepted,onShowCompletion:()=>{c.isCompletionVisible=!0,c.isManualTrigger=!1},options:o})},freeInlineCompletions:()=>{}});r.push(n);let s=e.onKeyDown(l=>{let p=P.get(e);if(!p)return;let m=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;p.isCompletionVisible&&m?(p.isCompletionAccepted=!0,p.isCompletionVisible=!1):p.isCompletionAccepted=!1});r.push(s);let a={deregister:()=>{r.forEach(l=>l.dispose()),q.clear(),P.delete(e),M=null},trigger:()=>Se(e)};return M=a,a}catch(n){return o.onError?o.onError(n):f(n),{deregister:()=>{r.forEach(s=>s.dispose()),P.delete(e),M=null},trigger:()=>{}}}},Se=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{W as Copilot,ye as registerCompletion,Be as registerCopilot};
138
+ export { G as Copilot, fe as registerCompletion, ke as registerCopilot };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "monacopilot",
3
- "version": "0.14.1",
3
+ "version": "0.15.0",
4
4
  "description": "AI auto-completion plugin for Monaco Editor",
5
5
  "main": "./build/index.js",
6
6
  "module": "./build/index.mjs",
@@ -25,6 +25,7 @@
25
25
  "@anthropic-ai/sdk": "^0.27.3",
26
26
  "@commitlint/cli": "^19.5.0",
27
27
  "@commitlint/config-conventional": "^19.5.0",
28
+ "@google/generative-ai": "^0.21.0",
28
29
  "@ianvs/prettier-plugin-sort-imports": "^4.2.1",
29
30
  "@release-it/conventional-changelog": "^8.0.2",
30
31
  "@typescript-eslint/eslint-plugin": "^7.3.1",
@@ -60,5 +61,6 @@
60
61
  }
61
62
  ],
62
63
  "license": "MIT",
63
- "author": "Arshad Yaseen <m@arshadyaseen.com> (https://arshadyaseen.com)"
64
+ "author": "Arshad Yaseen <m@arshadyaseen.com> (https://arshadyaseen.com)",
65
+ "dependencies": {}
64
66
  }