-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathclient.ts
151 lines (143 loc) · 5.98 KB
/
client.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
import "ace-code/esm-resolver";
import {AceLanguageClient} from "ace-linters/build/ace-language-client";
import {addFormatCommand, createEditorWithLSP} from "../utils";
import {jsContent} from "../docs-example/javascript-example";
import {LanguageClientConfig} from "ace-linters/types/types/language-service";
import {Ace} from "ace-code";
import {Autocomplete} from "ace-code/src/autocomplete";
import "ace-code/src/ext/inline_autocomplete";
let modes = [
{name: "javascript", mode: "ace/mode/javascript", content: jsContent},
]
const defaultGenerationConfiguration = {
"model": "model1",
"parameters": {
"max_tokens": 128,
"max_context": 1024,
"messages": [
{
"role": "system",
"content": "Instructions:\n- You are an AI programming assistant.\n- Given a piece of code with the cursor location marked by \"<CURSOR>\", replace \"<CURSOR>\" with the correct code or comment.\n- First, think step-by-step.\n- Describe your plan for what to build in pseudocode, written out in great detail.\n- Then output the code replacing the \"<CURSOR>\".\n- Ensure that your completion fits within the language context of the provided code snippet.\n\nRules:\n- Only respond with code or comments.\n- Only replace \"<CURSOR>\"; do not include any previously written code.\n- Never include \"<CURSOR>\" in your response.\n- If the cursor is within a comment, complete the comment meaningfully.\n- Handle ambiguous cases by providing the most contextually appropriate completion.\n- Be consistent with your responses."
},
{
"role": "user",
"content": "def greet(name):\n print(f\"Hello, {<CURSOR>}\")"
},
{
"role": "assistant",
"content": "name"
},
{
"role": "user",
"content": "function sum(a, b) {\n return a + <CURSOR>;\n}"
},
{
"role": "assistant",
"content": "b"
},
{
"role": "user",
"content": "fn multiply(a: i32, b: i32) -> i32 {\n a * <CURSOR>\n}"
},
{
"role": "assistant",
"content": "b"
},
{
"role": "user",
"content": "# <CURSOR>\ndef add(a, b):\n return a + b"
},
{
"role": "assistant",
"content": "Adds two numbers"
},
{
"role": "user",
"content": "# This function checks if a number is even\n<CURSOR>"
},
{
"role": "assistant",
"content": "def is_even(n):\n return n % 2 == 0"
},
{
"role": "user",
"content": "public class HelloWorld {\n public static void main(String[] args) {\n System.out.println(\"Hello, <CURSOR>\");\n }\n}"
},
{
"role": "assistant",
"content": "world"
},
{
"role": "user",
"content": "try:\n # Trying to open a file\n file = open(\"example.txt\", \"r\")\n # <CURSOR>\nfinally:\n file.close()"
},
{
"role": "assistant",
"content": "content = file.read()"
},
{
"role": "user",
"content": "#include <iostream>\nusing namespace std;\n\nint main() {\n int a = 5, b = 10;\n cout << \"Sum: \" << (a + <CURSOR>) << endl;\n return 0;\n}"
},
{
"role": "assistant",
"content": "b"
},
{
"role": "user",
"content": "<!DOCTYPE html>\n<html>\n<head>\n <title>My Page</title>\n</head>\n<body>\n <h1>Welcome to My Page</h1>\n <p>This is a sample page with a list of items:</p>\n <ul>\n <li>Item 1</li>\n <li>Item 2</li>\n <li><CURSOR></li>\n </ul>\n</body>\n</html>"
},
{
"role": "assistant",
"content": "Item 3"
},
{
"role": "user",
"content": "{CODE}"
}
]
}
}
// you will need OPENAI_API_KEY in env or use "auth_token" instead of "auth_token_env_var_name"
const defaultServerConfiguration =
{
"memory": {
"file_store": {}
},
"models": {
"model1": {
"type": "open_ai",
"chat_endpoint": "https://api.openai.com/v1/chat/completions",
"model": "gpt-3.5-turbo-0125",
"auth_token_env_var_name": "OPENAI_API_KEY"
}
},
"completion": {
...defaultGenerationConfiguration
}
}
const serverData: LanguageClientConfig = {
module: () => import("ace-linters/build/language-client"),
modes: "javascript",
type: "socket",
socket: new WebSocket("ws://localhost:3030/lsp-ai"),
initializationOptions: defaultServerConfiguration
}
let languageProvider = AceLanguageClient.for(serverData);
let editor = createEditorWithLSP(modes[0], 0, languageProvider);
//@ts-expect-error this should be added to ace declaration
editor.setOption("enableInlineAutocompletion", true);
editor.setOption("liveAutocompletionDelay", 500);
enableInnerAutocomplete(editor);
function enableInnerAutocomplete(editor: Ace.Editor) {
let originalAutocompleteCommand = editor.commands.byName.startAutocomplete.exec;
editor.commands.byName.startAutocomplete.exec = function (editor) {
var autocomplete = Autocomplete.for(editor);
autocomplete.getCompletionProvider().ignoreCaption = true;
autocomplete.inlineEnabled = true;
autocomplete.ignoreCaption = true;
// @ts-ignore
originalAutocompleteCommand(...arguments);
}
}
addFormatCommand(languageProvider);