diff options
| author | Nate Sesti <sestinj@gmail.com> | 2023-08-01 14:25:33 -0700 | 
|---|---|---|
| committer | Nate Sesti <sestinj@gmail.com> | 2023-08-01 14:25:33 -0700 | 
| commit | 74a52c8399b3ccf2d2100b088b79e65c6ca6ad7e (patch) | |
| tree | c9cd4ab8e42990ca90de244578f0c0e51fe29008 | |
| parent | fe1b9265a631f3ce5ace109d1eac6716b1fe2eb6 (diff) | |
| download | sncontinue-74a52c8399b3ccf2d2100b088b79e65c6ca6ad7e.tar.gz sncontinue-74a52c8399b3ccf2d2100b088b79e65c6ca6ad7e.tar.bz2 sncontinue-74a52c8399b3ccf2d2100b088b79e65c6ca6ad7e.zip | |
fix: :bug: bug when highlighting code prior to context_manager creation
| -rw-r--r-- | continuedev/src/continuedev/core/autopilot.py | 6 | ||||
| -rw-r--r-- | continuedev/src/continuedev/core/context.py | 17 | ||||
| -rw-r--r-- | extension/package-lock.json | 4 | ||||
| -rw-r--r-- | extension/package.json | 2 | 
4 files changed, 16 insertions, 13 deletions
| diff --git a/continuedev/src/continuedev/core/autopilot.py b/continuedev/src/continuedev/core/autopilot.py index d92c51cd..99b9185f 100644 --- a/continuedev/src/continuedev/core/autopilot.py +++ b/continuedev/src/continuedev/core/autopilot.py @@ -54,7 +54,7 @@ class Autopilot(ContinueBaseModel):      history: History = History.from_empty()      context: Context = Context()      full_state: Union[FullState, None] = None -    context_manager: Union[ContextManager, None] = None +    context_manager: ContextManager = ContextManager()      continue_sdk: ContinueSDK = None      _on_update_callbacks: List[Callable[[FullState], None]] = [] @@ -72,7 +72,7 @@ class Autopilot(ContinueBaseModel):              self.policy = override_policy          # Load documents into the search index -        self.context_manager = await ContextManager.create( +        await self.context_manager.start(              self.continue_sdk.config.context_providers + [                  HighlightedCodeContextProvider(ide=self.ide),                  FileContextProvider(workspace_dir=self.ide.workspace_directory) @@ -98,7 +98,7 @@ class Autopilot(ContinueBaseModel):              user_input_queue=self._main_user_input_queue,              slash_commands=self.get_available_slash_commands(),              adding_highlighted_code=self.context_manager.context_providers[ -                "code"].adding_highlighted_code if self.context_manager is not None else False, +                "code"].adding_highlighted_code if "code" in self.context_manager.context_providers else False,              selected_context_items=await self.context_manager.get_selected_items() if self.context_manager is not None else [],          )          self.full_state = full_state diff --git a/continuedev/src/continuedev/core/context.py b/continuedev/src/continuedev/core/context.py index e968c35c..3f5f6fd3 100644 --- a/continuedev/src/continuedev/core/context.py +++ b/continuedev/src/continuedev/core/context.py @@ -133,14 +133,19 @@ class ContextManager:          """          return sum([await provider.get_chat_messages() for provider in self.context_providers.values()], []) -    def __init__(self, context_providers: List[ContextProvider]): +    def __init__(self): +        self.context_providers = {} +        self.provider_titles = set() + +    async def start(self, context_providers: List[ContextProvider]): +        """ +        Starts the context manager. +        """          self.context_providers = {              prov.title: prov for prov in context_providers}          self.provider_titles = {              provider.title for provider in context_providers} -    @classmethod -    async def create(cls, context_providers: List[ContextProvider]):          async with Client('http://localhost:7700') as search_client:              meilisearch_running = True              try: @@ -154,10 +159,8 @@ class ContextManager:              if not meilisearch_running:                  logger.warning(                      "MeiliSearch not running, avoiding any dependent context providers") -                context_providers = list( -                    filter(lambda cp: cp.title == "code", context_providers)) - -        return cls(context_providers) +                self.context_providers = list( +                    filter(lambda cp: cp.title == "code", self.context_providers))      async def load_index(self, workspace_dir: str):          for _, provider in self.context_providers.items(): diff --git a/extension/package-lock.json b/extension/package-lock.json index 4c5b6263..abca8d98 100644 --- a/extension/package-lock.json +++ b/extension/package-lock.json @@ -1,12 +1,12 @@  {    "name": "continue", -  "version": "0.0.234", +  "version": "0.0.235",    "lockfileVersion": 2,    "requires": true,    "packages": {      "": {        "name": "continue", -      "version": "0.0.234", +      "version": "0.0.235",        "license": "Apache-2.0",        "dependencies": {          "@electron/rebuild": "^3.2.10", diff --git a/extension/package.json b/extension/package.json index 42c0d382..15e7676d 100644 --- a/extension/package.json +++ b/extension/package.json @@ -14,7 +14,7 @@    "displayName": "Continue",    "pricing": "Free",    "description": "The open-source coding autopilot", -  "version": "0.0.234", +  "version": "0.0.235",    "publisher": "Continue",    "engines": {      "vscode": "^1.67.0" | 
