summaryrefslogtreecommitdiff
path: root/continuedev
diff options
context:
space:
mode:
Diffstat (limited to 'continuedev')
-rw-r--r--continuedev/src/continuedev/core/autopilot.py11
-rw-r--r--continuedev/src/continuedev/core/main.py1
-rw-r--r--continuedev/src/continuedev/server/gui.py7
-rw-r--r--continuedev/src/continuedev/steps/core/core.py83
4 files changed, 68 insertions, 34 deletions
diff --git a/continuedev/src/continuedev/core/autopilot.py b/continuedev/src/continuedev/core/autopilot.py
index 313ceded..29be3b79 100644
--- a/continuedev/src/continuedev/core/autopilot.py
+++ b/continuedev/src/continuedev/core/autopilot.py
@@ -69,7 +69,8 @@ class Autopilot(ContinueBaseModel):
user_input_queue=self._main_user_input_queue,
default_model=self.continue_sdk.config.default_model,
highlighted_ranges=self._highlighted_ranges,
- slash_commands=self.get_available_slash_commands()
+ slash_commands=self.get_available_slash_commands(),
+ adding_highlighted_code=self._adding_highlighted_code,
)
def get_available_slash_commands(self) -> List[Dict]:
@@ -140,8 +141,12 @@ class Autopilot(ContinueBaseModel):
await self._run_singular_step(step)
_highlighted_ranges: List[RangeInFileWithContents] = []
+ _adding_highlighted_code: bool = False
async def handle_highlighted_code(self, range_in_files: List[RangeInFileWithContents]):
+ if not self._adding_highlighted_code:
+ return
+
workspace_path = self.continue_sdk.ide.workspace_directory
for rif in range_in_files:
rif.filepath = os.path.basename(rif.filepath)
@@ -186,6 +191,10 @@ class Autopilot(ContinueBaseModel):
self._highlighted_ranges = kept_ranges
await self.update_subscribers()
+ async def toggle_adding_highlighted_code(self):
+ self._adding_highlighted_code = not self._adding_highlighted_code
+ await self.update_subscribers()
+
async def _run_singular_step(self, step: "Step", is_future_step: bool = False) -> Coroutine[Observation, None, None]:
# Allow config to set disallowed steps
if step.__class__.__name__ in self.continue_sdk.config.disallowed_steps:
diff --git a/continuedev/src/continuedev/core/main.py b/continuedev/src/continuedev/core/main.py
index 8bad09d1..28fd964e 100644
--- a/continuedev/src/continuedev/core/main.py
+++ b/continuedev/src/continuedev/core/main.py
@@ -207,6 +207,7 @@ class FullState(ContinueBaseModel):
default_model: str
highlighted_ranges: List[RangeInFileWithContents]
slash_commands: List[SlashCommandDescription]
+ adding_highlighted_code: bool
class ContinueSDK:
diff --git a/continuedev/src/continuedev/server/gui.py b/continuedev/src/continuedev/server/gui.py
index 4e960f7c..fa573b37 100644
--- a/continuedev/src/continuedev/server/gui.py
+++ b/continuedev/src/continuedev/server/gui.py
@@ -85,6 +85,8 @@ class GUIProtocolServer(AbstractGUIProtocolServer):
self.on_delete_at_index(data["index"])
elif message_type == "delete_context_at_indices":
self.on_delete_context_at_indices(data["indices"])
+ elif message_type == "toggle_adding_highlighted_code":
+ self.on_toggle_adding_highlighted_code()
except Exception as e:
print(e)
@@ -128,6 +130,11 @@ class GUIProtocolServer(AbstractGUIProtocolServer):
self.session.autopilot.delete_context_at_indices(indices)
)
+ def on_toggle_adding_highlighted_code(self):
+ asyncio.create_task(
+ self.session.autopilot.toggle_adding_highlighted_code()
+ )
+
@router.websocket("/ws")
async def websocket_endpoint(websocket: WebSocket, session: Session = Depends(websocket_session)):
diff --git a/continuedev/src/continuedev/steps/core/core.py b/continuedev/src/continuedev/steps/core/core.py
index b9f0da35..c74412ba 100644
--- a/continuedev/src/continuedev/steps/core/core.py
+++ b/continuedev/src/continuedev/steps/core/core.py
@@ -286,6 +286,7 @@ class DefaultModelEditCodeStep(Step):
return "```" in line or "<modified_code_to_edit>" in line or "<file_prefix>" in line or "</file_prefix>" in line or "<file_suffix>" in line or "</file_suffix>" in line or "<user_request>" in line or "</user_request>" in line or "<code_to_edit>" in line
async def stream_rif(self, rif: RangeInFileWithContents, sdk: ContinueSDK):
+ await sdk.ide.saveFile(rif.filepath)
full_file_contents = await sdk.ide.readFile(rif.filepath)
file_prefix, contents, file_suffix, model_to_use = await self.get_prompt_parts(
@@ -295,6 +296,17 @@ class DefaultModelEditCodeStep(Step):
prompt = self.compile_prompt(file_prefix, contents, file_suffix, sdk)
full_file_contents_lines = full_file_contents.split("\n")
+ async def sendDiffUpdate(lines: List[str], sdk: ContinueSDK):
+ nonlocal full_file_contents_lines, rif
+
+ completion = "\n".join(lines)
+
+ full_prefix_lines = full_file_contents_lines[:rif.range.start.line]
+ full_suffix_lines = full_file_contents_lines[rif.range.end.line + 1:]
+ new_file_contents = "\n".join(
+ full_prefix_lines) + "\n" + completion + "\n" + "\n".join(full_suffix_lines)
+ await sdk.ide.showDiff(rif.filepath, new_file_contents)
+
# Important state variables
# -------------------------
original_lines = [] if rif.contents == "" else rif.contents.split("\n")
@@ -435,16 +447,16 @@ class DefaultModelEditCodeStep(Step):
chunk_lines.pop() # because this will be an empty string
else:
unfinished_line = chunk_lines.pop()
- lines.extend(chunk_lines)
+ lines.extend(map(lambda l: common_whitespace + l, chunk_lines))
+
+ if True:
+ await sendDiffUpdate(lines, sdk)
# Deal with newly accumulated lines
for line in chunk_lines:
# Trailing whitespace doesn't matter
line = line.rstrip()
- # Add the common whitespace that was removed before prompting
- line = common_whitespace + line
-
# Lines that should signify the end of generation
if self.is_end_line(line):
break
@@ -463,7 +475,9 @@ class DefaultModelEditCodeStep(Step):
break
# If none of the above, insert the line!
- await handle_generated_line(line)
+ if False:
+ await handle_generated_line(line)
+
completion_lines_covered += 1
current_line_in_file += 1
@@ -475,34 +489,37 @@ class DefaultModelEditCodeStep(Step):
completion_lines_covered += 1
current_line_in_file += 1
- # If the current block isn't empty, add that suggestion
- if len(current_block_lines) > 0:
- # We have a chance to back-track here for blank lines that are repeats of the end of the original
- # Don't want to have the same ending in both the original and the generated, can just leave it there
- num_to_remove = 0
- for i in range(-1, -len(current_block_lines) - 1, -1):
- if len(original_lines_below_previous_blocks) == 0:
- break
- if current_block_lines[i] == original_lines_below_previous_blocks[-1]:
- num_to_remove += 1
- original_lines_below_previous_blocks.pop()
- else:
- break
- current_block_lines = current_block_lines[:-
- num_to_remove] if num_to_remove > 0 else current_block_lines
-
- # It's also possible that some lines match at the beginning of the block
- # while len(current_block_lines) > 0 and len(original_lines_below_previous_blocks) > 0 and current_block_lines[0] == original_lines_below_previous_blocks[0]:
- # current_block_lines.pop(0)
- # original_lines_below_previous_blocks.pop(0)
- # current_block_start += 1
-
- await sdk.ide.showSuggestion(FileEdit(
- filepath=rif.filepath,
- range=Range.from_shorthand(
- current_block_start, 0, current_block_start + len(original_lines_below_previous_blocks), 0),
- replacement="\n".join(current_block_lines)
- ))
+ await sendDiffUpdate(lines, sdk)
+
+ if False:
+ # If the current block isn't empty, add that suggestion
+ if len(current_block_lines) > 0:
+ # We have a chance to back-track here for blank lines that are repeats of the end of the original
+ # Don't want to have the same ending in both the original and the generated, can just leave it there
+ num_to_remove = 0
+ for i in range(-1, -len(current_block_lines) - 1, -1):
+ if len(original_lines_below_previous_blocks) == 0:
+ break
+ if current_block_lines[i] == original_lines_below_previous_blocks[-1]:
+ num_to_remove += 1
+ original_lines_below_previous_blocks.pop()
+ else:
+ break
+ current_block_lines = current_block_lines[:-
+ num_to_remove] if num_to_remove > 0 else current_block_lines
+
+ # It's also possible that some lines match at the beginning of the block
+ # while len(current_block_lines) > 0 and len(original_lines_below_previous_blocks) > 0 and current_block_lines[0] == original_lines_below_previous_blocks[0]:
+ # current_block_lines.pop(0)
+ # original_lines_below_previous_blocks.pop(0)
+ # current_block_start += 1
+
+ await sdk.ide.showSuggestion(FileEdit(
+ filepath=rif.filepath,
+ range=Range.from_shorthand(
+ current_block_start, 0, current_block_start + len(original_lines_below_previous_blocks), 0),
+ replacement="\n".join(current_block_lines)
+ ))
# Record the completion
completion = "\n".join(lines)