monacopilot 0.16.9 → 0.17.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
@@ -41,8 +41,10 @@
41
41
  - [Max Context Lines](#max-context-lines)
42
42
  - [Caching Completions](#caching-completions)
43
43
  - [Handling Errors](#handling-errors)
44
- - [Completion Event Handlers](#completion-event-handlers)
45
44
  - [Custom Request Handler](#custom-request-handler)
45
+ - [Completion Event Handlers](#completion-event-handlers)
46
+ - [onCompletionShown](#oncompletionshown)
47
+ - [onCompletionAccepted](#oncompletionaccepted)
46
48
  - [Copilot Options](#copilot-options)
47
49
  - [Changing the Provider and Model](#changing-the-provider-and-model)
48
50
  - [Custom Model](#custom-model)
@@ -428,13 +430,6 @@ The editor provides several events to handle completion suggestions. These event
428
430
 
429
431
  This event is triggered when a completion suggestion is shown to the user. You can use this event to log or perform actions when a suggestion is displayed.
430
432
 
431
- **Parameters:**
432
-
433
- - `completion` (string): The completion text that is being shown
434
- - `range` (EditorRange | undefined): The editor range where the completion will be inserted
435
-
436
- **Example:**
437
-
438
433
  ```javascript
439
434
  registerCompletion(monaco, editor, {
440
435
  // ... other options
@@ -444,12 +439,15 @@ registerCompletion(monaco, editor, {
444
439
  });
445
440
  ```
446
441
 
442
+ **Parameters:**
443
+
444
+ - `completion` (string): The completion text that is being shown
445
+ - `range` (EditorRange | undefined): The editor range where the completion will be inserted
446
+
447
447
  #### onCompletionAccepted
448
448
 
449
449
  Event triggered when a completion suggestion is accepted by the user.
450
450
 
451
- **Example**
452
-
453
451
  ```javascript
454
452
  registerCompletion(monaco, editor, {
455
453
  // ... other options
@@ -474,12 +472,13 @@ const copilot = new Copilot(process.env.OPENAI_API_KEY, {
474
472
 
475
473
  There are other providers and models available. Here is a list:
476
474
 
477
- | Provider | Models |
478
- | --------- | ----------------------------------------------------------- |
479
- | Groq | `llama-3-70b` |
480
- | OpenAI | `gpt-4o`, `gpt-4o-mini`, `o1-mini (beta model)` |
481
- | Anthropic | `claude-3-5-sonnet`, `claude-3-haiku`, `claude-3-5-haiku` |
482
- | Google | `gemini-1.5-pro`, `gemini-1.5-flash`, `gemini-1.5-flash-8b` |
475
+ | Provider | Models | Notes |
476
+ | --------- | ----------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
477
+ | groq | `llama-3-70b` | Offers moderate accuracy with extremely fast response times. Ideal for real-time completions while typing. |
478
+ | openai | `gpt-4o`, `gpt-4o-mini`, `o1-mini (beta model)` | |
479
+ | anthropic | `claude-3-5-sonnet`, `claude-3-haiku`, `claude-3-5-haiku` | Claude-3-5-haiku provides an optimal balance between accuracy and response time. |
480
+ | google | `gemini-1.5-pro`, `gemini-1.5-flash`, `gemini-1.5-flash-8b` | |
481
+ | deepseek | `v3` | Provides highly accurate completions using Fill-in-the-Middle (FIM) technology. While response times are slower, it excels in completion accuracy. Best choice when precision is the top priority. |
483
482
 
484
483
  ### Custom Model
485
484
 
package/build/index.d.mts CHANGED
@@ -1,36 +1,72 @@
1
- import { Message } from '@anthropic-ai/sdk/resources';
2
- import { ChatCompletion as ChatCompletion$1 } from 'groq-sdk/resources/chat/completions';
3
- import { ChatCompletion } from 'openai/resources/chat/completions';
1
+ import { Message, MessageCreateParams } from '@anthropic-ai/sdk/resources';
2
+ import { ModelParams, GenerateContentResponse } from '@google/generative-ai';
3
+ import { ChatCompletion as ChatCompletion$1, ChatCompletionCreateParamsBase as ChatCompletionCreateParamsBase$1 } from 'groq-sdk/resources/chat/completions';
4
+ import { ChatCompletion, ChatCompletionCreateParamsBase } from 'openai/resources/chat/completions';
4
5
  import * as monaco from 'monaco-editor/esm/vs/editor/editor.api';
5
6
 
7
+ declare const COPILOT_MODEL_IDS: Record<CopilotModel, string>;
8
+
9
+ type DeepSeekChatCompletionType = {
10
+ choices: {
11
+ text: string;
12
+ }[];
13
+ };
14
+ type DeepSeekChatCompletionCreateParamsBase = {
15
+ model: (typeof COPILOT_MODEL_IDS)['v3'];
16
+ prompt: string;
17
+ suffix: string;
18
+ temperature: number;
19
+ max_tokens: number;
20
+ };
21
+
6
22
  /**
7
- * Models available for OpenAI provider.
8
- */
9
- type OpenAIModel = 'gpt-4o' | 'gpt-4o-mini' | 'o1-mini';
10
- /**
11
- * Models available for Groq provider.
12
- */
13
- type GroqModel = 'llama-3-70b';
14
- /**
15
- * Models available for Anthropic provider.
16
- */
17
- type AnthropicModel = 'claude-3-5-sonnet' | 'claude-3-5-haiku' | 'claude-3-haiku';
18
- /**
19
- * Models available for Google provider.
23
+ * Providers supported by Copilot.
20
24
  */
21
- type GoogleModel = 'gemini-1.5-flash' | 'gemini-1.5-flash-8b' | 'gemini-1.5-pro';
25
+ type CopilotProvider = 'openai' | 'groq' | 'anthropic' | 'google' | 'deepseek';
22
26
  /**
23
- * Union of all predefined Copilot models.
27
+ * Core type mapping for provider-specific implementations
24
28
  */
25
- type CopilotModel = OpenAIModel | GroqModel | AnthropicModel | GoogleModel;
29
+ interface ProviderImplementationMap {
30
+ openai: {
31
+ Model: 'gpt-4o' | 'gpt-4o-mini' | 'o1-mini';
32
+ Params: ChatCompletionCreateParamsBase;
33
+ Completion: ChatCompletion;
34
+ };
35
+ groq: {
36
+ Model: 'llama-3-70b';
37
+ Params: ChatCompletionCreateParamsBase$1;
38
+ Completion: ChatCompletion$1;
39
+ };
40
+ anthropic: {
41
+ Model: 'claude-3-5-sonnet' | 'claude-3-5-haiku' | 'claude-3-haiku';
42
+ Params: MessageCreateParams;
43
+ Completion: Message;
44
+ };
45
+ google: {
46
+ Model: 'gemini-1.5-flash' | 'gemini-1.5-flash-8b' | 'gemini-1.5-pro';
47
+ Params: ModelParams;
48
+ Completion: GenerateContentResponse;
49
+ };
50
+ deepseek: {
51
+ Model: 'v3';
52
+ Params: DeepSeekChatCompletionCreateParamsBase;
53
+ Completion: DeepSeekChatCompletionType;
54
+ };
55
+ }
26
56
  /**
27
- * Providers supported by Copilot.
57
+ * Models available for each provider (maintained as individual exports)
28
58
  */
29
- type CopilotProvider = 'openai' | 'groq' | 'anthropic' | 'google';
59
+ type OpenAIModel = ProviderImplementationMap['openai']['Model'];
60
+ type GroqModel = ProviderImplementationMap['groq']['Model'];
61
+ type AnthropicModel = ProviderImplementationMap['anthropic']['Model'];
30
62
  /**
31
- * Specific ChatCompletion types for each provider.
63
+ * Union of all predefined Copilot models
32
64
  */
65
+ type CopilotModel = {
66
+ [K in CopilotProvider]: ProviderImplementationMap[K]['Model'];
67
+ }[CopilotProvider];
33
68
  type OpenAIChatCompletion = ChatCompletion;
69
+ type DeepSeekChatCompletion = DeepSeekChatCompletionType;
34
70
  type GroqChatCompletion = ChatCompletion$1;
35
71
  type AnthropicChatCompletion = Message;
36
72
  /**
@@ -41,107 +77,40 @@ interface PromptData {
41
77
  user: string;
42
78
  }
43
79
  /**
44
- * Function type for configuring a custom model.
80
+ * Custom model configuration types
45
81
  */
46
82
  type CustomCopilotModelConfig = (apiKey: string, prompt: PromptData) => {
47
- /**
48
- * The URL endpoint for the custom model's API.
49
- */
83
+ /** The URL endpoint for the custom model's API */
50
84
  endpoint: string;
51
- /**
52
- * Additional HTTP headers to include with the API request.
53
- * Use this to add any necessary authentication or custom headers.
54
- */
85
+ /** Additional HTTP headers */
55
86
  headers?: Record<string, string>;
56
- /**
57
- * The data to be sent in the request body to the custom model API.
58
- */
87
+ /** Request body data */
59
88
  body?: Record<string, unknown>;
60
89
  };
61
- /**
62
- * Function type for transforming the response from a custom model.
63
- */
64
90
  type CustomCopilotModelTransformResponse = (response: unknown) => {
65
- /**
66
- * The text generated by the custom model.
67
- */
91
+ /** The generated text */
68
92
  text: string | null;
69
- /**
70
- * @deprecated Use `text` instead. This property will be removed in a future version.
71
- */
93
+ /** @deprecated Use `text` instead */
72
94
  completion?: string | null;
73
95
  };
74
- /**
75
- * Definition of a custom Copilot model.
76
- */
77
96
  interface CustomCopilotModel {
78
- /**
79
- * Function to configure the custom model.
80
- */
97
+ /** Configuration function */
81
98
  config: CustomCopilotModelConfig;
82
- /**
83
- * Function to transform the response from the custom model.
84
- */
99
+ /** Response transformer */
85
100
  transformResponse: CustomCopilotModelTransformResponse;
86
101
  }
87
102
  /**
88
- * Configuration options for initializing a Copilot instance.
89
- * The `model` property is type-safe and varies based on the specified `provider`.
103
+ * Enhanced Copilot options using mapped types
90
104
  */
91
- type CopilotOptions = {
92
- /**
93
- * Specifies the provider for the Copilot instance.
94
- * Supported providers include 'openai', 'anthropic', 'groq', and 'google'.
95
- */
96
- provider: 'openai';
97
- /**
98
- * Defines the model to be used for Copilot LLM (Language Model) requests.
99
- * This must be a model from the 'openai' provider.
100
- */
101
- model: OpenAIModel;
102
- } | {
103
- /**
104
- * Specifies the 'groq' provider for the Copilot instance.
105
- */
106
- provider: 'groq';
107
- /**
108
- * Defines the model to be used for Copilot LLM requests.
109
- * This must be a model from the 'groq' provider.
110
- */
111
- model: GroqModel;
112
- } | {
113
- /**
114
- * Specifies the 'anthropic' provider for the Copilot instance.
115
- */
116
- provider: 'anthropic';
117
- /**
118
- * Defines the model to be used for Copilot LLM requests.
119
- * This must be a model from the 'anthropic' provider.
120
- */
121
- model: AnthropicModel;
122
- } | {
123
- /**
124
- * Specifies the 'google' provider for the Copilot instance.
125
- */
126
- provider: 'google';
127
- /**
128
- * Defines the model to be used for Copilot LLM requests.
129
- * This must be a model from the 'google' provider.
130
- */
131
- model: GoogleModel;
132
- } | {
133
- /**
134
- * When no provider is specified, only custom models are allowed.
135
- */
105
+ type ProviderOptions<T extends CopilotProvider> = {
106
+ provider: T;
107
+ model: ProviderImplementationMap[T]['Model'];
108
+ };
109
+ type CustomOptions = {
136
110
  provider?: undefined;
137
- /**
138
- * Defines the model to be used for Copilot LLM requests.
139
- * Must be a custom model when no provider is specified.
140
- * For more information, refer to the documentation:
141
- * @see https://github.com/arshad-yaseen/monacopilot?tab=readme-ov-file#custom-model
142
- */
143
111
  model: CustomCopilotModel;
144
112
  };
113
+ type CopilotOptions = ProviderOptions<'openai'> | ProviderOptions<'groq'> | ProviderOptions<'anthropic'> | ProviderOptions<'google'> | ProviderOptions<'deepseek'> | CustomOptions;
145
114
 
146
115
  type Monaco = typeof monaco;
147
116
  type StandaloneCodeEditor = monaco.editor.IStandaloneCodeEditor;
@@ -386,4 +355,4 @@ declare class Copilot {
386
355
  */
387
356
  declare const registerCompletion: (monaco: Monaco, editor: StandaloneCodeEditor, options: RegisterCompletionOptions) => CompletionRegistration;
388
357
 
389
- export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type CopilotModel, type CopilotOptions, type CopilotProvider, type CustomCopilotModel, type CustomCopilotModelConfig, type CustomCopilotModelTransformResponse, type GroqChatCompletion, type GroqModel, type Monaco, type OpenAIChatCompletion, type OpenAIModel, type RegisterCompletionOptions, type StandaloneCodeEditor, registerCompletion };
358
+ export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type CopilotModel, type CopilotOptions, type CopilotProvider, type CustomCopilotModel, type CustomCopilotModelConfig, type CustomCopilotModelTransformResponse, type DeepSeekChatCompletion, type GroqChatCompletion, type GroqModel, type Monaco, type OpenAIChatCompletion, type OpenAIModel, type RegisterCompletionOptions, type StandaloneCodeEditor, registerCompletion };
package/build/index.d.ts CHANGED
@@ -1,36 +1,72 @@
1
- import { Message } from '@anthropic-ai/sdk/resources';
2
- import { ChatCompletion as ChatCompletion$1 } from 'groq-sdk/resources/chat/completions';
3
- import { ChatCompletion } from 'openai/resources/chat/completions';
1
+ import { Message, MessageCreateParams } from '@anthropic-ai/sdk/resources';
2
+ import { ModelParams, GenerateContentResponse } from '@google/generative-ai';
3
+ import { ChatCompletion as ChatCompletion$1, ChatCompletionCreateParamsBase as ChatCompletionCreateParamsBase$1 } from 'groq-sdk/resources/chat/completions';
4
+ import { ChatCompletion, ChatCompletionCreateParamsBase } from 'openai/resources/chat/completions';
4
5
  import * as monaco from 'monaco-editor/esm/vs/editor/editor.api';
5
6
 
7
+ declare const COPILOT_MODEL_IDS: Record<CopilotModel, string>;
8
+
9
+ type DeepSeekChatCompletionType = {
10
+ choices: {
11
+ text: string;
12
+ }[];
13
+ };
14
+ type DeepSeekChatCompletionCreateParamsBase = {
15
+ model: (typeof COPILOT_MODEL_IDS)['v3'];
16
+ prompt: string;
17
+ suffix: string;
18
+ temperature: number;
19
+ max_tokens: number;
20
+ };
21
+
6
22
  /**
7
- * Models available for OpenAI provider.
8
- */
9
- type OpenAIModel = 'gpt-4o' | 'gpt-4o-mini' | 'o1-mini';
10
- /**
11
- * Models available for Groq provider.
12
- */
13
- type GroqModel = 'llama-3-70b';
14
- /**
15
- * Models available for Anthropic provider.
16
- */
17
- type AnthropicModel = 'claude-3-5-sonnet' | 'claude-3-5-haiku' | 'claude-3-haiku';
18
- /**
19
- * Models available for Google provider.
23
+ * Providers supported by Copilot.
20
24
  */
21
- type GoogleModel = 'gemini-1.5-flash' | 'gemini-1.5-flash-8b' | 'gemini-1.5-pro';
25
+ type CopilotProvider = 'openai' | 'groq' | 'anthropic' | 'google' | 'deepseek';
22
26
  /**
23
- * Union of all predefined Copilot models.
27
+ * Core type mapping for provider-specific implementations
24
28
  */
25
- type CopilotModel = OpenAIModel | GroqModel | AnthropicModel | GoogleModel;
29
+ interface ProviderImplementationMap {
30
+ openai: {
31
+ Model: 'gpt-4o' | 'gpt-4o-mini' | 'o1-mini';
32
+ Params: ChatCompletionCreateParamsBase;
33
+ Completion: ChatCompletion;
34
+ };
35
+ groq: {
36
+ Model: 'llama-3-70b';
37
+ Params: ChatCompletionCreateParamsBase$1;
38
+ Completion: ChatCompletion$1;
39
+ };
40
+ anthropic: {
41
+ Model: 'claude-3-5-sonnet' | 'claude-3-5-haiku' | 'claude-3-haiku';
42
+ Params: MessageCreateParams;
43
+ Completion: Message;
44
+ };
45
+ google: {
46
+ Model: 'gemini-1.5-flash' | 'gemini-1.5-flash-8b' | 'gemini-1.5-pro';
47
+ Params: ModelParams;
48
+ Completion: GenerateContentResponse;
49
+ };
50
+ deepseek: {
51
+ Model: 'v3';
52
+ Params: DeepSeekChatCompletionCreateParamsBase;
53
+ Completion: DeepSeekChatCompletionType;
54
+ };
55
+ }
26
56
  /**
27
- * Providers supported by Copilot.
57
+ * Models available for each provider (maintained as individual exports)
28
58
  */
29
- type CopilotProvider = 'openai' | 'groq' | 'anthropic' | 'google';
59
+ type OpenAIModel = ProviderImplementationMap['openai']['Model'];
60
+ type GroqModel = ProviderImplementationMap['groq']['Model'];
61
+ type AnthropicModel = ProviderImplementationMap['anthropic']['Model'];
30
62
  /**
31
- * Specific ChatCompletion types for each provider.
63
+ * Union of all predefined Copilot models
32
64
  */
65
+ type CopilotModel = {
66
+ [K in CopilotProvider]: ProviderImplementationMap[K]['Model'];
67
+ }[CopilotProvider];
33
68
  type OpenAIChatCompletion = ChatCompletion;
69
+ type DeepSeekChatCompletion = DeepSeekChatCompletionType;
34
70
  type GroqChatCompletion = ChatCompletion$1;
35
71
  type AnthropicChatCompletion = Message;
36
72
  /**
@@ -41,107 +77,40 @@ interface PromptData {
41
77
  user: string;
42
78
  }
43
79
  /**
44
- * Function type for configuring a custom model.
80
+ * Custom model configuration types
45
81
  */
46
82
  type CustomCopilotModelConfig = (apiKey: string, prompt: PromptData) => {
47
- /**
48
- * The URL endpoint for the custom model's API.
49
- */
83
+ /** The URL endpoint for the custom model's API */
50
84
  endpoint: string;
51
- /**
52
- * Additional HTTP headers to include with the API request.
53
- * Use this to add any necessary authentication or custom headers.
54
- */
85
+ /** Additional HTTP headers */
55
86
  headers?: Record<string, string>;
56
- /**
57
- * The data to be sent in the request body to the custom model API.
58
- */
87
+ /** Request body data */
59
88
  body?: Record<string, unknown>;
60
89
  };
61
- /**
62
- * Function type for transforming the response from a custom model.
63
- */
64
90
  type CustomCopilotModelTransformResponse = (response: unknown) => {
65
- /**
66
- * The text generated by the custom model.
67
- */
91
+ /** The generated text */
68
92
  text: string | null;
69
- /**
70
- * @deprecated Use `text` instead. This property will be removed in a future version.
71
- */
93
+ /** @deprecated Use `text` instead */
72
94
  completion?: string | null;
73
95
  };
74
- /**
75
- * Definition of a custom Copilot model.
76
- */
77
96
  interface CustomCopilotModel {
78
- /**
79
- * Function to configure the custom model.
80
- */
97
+ /** Configuration function */
81
98
  config: CustomCopilotModelConfig;
82
- /**
83
- * Function to transform the response from the custom model.
84
- */
99
+ /** Response transformer */
85
100
  transformResponse: CustomCopilotModelTransformResponse;
86
101
  }
87
102
  /**
88
- * Configuration options for initializing a Copilot instance.
89
- * The `model` property is type-safe and varies based on the specified `provider`.
103
+ * Enhanced Copilot options using mapped types
90
104
  */
91
- type CopilotOptions = {
92
- /**
93
- * Specifies the provider for the Copilot instance.
94
- * Supported providers include 'openai', 'anthropic', 'groq', and 'google'.
95
- */
96
- provider: 'openai';
97
- /**
98
- * Defines the model to be used for Copilot LLM (Language Model) requests.
99
- * This must be a model from the 'openai' provider.
100
- */
101
- model: OpenAIModel;
102
- } | {
103
- /**
104
- * Specifies the 'groq' provider for the Copilot instance.
105
- */
106
- provider: 'groq';
107
- /**
108
- * Defines the model to be used for Copilot LLM requests.
109
- * This must be a model from the 'groq' provider.
110
- */
111
- model: GroqModel;
112
- } | {
113
- /**
114
- * Specifies the 'anthropic' provider for the Copilot instance.
115
- */
116
- provider: 'anthropic';
117
- /**
118
- * Defines the model to be used for Copilot LLM requests.
119
- * This must be a model from the 'anthropic' provider.
120
- */
121
- model: AnthropicModel;
122
- } | {
123
- /**
124
- * Specifies the 'google' provider for the Copilot instance.
125
- */
126
- provider: 'google';
127
- /**
128
- * Defines the model to be used for Copilot LLM requests.
129
- * This must be a model from the 'google' provider.
130
- */
131
- model: GoogleModel;
132
- } | {
133
- /**
134
- * When no provider is specified, only custom models are allowed.
135
- */
105
+ type ProviderOptions<T extends CopilotProvider> = {
106
+ provider: T;
107
+ model: ProviderImplementationMap[T]['Model'];
108
+ };
109
+ type CustomOptions = {
136
110
  provider?: undefined;
137
- /**
138
- * Defines the model to be used for Copilot LLM requests.
139
- * Must be a custom model when no provider is specified.
140
- * For more information, refer to the documentation:
141
- * @see https://github.com/arshad-yaseen/monacopilot?tab=readme-ov-file#custom-model
142
- */
143
111
  model: CustomCopilotModel;
144
112
  };
113
+ type CopilotOptions = ProviderOptions<'openai'> | ProviderOptions<'groq'> | ProviderOptions<'anthropic'> | ProviderOptions<'google'> | ProviderOptions<'deepseek'> | CustomOptions;
145
114
 
146
115
  type Monaco = typeof monaco;
147
116
  type StandaloneCodeEditor = monaco.editor.IStandaloneCodeEditor;
@@ -386,4 +355,4 @@ declare class Copilot {
386
355
  */
387
356
  declare const registerCompletion: (monaco: Monaco, editor: StandaloneCodeEditor, options: RegisterCompletionOptions) => CompletionRegistration;
388
357
 
389
- export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type CopilotModel, type CopilotOptions, type CopilotProvider, type CustomCopilotModel, type CustomCopilotModelConfig, type CustomCopilotModelTransformResponse, type GroqChatCompletion, type GroqModel, type Monaco, type OpenAIChatCompletion, type OpenAIModel, type RegisterCompletionOptions, type StandaloneCodeEditor, registerCompletion };
358
+ export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type CopilotModel, type CopilotOptions, type CopilotProvider, type CustomCopilotModel, type CustomCopilotModelConfig, type CustomCopilotModelTransformResponse, type DeepSeekChatCompletion, type GroqChatCompletion, type GroqModel, type Monaco, type OpenAIChatCompletion, type OpenAIModel, type RegisterCompletionOptions, type StandaloneCodeEditor, registerCompletion };
package/build/index.js CHANGED
@@ -1,12 +1,12 @@
1
1
  'use strict';
2
2
 
3
- var H=["groq","openai","anthropic","google"],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-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"},j={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},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"};var E=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,X=t=>t.charAt(0).toUpperCase()+t.slice(1),V=(t,e,o={})=>{if(e<=0)return "";let n=t.split(`
3
+ var H=["groq","openai","anthropic","google","deepseek"],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-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",v3:"deepseek-chat"},j={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"],deepseek:["v3"]},x={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models",deepseek:"https://api.deepseek.com/beta/completions"};var E=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,X=t=>t.charAt(0).toUpperCase()+t.slice(1),V=(t,e,o={})=>{if(e<=0)return "";let n=t.split(`
4
4
  `),i=n.length;if(e>=i)return t;if(o.from==="end"){let s=n.slice(-e);return s.every(m=>m==="")?`
5
5
  `.repeat(e):s.join(`
6
6
  `)}let r=n.slice(0,e);return r.every(s=>s==="")?`
7
7
  `.repeat(e):r.join(`
8
8
  `)};var J=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var Y=(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}),z=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var Z=async(t,e,o={})=>{let n=o.timeout??3e4,i=AbortSignal.timeout(n),r=o.signal?AbortSignal.any([i,o.signal]):i,s={"Content-Type":"application/json",...o.headers},m=e==="POST"&&o.body?JSON.stringify(o.body):void 0,d=await fetch(t,{method:e,headers:s,body:m,signal:r});if(!d.ok){let l=await d.json().catch(()=>null),p=l?`
9
- ${JSON.stringify(l,null,2)}`:"",a=o.fallbackError||"Network request failed";throw new Error(`${a} (${d.status})${p}`)}return d.json()},de=(t,e)=>Z(t,"GET",e),ce=(t,e,o)=>Z(t,"POST",{...o,body:e}),I={GET:de,POST:ce};var w=(t,e=600,o=200)=>{let n=null,i=0,r=null,s=null,m=!1,d=(...l)=>{if(m)return Promise.resolve(void 0);r=l;let p=Date.now(),a=p-i;i=p,n&&(clearTimeout(n),n=null);let u=a<o?e:o;return s=new Promise((g,y)=>{n=setTimeout(async()=>{m=!0;try{if(r){let C=await t(...r);g(C);}else g(void 0);}catch(C){y(C);}finally{m=!1,n=null,r=null;}},u);}),s};return d.cancel=()=>{n&&(clearTimeout(n),n=null),r=null;},d};var ue=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
9
+ ${JSON.stringify(l,null,2)}`:"",a=o.fallbackError||"Network request failed";throw new Error(`${a} (${d.status})${p}`)}return d.json()},de=(t,e)=>Z(t,"GET",e),ce=(t,e,o)=>Z(t,"POST",{...o,body:e}),L={GET:de,POST:ce};var k=(t,e=600,o=200)=>{let n=null,i=0,r=null,s=null,m=!1,d=(...l)=>{if(m)return Promise.resolve(void 0);r=l;let p=Date.now(),a=p-i;i=p,n&&(clearTimeout(n),n=null);let u=a<o?e:o;return s=new Promise((g,P)=>{n=setTimeout(async()=>{m=!0;try{if(r){let C=await t(...r);g(C);}else g(void 0);}catch(C){P(C);}finally{m=!1,n=null,r=null;}},u);}),s};return d.cancel=()=>{n&&(clearTimeout(n),n=null),r=null;},d};var ue=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
10
10
  <related_file>
11
11
  <filePath>${e}</filePath>
12
12
  <fileContent>
@@ -34,16 +34,16 @@ ${r}<cursor>${s}
34
34
 
35
35
  ${X(m)} the code at <cursor>.
36
36
 
37
- Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:l,user:p}};var Ce={createEndpoint:()=>b.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:B(t),...!o&&{temperature:.1},max_completion_tokens:500,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},ge={createEndpoint:()=>b.groq,createRequestBody:(t,e)=>({model:B(t),temperature:.1,max_tokens:500,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},he={createEndpoint:()=>b.anthropic,createRequestBody:(t,e)=>({model:B(t),temperature:.1,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:500}),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}},fe={createEndpoint:(t,e)=>`${b.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:B(t),system_instruction:{parts:{text:e.system}},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},S={openai:Ce,groq:ge,anthropic:he,google:fe},ee=(t,e,o)=>S[o].createEndpoint(t,e),te=(t,e,o)=>S[e].createRequestBody(t,o),oe=(t,e)=>S[e].createHeaders(t),ne=(t,e)=>S[e].parseCompletion(t),B=t=>G[t];var ye="\x1B[91m",re="\x1B[93m",K="\x1B[0m",U="\x1B[1m",ie=t=>t instanceof Error?t.message:typeof t=="string"?t:"An unknown error occurred",q=t=>{let e=ie(t),o=`${ye}${U}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},M=(t,e)=>{console.warn(`${re}${U}[MONACOPILOT WARN] ${t}${e?`
38
- ${ie(e)}`:""}${K}`);};var se=(t,e,o)=>console.warn(`${re}${U}[MONACOPILOT DEPRECATED] "${t}" is deprecated${` in ${o}`}. Please use "${e}" instead. It will be removed in a future version.${K}`);var W=class{constructor(e,o){this.validateParams(e,o),this.apiKey=e,this.provider=o.provider,this.model=o.model,this.validateInputs();}validateParams(e,o){if(!e)throw new Error("Please provide an API key.");if(!o||typeof o=="object"&&Object.keys(o).length===0)throw new Error("Please provide options.")}validateInputs(){if(typeof this.model=="object"){if(this.provider!==void 0)throw new Error("Provider should not be specified when using a custom model.");if(!("config"in this.model)||!("transformResponse"in this.model))throw new Error("Please ensure both config and transformResponse are provided for custom model.");return}if(!this.provider||!H.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${E(H)}`);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: ${E(j[this.provider])}`)}async complete(e){let{body:o,options:n}=e,{completionMetadata:i}=o,{headers:r={},customPrompt:s}=n??{},m=this.generatePrompt(i,s),{endpoint:d,requestBody:l,headers:p}=this.prepareRequestDetails(m);try{let a=await this.sendCompletionRequest(d,l,{...p,...r});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,o){let n=Q(e);return o?{...n,...o(e)}:n}prepareRequestDetails(e){if(typeof this.model=="object"&&"config"in this.model){let o=this.model.config(this.apiKey,e),n=o.endpoint,i=o.body??{},r=o.headers??{};return {endpoint:n,requestBody:i,headers:r}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let o=ee(this.model,this.apiKey,this.provider),n=oe(this.apiKey,this.provider),i=te(this.model,this.provider,e);return {endpoint:o,requestBody:i,headers:n}}}async sendCompletionRequest(e,o,n){return I.POST(e,o,{headers:n})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&se("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:ne(e,this.provider),raw:e}}}handleCompletionError(e){return {error:q(e).message,completion:null}}};var F=class{constructor(e,o,n){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=o,this.textBeforeCursorInLine=n;}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}indentByColumn(){let e=this.formattedCompletion.split(`
37
+ Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:l,user:p}};var Ce={createEndpoint:()=>x.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:O(t),...!o&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.[0]?.message.content??null},ge={createEndpoint:()=>x.groq,createRequestBody:(t,e)=>({model:O(t),temperature:.1,max_tokens:500,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.[0]?.message.content??null},he={createEndpoint:()=>x.anthropic,createRequestBody:(t,e)=>({model:O(t),temperature:.1,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:500}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{let e=t.content?.[0];return e&&"text"in e?e.text:null}},fe={createEndpoint:(t,e)=>`${x.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:O(t),system_instruction:{parts:[{text:e.system}]},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{parts:[{text:e.user}]}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>t.candidates?.[0]?.content?.parts?.[0]?.text??null},Pe={createEndpoint:()=>x.deepseek,createRequestBody:(t,e,o)=>({model:O(t),prompt:o.textBeforeCursor,suffix:o.textAfterCursor,temperature:.1,max_tokens:500}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>typeof t.choices?.[0]?.text=="string"?t.choices[0].text:null},S={openai:Ce,groq:ge,anthropic:he,google:fe,deepseek:Pe},ee=(t,e,o)=>S[o].createEndpoint(t,e),te=(t,e,o,n)=>S[e].createRequestBody(t,o,n),oe=(t,e)=>S[e].createHeaders(t),ne=(t,e)=>S[e].parseCompletion(t),O=t=>G[t];var ye="\x1B[91m",re="\x1B[93m",K="\x1B[0m",U="\x1B[1m",ie=t=>t instanceof Error?t.message:typeof t=="string"?t:"An unknown error occurred",B=t=>{let e=ie(t),o=`${ye}${U}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},I=(t,e)=>{console.warn(`${re}${U}[MONACOPILOT WARN] ${t}${e?`
38
+ ${ie(e)}`:""}${K}`);};var se=(t,e,o)=>console.warn(`${re}${U}[MONACOPILOT DEPRECATED] "${t}" is deprecated${` in ${o}`}. Please use "${e}" instead. It will be removed in a future version.${K}`);var W=class{constructor(e,o){this.validateParams(e,o),this.apiKey=e,this.provider=o.provider,this.model=o.model,this.validateInputs();}validateParams(e,o){if(!e)throw new Error("Please provide an API key.");if(!o||typeof o=="object"&&Object.keys(o).length===0)throw new Error("Please provide options.")}validateInputs(){if(typeof this.model=="object"){if(this.provider!==void 0)throw new Error("Provider should not be specified when using a custom model.");if(!("config"in this.model)||!("transformResponse"in this.model))throw new Error("Please ensure both config and transformResponse are provided for custom model.");return}if(!this.provider||!H.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${E(H)}`);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: ${E(j[this.provider])}`)}async complete(e){let{body:o,options:n}=e,{completionMetadata:i}=o,{headers:r={},customPrompt:s}=n??{},m=this.generatePrompt(i,s),{endpoint:d,requestBody:l,headers:p}=this.prepareRequestDetails(m,i);try{let a=await this.sendCompletionRequest(d,l,{...p,...r});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,o){let n=Q(e);return o?{...n,...o(e)}:n}prepareRequestDetails(e,o){if(typeof this.model=="object"&&"config"in this.model){let n=this.model.config(this.apiKey,e),i=n.endpoint,r=n.body??{},s=n.headers??{};return {endpoint:i,requestBody:r,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let n=ee(this.model,this.apiKey,this.provider),i=oe(this.apiKey,this.provider),r=te(this.model,this.provider,e,o);return {endpoint:n,requestBody:r,headers:i}}}async sendCompletionRequest(e,o,n){return L.POST(e,o,{headers:n})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&se("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:ne(e,this.provider),raw:e}}}handleCompletionError(e){return {error:B(e).message,completion:null}}};var q=class{constructor(e,o,n){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=o,this.textBeforeCursorInLine=n;}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}indentByColumn(){let e=this.formattedCompletion.split(`
39
39
  `);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let o=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
40
40
  `+e.slice(1).map(n=>o+n).join(`
41
41
  `),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,n=e,i;for(;(i=o.exec(e))!==null;){let r=i[0],s=r.split(`
42
42
  `).slice(1,-1).join(`
43
43
  `);n=n.replace(r,s);}return n.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
44
44
 
45
- `),this}build(){return this.formattedCompletion}};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 D=class D{constructor(){this.cache=new k(D.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(n=>this.isValidCacheItem(n,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,n){let i=n.getValueInRange(e.range),r=T(o,n);return r.length<e.textBeforeCursor.length||!r.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,o,i)}isPositionValid(e,o,n){let{range:i,completion:r}=e,{startLineNumber:s,startColumn:m,endLineNumber:d,endColumn:l}=i,{lineNumber:p,column:a}=o;if(!r.startsWith(n))return !1;let u=p===s&&a===m;if(s===d)return u||p===s&&a>=m&&a<=l;let g=p>s&&p<d?!0:p===s&&a>=m||p===d&&a<=l;return u||g}};D.MAX_CACHE_SIZE=10;var N=D;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,n){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let i=n.getOffsetAt(e),r=n.getValue().substring(0,i),s=n.getValue().substring(i),m=0,d=0,l=0,p=0,a=o.length,u=r.length,g=s.length;if(i>=n.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(g===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let y=Math.min(a,u);for(let c=1;c<=y;c++){let R=o.substring(0,c),me=r.slice(-c);R===me&&(p=c);}let C=Math.min(a,g);for(let c=0;c<C&&o[c]===s[c];c++)m++;for(let c=1;c<=C;c++)o.slice(-c)===s.slice(0,c)&&(d=c);if(l=Math.max(m,d),l===0){for(let c=1;c<a;c++)if(s.startsWith(o.substring(c))){l=a-c;break}}let P=p>0?n.getPositionAt(i-p):e,f=i+l,h=n.getPositionAt(f);return new this.monaco.Range(P.lineNumber,P.column,h.lineNumber,h.column)}computeCacheRange(e,o){let n=e.lineNumber,i=e.column,r=o.split(`
46
- `),s=r.length-1,m=n+s,d=s===0?i+r[0].length:r[s].length+1;return new this.monaco.Range(n,i,m,d)}};var Pe="application/json",ae=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:i}=await I.POST(e,o,{headers:{"Content-Type":Pe},fallbackError:"Error while fetching completion item"});if(i)throw new Error(i);return {completion:n}},le=({pos:t,mdl:e,options:o})=>{let{filename:n,language:i,technologies:r,relatedFiles:s,maxContextLines:m}=o,d=Re(t,e),p=!!s?.length?3:2,a=m?Math.floor(m/p):void 0,u=(f,h,c)=>{let R=f(t,e);return h?V(R,h,c):R},g=(f,h)=>!f||!h?f:f.map(({content:c,...R})=>({...R,content:V(c,h)})),y=u(T,a,{from:"end"}),C=u(z,a),P=g(s,a);return {filename:n,language:i,technologies:r,relatedFiles:P,textBeforeCursor:y,textAfterCursor:C,cursorPosition:t,editorState:{completionMode:d}}},Re=(t,e)=>{let o=J(t,e),n=z(t,e);return o?"insert":n.trim()?"complete":"continue"};var x=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var xe=t=>({onTyping:w(t,600,200),onIdle:w(t,600,400),onDemand:w(t,0,0)}),_=new N,be=async({monaco:t,mdl:e,pos:o,token:n,isCompletionAccepted:i,options:r})=>{let{trigger:s="onIdle",endpoint:m,enableCaching:d=!0,onError:l,requestHandler:p}=r;if(d){let a=_.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return x(a)}if(n.isCancellationRequested||i)return x([]);try{let u=xe(p??ae)[s];n.onCancellationRequested(()=>{u.cancel();});let g=le({pos:o,mdl:e,options:r}),{completion:y}=await u({endpoint:m,body:{completionMetadata:g}});if(y){let C=new F(y,o.column,Y(o,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),P=new $(t),f=P.computeInsertionRange(o,C,e),h=P.computeCacheRange(o,C);return d&&_.add({completion:C,range:h,textBeforeCursor:T(o,e)}),x([{insertText:C,range:f}])}}catch(a){if(Ee(a))return x([]);l?l(a):M("Cannot provide completion",a);}return x([])},Ee=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,pe=be;var O=new WeakMap,v=null,Me=(t,e,o)=>{v&&v.deregister();let n=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};O.set(e,i),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let r=O.get(e);if(!r)return M("Completion is not registered properly. State not found."),{deregister:()=>{},trigger:()=>{}};let s=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(l,p,a,u)=>{if(!(o.trigger==="onDemand"&&!r.isManualTrigger))return pe({monaco:t,mdl:l,pos:p,token:u,isCompletionAccepted:r.isCompletionAccepted,options:o})},handleItemDidShow:(l,p,a)=>{r.isCompletionVisible=!0,r.isManualTrigger=!1,!r.isCompletionAccepted&&o.onCompletionShown?.(a,p.range);},freeInlineCompletions:()=>{}});n.push(s);let m=e.onKeyDown(l=>{let p=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;r.isCompletionVisible&&p?(o.onCompletionAccepted?.(),r.isCompletionAccepted=!0,r.isCompletionVisible=!1):r.isCompletionAccepted=!1;});n.push(m);let d={deregister:()=>{n.forEach(l=>l.dispose()),_.clear(),O.delete(e),v=null;},trigger:()=>ve(e)};return v=d,d}catch(r){return o.onError?o.onError(r):q(r),{deregister:()=>{n.forEach(s=>s.dispose()),O.delete(e),v=null;},trigger:()=>{}}}},ve=t=>{let e=O.get(t);if(!e){M("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};
45
+ `),this}build(){return this.formattedCompletion}};var D=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 N=class N{constructor(){this.cache=new D(N.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(n=>this.isValidCacheItem(n,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,n){let i=n.getValueInRange(e.range),r=T(o,n);return r.length<e.textBeforeCursor.length||!r.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,o,i)}isPositionValid(e,o,n){let{range:i,completion:r}=e,{startLineNumber:s,startColumn:m,endLineNumber:d,endColumn:l}=i,{lineNumber:p,column:a}=o;if(!r.startsWith(n))return !1;let u=p===s&&a===m;if(s===d)return u||p===s&&a>=m&&a<=l;let g=p>s&&p<d?!0:p===s&&a>=m||p===d&&a<=l;return u||g}};N.MAX_CACHE_SIZE=10;var F=N;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,n){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let i=n.getOffsetAt(e),r=n.getValue().substring(0,i),s=n.getValue().substring(i),m=0,d=0,l=0,p=0,a=o.length,u=r.length,g=s.length;if(i>=n.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(g===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let P=Math.min(a,u);for(let c=1;c<=P;c++){let R=o.substring(0,c),me=r.slice(-c);R===me&&(p=c);}let C=Math.min(a,g);for(let c=0;c<C&&o[c]===s[c];c++)m++;for(let c=1;c<=C;c++)o.slice(-c)===s.slice(0,c)&&(d=c);if(l=Math.max(m,d),l===0){for(let c=1;c<a;c++)if(s.startsWith(o.substring(c))){l=a-c;break}}let y=p>0?n.getPositionAt(i-p):e,f=i+l,h=n.getPositionAt(f);return new this.monaco.Range(y.lineNumber,y.column,h.lineNumber,h.column)}computeCacheRange(e,o){let n=e.lineNumber,i=e.column,r=o.split(`
46
+ `),s=r.length-1,m=n+s,d=s===0?i+r[0].length:r[s].length+1;return new this.monaco.Range(n,i,m,d)}};var Re="application/json",ae=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:i}=await L.POST(e,o,{headers:{"Content-Type":Re},fallbackError:"Error while fetching completion item"});if(i)throw new Error(i);return {completion:n}},le=({pos:t,mdl:e,options:o})=>{let{filename:n,language:i,technologies:r,relatedFiles:s,maxContextLines:m}=o,d=xe(t,e),p=!!s?.length?3:2,a=m?Math.floor(m/p):void 0,u=(f,h,c)=>{let R=f(t,e);return h?V(R,h,c):R},g=(f,h)=>!f||!h?f:f.map(({content:c,...R})=>({...R,content:V(c,h)})),P=u(T,a,{from:"end"}),C=u(z,a),y=g(s,a);return {filename:n,language:i,technologies:r,relatedFiles:y,textBeforeCursor:P,textAfterCursor:C,cursorPosition:t,editorState:{completionMode:d}}},xe=(t,e)=>{let o=J(t,e),n=z(t,e);return o?"insert":n.trim()?"complete":"continue"};var b=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var be=t=>({onTyping:k(t,600,200),onIdle:k(t,600,400),onDemand:k(t,0,0)}),_=new F,Ee=async({monaco:t,mdl:e,pos:o,token:n,isCompletionAccepted:i,options:r})=>{let{trigger:s="onIdle",endpoint:m,enableCaching:d=!0,onError:l,requestHandler:p}=r;if(d){let a=_.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return b(a)}if(n.isCancellationRequested||i)return b([]);try{let u=be(p??ae)[s];n.onCancellationRequested(()=>{u.cancel();});let g=le({pos:o,mdl:e,options:r}),{completion:P}=await u({endpoint:m,body:{completionMetadata:g}});if(P){let C=new q(P,o.column,Y(o,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),y=new $(t),f=y.computeInsertionRange(o,C,e),h=y.computeCacheRange(o,C);return d&&_.add({completion:C,range:h,textBeforeCursor:T(o,e)}),b([{insertText:C,range:f}])}}catch(a){if(Me(a))return b([]);l?l(a):I("Cannot provide completion",a);}return b([])},Me=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,pe=Ee;var A=new WeakMap,w=null,ve=(t,e,o)=>{w&&w.deregister();let n=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};A.set(e,i),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let r=A.get(e);if(!r)return I("Completion is not registered properly. State not found."),{deregister:()=>{},trigger:()=>{}};let s=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(l,p,a,u)=>{if(!(o.trigger==="onDemand"&&!r.isManualTrigger))return pe({monaco:t,mdl:l,pos:p,token:u,isCompletionAccepted:r.isCompletionAccepted,options:o})},handleItemDidShow:(l,p,a)=>{r.isCompletionVisible=!0,r.isManualTrigger=!1,!r.isCompletionAccepted&&o.onCompletionShown?.(a,p.range);},freeInlineCompletions:()=>{}});n.push(s);let m=e.onKeyDown(l=>{let p=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;r.isCompletionVisible&&p?(o.onCompletionAccepted?.(),r.isCompletionAccepted=!0,r.isCompletionVisible=!1):r.isCompletionAccepted=!1;});n.push(m);let d={deregister:()=>{n.forEach(l=>l.dispose()),_.clear(),A.delete(e),w=null;},trigger:()=>Oe(e)};return w=d,d}catch(r){return o.onError?o.onError(r):B(r),{deregister:()=>{n.forEach(s=>s.dispose()),A.delete(e),w=null;},trigger:()=>{}}}},Oe=t=>{let e=A.get(t);if(!e){I("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};
47
47
 
48
48
  exports.Copilot = W;
49
- exports.registerCompletion = Me;
49
+ exports.registerCompletion = ve;
package/build/index.mjs CHANGED
@@ -1,10 +1,10 @@
1
- var H=["groq","openai","anthropic","google"],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-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"},j={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"]},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"};var E=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,X=t=>t.charAt(0).toUpperCase()+t.slice(1),V=(t,e,o={})=>{if(e<=0)return "";let n=t.split(`
1
+ var H=["groq","openai","anthropic","google","deepseek"],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-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",v3:"deepseek-chat"},j={groq:["llama-3-70b"],openai:["gpt-4o","gpt-4o-mini","o1-mini"],anthropic:["claude-3-5-sonnet","claude-3-haiku","claude-3-5-haiku"],google:["gemini-1.5-flash-8b","gemini-1.5-pro","gemini-1.5-flash"],deepseek:["v3"]},x={groq:"https://api.groq.com/openai/v1/chat/completions",openai:"https://api.openai.com/v1/chat/completions",anthropic:"https://api.anthropic.com/v1/messages",google:"https://generativelanguage.googleapis.com/v1beta/models",deepseek:"https://api.deepseek.com/beta/completions"};var E=t=>!t||t.length===0?"":t.length===1?t[0]:`${t.slice(0,-1).join(", ")} and ${t.slice(-1)}`,X=t=>t.charAt(0).toUpperCase()+t.slice(1),V=(t,e,o={})=>{if(e<=0)return "";let n=t.split(`
2
2
  `),i=n.length;if(e>=i)return t;if(o.from==="end"){let s=n.slice(-e);return s.every(m=>m==="")?`
3
3
  `.repeat(e):s.join(`
4
4
  `)}let r=n.slice(0,e);return r.every(s=>s==="")?`
5
5
  `.repeat(e):r.join(`
6
6
  `)};var J=(t,e)=>e.getLineContent(t.lineNumber)[t.column-1];var Y=(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}),z=(t,e)=>e.getValueInRange({startLineNumber:t.lineNumber,startColumn:t.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var Z=async(t,e,o={})=>{let n=o.timeout??3e4,i=AbortSignal.timeout(n),r=o.signal?AbortSignal.any([i,o.signal]):i,s={"Content-Type":"application/json",...o.headers},m=e==="POST"&&o.body?JSON.stringify(o.body):void 0,d=await fetch(t,{method:e,headers:s,body:m,signal:r});if(!d.ok){let l=await d.json().catch(()=>null),p=l?`
7
- ${JSON.stringify(l,null,2)}`:"",a=o.fallbackError||"Network request failed";throw new Error(`${a} (${d.status})${p}`)}return d.json()},de=(t,e)=>Z(t,"GET",e),ce=(t,e,o)=>Z(t,"POST",{...o,body:e}),I={GET:de,POST:ce};var w=(t,e=600,o=200)=>{let n=null,i=0,r=null,s=null,m=!1,d=(...l)=>{if(m)return Promise.resolve(void 0);r=l;let p=Date.now(),a=p-i;i=p,n&&(clearTimeout(n),n=null);let u=a<o?e:o;return s=new Promise((g,y)=>{n=setTimeout(async()=>{m=!0;try{if(r){let C=await t(...r);g(C);}else g(void 0);}catch(C){y(C);}finally{m=!1,n=null,r=null;}},u);}),s};return d.cancel=()=>{n&&(clearTimeout(n),n=null),r=null;},d};var ue=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
7
+ ${JSON.stringify(l,null,2)}`:"",a=o.fallbackError||"Network request failed";throw new Error(`${a} (${d.status})${p}`)}return d.json()},de=(t,e)=>Z(t,"GET",e),ce=(t,e,o)=>Z(t,"POST",{...o,body:e}),L={GET:de,POST:ce};var k=(t,e=600,o=200)=>{let n=null,i=0,r=null,s=null,m=!1,d=(...l)=>{if(m)return Promise.resolve(void 0);r=l;let p=Date.now(),a=p-i;i=p,n&&(clearTimeout(n),n=null);let u=a<o?e:o;return s=new Promise((g,P)=>{n=setTimeout(async()=>{m=!0;try{if(r){let C=await t(...r);g(C);}else g(void 0);}catch(C){P(C);}finally{m=!1,n=null,r=null;}},u);}),s};return d.cancel=()=>{n&&(clearTimeout(n),n=null),r=null;},d};var ue=t=>!t||t.length===0?"":t.map(({path:e,content:o})=>`
8
8
  <related_file>
9
9
  <filePath>${e}</filePath>
10
10
  <fileContent>
@@ -32,15 +32,15 @@ ${r}<cursor>${s}
32
32
 
33
33
  ${X(m)} the code at <cursor>.
34
34
 
35
- Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:l,user:p}};var Ce={createEndpoint:()=>b.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:B(t),...!o&&{temperature:.1},max_completion_tokens:500,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},ge={createEndpoint:()=>b.groq,createRequestBody:(t,e)=>({model:B(t),temperature:.1,max_tokens:500,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.length?t.choices[0].message.content:null},he={createEndpoint:()=>b.anthropic,createRequestBody:(t,e)=>({model:B(t),temperature:.1,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:500}),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}},fe={createEndpoint:(t,e)=>`${b.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:B(t),system_instruction:{parts:{text:e.system}},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{parts:{text:e.user}}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>{if(!t.candidates?.length||!t.candidates[0]?.content||!t.candidates[0].content?.parts?.length)return null;let e=t.candidates[0].content;return "text"in e.parts[0]&&typeof e.parts[0].text=="string"?e.parts[0].text:null}},S={openai:Ce,groq:ge,anthropic:he,google:fe},ee=(t,e,o)=>S[o].createEndpoint(t,e),te=(t,e,o)=>S[e].createRequestBody(t,o),oe=(t,e)=>S[e].createHeaders(t),ne=(t,e)=>S[e].parseCompletion(t),B=t=>G[t];var ye="\x1B[91m",re="\x1B[93m",K="\x1B[0m",U="\x1B[1m",ie=t=>t instanceof Error?t.message:typeof t=="string"?t:"An unknown error occurred",q=t=>{let e=ie(t),o=`${ye}${U}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},M=(t,e)=>{console.warn(`${re}${U}[MONACOPILOT WARN] ${t}${e?`
36
- ${ie(e)}`:""}${K}`);};var se=(t,e,o)=>console.warn(`${re}${U}[MONACOPILOT DEPRECATED] "${t}" is deprecated${` in ${o}`}. Please use "${e}" instead. It will be removed in a future version.${K}`);var W=class{constructor(e,o){this.validateParams(e,o),this.apiKey=e,this.provider=o.provider,this.model=o.model,this.validateInputs();}validateParams(e,o){if(!e)throw new Error("Please provide an API key.");if(!o||typeof o=="object"&&Object.keys(o).length===0)throw new Error("Please provide options.")}validateInputs(){if(typeof this.model=="object"){if(this.provider!==void 0)throw new Error("Provider should not be specified when using a custom model.");if(!("config"in this.model)||!("transformResponse"in this.model))throw new Error("Please ensure both config and transformResponse are provided for custom model.");return}if(!this.provider||!H.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${E(H)}`);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: ${E(j[this.provider])}`)}async complete(e){let{body:o,options:n}=e,{completionMetadata:i}=o,{headers:r={},customPrompt:s}=n??{},m=this.generatePrompt(i,s),{endpoint:d,requestBody:l,headers:p}=this.prepareRequestDetails(m);try{let a=await this.sendCompletionRequest(d,l,{...p,...r});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,o){let n=Q(e);return o?{...n,...o(e)}:n}prepareRequestDetails(e){if(typeof this.model=="object"&&"config"in this.model){let o=this.model.config(this.apiKey,e),n=o.endpoint,i=o.body??{},r=o.headers??{};return {endpoint:n,requestBody:i,headers:r}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let o=ee(this.model,this.apiKey,this.provider),n=oe(this.apiKey,this.provider),i=te(this.model,this.provider,e);return {endpoint:o,requestBody:i,headers:n}}}async sendCompletionRequest(e,o,n){return I.POST(e,o,{headers:n})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&se("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:ne(e,this.provider),raw:e}}}handleCompletionError(e){return {error:q(e).message,completion:null}}};var F=class{constructor(e,o,n){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=o,this.textBeforeCursorInLine=n;}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}indentByColumn(){let e=this.formattedCompletion.split(`
35
+ Output only the raw code to be inserted at the cursor location without any additional text or comments.`;return {system:l,user:p}};var Ce={createEndpoint:()=>x.openai,createRequestBody:(t,e)=>{let o=t==="o1-mini";return {model:O(t),...!o&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}},createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.[0]?.message.content??null},ge={createEndpoint:()=>x.groq,createRequestBody:(t,e)=>({model:O(t),temperature:.1,max_tokens:500,messages:[{role:"system",content:e.system},{role:"user",content:e.user}]}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>t.choices?.[0]?.message.content??null},he={createEndpoint:()=>x.anthropic,createRequestBody:(t,e)=>({model:O(t),temperature:.1,system:e.system,messages:[{role:"user",content:e.user}],max_tokens:500}),createHeaders:t=>({"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"}),parseCompletion:t=>{let e=t.content?.[0];return e&&"text"in e?e.text:null}},fe={createEndpoint:(t,e)=>`${x.google}/${t}:generateContent?key=${e}`,createRequestBody:(t,e)=>({model:O(t),system_instruction:{parts:[{text:e.system}]},generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{parts:[{text:e.user}]}]}),createHeaders:()=>({"Content-Type":"application/json"}),parseCompletion:t=>t.candidates?.[0]?.content?.parts?.[0]?.text??null},Pe={createEndpoint:()=>x.deepseek,createRequestBody:(t,e,o)=>({model:O(t),prompt:o.textBeforeCursor,suffix:o.textAfterCursor,temperature:.1,max_tokens:500}),createHeaders:t=>({"Content-Type":"application/json",Authorization:`Bearer ${t}`}),parseCompletion:t=>typeof t.choices?.[0]?.text=="string"?t.choices[0].text:null},S={openai:Ce,groq:ge,anthropic:he,google:fe,deepseek:Pe},ee=(t,e,o)=>S[o].createEndpoint(t,e),te=(t,e,o,n)=>S[e].createRequestBody(t,o,n),oe=(t,e)=>S[e].createHeaders(t),ne=(t,e)=>S[e].parseCompletion(t),O=t=>G[t];var ye="\x1B[91m",re="\x1B[93m",K="\x1B[0m",U="\x1B[1m",ie=t=>t instanceof Error?t.message:typeof t=="string"?t:"An unknown error occurred",B=t=>{let e=ie(t),o=`${ye}${U}[MONACOPILOT ERROR] ${e}${K}`;return console.error(o),{message:e}},I=(t,e)=>{console.warn(`${re}${U}[MONACOPILOT WARN] ${t}${e?`
36
+ ${ie(e)}`:""}${K}`);};var se=(t,e,o)=>console.warn(`${re}${U}[MONACOPILOT DEPRECATED] "${t}" is deprecated${` in ${o}`}. Please use "${e}" instead. It will be removed in a future version.${K}`);var W=class{constructor(e,o){this.validateParams(e,o),this.apiKey=e,this.provider=o.provider,this.model=o.model,this.validateInputs();}validateParams(e,o){if(!e)throw new Error("Please provide an API key.");if(!o||typeof o=="object"&&Object.keys(o).length===0)throw new Error("Please provide options.")}validateInputs(){if(typeof this.model=="object"){if(this.provider!==void 0)throw new Error("Provider should not be specified when using a custom model.");if(!("config"in this.model)||!("transformResponse"in this.model))throw new Error("Please ensure both config and transformResponse are provided for custom model.");return}if(!this.provider||!H.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${E(H)}`);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: ${E(j[this.provider])}`)}async complete(e){let{body:o,options:n}=e,{completionMetadata:i}=o,{headers:r={},customPrompt:s}=n??{},m=this.generatePrompt(i,s),{endpoint:d,requestBody:l,headers:p}=this.prepareRequestDetails(m,i);try{let a=await this.sendCompletionRequest(d,l,{...p,...r});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,o){let n=Q(e);return o?{...n,...o(e)}:n}prepareRequestDetails(e,o){if(typeof this.model=="object"&&"config"in this.model){let n=this.model.config(this.apiKey,e),i=n.endpoint,r=n.body??{},s=n.headers??{};return {endpoint:i,requestBody:r,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let n=ee(this.model,this.apiKey,this.provider),i=oe(this.apiKey,this.provider),r=te(this.model,this.provider,e,o);return {endpoint:n,requestBody:r,headers:i}}}async sendCompletionRequest(e,o,n){return L.POST(e,o,{headers:n})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let o=this.model.transformResponse(e);return "completion"in o&&se("completion","text","Copilot.options.model.transformResponse"),{completion:o.text??o.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:ne(e,this.provider),raw:e}}}handleCompletionError(e){return {error:B(e).message,completion:null}}};var q=class{constructor(e,o,n){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=o,this.textBeforeCursorInLine=n;}setCompletion(e){return this.formattedCompletion=e,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}indentByColumn(){let e=this.formattedCompletion.split(`
37
37
  `);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let o=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
38
38
  `+e.slice(1).map(n=>o+n).join(`
39
39
  `),this}removeMarkdownCodeBlocks(e){let o=/```[\s\S]*?```/g,n=e,i;for(;(i=o.exec(e))!==null;){let r=i[0],s=r.split(`
40
40
  `).slice(1,-1).join(`
41
41
  `);n=n.replace(r,s);}return n.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
42
42
 
43
- `),this}build(){return this.formattedCompletion}};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 D=class D{constructor(){this.cache=new k(D.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(n=>this.isValidCacheItem(n,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,n){let i=n.getValueInRange(e.range),r=T(o,n);return r.length<e.textBeforeCursor.length||!r.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,o,i)}isPositionValid(e,o,n){let{range:i,completion:r}=e,{startLineNumber:s,startColumn:m,endLineNumber:d,endColumn:l}=i,{lineNumber:p,column:a}=o;if(!r.startsWith(n))return !1;let u=p===s&&a===m;if(s===d)return u||p===s&&a>=m&&a<=l;let g=p>s&&p<d?!0:p===s&&a>=m||p===d&&a<=l;return u||g}};D.MAX_CACHE_SIZE=10;var N=D;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,n){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let i=n.getOffsetAt(e),r=n.getValue().substring(0,i),s=n.getValue().substring(i),m=0,d=0,l=0,p=0,a=o.length,u=r.length,g=s.length;if(i>=n.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(g===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let y=Math.min(a,u);for(let c=1;c<=y;c++){let R=o.substring(0,c),me=r.slice(-c);R===me&&(p=c);}let C=Math.min(a,g);for(let c=0;c<C&&o[c]===s[c];c++)m++;for(let c=1;c<=C;c++)o.slice(-c)===s.slice(0,c)&&(d=c);if(l=Math.max(m,d),l===0){for(let c=1;c<a;c++)if(s.startsWith(o.substring(c))){l=a-c;break}}let P=p>0?n.getPositionAt(i-p):e,f=i+l,h=n.getPositionAt(f);return new this.monaco.Range(P.lineNumber,P.column,h.lineNumber,h.column)}computeCacheRange(e,o){let n=e.lineNumber,i=e.column,r=o.split(`
44
- `),s=r.length-1,m=n+s,d=s===0?i+r[0].length:r[s].length+1;return new this.monaco.Range(n,i,m,d)}};var Pe="application/json",ae=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:i}=await I.POST(e,o,{headers:{"Content-Type":Pe},fallbackError:"Error while fetching completion item"});if(i)throw new Error(i);return {completion:n}},le=({pos:t,mdl:e,options:o})=>{let{filename:n,language:i,technologies:r,relatedFiles:s,maxContextLines:m}=o,d=Re(t,e),p=!!s?.length?3:2,a=m?Math.floor(m/p):void 0,u=(f,h,c)=>{let R=f(t,e);return h?V(R,h,c):R},g=(f,h)=>!f||!h?f:f.map(({content:c,...R})=>({...R,content:V(c,h)})),y=u(T,a,{from:"end"}),C=u(z,a),P=g(s,a);return {filename:n,language:i,technologies:r,relatedFiles:P,textBeforeCursor:y,textAfterCursor:C,cursorPosition:t,editorState:{completionMode:d}}},Re=(t,e)=>{let o=J(t,e),n=z(t,e);return o?"insert":n.trim()?"complete":"continue"};var x=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var xe=t=>({onTyping:w(t,600,200),onIdle:w(t,600,400),onDemand:w(t,0,0)}),_=new N,be=async({monaco:t,mdl:e,pos:o,token:n,isCompletionAccepted:i,options:r})=>{let{trigger:s="onIdle",endpoint:m,enableCaching:d=!0,onError:l,requestHandler:p}=r;if(d){let a=_.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return x(a)}if(n.isCancellationRequested||i)return x([]);try{let u=xe(p??ae)[s];n.onCancellationRequested(()=>{u.cancel();});let g=le({pos:o,mdl:e,options:r}),{completion:y}=await u({endpoint:m,body:{completionMetadata:g}});if(y){let C=new F(y,o.column,Y(o,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),P=new $(t),f=P.computeInsertionRange(o,C,e),h=P.computeCacheRange(o,C);return d&&_.add({completion:C,range:h,textBeforeCursor:T(o,e)}),x([{insertText:C,range:f}])}}catch(a){if(Ee(a))return x([]);l?l(a):M("Cannot provide completion",a);}return x([])},Ee=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,pe=be;var O=new WeakMap,v=null,Me=(t,e,o)=>{v&&v.deregister();let n=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};O.set(e,i),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let r=O.get(e);if(!r)return M("Completion is not registered properly. State not found."),{deregister:()=>{},trigger:()=>{}};let s=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(l,p,a,u)=>{if(!(o.trigger==="onDemand"&&!r.isManualTrigger))return pe({monaco:t,mdl:l,pos:p,token:u,isCompletionAccepted:r.isCompletionAccepted,options:o})},handleItemDidShow:(l,p,a)=>{r.isCompletionVisible=!0,r.isManualTrigger=!1,!r.isCompletionAccepted&&o.onCompletionShown?.(a,p.range);},freeInlineCompletions:()=>{}});n.push(s);let m=e.onKeyDown(l=>{let p=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;r.isCompletionVisible&&p?(o.onCompletionAccepted?.(),r.isCompletionAccepted=!0,r.isCompletionVisible=!1):r.isCompletionAccepted=!1;});n.push(m);let d={deregister:()=>{n.forEach(l=>l.dispose()),_.clear(),O.delete(e),v=null;},trigger:()=>ve(e)};return v=d,d}catch(r){return o.onError?o.onError(r):q(r),{deregister:()=>{n.forEach(s=>s.dispose()),O.delete(e),v=null;},trigger:()=>{}}}},ve=t=>{let e=O.get(t);if(!e){M("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};
43
+ `),this}build(){return this.formattedCompletion}};var D=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 N=class N{constructor(){this.cache=new D(N.MAX_CACHE_SIZE);}get(e,o){return this.cache.getAll().filter(n=>this.isValidCacheItem(n,e,o))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,o,n){let i=n.getValueInRange(e.range),r=T(o,n);return r.length<e.textBeforeCursor.length||!r.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,o,i)}isPositionValid(e,o,n){let{range:i,completion:r}=e,{startLineNumber:s,startColumn:m,endLineNumber:d,endColumn:l}=i,{lineNumber:p,column:a}=o;if(!r.startsWith(n))return !1;let u=p===s&&a===m;if(s===d)return u||p===s&&a>=m&&a<=l;let g=p>s&&p<d?!0:p===s&&a>=m||p===d&&a<=l;return u||g}};N.MAX_CACHE_SIZE=10;var F=N;var $=class{constructor(e){this.monaco=e;}computeInsertionRange(e,o,n){if(!o)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let i=n.getOffsetAt(e),r=n.getValue().substring(0,i),s=n.getValue().substring(i),m=0,d=0,l=0,p=0,a=o.length,u=r.length,g=s.length;if(i>=n.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(g===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let P=Math.min(a,u);for(let c=1;c<=P;c++){let R=o.substring(0,c),me=r.slice(-c);R===me&&(p=c);}let C=Math.min(a,g);for(let c=0;c<C&&o[c]===s[c];c++)m++;for(let c=1;c<=C;c++)o.slice(-c)===s.slice(0,c)&&(d=c);if(l=Math.max(m,d),l===0){for(let c=1;c<a;c++)if(s.startsWith(o.substring(c))){l=a-c;break}}let y=p>0?n.getPositionAt(i-p):e,f=i+l,h=n.getPositionAt(f);return new this.monaco.Range(y.lineNumber,y.column,h.lineNumber,h.column)}computeCacheRange(e,o){let n=e.lineNumber,i=e.column,r=o.split(`
44
+ `),s=r.length-1,m=n+s,d=s===0?i+r[0].length:r[s].length+1;return new this.monaco.Range(n,i,m,d)}};var Re="application/json",ae=async t=>{let{endpoint:e,body:o}=t,{completion:n,error:i}=await L.POST(e,o,{headers:{"Content-Type":Re},fallbackError:"Error while fetching completion item"});if(i)throw new Error(i);return {completion:n}},le=({pos:t,mdl:e,options:o})=>{let{filename:n,language:i,technologies:r,relatedFiles:s,maxContextLines:m}=o,d=xe(t,e),p=!!s?.length?3:2,a=m?Math.floor(m/p):void 0,u=(f,h,c)=>{let R=f(t,e);return h?V(R,h,c):R},g=(f,h)=>!f||!h?f:f.map(({content:c,...R})=>({...R,content:V(c,h)})),P=u(T,a,{from:"end"}),C=u(z,a),y=g(s,a);return {filename:n,language:i,technologies:r,relatedFiles:y,textBeforeCursor:P,textAfterCursor:C,cursorPosition:t,editorState:{completionMode:d}}},xe=(t,e)=>{let o=J(t,e),n=z(t,e);return o?"insert":n.trim()?"complete":"continue"};var b=t=>({items:t,enableForwardStability:!0,suppressSuggestions:!0});var be=t=>({onTyping:k(t,600,200),onIdle:k(t,600,400),onDemand:k(t,0,0)}),_=new F,Ee=async({monaco:t,mdl:e,pos:o,token:n,isCompletionAccepted:i,options:r})=>{let{trigger:s="onIdle",endpoint:m,enableCaching:d=!0,onError:l,requestHandler:p}=r;if(d){let a=_.get(o,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return b(a)}if(n.isCancellationRequested||i)return b([]);try{let u=be(p??ae)[s];n.onCancellationRequested(()=>{u.cancel();});let g=le({pos:o,mdl:e,options:r}),{completion:P}=await u({endpoint:m,body:{completionMetadata:g}});if(P){let C=new q(P,o.column,Y(o,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),y=new $(t),f=y.computeInsertionRange(o,C,e),h=y.computeCacheRange(o,C);return d&&_.add({completion:C,range:h,textBeforeCursor:T(o,e)}),b([{insertText:C,range:f}])}}catch(a){if(Me(a))return b([]);l?l(a):I("Cannot provide completion",a);}return b([])},Me=t=>typeof t=="string"?t==="Cancelled"||t==="AbortError":t instanceof Error?t.message==="Cancelled"||t.name==="AbortError":!1,pe=Ee;var A=new WeakMap,w=null,ve=(t,e,o)=>{w&&w.deregister();let n=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};A.set(e,i),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let r=A.get(e);if(!r)return I("Completion is not registered properly. State not found."),{deregister:()=>{},trigger:()=>{}};let s=t.languages.registerInlineCompletionsProvider(o.language,{provideInlineCompletions:(l,p,a,u)=>{if(!(o.trigger==="onDemand"&&!r.isManualTrigger))return pe({monaco:t,mdl:l,pos:p,token:u,isCompletionAccepted:r.isCompletionAccepted,options:o})},handleItemDidShow:(l,p,a)=>{r.isCompletionVisible=!0,r.isManualTrigger=!1,!r.isCompletionAccepted&&o.onCompletionShown?.(a,p.range);},freeInlineCompletions:()=>{}});n.push(s);let m=e.onKeyDown(l=>{let p=l.keyCode===t.KeyCode.Tab||l.keyCode===t.KeyCode.RightArrow&&l.metaKey;r.isCompletionVisible&&p?(o.onCompletionAccepted?.(),r.isCompletionAccepted=!0,r.isCompletionVisible=!1):r.isCompletionAccepted=!1;});n.push(m);let d={deregister:()=>{n.forEach(l=>l.dispose()),_.clear(),A.delete(e),w=null;},trigger:()=>Oe(e)};return w=d,d}catch(r){return o.onError?o.onError(r):B(r),{deregister:()=>{n.forEach(s=>s.dispose()),A.delete(e),w=null;},trigger:()=>{}}}},Oe=t=>{let e=A.get(t);if(!e){I("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,t.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};
45
45
 
46
- export { W as Copilot, Me as registerCompletion };
46
+ export { W as Copilot, ve as registerCompletion };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "monacopilot",
3
- "version": "0.16.9",
3
+ "version": "0.17.0",
4
4
  "description": "AI auto-completion plugin for Monaco Editor",
5
5
  "main": "./build/index.js",
6
6
  "module": "./build/index.mjs",