code-puppy 0.0.158__tar.gz → 0.0.160__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {code_puppy-0.0.158 → code_puppy-0.0.160}/PKG-INFO +1 -1
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/config.py +13 -8
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/messaging/queue_console.py +3 -2
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tools/file_modifications.py +22 -14
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/components/chat_view.py +38 -21
- {code_puppy-0.0.158 → code_puppy-0.0.160}/pyproject.toml +1 -1
- {code_puppy-0.0.158 → code_puppy-0.0.160}/.gitignore +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/LICENSE +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/README.md +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/__init__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/__main__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/agent.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/agents/__init__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/agents/agent_code_puppy.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/agents/agent_creator_agent.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/agents/agent_manager.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/agents/agent_orchestrator.json +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/agents/base_agent.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/agents/json_agent.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/agents/runtime_manager.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/callbacks.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/__init__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/command_handler.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/file_path_completion.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/load_context_completion.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/__init__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/add_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/base.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/handler.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/help_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/install_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/list_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/logs_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/remove_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/restart_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/search_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/start_all_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/start_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/status_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/stop_all_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/stop_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/test_command.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/utils.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/mcp/wizard_utils.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/meta_command_handler.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/model_picker_completion.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/motd.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/prompt_toolkit_completion.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/utils.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/http_utils.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/main.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/__init__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/async_lifecycle.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/blocking_startup.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/captured_stdio_server.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/circuit_breaker.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/config_wizard.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/dashboard.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/error_isolation.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/examples/retry_example.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/health_monitor.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/managed_server.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/manager.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/registry.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/retry_manager.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/server_registry_catalog.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/status_tracker.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/mcp/system_tools.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/message_history_processor.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/messaging/__init__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/messaging/message_queue.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/messaging/renderers.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/messaging/spinner/__init__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/messaging/spinner/console_spinner.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/messaging/spinner/spinner_base.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/messaging/spinner/textual_spinner.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/model_factory.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/models.json +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/plugins/__init__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/reopenable_async_client.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/round_robin_model.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/state_management.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/status_display.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/summarization_agent.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tools/__init__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tools/agent_tools.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tools/command_runner.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tools/common.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tools/file_operations.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tools/tools_content.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/__init__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/app.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/components/__init__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/components/command_history_modal.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/components/copy_button.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/components/custom_widgets.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/components/human_input_modal.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/components/input_area.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/components/sidebar.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/components/status_bar.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/messages.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/models/__init__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/models/chat_message.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/models/command_history.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/models/enums.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/screens/__init__.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/screens/help.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/screens/mcp_install_wizard.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/screens/settings.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/screens/tools.py +0 -0
- {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/version_checker.py +0 -0
| @@ -164,7 +164,7 @@ _default_model_cache = None | |
| 164 164 | 
             
            def _default_model_from_models_json():
         | 
| 165 165 | 
             
                """Attempt to load the first model name from models.json.
         | 
| 166 166 |  | 
| 167 | 
            -
                Falls back to the hard-coded default (`` | 
| 167 | 
            +
                Falls back to the hard-coded default (``gpt-5``) if the file
         | 
| 168 168 | 
             
                cannot be read for any reason or is empty.
         | 
| 169 169 | 
             
                """
         | 
| 170 170 | 
             
                global _default_model_cache
         | 
| @@ -178,11 +178,17 @@ def _default_model_from_models_json(): | |
| 178 178 | 
             
                    from code_puppy.model_factory import ModelFactory
         | 
| 179 179 |  | 
| 180 180 | 
             
                    models_config = ModelFactory.load_config()
         | 
| 181 | 
            -
                     | 
| 182 | 
            -
             | 
| 183 | 
            -
             | 
| 181 | 
            +
                    if models_config:
         | 
| 182 | 
            +
                        # Get the first key from the models config
         | 
| 183 | 
            +
                        first_key = next(iter(models_config))
         | 
| 184 | 
            +
                        _default_model_cache = first_key
         | 
| 185 | 
            +
                        return first_key
         | 
| 186 | 
            +
                    else:
         | 
| 187 | 
            +
                        # If models_config is empty, fall back to gpt-5
         | 
| 188 | 
            +
                        _default_model_cache = "gpt-5"
         | 
| 189 | 
            +
                        return "gpt-5"
         | 
| 184 190 | 
             
                except Exception:
         | 
| 185 | 
            -
                    # Any problem (network, file missing, empty dict, etc.) => fall back
         | 
| 191 | 
            +
                    # Any problem (network, file missing, empty dict, etc.) => fall back to gpt-5
         | 
| 186 192 | 
             
                    _default_model_cache = "gpt-5"
         | 
| 187 193 | 
             
                    return "gpt-5"
         | 
| 188 194 |  | 
| @@ -198,8 +204,7 @@ def _validate_model_exists(model_name: str) -> bool: | |
| 198 204 | 
             
                try:
         | 
| 199 205 | 
             
                    from code_puppy.model_factory import ModelFactory
         | 
| 200 206 |  | 
| 201 | 
            -
                     | 
| 202 | 
            -
                    models_config = ModelFactory.load_config(models_config_path)
         | 
| 207 | 
            +
                    models_config = ModelFactory.load_config()
         | 
| 203 208 | 
             
                    exists = model_name in models_config
         | 
| 204 209 |  | 
| 205 210 | 
             
                    # Cache the result
         | 
| @@ -487,4 +492,4 @@ def save_command_to_history(command: str): | |
| 487 492 | 
             
                    error_msg = (
         | 
| 488 493 | 
             
                        f"❌ An unexpected error occurred while saving command history: {str(e)}"
         | 
| 489 494 | 
             
                    )
         | 
| 490 | 
            -
                    direct_console.print(f"[bold red]{error_msg}[/bold red]")
         | 
| 495 | 
            +
                    direct_console.print(f"[bold red]{error_msg}[/bold red]")
         | 
| @@ -58,9 +58,10 @@ class QueueConsole: | |
| 58 58 | 
             
                                from rich.console import Console
         | 
| 59 59 |  | 
| 60 60 | 
             
                                string_io = StringIO()
         | 
| 61 | 
            -
                                # Use markup= | 
| 61 | 
            +
                                # Use markup=True to properly process rich styling
         | 
| 62 | 
            +
                                # Use a reasonable width to prevent wrapping issues
         | 
| 62 63 | 
             
                                temp_console = Console(
         | 
| 63 | 
            -
                                    file=string_io, width=80, legacy_windows=False, markup= | 
| 64 | 
            +
                                    file=string_io, width=80, legacy_windows=False, markup=True
         | 
| 64 65 | 
             
                                )
         | 
| 65 66 | 
             
                                temp_console.print(v)
         | 
| 66 67 | 
             
                                processed_values.append(string_io.getvalue().rstrip("\n"))
         | 
| @@ -525,23 +525,31 @@ def register_file_modifications_tools(agent): | |
| 525 525 | 
             
                    """
         | 
| 526 526 | 
             
                    # Generate group_id for edit_file tool execution
         | 
| 527 527 | 
             
                    if isinstance(payload, str):
         | 
| 528 | 
            -
                         | 
| 529 | 
            -
             | 
| 530 | 
            -
             | 
| 531 | 
            -
                             | 
| 532 | 
            -
             | 
| 533 | 
            -
                             | 
| 534 | 
            -
             | 
| 535 | 
            -
                             | 
| 536 | 
            -
             | 
| 537 | 
            -
                             | 
| 538 | 
            -
             | 
| 539 | 
            -
                                file_path  | 
| 528 | 
            +
                        try:
         | 
| 529 | 
            +
                            # Fallback for weird models that just can't help but send json strings...
         | 
| 530 | 
            +
                            payload = json.loads(json_repair.repair_json(payload))
         | 
| 531 | 
            +
                            if "replacements" in payload:
         | 
| 532 | 
            +
                                payload = ReplacementsPayload(**payload)
         | 
| 533 | 
            +
                            elif "delete_snippet" in payload:
         | 
| 534 | 
            +
                                payload = DeleteSnippetPayload(**payload)
         | 
| 535 | 
            +
                            elif "content" in payload:
         | 
| 536 | 
            +
                                payload = ContentPayload(**payload)
         | 
| 537 | 
            +
                            else:
         | 
| 538 | 
            +
                                file_path = "Unknown"
         | 
| 539 | 
            +
                                if "file_path" in payload:
         | 
| 540 | 
            +
                                    file_path = payload["file_path"]
         | 
| 541 | 
            +
                                return {
         | 
| 542 | 
            +
                                    "success": False,
         | 
| 543 | 
            +
                                    "path": file_path,
         | 
| 544 | 
            +
                                    "message": "One of 'content', 'replacements', or 'delete_snippet' must be provided in payload.",
         | 
| 545 | 
            +
                                    "changed": False,
         | 
| 546 | 
            +
                                }
         | 
| 547 | 
            +
                        except Exception as e:
         | 
| 540 548 | 
             
                            return {
         | 
| 541 549 | 
             
                                "success": False,
         | 
| 542 550 | 
             
                                "path": file_path,
         | 
| 543 | 
            -
                                "message": " | 
| 544 | 
            -
                                "changed": False | 
| 551 | 
            +
                                "message": f"edit_file call failed: {str(e)}",
         | 
| 552 | 
            +
                                "changed": False
         | 
| 545 553 | 
             
                            }
         | 
| 546 554 | 
             
                    group_id = generate_group_id("edit_file", payload.file_path)
         | 
| 547 555 | 
             
                    result = _edit_file(context, payload, group_id)
         | 
| @@ -261,8 +261,35 @@ class ChatView(VerticalScroll): | |
| 261 261 | 
             
                    else:
         | 
| 262 262 | 
             
                        separator = "\n"
         | 
| 263 263 |  | 
| 264 | 
            -
                    #  | 
| 265 | 
            -
                    last_message.content  | 
| 264 | 
            +
                    # Handle content concatenation carefully to preserve Rich objects
         | 
| 265 | 
            +
                    if hasattr(last_message.content, "__rich_console__") or hasattr(message.content, "__rich_console__"):
         | 
| 266 | 
            +
                        # If either content is a Rich object, convert both to text and concatenate
         | 
| 267 | 
            +
                        from io import StringIO
         | 
| 268 | 
            +
                        from rich.console import Console
         | 
| 269 | 
            +
                        
         | 
| 270 | 
            +
                        # Convert existing content to string
         | 
| 271 | 
            +
                        if hasattr(last_message.content, "__rich_console__"):
         | 
| 272 | 
            +
                            string_io = StringIO()
         | 
| 273 | 
            +
                            temp_console = Console(file=string_io, width=80, legacy_windows=False, markup=False)
         | 
| 274 | 
            +
                            temp_console.print(last_message.content)
         | 
| 275 | 
            +
                            existing_content = string_io.getvalue().rstrip("\n")
         | 
| 276 | 
            +
                        else:
         | 
| 277 | 
            +
                            existing_content = str(last_message.content)
         | 
| 278 | 
            +
                        
         | 
| 279 | 
            +
                        # Convert new content to string
         | 
| 280 | 
            +
                        if hasattr(message.content, "__rich_console__"):
         | 
| 281 | 
            +
                            string_io = StringIO()
         | 
| 282 | 
            +
                            temp_console = Console(file=string_io, width=80, legacy_windows=False, markup=False)
         | 
| 283 | 
            +
                            temp_console.print(message.content)
         | 
| 284 | 
            +
                            new_content = string_io.getvalue().rstrip("\n")
         | 
| 285 | 
            +
                        else:
         | 
| 286 | 
            +
                            new_content = str(message.content)
         | 
| 287 | 
            +
                        
         | 
| 288 | 
            +
                        # Combine as plain text
         | 
| 289 | 
            +
                        last_message.content = existing_content + separator + new_content
         | 
| 290 | 
            +
                    else:
         | 
| 291 | 
            +
                        # Both are strings, safe to concatenate
         | 
| 292 | 
            +
                        last_message.content += separator + message.content
         | 
| 266 293 |  | 
| 267 294 | 
             
                    # Update the widget based on message type
         | 
| 268 295 | 
             
                    if last_message.type == MessageType.AGENT_RESPONSE:
         | 
| @@ -282,25 +309,15 @@ class ChatView(VerticalScroll): | |
| 282 309 | 
             
                            copy_button.update_text_to_copy(last_message.content)
         | 
| 283 310 | 
             
                    else:
         | 
| 284 311 | 
             
                        # Handle other message types
         | 
| 285 | 
            -
                        content  | 
| 286 | 
            -
             | 
| 287 | 
            -
                         | 
| 288 | 
            -
             | 
| 289 | 
            -
                             | 
| 290 | 
            -
             | 
| 291 | 
            -
                             | 
| 292 | 
            -
             | 
| 293 | 
            -
             | 
| 294 | 
            -
                            )
         | 
| 295 | 
            -
                        ):
         | 
| 296 | 
            -
                            # Treat as literal text
         | 
| 297 | 
            -
                            last_widget.update(Text(content))
         | 
| 298 | 
            -
                        else:
         | 
| 299 | 
            -
                            # Try to render markup
         | 
| 300 | 
            -
                            try:
         | 
| 301 | 
            -
                                last_widget.update(Text.from_markup(content))
         | 
| 302 | 
            -
                            except Exception:
         | 
| 303 | 
            -
                                last_widget.update(Text(content))
         | 
| 312 | 
            +
                        # After the content concatenation above, content is always a string
         | 
| 313 | 
            +
                        # Try to parse markup when safe to do so
         | 
| 314 | 
            +
                        try:
         | 
| 315 | 
            +
                            # Try to parse as markup first - this handles rich styling correctly
         | 
| 316 | 
            +
                            last_widget.update(Text.from_markup(last_message.content))
         | 
| 317 | 
            +
                        except Exception:
         | 
| 318 | 
            +
                            # If markup parsing fails, fall back to plain text
         | 
| 319 | 
            +
                            # This handles cases where content contains literal square brackets
         | 
| 320 | 
            +
                            last_widget.update(Text(last_message.content))
         | 
| 304 321 |  | 
| 305 322 | 
             
                    # Add the new message to our tracking lists
         | 
| 306 323 | 
             
                    self.messages.append(message)
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
    
        {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/load_context_completion.py
    RENAMED
    
    | 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
    
        {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/model_picker_completion.py
    RENAMED
    
    | 
            File without changes
         | 
| 
            File without changes
         | 
    
        {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/command_line/prompt_toolkit_completion.py
    RENAMED
    
    | 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
    
        {code_puppy-0.0.158 → code_puppy-0.0.160}/code_puppy/tui/components/command_history_modal.py
    RENAMED
    
    | 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         |