monacopilot 0.16.10 → 0.17.1
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 +7 -6
- package/build/index.d.mts +73 -107
- package/build/index.d.ts +73 -107
- package/build/index.js +23 -23
- package/build/index.mjs +22 -22
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -472,12 +472,13 @@ const copilot = new Copilot(process.env.OPENAI_API_KEY, {
|
|
|
472
472
|
|
|
473
473
|
There are other providers and models available. Here is a list:
|
|
474
474
|
|
|
475
|
-
| Provider | Models |
|
|
476
|
-
| --------- | ----------------------------------------------------------- |
|
|
477
|
-
|
|
|
478
|
-
|
|
|
479
|
-
|
|
|
480
|
-
|
|
|
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. |
|
|
481
482
|
|
|
482
483
|
### Custom Model
|
|
483
484
|
|
package/build/index.d.mts
CHANGED
|
@@ -1,38 +1,74 @@
|
|
|
1
|
-
import { Message } from '@anthropic-ai/sdk/resources';
|
|
2
|
-
import {
|
|
3
|
-
import { ChatCompletion } from '
|
|
1
|
+
import { Message, MessageCreateParams } from '@anthropic-ai/sdk/resources';
|
|
2
|
+
import { GenerateContentRequest, 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 MODEL_IDS: Record<Model, string>;
|
|
8
|
+
|
|
6
9
|
/**
|
|
7
|
-
*
|
|
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.
|
|
10
|
+
* Providers supported by Copilot.
|
|
20
11
|
*/
|
|
21
|
-
type
|
|
12
|
+
type Provider = 'openai' | 'groq' | 'anthropic' | 'google' | 'deepseek';
|
|
13
|
+
type DeepSeekChatCompletionType = {
|
|
14
|
+
choices: {
|
|
15
|
+
text: string;
|
|
16
|
+
}[];
|
|
17
|
+
};
|
|
18
|
+
type DeepSeekChatCompletionCreateParamsBase = {
|
|
19
|
+
model: (typeof MODEL_IDS)['v3'];
|
|
20
|
+
prompt: string;
|
|
21
|
+
suffix: string;
|
|
22
|
+
temperature: number;
|
|
23
|
+
max_tokens: number;
|
|
24
|
+
};
|
|
22
25
|
/**
|
|
23
|
-
*
|
|
26
|
+
* Core type mapping for provider-specific implementations
|
|
24
27
|
*/
|
|
25
|
-
|
|
28
|
+
interface ProviderImplementationMap {
|
|
29
|
+
openai: {
|
|
30
|
+
Model: 'gpt-4o' | 'gpt-4o-mini' | 'o1-mini';
|
|
31
|
+
Params: ChatCompletionCreateParamsBase;
|
|
32
|
+
Completion: ChatCompletion;
|
|
33
|
+
};
|
|
34
|
+
groq: {
|
|
35
|
+
Model: 'llama-3-70b';
|
|
36
|
+
Params: ChatCompletionCreateParamsBase$1;
|
|
37
|
+
Completion: ChatCompletion$1;
|
|
38
|
+
};
|
|
39
|
+
anthropic: {
|
|
40
|
+
Model: 'claude-3-5-sonnet' | 'claude-3-5-haiku' | 'claude-3-haiku';
|
|
41
|
+
Params: MessageCreateParams;
|
|
42
|
+
Completion: Message;
|
|
43
|
+
};
|
|
44
|
+
google: {
|
|
45
|
+
Model: 'gemini-1.5-flash' | 'gemini-1.5-flash-8b' | 'gemini-1.5-pro';
|
|
46
|
+
Params: GenerateContentRequest;
|
|
47
|
+
Completion: GenerateContentResponse;
|
|
48
|
+
};
|
|
49
|
+
deepseek: {
|
|
50
|
+
Model: 'v3';
|
|
51
|
+
Params: DeepSeekChatCompletionCreateParamsBase;
|
|
52
|
+
Completion: DeepSeekChatCompletionType;
|
|
53
|
+
};
|
|
54
|
+
}
|
|
26
55
|
/**
|
|
27
|
-
*
|
|
56
|
+
* Models available for each provider (maintained as individual exports)
|
|
28
57
|
*/
|
|
29
|
-
type
|
|
58
|
+
type OpenAIModel = ProviderImplementationMap['openai']['Model'];
|
|
59
|
+
type GroqModel = ProviderImplementationMap['groq']['Model'];
|
|
60
|
+
type AnthropicModel = ProviderImplementationMap['anthropic']['Model'];
|
|
30
61
|
/**
|
|
31
|
-
*
|
|
62
|
+
* Union of all predefined Copilot models
|
|
32
63
|
*/
|
|
64
|
+
type Model = {
|
|
65
|
+
[K in Provider]: ProviderImplementationMap[K]['Model'];
|
|
66
|
+
}[Provider];
|
|
33
67
|
type OpenAIChatCompletion = ChatCompletion;
|
|
68
|
+
type DeepSeekChatCompletion = DeepSeekChatCompletionType;
|
|
34
69
|
type GroqChatCompletion = ChatCompletion$1;
|
|
35
70
|
type AnthropicChatCompletion = Message;
|
|
71
|
+
|
|
36
72
|
/**
|
|
37
73
|
* Data structure representing the prompt data.
|
|
38
74
|
*/
|
|
@@ -41,107 +77,37 @@ interface PromptData {
|
|
|
41
77
|
user: string;
|
|
42
78
|
}
|
|
43
79
|
/**
|
|
44
|
-
*
|
|
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
|
-
|
|
88
|
-
* Configuration options for initializing a Copilot instance.
|
|
89
|
-
* The `model` property is type-safe and varies based on the specified `provider`.
|
|
90
|
-
*/
|
|
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
|
-
*/
|
|
102
|
+
type CustomOptions = {
|
|
136
103
|
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
104
|
model: CustomCopilotModel;
|
|
144
105
|
};
|
|
106
|
+
type CopilotOptions = ProviderOptions<'openai'> | ProviderOptions<'groq'> | ProviderOptions<'anthropic'> | ProviderOptions<'google'> | ProviderOptions<'deepseek'> | CustomOptions;
|
|
107
|
+
type ProviderOptions<T extends Provider> = {
|
|
108
|
+
provider: T;
|
|
109
|
+
model: ProviderImplementationMap[T]['Model'];
|
|
110
|
+
};
|
|
145
111
|
|
|
146
112
|
type Monaco = typeof monaco;
|
|
147
113
|
type StandaloneCodeEditor = monaco.editor.IStandaloneCodeEditor;
|
|
@@ -386,4 +352,4 @@ declare class Copilot {
|
|
|
386
352
|
*/
|
|
387
353
|
declare const registerCompletion: (monaco: Monaco, editor: StandaloneCodeEditor, options: RegisterCompletionOptions) => CompletionRegistration;
|
|
388
354
|
|
|
389
|
-
export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type
|
|
355
|
+
export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type CopilotOptions, type CustomCopilotModel, type CustomCopilotModelConfig, type CustomCopilotModelTransformResponse, type DeepSeekChatCompletion, type GroqChatCompletion, type GroqModel, type Model, type Monaco, type OpenAIChatCompletion, type OpenAIModel, type Provider, type RegisterCompletionOptions, type StandaloneCodeEditor, registerCompletion };
|
package/build/index.d.ts
CHANGED
|
@@ -1,38 +1,74 @@
|
|
|
1
|
-
import { Message } from '@anthropic-ai/sdk/resources';
|
|
2
|
-
import {
|
|
3
|
-
import { ChatCompletion } from '
|
|
1
|
+
import { Message, MessageCreateParams } from '@anthropic-ai/sdk/resources';
|
|
2
|
+
import { GenerateContentRequest, 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 MODEL_IDS: Record<Model, string>;
|
|
8
|
+
|
|
6
9
|
/**
|
|
7
|
-
*
|
|
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.
|
|
10
|
+
* Providers supported by Copilot.
|
|
20
11
|
*/
|
|
21
|
-
type
|
|
12
|
+
type Provider = 'openai' | 'groq' | 'anthropic' | 'google' | 'deepseek';
|
|
13
|
+
type DeepSeekChatCompletionType = {
|
|
14
|
+
choices: {
|
|
15
|
+
text: string;
|
|
16
|
+
}[];
|
|
17
|
+
};
|
|
18
|
+
type DeepSeekChatCompletionCreateParamsBase = {
|
|
19
|
+
model: (typeof MODEL_IDS)['v3'];
|
|
20
|
+
prompt: string;
|
|
21
|
+
suffix: string;
|
|
22
|
+
temperature: number;
|
|
23
|
+
max_tokens: number;
|
|
24
|
+
};
|
|
22
25
|
/**
|
|
23
|
-
*
|
|
26
|
+
* Core type mapping for provider-specific implementations
|
|
24
27
|
*/
|
|
25
|
-
|
|
28
|
+
interface ProviderImplementationMap {
|
|
29
|
+
openai: {
|
|
30
|
+
Model: 'gpt-4o' | 'gpt-4o-mini' | 'o1-mini';
|
|
31
|
+
Params: ChatCompletionCreateParamsBase;
|
|
32
|
+
Completion: ChatCompletion;
|
|
33
|
+
};
|
|
34
|
+
groq: {
|
|
35
|
+
Model: 'llama-3-70b';
|
|
36
|
+
Params: ChatCompletionCreateParamsBase$1;
|
|
37
|
+
Completion: ChatCompletion$1;
|
|
38
|
+
};
|
|
39
|
+
anthropic: {
|
|
40
|
+
Model: 'claude-3-5-sonnet' | 'claude-3-5-haiku' | 'claude-3-haiku';
|
|
41
|
+
Params: MessageCreateParams;
|
|
42
|
+
Completion: Message;
|
|
43
|
+
};
|
|
44
|
+
google: {
|
|
45
|
+
Model: 'gemini-1.5-flash' | 'gemini-1.5-flash-8b' | 'gemini-1.5-pro';
|
|
46
|
+
Params: GenerateContentRequest;
|
|
47
|
+
Completion: GenerateContentResponse;
|
|
48
|
+
};
|
|
49
|
+
deepseek: {
|
|
50
|
+
Model: 'v3';
|
|
51
|
+
Params: DeepSeekChatCompletionCreateParamsBase;
|
|
52
|
+
Completion: DeepSeekChatCompletionType;
|
|
53
|
+
};
|
|
54
|
+
}
|
|
26
55
|
/**
|
|
27
|
-
*
|
|
56
|
+
* Models available for each provider (maintained as individual exports)
|
|
28
57
|
*/
|
|
29
|
-
type
|
|
58
|
+
type OpenAIModel = ProviderImplementationMap['openai']['Model'];
|
|
59
|
+
type GroqModel = ProviderImplementationMap['groq']['Model'];
|
|
60
|
+
type AnthropicModel = ProviderImplementationMap['anthropic']['Model'];
|
|
30
61
|
/**
|
|
31
|
-
*
|
|
62
|
+
* Union of all predefined Copilot models
|
|
32
63
|
*/
|
|
64
|
+
type Model = {
|
|
65
|
+
[K in Provider]: ProviderImplementationMap[K]['Model'];
|
|
66
|
+
}[Provider];
|
|
33
67
|
type OpenAIChatCompletion = ChatCompletion;
|
|
68
|
+
type DeepSeekChatCompletion = DeepSeekChatCompletionType;
|
|
34
69
|
type GroqChatCompletion = ChatCompletion$1;
|
|
35
70
|
type AnthropicChatCompletion = Message;
|
|
71
|
+
|
|
36
72
|
/**
|
|
37
73
|
* Data structure representing the prompt data.
|
|
38
74
|
*/
|
|
@@ -41,107 +77,37 @@ interface PromptData {
|
|
|
41
77
|
user: string;
|
|
42
78
|
}
|
|
43
79
|
/**
|
|
44
|
-
*
|
|
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
|
-
|
|
88
|
-
* Configuration options for initializing a Copilot instance.
|
|
89
|
-
* The `model` property is type-safe and varies based on the specified `provider`.
|
|
90
|
-
*/
|
|
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
|
-
*/
|
|
102
|
+
type CustomOptions = {
|
|
136
103
|
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
104
|
model: CustomCopilotModel;
|
|
144
105
|
};
|
|
106
|
+
type CopilotOptions = ProviderOptions<'openai'> | ProviderOptions<'groq'> | ProviderOptions<'anthropic'> | ProviderOptions<'google'> | ProviderOptions<'deepseek'> | CustomOptions;
|
|
107
|
+
type ProviderOptions<T extends Provider> = {
|
|
108
|
+
provider: T;
|
|
109
|
+
model: ProviderImplementationMap[T]['Model'];
|
|
110
|
+
};
|
|
145
111
|
|
|
146
112
|
type Monaco = typeof monaco;
|
|
147
113
|
type StandaloneCodeEditor = monaco.editor.IStandaloneCodeEditor;
|
|
@@ -386,4 +352,4 @@ declare class Copilot {
|
|
|
386
352
|
*/
|
|
387
353
|
declare const registerCompletion: (monaco: Monaco, editor: StandaloneCodeEditor, options: RegisterCompletionOptions) => CompletionRegistration;
|
|
388
354
|
|
|
389
|
-
export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type
|
|
355
|
+
export { type AnthropicChatCompletion, type AnthropicModel, type CompletionMetadata, type CompletionRegistration, type CompletionRequest, type CompletionRequestBody, type CompletionRequestOptions, Copilot, type CopilotOptions, type CustomCopilotModel, type CustomCopilotModelConfig, type CustomCopilotModelTransformResponse, type DeepSeekChatCompletion, type GroqChatCompletion, type GroqModel, type Model, type Monaco, type OpenAIChatCompletion, type OpenAIModel, type Provider, type RegisterCompletionOptions, type StandaloneCodeEditor, registerCompletion };
|
package/build/index.js
CHANGED
|
@@ -1,49 +1,49 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
4
|
-
`),i=
|
|
3
|
+
var W=["groq","openai","anthropic","google","deepseek"],P={"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"},X={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"]},R={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 g=class{};var w=class extends g{createEndpoint(){return R.anthropic}createRequestBody(e,t){return {model:P[e],temperature:.1,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}}parseCompletion(e){let t=e.content?.[0];return t&&"text"in t?t.text:null}};var L=class extends g{createEndpoint(){return R.deepseek}createRequestBody(e,t,r){return {model:P[e],prompt:r.textBeforeCursor,suffix:r.textAfterCursor,temperature:.1,max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return typeof e.choices?.[0]?.text=="string"?e.choices[0].text:null}};var N=class extends g{createEndpoint(e,t){return `${R.google}/${P[e]}:generateContent?key=${t}`}createRequestBody(e,t){return {systemInstruction:t.system,generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{role:"user",parts:[{text:t.user}]}]}}createHeaders(){return {"Content-Type":"application/json"}}parseCompletion(e){return e.candidates?.[0]?.content?.parts?.[0]?.text??null}};var S=class extends g{createEndpoint(){return R.groq}createRequestBody(e,t){return {model:P[e],temperature:.1,max_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var _=class extends g{createEndpoint(){return R.openai}createRequestBody(e,t){let r=e==="o1-mini";return {model:P[e],...!r&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var B={openai:new _,groq:new S,anthropic:new w,google:new N,deepseek:new L},ee=(o,e,t)=>B[t].createEndpoint(o,e),te=(o,e,t,r)=>B[e].createRequestBody(o,t,r),oe=(o,e)=>B[e].createHeaders(o),re=(o,e)=>B[e].parseCompletion(o);var I=o=>!o||o.length===0?"":o.length===1?o[0]:`${o.slice(0,-1).join(", ")} and ${o.slice(-1)}`,ne=o=>o.charAt(0).toUpperCase()+o.slice(1),G=(o,e,t={})=>{if(e<=0)return "";let r=o.split(`
|
|
4
|
+
`),i=r.length;if(e>=i)return o;if(t.from==="end"){let s=r.slice(-e);return s.every(m=>m==="")?`
|
|
5
5
|
`.repeat(e):s.join(`
|
|
6
|
-
`)}let r
|
|
7
|
-
`.repeat(e):
|
|
8
|
-
`)};var
|
|
9
|
-
${JSON.stringify(l,null,2)}`:"",a=
|
|
6
|
+
`)}let n=r.slice(0,e);return n.every(s=>s==="")?`
|
|
7
|
+
`.repeat(e):n.join(`
|
|
8
|
+
`)};var ie=(o,e)=>e.getLineContent(o.lineNumber)[o.column-1];var se=(o,e)=>e.getLineContent(o.lineNumber).slice(0,o.column-1),v=(o,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:o.lineNumber,endColumn:o.column}),J=(o,e)=>e.getValueInRange({startLineNumber:o.lineNumber,startColumn:o.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var ae=async(o,e,t={})=>{let r=t.timeout??3e4,i=AbortSignal.timeout(r),n=t.signal?AbortSignal.any([i,t.signal]):i,s={"Content-Type":"application/json",...t.headers},m=e==="POST"&&t.body?JSON.stringify(t.body):void 0,c=await fetch(o,{method:e,headers:s,body:m,signal:n});if(!c.ok){let l=await c.json().catch(()=>null),p=l?`
|
|
9
|
+
${JSON.stringify(l,null,2)}`:"",a=t.fallbackError||"Network request failed";throw new Error(`${a} (${c.status})${p}`)}return c.json()},fe=(o,e)=>ae(o,"GET",e),he=(o,e,t)=>ae(o,"POST",{...t,body:e}),F={GET:fe,POST:he};var q=(o,e=600,t=200)=>{let r=null,i=0,n=null,s=null,m=!1,c=(...l)=>{if(m)return Promise.resolve(void 0);n=l;let p=Date.now(),a=p-i;i=p,r&&(clearTimeout(r),r=null);let u=a<t?e:t;return s=new Promise((f,T)=>{r=setTimeout(async()=>{m=!0;try{if(n){let C=await o(...n);f(C);}else f(void 0);}catch(C){T(C);}finally{m=!1,r=null,n=null;}},u);}),s};return c.cancel=()=>{r&&(clearTimeout(r),r=null),n=null;},c};var Pe=o=>!o||o.length===0?"":o.map(({path:e,content:t})=>`
|
|
10
10
|
<related_file>
|
|
11
11
|
<filePath>${e}</filePath>
|
|
12
12
|
<fileContent>
|
|
13
13
|
\`\`\`
|
|
14
|
-
${
|
|
14
|
+
${t}
|
|
15
15
|
\`\`\`
|
|
16
16
|
</fileContent>
|
|
17
17
|
</related_file>`.trim()).join(`
|
|
18
18
|
|
|
19
|
-
`),
|
|
19
|
+
`),le=o=>{let{technologies:e=[],filename:t,relatedFiles:r,language:i,textBeforeCursor:n="",textAfterCursor:s="",editorState:{completionMode:m}}=o,c=I([i,...e].filter(a=>typeof a=="string"&&!!a)),l=`
|
|
20
20
|
You are an expert code completion assistant.
|
|
21
21
|
|
|
22
22
|
**Context:**
|
|
23
|
-
File: ${
|
|
23
|
+
File: ${t||"Untitled"}
|
|
24
24
|
Language: ${i||"Undetermined"}
|
|
25
25
|
Mode: ${m}
|
|
26
|
-
Stack: ${
|
|
26
|
+
Stack: ${c||"None"}`,p=`
|
|
27
27
|
**Related Files:**
|
|
28
|
-
${
|
|
28
|
+
${Pe(r)}
|
|
29
29
|
|
|
30
30
|
**Source:**
|
|
31
31
|
\`\`\`
|
|
32
|
-
${
|
|
32
|
+
${n}<cursor>${s}
|
|
33
33
|
\`\`\`
|
|
34
34
|
|
|
35
|
-
${
|
|
35
|
+
${ne(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
|
|
38
|
-
${
|
|
39
|
-
`);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let
|
|
40
|
-
`+e.slice(1).map(
|
|
41
|
-
`),this}removeMarkdownCodeBlocks(e){let
|
|
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 Re="\x1B[91m",pe="\x1B[93m",Y="\x1B[0m",Z="\x1B[1m",me=o=>o instanceof Error?o.message:typeof o=="string"?o:"An unknown error occurred",$=o=>{let e=me(o),t=`${Re}${Z}[MONACOPILOT ERROR] ${e}${Y}`;return console.error(t),{message:e}},k=(o,e)=>{console.warn(`${pe}${Z}[MONACOPILOT WARN] ${o}${e?`
|
|
38
|
+
${me(e)}`:""}${Y}`);};var ce=(o,e,t)=>console.warn(`${pe}${Z}[MONACOPILOT DEPRECATED] "${o}" is deprecated${` in ${t}`}. Please use "${e}" instead. It will be removed in a future version.${Y}`);var Q=class{constructor(e,t){this.validateParams(e,t),this.apiKey=e,this.provider=t.provider,this.model=t.model,this.validateInputs();}validateParams(e,t){if(!e)throw new Error("Please provide an API key.");if(!t||typeof t=="object"&&Object.keys(t).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||!W.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${I(W)}`);if(typeof this.model=="string"&&!X[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${I(X[this.provider])}`)}async complete(e){let{body:t,options:r}=e,{completionMetadata:i}=t,{headers:n={},customPrompt:s}=r??{},m=this.generatePrompt(i,s),{endpoint:c,requestBody:l,headers:p}=this.prepareRequestDetails(m,i);try{let a=await this.sendCompletionRequest(c,l,{...p,...n});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,t){let r=le(e);return t?{...r,...t(e)}:r}prepareRequestDetails(e,t){if(typeof this.model=="object"&&"config"in this.model){let r=this.model.config(this.apiKey,e),i=r.endpoint,n=r.body??{},s=r.headers??{};return {endpoint:i,requestBody:n,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let r=ee(this.model,this.apiKey,this.provider),i=oe(this.apiKey,this.provider),n=te(this.model,this.provider,e,t);return {endpoint:r,requestBody:n,headers:i}}}async sendCompletionRequest(e,t,r){return F.POST(e,t,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let t=this.model.transformResponse(e);return "completion"in t&&ce("completion","text","Copilot.options.model.transformResponse"),{completion:t.text??t.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:re(e,this.provider),raw:e}}}handleCompletionError(e){return {error:$(e).message,completion:null}}};var H=class{constructor(e,t,r){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=t,this.textBeforeCursorInLine=r;}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
|
+
`);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let t=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
|
|
40
|
+
`+e.slice(1).map(r=>t+r).join(`
|
|
41
|
+
`),this}removeMarkdownCodeBlocks(e){let t=/```[\s\S]*?```/g,r=e,i;for(;(i=t.exec(e))!==null;){let n=i[0],s=n.split(`
|
|
42
42
|
`).slice(1,-1).join(`
|
|
43
|
-
`);
|
|
43
|
+
`);r=r.replace(n,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
44
44
|
|
|
45
|
-
`),this}build(){return this.formattedCompletion}};var
|
|
46
|
-
`),s=
|
|
45
|
+
`),this}build(){return this.formattedCompletion}};var V=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let t;return this.size===this.capacity&&(t=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,t}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 U=class U{constructor(){this.cache=new V(U.MAX_CACHE_SIZE);}get(e,t){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,t))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,t,r){let i=r.getValueInRange(e.range),n=v(t,r);return n.length<e.textBeforeCursor.length||!n.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,t,i)}isPositionValid(e,t,r){let{range:i,completion:n}=e,{startLineNumber:s,startColumn:m,endLineNumber:c,endColumn:l}=i,{lineNumber:p,column:a}=t;if(!n.startsWith(r))return !1;let u=p===s&&a===m;if(s===c)return u||p===s&&a>=m&&a<=l;let f=p>s&&p<c?!0:p===s&&a>=m||p===c&&a<=l;return u||f}};U.MAX_CACHE_SIZE=10;var j=U;var K=class{constructor(e){this.monaco=e;}computeInsertionRange(e,t,r){if(!t)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let i=r.getOffsetAt(e),n=r.getValue().substring(0,i),s=r.getValue().substring(i),m=0,c=0,l=0,p=0,a=t.length,u=n.length,f=s.length;if(i>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(f===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let T=Math.min(a,u);for(let d=1;d<=T;d++){let b=t.substring(0,d),ge=n.slice(-d);b===ge&&(p=d);}let C=Math.min(a,f);for(let d=0;d<C&&t[d]===s[d];d++)m++;for(let d=1;d<=C;d++)t.slice(-d)===s.slice(0,d)&&(c=d);if(l=Math.max(m,c),l===0){for(let d=1;d<a;d++)if(s.startsWith(t.substring(d))){l=a-d;break}}let x=p>0?r.getPositionAt(i-p):e,y=i+l,h=r.getPositionAt(y);return new this.monaco.Range(x.lineNumber,x.column,h.lineNumber,h.column)}computeCacheRange(e,t){let r=e.lineNumber,i=e.column,n=t.split(`
|
|
46
|
+
`),s=n.length-1,m=r+s,c=s===0?i+n[0].length:n[s].length+1;return new this.monaco.Range(r,i,m,c)}};var ye="application/json",de=async o=>{let{endpoint:e,body:t}=o,{completion:r,error:i}=await F.POST(e,t,{headers:{"Content-Type":ye},fallbackError:"Error while fetching completion item"});if(i)throw new Error(i);return {completion:r}},ue=({pos:o,mdl:e,options:t})=>{let{filename:r,language:i,technologies:n,relatedFiles:s,maxContextLines:m}=t,c=Ee(o,e),p=!!s?.length?3:2,a=m?Math.floor(m/p):void 0,u=(y,h,d)=>{let b=y(o,e);return h?G(b,h,d):b},f=(y,h)=>!y||!h?y:y.map(({content:d,...b})=>({...b,content:G(d,h)})),T=u(v,a,{from:"end"}),C=u(J,a),x=f(s,a);return {filename:r,language:i,technologies:n,relatedFiles:x,textBeforeCursor:T,textAfterCursor:C,cursorPosition:o,editorState:{completionMode:c}}},Ee=(o,e)=>{let t=ie(o,e),r=J(o,e);return t?"insert":r.trim()?"complete":"continue"};var O=o=>({items:o,enableForwardStability:!0,suppressSuggestions:!0});var Te=o=>({onTyping:q(o,600,200),onIdle:q(o,600,400),onDemand:q(o,0,0)}),z=new j,xe=async({monaco:o,mdl:e,pos:t,token:r,isCompletionAccepted:i,options:n})=>{let{trigger:s="onIdle",endpoint:m,enableCaching:c=!0,onError:l,requestHandler:p}=n;if(c){let a=z.get(t,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return O(a)}if(r.isCancellationRequested||i)return O([]);try{let u=Te(p??de)[s];r.onCancellationRequested(()=>{u.cancel();});let f=ue({pos:t,mdl:e,options:n}),{completion:T}=await u({endpoint:m,body:{completionMetadata:f}});if(T){let C=new H(T,t.column,se(t,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),x=new K(o),y=x.computeInsertionRange(t,C,e),h=x.computeCacheRange(t,C);return c&&z.add({completion:C,range:h,textBeforeCursor:v(t,e)}),O([{insertText:C,range:y}])}}catch(a){if(be(a))return O([]);l?l(a):k("Cannot provide completion",a);}return O([])},be=o=>typeof o=="string"?o==="Cancelled"||o==="AbortError":o instanceof Error?o.message==="Cancelled"||o.name==="AbortError":!1,Ce=xe;var D=new WeakMap,A=null,ve=(o,e,t)=>{A&&A.deregister();let r=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};D.set(e,i),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let n=D.get(e);if(!n)return k("Completion is not registered properly. State not found."),{deregister:()=>{},trigger:()=>{}};let s=o.languages.registerInlineCompletionsProvider(t.language,{provideInlineCompletions:(l,p,a,u)=>{if(!(t.trigger==="onDemand"&&!n.isManualTrigger))return Ce({monaco:o,mdl:l,pos:p,token:u,isCompletionAccepted:n.isCompletionAccepted,options:t})},handleItemDidShow:(l,p,a)=>{n.isCompletionVisible=!0,n.isManualTrigger=!1,!n.isCompletionAccepted&&t.onCompletionShown?.(a,p.range);},freeInlineCompletions:()=>{}});r.push(s);let m=e.onKeyDown(l=>{let p=l.keyCode===o.KeyCode.Tab||l.keyCode===o.KeyCode.RightArrow&&l.metaKey;n.isCompletionVisible&&p?(t.onCompletionAccepted?.(),n.isCompletionAccepted=!0,n.isCompletionVisible=!1):n.isCompletionAccepted=!1;});r.push(m);let c={deregister:()=>{r.forEach(l=>l.dispose()),z.clear(),D.delete(e),A=null;},trigger:()=>Oe(e)};return A=c,c}catch(n){return t.onError?t.onError(n):$(n),{deregister:()=>{r.forEach(s=>s.dispose()),D.delete(e),A=null;},trigger:()=>{}}}},Oe=o=>{let e=D.get(o);if(!e){k("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,o.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};
|
|
47
47
|
|
|
48
|
-
exports.Copilot =
|
|
49
|
-
exports.registerCompletion =
|
|
48
|
+
exports.Copilot = Q;
|
|
49
|
+
exports.registerCompletion = ve;
|
package/build/index.mjs
CHANGED
|
@@ -1,46 +1,46 @@
|
|
|
1
|
-
var
|
|
2
|
-
`),i=
|
|
1
|
+
var W=["groq","openai","anthropic","google","deepseek"],P={"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"},X={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"]},R={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 g=class{};var w=class extends g{createEndpoint(){return R.anthropic}createRequestBody(e,t){return {model:P[e],temperature:.1,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}}parseCompletion(e){let t=e.content?.[0];return t&&"text"in t?t.text:null}};var L=class extends g{createEndpoint(){return R.deepseek}createRequestBody(e,t,r){return {model:P[e],prompt:r.textBeforeCursor,suffix:r.textAfterCursor,temperature:.1,max_tokens:500}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return typeof e.choices?.[0]?.text=="string"?e.choices[0].text:null}};var N=class extends g{createEndpoint(e,t){return `${R.google}/${P[e]}:generateContent?key=${t}`}createRequestBody(e,t){return {systemInstruction:t.system,generationConfig:{temperature:.1,maxOutputTokens:500},contents:[{role:"user",parts:[{text:t.user}]}]}}createHeaders(){return {"Content-Type":"application/json"}}parseCompletion(e){return e.candidates?.[0]?.content?.parts?.[0]?.text??null}};var S=class extends g{createEndpoint(){return R.groq}createRequestBody(e,t){return {model:P[e],temperature:.1,max_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var _=class extends g{createEndpoint(){return R.openai}createRequestBody(e,t){let r=e==="o1-mini";return {model:P[e],...!r&&{temperature:.1},max_completion_tokens:500,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}}createHeaders(e){return {"Content-Type":"application/json",Authorization:`Bearer ${e}`}}parseCompletion(e){return e.choices?.[0]?.message.content??null}};var B={openai:new _,groq:new S,anthropic:new w,google:new N,deepseek:new L},ee=(o,e,t)=>B[t].createEndpoint(o,e),te=(o,e,t,r)=>B[e].createRequestBody(o,t,r),oe=(o,e)=>B[e].createHeaders(o),re=(o,e)=>B[e].parseCompletion(o);var I=o=>!o||o.length===0?"":o.length===1?o[0]:`${o.slice(0,-1).join(", ")} and ${o.slice(-1)}`,ne=o=>o.charAt(0).toUpperCase()+o.slice(1),G=(o,e,t={})=>{if(e<=0)return "";let r=o.split(`
|
|
2
|
+
`),i=r.length;if(e>=i)return o;if(t.from==="end"){let s=r.slice(-e);return s.every(m=>m==="")?`
|
|
3
3
|
`.repeat(e):s.join(`
|
|
4
|
-
`)}let r
|
|
5
|
-
`.repeat(e):
|
|
6
|
-
`)};var
|
|
7
|
-
${JSON.stringify(l,null,2)}`:"",a=
|
|
4
|
+
`)}let n=r.slice(0,e);return n.every(s=>s==="")?`
|
|
5
|
+
`.repeat(e):n.join(`
|
|
6
|
+
`)};var ie=(o,e)=>e.getLineContent(o.lineNumber)[o.column-1];var se=(o,e)=>e.getLineContent(o.lineNumber).slice(0,o.column-1),v=(o,e)=>e.getValueInRange({startLineNumber:1,startColumn:1,endLineNumber:o.lineNumber,endColumn:o.column}),J=(o,e)=>e.getValueInRange({startLineNumber:o.lineNumber,startColumn:o.column,endLineNumber:e.getLineCount(),endColumn:e.getLineMaxColumn(e.getLineCount())});var ae=async(o,e,t={})=>{let r=t.timeout??3e4,i=AbortSignal.timeout(r),n=t.signal?AbortSignal.any([i,t.signal]):i,s={"Content-Type":"application/json",...t.headers},m=e==="POST"&&t.body?JSON.stringify(t.body):void 0,c=await fetch(o,{method:e,headers:s,body:m,signal:n});if(!c.ok){let l=await c.json().catch(()=>null),p=l?`
|
|
7
|
+
${JSON.stringify(l,null,2)}`:"",a=t.fallbackError||"Network request failed";throw new Error(`${a} (${c.status})${p}`)}return c.json()},fe=(o,e)=>ae(o,"GET",e),he=(o,e,t)=>ae(o,"POST",{...t,body:e}),F={GET:fe,POST:he};var q=(o,e=600,t=200)=>{let r=null,i=0,n=null,s=null,m=!1,c=(...l)=>{if(m)return Promise.resolve(void 0);n=l;let p=Date.now(),a=p-i;i=p,r&&(clearTimeout(r),r=null);let u=a<t?e:t;return s=new Promise((f,T)=>{r=setTimeout(async()=>{m=!0;try{if(n){let C=await o(...n);f(C);}else f(void 0);}catch(C){T(C);}finally{m=!1,r=null,n=null;}},u);}),s};return c.cancel=()=>{r&&(clearTimeout(r),r=null),n=null;},c};var Pe=o=>!o||o.length===0?"":o.map(({path:e,content:t})=>`
|
|
8
8
|
<related_file>
|
|
9
9
|
<filePath>${e}</filePath>
|
|
10
10
|
<fileContent>
|
|
11
11
|
\`\`\`
|
|
12
|
-
${
|
|
12
|
+
${t}
|
|
13
13
|
\`\`\`
|
|
14
14
|
</fileContent>
|
|
15
15
|
</related_file>`.trim()).join(`
|
|
16
16
|
|
|
17
|
-
`),
|
|
17
|
+
`),le=o=>{let{technologies:e=[],filename:t,relatedFiles:r,language:i,textBeforeCursor:n="",textAfterCursor:s="",editorState:{completionMode:m}}=o,c=I([i,...e].filter(a=>typeof a=="string"&&!!a)),l=`
|
|
18
18
|
You are an expert code completion assistant.
|
|
19
19
|
|
|
20
20
|
**Context:**
|
|
21
|
-
File: ${
|
|
21
|
+
File: ${t||"Untitled"}
|
|
22
22
|
Language: ${i||"Undetermined"}
|
|
23
23
|
Mode: ${m}
|
|
24
|
-
Stack: ${
|
|
24
|
+
Stack: ${c||"None"}`,p=`
|
|
25
25
|
**Related Files:**
|
|
26
|
-
${
|
|
26
|
+
${Pe(r)}
|
|
27
27
|
|
|
28
28
|
**Source:**
|
|
29
29
|
\`\`\`
|
|
30
|
-
${
|
|
30
|
+
${n}<cursor>${s}
|
|
31
31
|
\`\`\`
|
|
32
32
|
|
|
33
|
-
${
|
|
33
|
+
${ne(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
|
|
36
|
-
${
|
|
37
|
-
`);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let
|
|
38
|
-
`+e.slice(1).map(
|
|
39
|
-
`),this}removeMarkdownCodeBlocks(e){let
|
|
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 Re="\x1B[91m",pe="\x1B[93m",Y="\x1B[0m",Z="\x1B[1m",me=o=>o instanceof Error?o.message:typeof o=="string"?o:"An unknown error occurred",$=o=>{let e=me(o),t=`${Re}${Z}[MONACOPILOT ERROR] ${e}${Y}`;return console.error(t),{message:e}},k=(o,e)=>{console.warn(`${pe}${Z}[MONACOPILOT WARN] ${o}${e?`
|
|
36
|
+
${me(e)}`:""}${Y}`);};var ce=(o,e,t)=>console.warn(`${pe}${Z}[MONACOPILOT DEPRECATED] "${o}" is deprecated${` in ${t}`}. Please use "${e}" instead. It will be removed in a future version.${Y}`);var Q=class{constructor(e,t){this.validateParams(e,t),this.apiKey=e,this.provider=t.provider,this.model=t.model,this.validateInputs();}validateParams(e,t){if(!e)throw new Error("Please provide an API key.");if(!t||typeof t=="object"&&Object.keys(t).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||!W.includes(this.provider))throw new Error(`Provider must be specified and supported when using built-in models. Please choose from: ${I(W)}`);if(typeof this.model=="string"&&!X[this.provider].includes(this.model))throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${I(X[this.provider])}`)}async complete(e){let{body:t,options:r}=e,{completionMetadata:i}=t,{headers:n={},customPrompt:s}=r??{},m=this.generatePrompt(i,s),{endpoint:c,requestBody:l,headers:p}=this.prepareRequestDetails(m,i);try{let a=await this.sendCompletionRequest(c,l,{...p,...n});return this.processCompletionResponse(a)}catch(a){return this.handleCompletionError(a)}}generatePrompt(e,t){let r=le(e);return t?{...r,...t(e)}:r}prepareRequestDetails(e,t){if(typeof this.model=="object"&&"config"in this.model){let r=this.model.config(this.apiKey,e),i=r.endpoint,n=r.body??{},s=r.headers??{};return {endpoint:i,requestBody:n,headers:s}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");let r=ee(this.model,this.apiKey,this.provider),i=oe(this.apiKey,this.provider),n=te(this.model,this.provider,e,t);return {endpoint:r,requestBody:n,headers:i}}}async sendCompletionRequest(e,t,r){return F.POST(e,t,{headers:r})}processCompletionResponse(e){if(typeof this.model=="object"&&"transformResponse"in this.model){let t=this.model.transformResponse(e);return "completion"in t&&ce("completion","text","Copilot.options.model.transformResponse"),{completion:t.text??t.completion??null,raw:e}}else {if(!this.provider)throw new Error("Provider is required for non-custom models");return {completion:re(e,this.provider),raw:e}}}handleCompletionError(e){return {error:$(e).message,completion:null}}};var H=class{constructor(e,t,r){this.formattedCompletion="";this.currentColumn=0;this.textBeforeCursorInLine="";this.formattedCompletion=e,this.currentColumn=t,this.textBeforeCursorInLine=r;}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
|
+
`);if(e.length<=1||this.textBeforeCursorInLine.trim()!=="")return this;let t=" ".repeat(this.currentColumn-1);return this.formattedCompletion=e[0]+`
|
|
38
|
+
`+e.slice(1).map(r=>t+r).join(`
|
|
39
|
+
`),this}removeMarkdownCodeBlocks(e){let t=/```[\s\S]*?```/g,r=e,i;for(;(i=t.exec(e))!==null;){let n=i[0],s=n.split(`
|
|
40
40
|
`).slice(1,-1).join(`
|
|
41
|
-
`);
|
|
41
|
+
`);r=r.replace(n,s);}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
|
|
42
42
|
|
|
43
|
-
`),this}build(){return this.formattedCompletion}};var
|
|
44
|
-
`),s=
|
|
43
|
+
`),this}build(){return this.formattedCompletion}};var V=class{constructor(e){this.capacity=e;this.head=0;this.tail=0;this.size=0;this.buffer=new Array(e);}enqueue(e){let t;return this.size===this.capacity&&(t=this.dequeue()),this.buffer[this.tail]=e,this.tail=(this.tail+1)%this.capacity,this.size++,t}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 U=class U{constructor(){this.cache=new V(U.MAX_CACHE_SIZE);}get(e,t){return this.cache.getAll().filter(r=>this.isValidCacheItem(r,e,t))}add(e){this.cache.enqueue(e);}clear(){this.cache.clear();}isValidCacheItem(e,t,r){let i=r.getValueInRange(e.range),n=v(t,r);return n.length<e.textBeforeCursor.length||!n.startsWith(e.textBeforeCursor)?!1:this.isPositionValid(e,t,i)}isPositionValid(e,t,r){let{range:i,completion:n}=e,{startLineNumber:s,startColumn:m,endLineNumber:c,endColumn:l}=i,{lineNumber:p,column:a}=t;if(!n.startsWith(r))return !1;let u=p===s&&a===m;if(s===c)return u||p===s&&a>=m&&a<=l;let f=p>s&&p<c?!0:p===s&&a>=m||p===c&&a<=l;return u||f}};U.MAX_CACHE_SIZE=10;var j=U;var K=class{constructor(e){this.monaco=e;}computeInsertionRange(e,t,r){if(!t)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let i=r.getOffsetAt(e),n=r.getValue().substring(0,i),s=r.getValue().substring(i),m=0,c=0,l=0,p=0,a=t.length,u=n.length,f=s.length;if(i>=r.getValue().length)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);if(f===0)return new this.monaco.Range(e.lineNumber,e.column,e.lineNumber,e.column);let T=Math.min(a,u);for(let d=1;d<=T;d++){let b=t.substring(0,d),ge=n.slice(-d);b===ge&&(p=d);}let C=Math.min(a,f);for(let d=0;d<C&&t[d]===s[d];d++)m++;for(let d=1;d<=C;d++)t.slice(-d)===s.slice(0,d)&&(c=d);if(l=Math.max(m,c),l===0){for(let d=1;d<a;d++)if(s.startsWith(t.substring(d))){l=a-d;break}}let x=p>0?r.getPositionAt(i-p):e,y=i+l,h=r.getPositionAt(y);return new this.monaco.Range(x.lineNumber,x.column,h.lineNumber,h.column)}computeCacheRange(e,t){let r=e.lineNumber,i=e.column,n=t.split(`
|
|
44
|
+
`),s=n.length-1,m=r+s,c=s===0?i+n[0].length:n[s].length+1;return new this.monaco.Range(r,i,m,c)}};var ye="application/json",de=async o=>{let{endpoint:e,body:t}=o,{completion:r,error:i}=await F.POST(e,t,{headers:{"Content-Type":ye},fallbackError:"Error while fetching completion item"});if(i)throw new Error(i);return {completion:r}},ue=({pos:o,mdl:e,options:t})=>{let{filename:r,language:i,technologies:n,relatedFiles:s,maxContextLines:m}=t,c=Ee(o,e),p=!!s?.length?3:2,a=m?Math.floor(m/p):void 0,u=(y,h,d)=>{let b=y(o,e);return h?G(b,h,d):b},f=(y,h)=>!y||!h?y:y.map(({content:d,...b})=>({...b,content:G(d,h)})),T=u(v,a,{from:"end"}),C=u(J,a),x=f(s,a);return {filename:r,language:i,technologies:n,relatedFiles:x,textBeforeCursor:T,textAfterCursor:C,cursorPosition:o,editorState:{completionMode:c}}},Ee=(o,e)=>{let t=ie(o,e),r=J(o,e);return t?"insert":r.trim()?"complete":"continue"};var O=o=>({items:o,enableForwardStability:!0,suppressSuggestions:!0});var Te=o=>({onTyping:q(o,600,200),onIdle:q(o,600,400),onDemand:q(o,0,0)}),z=new j,xe=async({monaco:o,mdl:e,pos:t,token:r,isCompletionAccepted:i,options:n})=>{let{trigger:s="onIdle",endpoint:m,enableCaching:c=!0,onError:l,requestHandler:p}=n;if(c){let a=z.get(t,e).map(u=>({insertText:u.completion,range:u.range}));if(a.length>0)return O(a)}if(r.isCancellationRequested||i)return O([]);try{let u=Te(p??de)[s];r.onCancellationRequested(()=>{u.cancel();});let f=ue({pos:t,mdl:e,options:n}),{completion:T}=await u({endpoint:m,body:{completionMetadata:f}});if(T){let C=new H(T,t.column,se(t,e)).removeMarkdownCodeSyntax().removeExcessiveNewlines().removeInvalidLineBreaks().indentByColumn().build(),x=new K(o),y=x.computeInsertionRange(t,C,e),h=x.computeCacheRange(t,C);return c&&z.add({completion:C,range:h,textBeforeCursor:v(t,e)}),O([{insertText:C,range:y}])}}catch(a){if(be(a))return O([]);l?l(a):k("Cannot provide completion",a);}return O([])},be=o=>typeof o=="string"?o==="Cancelled"||o==="AbortError":o instanceof Error?o.message==="Cancelled"||o.name==="AbortError":!1,Ce=xe;var D=new WeakMap,A=null,ve=(o,e,t)=>{A&&A.deregister();let r=[],i={isCompletionAccepted:!1,isCompletionVisible:!1,isManualTrigger:!1};D.set(e,i),e.updateOptions({inlineSuggest:{enabled:!0,mode:"subwordSmart"}});try{let n=D.get(e);if(!n)return k("Completion is not registered properly. State not found."),{deregister:()=>{},trigger:()=>{}};let s=o.languages.registerInlineCompletionsProvider(t.language,{provideInlineCompletions:(l,p,a,u)=>{if(!(t.trigger==="onDemand"&&!n.isManualTrigger))return Ce({monaco:o,mdl:l,pos:p,token:u,isCompletionAccepted:n.isCompletionAccepted,options:t})},handleItemDidShow:(l,p,a)=>{n.isCompletionVisible=!0,n.isManualTrigger=!1,!n.isCompletionAccepted&&t.onCompletionShown?.(a,p.range);},freeInlineCompletions:()=>{}});r.push(s);let m=e.onKeyDown(l=>{let p=l.keyCode===o.KeyCode.Tab||l.keyCode===o.KeyCode.RightArrow&&l.metaKey;n.isCompletionVisible&&p?(t.onCompletionAccepted?.(),n.isCompletionAccepted=!0,n.isCompletionVisible=!1):n.isCompletionAccepted=!1;});r.push(m);let c={deregister:()=>{r.forEach(l=>l.dispose()),z.clear(),D.delete(e),A=null;},trigger:()=>Oe(e)};return A=c,c}catch(n){return t.onError?t.onError(n):$(n),{deregister:()=>{r.forEach(s=>s.dispose()),D.delete(e),A=null;},trigger:()=>{}}}},Oe=o=>{let e=D.get(o);if(!e){k("Completion is not registered. Use `registerCompletion` to register completion first.");return}e.isManualTrigger=!0,o.trigger("keyboard","editor.action.inlineSuggest.trigger",{});};
|
|
45
45
|
|
|
46
|
-
export {
|
|
46
|
+
export { Q as Copilot, ve as registerCompletion };
|