summaryrefslogtreecommitdiff
path: root/continuedev/src/continuedev/libs/steps/main.py
diff options
context:
space:
mode:
authorNate Sesti <33237525+sestinj@users.noreply.github.com>2023-05-27 18:35:51 -0400
committerGitHub <noreply@github.com>2023-05-27 18:35:51 -0400
commit5a14b71a3939f99c60f64b44683ed26c91677d0f (patch)
tree2eed99c3d64d4b2c594faba058545d0b3d09142f /continuedev/src/continuedev/libs/steps/main.py
parent0877ada8ed9f71f3ee792bcb34a4005e3c86827d (diff)
parent2015ab818405e290548c4e201fcbb4d2cb81ca8c (diff)
downloadsncontinue-5a14b71a3939f99c60f64b44683ed26c91677d0f.tar.gz
sncontinue-5a14b71a3939f99c60f64b44683ed26c91677d0f.tar.bz2
sncontinue-5a14b71a3939f99c60f64b44683ed26c91677d0f.zip
Merge pull request #11 from continuedev/syntactic-sugar
Syntactic sugar
Diffstat (limited to 'continuedev/src/continuedev/libs/steps/main.py')
-rw-r--r--continuedev/src/continuedev/libs/steps/main.py149
1 files changed, 26 insertions, 123 deletions
diff --git a/continuedev/src/continuedev/libs/steps/main.py b/continuedev/src/continuedev/libs/steps/main.py
index 70953e95..f28cb23f 100644
--- a/continuedev/src/continuedev/libs/steps/main.py
+++ b/continuedev/src/continuedev/libs/steps/main.py
@@ -1,18 +1,39 @@
-import time
from typing import Callable, Coroutine, List, Union
+from ..util.traceback_parsers import parse_python_traceback
from ..llm import LLM
from ...models.main import Traceback, Range
from ...models.filesystem_edit import EditDiff, FileEdit
from ...models.filesystem import RangeInFile, RangeInFileWithContents
-from ..observation import Observation, TextObservation
+from ...core.observation import Observation, TextObservation, TracebackObservation
from ..llm.prompt_utils import MarkdownStyleEncoderDecoder
from textwrap import dedent
-from ..core import History, Policy, Step, ContinueSDK, Observation
+from ...core.main import History, Policy, Step, ContinueSDK, Observation
import subprocess
-from ..util.traceback_parsers import parse_python_traceback
-from ..observation import TracebackObservation
import json
+from .core.core import EditCodeStep
+
+
+class RunCodeStep(Step):
+ cmd: str
+
+ async def describe(self, llm: LLM) -> Coroutine[str, None, None]:
+ return f"Ran command: `{self.cmd}`"
+
+ async def run(self, sdk: ContinueSDK) -> Coroutine[Observation, None, None]:
+ result = subprocess.run(
+ self.cmd.split(), stdout=subprocess.PIPE, stderr=subprocess.PIPE)
+ stdout = result.stdout.decode("utf-8")
+ stderr = result.stderr.decode("utf-8")
+ print(stdout, stderr)
+
+ # If it fails, return the error
+ tb = parse_python_traceback(stdout) or parse_python_traceback(stderr)
+ if tb:
+ return TracebackObservation(traceback=tb)
+ else:
+ self.hide = True
+ return None
class RunPolicyUntilDoneStep(Step):
@@ -51,124 +72,6 @@ class RunCommandStep(Step):
return TextObservation(text=stdout)
-class WaitForUserInputStep(Step):
- prompt: str
- name: str = "Waiting for user input"
-
- _description: Union[str, None] = None
-
- async def describe(self, llm: LLM) -> Coroutine[str, None, None]:
- return self.prompt
-
- async def run(self, sdk: ContinueSDK) -> Coroutine[Observation, None, None]:
- self._description = self.prompt
- resp = await sdk.wait_for_user_input()
- return TextObservation(text=resp)
-
-
-class WaitForUserConfirmationStep(Step):
- prompt: str
- name: str = "Waiting for user confirmation"
-
- async def describe(self, llm: LLM) -> Coroutine[str, None, None]:
- return self.prompt
-
- async def run(self, sdk: ContinueSDK) -> Coroutine[Observation, None, None]:
- self._description = self.prompt
- resp = await sdk.wait_for_user_input()
- return TextObservation(text=resp)
-
-
-class RunCodeStep(Step):
- cmd: str
-
- async def describe(self, llm: LLM) -> Coroutine[str, None, None]:
- return f"Ran command: `{self.cmd}`"
-
- async def run(self, sdk: ContinueSDK) -> Coroutine[Observation, None, None]:
- result = subprocess.run(
- self.cmd.split(), stdout=subprocess.PIPE, stderr=subprocess.PIPE)
- stdout = result.stdout.decode("utf-8")
- stderr = result.stderr.decode("utf-8")
- print(stdout, stderr)
-
- # If it fails, return the error
- tb = parse_python_traceback(stdout) or parse_python_traceback(stderr)
- if tb:
- return TracebackObservation(traceback=tb)
- else:
- self.hide = True
- return None
-
-
-class EditCodeStep(Step):
- # Might make an even more specific atomic step, which is "apply file edit"
- range_in_files: List[RangeInFile]
- prompt: str # String with {code} somewhere
- name: str = "Edit code"
-
- _edit_diffs: Union[List[EditDiff], None] = None
- _prompt: Union[str, None] = None
- _completion: Union[str, None] = None
-
- async def describe(self, llm: LLM) -> Coroutine[str, None, None]:
- if self._edit_diffs is None:
- return "Editing files: " + ", ".join(map(lambda rif: rif.filepath, self.range_in_files))
- elif len(self._edit_diffs) == 0:
- return "No edits made"
- else:
- return llm.complete(dedent(f"""{self._prompt}{self._completion}
-
- Maximally concise summary of changes in bullet points (can use markdown):
- """))
-
- async def run(self, sdk: ContinueSDK) -> Coroutine[Observation, None, None]:
- rif_with_contents = []
- for range_in_file in self.range_in_files:
- file_contents = await sdk.ide.readRangeInFile(range_in_file)
- rif_with_contents.append(
- RangeInFileWithContents.from_range_in_file(range_in_file, file_contents))
- enc_dec = MarkdownStyleEncoderDecoder(rif_with_contents)
- code_string = enc_dec.encode()
- prompt = self.prompt.format(code=code_string)
-
- completion = sdk.llm.complete(prompt)
-
- # Temporarily doing this to generate description.
- self._prompt = prompt
- self._completion = completion
-
- file_edits = enc_dec.decode(completion)
-
- self._edit_diffs = []
- for file_edit in file_edits:
- diff = await sdk.apply_filesystem_edit(file_edit)
- self._edit_diffs.append(diff)
-
- for filepath in set([file_edit.filepath for file_edit in file_edits]):
- await sdk.ide.saveFile(filepath)
- await sdk.ide.setFileOpen(filepath)
-
- return None
-
-
-class EditFileStep(Step):
- filepath: str
- prompt: str
- hide: bool = True
-
- async def describe(self, llm: LLM) -> Coroutine[str, None, None]:
- return "Editing file: " + self.filepath
-
- async def run(self, sdk: ContinueSDK) -> Coroutine[Observation, None, None]:
- file_contents = await sdk.ide.readFile(self.filepath)
- await sdk.run_step(EditCodeStep(
- range_in_files=[RangeInFile.from_entire_file(
- self.filepath, file_contents)],
- prompt=self.prompt
- ))
-
-
class FasterEditHighlightedCodeStep(Step):
user_input: str
hide = True