-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain.js
377 lines (223 loc) · 13.8 KB
/
main.js
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
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
// RUNGPT
// PASSGPT?
// features:
// to add, internet access and help.
// allow attaching of debugger
// have separate user terminal and allow them to view bot in real time, or view summary
// change help functionality, show list of commands
// maybe increase temperature if program repetedly fails
// give GPT option to change it's own temperature
// allow GPT to edit terminal code?
// go back to the same step if pressing back
// I spoke to XYZ, and told him ABC. (when GPT speaks to another model)
// NOTE: We lookup by index, do we want to change this to lookup by id, so if an item is removed, we still refer to the same item.
// TODO: standardise IDS and indexes, 0 indexed or not, decide!
// var subtask = this.terminal.getSubTask(this.context.task_id, this.context.subtask_id)
// move canPrune outside message so openai can't view it
const conversation = require('./GPT/conversation');
const GPT = require('./GPT/gpt');
const VirtualTerminal = require('./VirtualTerminal/Terminal');
var gpt = new GPT();
var convo = gpt.newConversation();
async function main() {
this.shouldRun = true;
var currentTask = `
Create tasks and subtasks for writing a random word generator, then create it using the action menu.
You should update the tasks and subtasks as you complete them.
Create an initial maximum of 1 tasks and no sub tasks
Please test and execute the code using iterative development.
`
//var currentTask = "Navigate to the action pane, and overwrite the file test.py with a simple word generator"
const terminal = new VirtualTerminal(convo, currentTask)
convo.addUser(`
================
You are a programmer, you have access to a virtual terminal.
In this terminal, you can navigate menus to solve a given task.
In order to achieve this goal, you have been given access to a virtual terminal.
The task has been split up into steps and sub steps. You will focus on one sub step at a time to achieve the final goal.
The final goal: ${currentTask}
In order to avoid context window size limitations, you will attempt to achieve a smaller goal with each sub step.
The virtual terminal allows you to log what you have attempted, make notes and edit code.
GPT (you) have been provided this terminal to achieve a final goal
The virtual terminal features the following:
1) Steps - Each step is a smaller subtask towards a final goal.
4) Code - Provides a sub menu that allows you to run/edit/execute code from the virtual terminal.
5) Actions - View, edit and execute files from the virtual terminal.
The actions menu is a text based implementation of VSCode, (for reference a websocket connection has been setup with a VSCode instance, providing access to it's functionality)
list - This will list files in workspace directory.
view - This will view a specified file in the VirtualTerminal
overwrite - This will overwrite a file in the workspace with text specified within the command
diagnostic - This will use a connection to VSCode to debug .py and .js files in the workspace directory.
terminal - This will provide access to a real terminal, via a websocket integration, you should avoid interactive commands such as nano, as each command is run directly as input -> output
a) Accessing a real terminal - The VirtualTerminal exposes functionality to run commands, and get the output of a real terminal, and real environment.
b) This access to a real terminal is not interactive, and relies on direct input -> output. For this reason, avoid commands that require interaction such as nano, or vim, and instead use functionality provided to you.
c) You may use the real terminal in exceeding cases in which real terminal inteaction is required, such as running a file, or any other supplemental interaction.
- After completing significant parts of the goal, you should ALWAYS return to the main menu, and update tasks, subtasks.
- You should use the \`view\`, \`overwrite\`, and \`diagnostic\` virtual commands extensively to debug the code.
- \`view\` will view a file from the workspace.
- \`overwrite\` will overwrite a file with text specified in the command
- \`diagnostic\` will run diagnostics using ..................
You should revisit the terminal to refresh your knowledge to ensure the best outcome.
You will navigate this terminal to achieve an outcome, do not attempt the same command, or series of commands repeatedly, attempt a new decision.
Each reply should contain:
- A command surrounded by the pattern <contextgptcommand> and </contextgptcommand>.
An example would be:
<contextgptcommand>
help
</contextgptcommand>
which would show a help menu
- A explicit description of what you are deciding to do,
- An explicit description of what you are trying to do. Include reasoning as to why you are making the decision, problems you encounter, and what we should do to solve it.
- Where possible, please supply a minimum of 2 reasons behind your decision.
- Surround your descrition with <contextgptdescription> and </contextgptdescription>.
An example would be:
<contextgptdescription>
I will use the "help" command to see the available options in the main menu. This will give me a better understanding of the commands I can use.
</contextgptdescription>
If any part of the above is unclear before you begin using the Virtual Terminal, immediately type \`human\` and gain clarification about the goal/task/expected outcome
================
`, {dontPrune: true})
/*
2) Diary - The diary contains a list of each item you have already attempted (within other conversations).
3) Notes - You are encouraged to write notes for yourself. This should include comments, suggestions, views and useful advice for your future self.
*/
var terminalOutput = await terminal.run()
console.log(terminalOutput)
convo.addUser(terminalOutput)
while(shouldRun){
if(!terminal.hasTerminalEnded()){
await new Promise((done) => {
convo.compute().then(async (answer) => {
console.log(answer)
convo.addSystem(answer)
var action = findTagContent(answer, 'contextgptcommand')
var thought = findTagContent(answer, 'contextgptdescription')
if(thought.trim() && action.trim()){
console.log("\n".repeat(5))
console.log("GPT Terminal Command: ");
console.log("> \x1b[33m" + action + "\x1b[0m")
console.log("\n".repeat(1))
console.log('\x1b[32m' + "GPT Thought: " + thought + '\x1b[0m');
console.log("\n".repeat(1))
terminalOutput = terminal.run(action).then((terminalOutput) => {
console.log(terminalOutput)
convo.addUser(terminalOutput)
done()
})
} else {
convo.addUser(`
================
Your response did not contain the <contextgptcommand> and <contextgptdescription> tags.
- A command surrounded by the pattern <contextgptcommand> and </contextgptcommand>.
An example would be:
<contextgptcommand>
help
</contextgptcommand>
which would show a help menu
- A explicit description of what you are deciding to do,
- An explicit description of what you are trying to do. Include reasoning as to why you are making the decision, problems you encounter, and what we should do to solve it.
- Where possible, please supply a minimum of 2 reasons behind your decision.
- Surround your descrition with <contextgptdescription> and </contextgptdescription>.
An example would be:
<contextgptdescription>
I will use the "help" command to see the available options in the main menu. This will give me a better understanding of the commands I can use.
</contextgptdescription>
================\n\n `)
console.log(`\n<Error: GPT did not use asterisks, asking GPT to repeat message>\n`)
done()
}
}).catch(async (err) => {
if(!err.gpt_error){
console.log(err)
process.exit()
}
if(err.error_code == 'context_length_exceeded'){
console.log("\n".repeat(10))
convo.pruneConversation()
var pruneMessage = '\n'.repeat(10) + `
! xxxxx ! ================ ! xxxxx !
The context window was exceeded, earlier messages were pruned.
Use \`diary\` for actions attempted before pruning.
! xxxxx ! ================ ! xxxxx !\n\n `.split('\n').map(line => line.trimStart()).join('\n')
console.log(pruneMessage)
convo.addUser(pruneMessage)
done()
} else {
console.log("Unknown error in main.js, not resolving promise.")
console.log(err)
}
})
})
}
//await new Promise(r => setTimeout(r, 2000));
}
}
main();
function findTagContent(text, tag) {
// Constructing the regex pattern to find the specified tag and its content
const pattern = new RegExp(`<${tag}>(.*?)</${tag}>`, 'gs');
// Using regex to find all occurrences of the pattern in the text
const matches = [];
let match;
while ((match = pattern.exec(text)) !== null) {
matches.push(match[1]);
}
if(matches.length == 0){
return ""
} else {
return matches[0]
}
}
/*
maybe give gpt the option to do it's own pruning - ADD TO DOC
add diary to every sub menu
add observer which watches actions in menu, and makes suggestions in notes. this will prevent loops. if hasn't visited main menu in a while, then run code to check it
CHANGE MAIN GOAL
- 1. OUTLINE PROGRAM
- 2. WRITE PROGRAM... testing ...
get GPT to write psuedo code, then create functions that should call each other.
*/
// add objectives too.
// when a task is checked off, change objectives/goals
// GPT should be able to change CURRENT OBJECTIVE
// reset to main menu every 60 seconds in case of hard stuck state.
// gpt-4, we can reset whole conversation history without pruning to prevent hallucinations - which do exist.
// allow got to find alternative solution
// add ability for GPT to view complete pruned conversation history
// maybe allow gpt to talk to it's future self after pruning
/*
terminal.switchTo('mainmenu')
var terminalOutput = await terminal.run()
console.log(terminalOutput)
convo.addUser(terminalOutput)
*/
// INTERACTION
//Screen Readers: These are software programs that help the visually impaired by reading out loud the text that is displayed on the screen. For Windows, popular screen readers include Narrator (built into Windows) and third-party applications like JAWS (Job Access With Speech) and NVDA (NonVisual Desktop Access).
//Keyboard Shortcuts and Accessibility Features: Windows includes various keyboard shortcuts that make navigation easier without a mouse. Additionally, there are accessibility features like Sticky Keys, Filter Keys, and Toggle Keys that help users with limited dexterity.
// Use NVDA (NonVisual Desktop Access) for reading the screen, and returning data to AI.
// add thought to diary, or maybe just use thought as diary?
// maybe keep a cost of how many tokens have been used up, and how many will be used when making commits?
// gpt has suggested undo feature, search and filter of subtasks and tasks.
// more details help menu
// GOOD SOLUTION::
// observation, explination, solution
// terminal should show a list of files and their purposes...?
// change Final Goal to CURRENT TASK
// strategy for each global task.
// ex. rename every function
// change prompt, create tasks for each function
// maybe start program with human<->gpt interaction, and see what to create from there
// Max tasks page
// Objectives trigger changing of tasks
// change variance llm paramtwe to repeat same output less
// make got also describe output each time
// maybe give gpt option to start task in task menu
// when task is complete loop back to tasks view - remove main menu?
// inform GPT that subtasks must contain all steps of task
// inform GPT about use of real terminal
// add task information to actionsmenu
// directive
// prompt question on action failure/task end. why do you think this failsd, what would be the solution
// give GPT the option to set it's own preferences.
// ie. Next time I'd like to use Python 3.7, GPT can set this preference within the terminal, and have it reiterated in the prompt
// find metric for "what worked last time"