code-puppy 0.0.163__py3-none-any.whl → 0.0.164__py3-none-any.whl
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/agent.py +8 -7
- code_puppy/agents/agent_creator_agent.py +7 -5
- code_puppy/command_line/command_handler.py +22 -20
- code_puppy/command_line/prompt_toolkit_completion.py +2 -2
- code_puppy/config.py +1 -1
- code_puppy/model_factory.py +14 -3
- code_puppy/tools/command_runner.py +0 -1
- code_puppy/tools/file_modifications.py +2 -3
- code_puppy/tui/components/chat_view.py +12 -6
- {code_puppy-0.0.163.dist-info → code_puppy-0.0.164.dist-info}/METADATA +1 -1
- {code_puppy-0.0.163.dist-info → code_puppy-0.0.164.dist-info}/RECORD +15 -15
- {code_puppy-0.0.163.data → code_puppy-0.0.164.data}/data/code_puppy/models.json +0 -0
- {code_puppy-0.0.163.dist-info → code_puppy-0.0.164.dist-info}/WHEEL +0 -0
- {code_puppy-0.0.163.dist-info → code_puppy-0.0.164.dist-info}/entry_points.txt +0 -0
- {code_puppy-0.0.163.dist-info → code_puppy-0.0.164.dist-info}/licenses/LICENSE +0 -0
    
        code_puppy/agent.py
    CHANGED
    
    | @@ -6,7 +6,6 @@ from pydantic_ai import Agent | |
| 6 6 | 
             
            from pydantic_ai.settings import ModelSettings
         | 
| 7 7 | 
             
            from pydantic_ai.usage import UsageLimits
         | 
| 8 8 |  | 
| 9 | 
            -
            from code_puppy.agents import get_current_agent_config
         | 
| 10 9 | 
             
            from code_puppy.message_history_processor import (
         | 
| 11 10 | 
             
                get_model_context_length,
         | 
| 12 11 | 
             
                message_history_accumulator,
         | 
| @@ -136,11 +135,12 @@ def reload_code_generation_agent(message_group: str | None): | |
| 136 135 |  | 
| 137 136 | 
             
                # Check if current agent has a pinned model
         | 
| 138 137 | 
             
                from code_puppy.agents import get_current_agent_config
         | 
| 138 | 
            +
             | 
| 139 139 | 
             
                agent_config = get_current_agent_config()
         | 
| 140 140 | 
             
                agent_model_name = None
         | 
| 141 | 
            -
                if hasattr(agent_config,  | 
| 141 | 
            +
                if hasattr(agent_config, "get_model_name"):
         | 
| 142 142 | 
             
                    agent_model_name = agent_config.get_model_name()
         | 
| 143 | 
            -
             | 
| 143 | 
            +
             | 
| 144 144 | 
             
                # Use agent-specific model if pinned, otherwise use global model
         | 
| 145 145 | 
             
                model_name = agent_model_name if agent_model_name else get_model_name()
         | 
| 146 146 | 
             
                emit_info(
         | 
| @@ -203,17 +203,18 @@ def get_code_generation_agent(force_reload=False, message_group: str | None = No | |
| 203 203 |  | 
| 204 204 | 
             
                # Get the global model name
         | 
| 205 205 | 
             
                global_model_name = get_model_name()
         | 
| 206 | 
            -
             | 
| 206 | 
            +
             | 
| 207 207 | 
             
                # Check if current agent has a pinned model
         | 
| 208 208 | 
             
                from code_puppy.agents import get_current_agent_config
         | 
| 209 | 
            +
             | 
| 209 210 | 
             
                agent_config = get_current_agent_config()
         | 
| 210 211 | 
             
                agent_model_name = None
         | 
| 211 | 
            -
                if hasattr(agent_config,  | 
| 212 | 
            +
                if hasattr(agent_config, "get_model_name"):
         | 
| 212 213 | 
             
                    agent_model_name = agent_config.get_model_name()
         | 
| 213 | 
            -
             | 
| 214 | 
            +
             | 
| 214 215 | 
             
                # Use agent-specific model if pinned, otherwise use global model
         | 
| 215 216 | 
             
                model_name = agent_model_name if agent_model_name else global_model_name
         | 
| 216 | 
            -
             | 
| 217 | 
            +
             | 
| 217 218 | 
             
                if _code_generation_agent is None or _LAST_MODEL_NAME != model_name or force_reload:
         | 
| 218 219 | 
             
                    return reload_code_generation_agent(message_group)
         | 
| 219 220 | 
             
                return _code_generation_agent
         | 
| @@ -28,15 +28,17 @@ class AgentCreatorAgent(BaseAgent): | |
| 28 28 | 
             
                def get_system_prompt(self) -> str:
         | 
| 29 29 | 
             
                    available_tools = get_available_tool_names()
         | 
| 30 30 | 
             
                    agents_dir = get_user_agents_directory()
         | 
| 31 | 
            -
             | 
| 31 | 
            +
             | 
| 32 32 | 
             
                    # Load available models dynamically
         | 
| 33 33 | 
             
                    models_config = ModelFactory.load_config()
         | 
| 34 34 | 
             
                    model_descriptions = []
         | 
| 35 35 | 
             
                    for model_name, model_info in models_config.items():
         | 
| 36 | 
            -
                        model_type = model_info.get( | 
| 37 | 
            -
                        context_length = model_info.get( | 
| 38 | 
            -
                        model_descriptions.append( | 
| 39 | 
            -
             | 
| 36 | 
            +
                        model_type = model_info.get("type", "Unknown")
         | 
| 37 | 
            +
                        context_length = model_info.get("context_length", "Unknown")
         | 
| 38 | 
            +
                        model_descriptions.append(
         | 
| 39 | 
            +
                            f"- **{model_name}**: {model_type} model with {context_length} context"
         | 
| 40 | 
            +
                        )
         | 
| 41 | 
            +
             | 
| 40 42 | 
             
                    available_models_str = "\n".join(model_descriptions)
         | 
| 41 43 |  | 
| 42 44 | 
             
                    return f"""You are the Agent Creator! 🏗️ Your mission is to help users create awesome JSON agent files through an interactive process.
         | 
| @@ -57,7 +57,9 @@ def get_commands_help(): | |
| 57 57 | 
             
                )
         | 
| 58 58 | 
             
                help_lines.append(
         | 
| 59 59 | 
             
                    Text("/compact", style="cyan")
         | 
| 60 | 
            -
                    + Text( | 
| 60 | 
            +
                    + Text(
         | 
| 61 | 
            +
                        "              Summarize and compact current chat history (uses compaction_strategy config)"
         | 
| 62 | 
            +
                    )
         | 
| 61 63 | 
             
                )
         | 
| 62 64 | 
             
                help_lines.append(
         | 
| 63 65 | 
             
                    Text("/dump_context", style="cyan")
         | 
| @@ -371,7 +373,7 @@ def handle_command(command: str): | |
| 371 373 |  | 
| 372 374 | 
             
                    # If no model matched, show available models
         | 
| 373 375 | 
             
                    from code_puppy.command_line.model_picker_completion import load_model_names
         | 
| 374 | 
            -
             | 
| 376 | 
            +
             | 
| 375 377 | 
             
                    new_input = update_model_in_input(model_command)
         | 
| 376 378 | 
             
                    if new_input is not None:
         | 
| 377 379 | 
             
                        from code_puppy.agents.runtime_manager import get_runtime_agent_manager
         | 
| @@ -406,76 +408,76 @@ def handle_command(command: str): | |
| 406 408 | 
             
                    from code_puppy.agents.json_agent import discover_json_agents
         | 
| 407 409 | 
             
                    from code_puppy.command_line.model_picker_completion import load_model_names
         | 
| 408 410 | 
             
                    import json
         | 
| 409 | 
            -
             | 
| 411 | 
            +
             | 
| 410 412 | 
             
                    tokens = command.split()
         | 
| 411 | 
            -
             | 
| 413 | 
            +
             | 
| 412 414 | 
             
                    if len(tokens) != 3:
         | 
| 413 415 | 
             
                        emit_warning("Usage: /pin_model <agent-name> <model-name>")
         | 
| 414 | 
            -
             | 
| 416 | 
            +
             | 
| 415 417 | 
             
                        # Show available models and JSON agents
         | 
| 416 418 | 
             
                        available_models = load_model_names()
         | 
| 417 419 | 
             
                        json_agents = discover_json_agents()
         | 
| 418 | 
            -
             | 
| 420 | 
            +
             | 
| 419 421 | 
             
                        emit_info("Available models:")
         | 
| 420 422 | 
             
                        for model in available_models:
         | 
| 421 423 | 
             
                            emit_info(f"  [cyan]{model}[/cyan]")
         | 
| 422 | 
            -
             | 
| 424 | 
            +
             | 
| 423 425 | 
             
                        if json_agents:
         | 
| 424 426 | 
             
                            emit_info("\nAvailable JSON agents:")
         | 
| 425 427 | 
             
                            for agent_name, agent_path in json_agents.items():
         | 
| 426 428 | 
             
                                emit_info(f"  [cyan]{agent_name}[/cyan] ({agent_path})")
         | 
| 427 429 | 
             
                        return True
         | 
| 428 | 
            -
             | 
| 430 | 
            +
             | 
| 429 431 | 
             
                    agent_name = tokens[1].lower()
         | 
| 430 432 | 
             
                    model_name = tokens[2]
         | 
| 431 | 
            -
             | 
| 433 | 
            +
             | 
| 432 434 | 
             
                    # Check if model exists
         | 
| 433 435 | 
             
                    available_models = load_model_names()
         | 
| 434 436 | 
             
                    if model_name not in available_models:
         | 
| 435 437 | 
             
                        emit_error(f"Model '{model_name}' not found")
         | 
| 436 438 | 
             
                        emit_warning(f"Available models: {', '.join(available_models)}")
         | 
| 437 439 | 
             
                        return True
         | 
| 438 | 
            -
             | 
| 440 | 
            +
             | 
| 439 441 | 
             
                    # Check that we're modifying a JSON agent (not a built-in Python agent)
         | 
| 440 442 | 
             
                    json_agents = discover_json_agents()
         | 
| 441 443 | 
             
                    if agent_name not in json_agents:
         | 
| 442 444 | 
             
                        emit_error(f"JSON agent '{agent_name}' not found")
         | 
| 443 | 
            -
             | 
| 445 | 
            +
             | 
| 444 446 | 
             
                        # Show available JSON agents
         | 
| 445 447 | 
             
                        if json_agents:
         | 
| 446 448 | 
             
                            emit_info("Available JSON agents:")
         | 
| 447 449 | 
             
                            for name, path in json_agents.items():
         | 
| 448 450 | 
             
                                emit_info(f"  [cyan]{name}[/cyan] ({path})")
         | 
| 449 451 | 
             
                        return True
         | 
| 450 | 
            -
             | 
| 452 | 
            +
             | 
| 451 453 | 
             
                    agent_file_path = json_agents[agent_name]
         | 
| 452 | 
            -
             | 
| 454 | 
            +
             | 
| 453 455 | 
             
                    # Load, modify, and save the agent configuration
         | 
| 454 456 | 
             
                    try:
         | 
| 455 457 | 
             
                        with open(agent_file_path, "r", encoding="utf-8") as f:
         | 
| 456 458 | 
             
                            agent_config = json.load(f)
         | 
| 457 | 
            -
             | 
| 459 | 
            +
             | 
| 458 460 | 
             
                        # Set the model
         | 
| 459 461 | 
             
                        agent_config["model"] = model_name
         | 
| 460 | 
            -
             | 
| 462 | 
            +
             | 
| 461 463 | 
             
                        # Save the updated configuration
         | 
| 462 464 | 
             
                        with open(agent_file_path, "w", encoding="utf-8") as f:
         | 
| 463 465 | 
             
                            json.dump(agent_config, f, indent=2, ensure_ascii=False)
         | 
| 464 | 
            -
             | 
| 466 | 
            +
             | 
| 465 467 | 
             
                        emit_success(f"Model '{model_name}' pinned to agent '{agent_name}'")
         | 
| 466 | 
            -
             | 
| 468 | 
            +
             | 
| 467 469 | 
             
                        # If this is the current agent, reload it to use the new model
         | 
| 468 470 | 
             
                        from code_puppy.agents import get_current_agent_config
         | 
| 469 471 | 
             
                        from code_puppy.agents.runtime_manager import get_runtime_agent_manager
         | 
| 470 | 
            -
             | 
| 472 | 
            +
             | 
| 471 473 | 
             
                        current_agent = get_current_agent_config()
         | 
| 472 474 | 
             
                        if current_agent.name == agent_name:
         | 
| 473 475 | 
             
                            manager = get_runtime_agent_manager()
         | 
| 474 476 | 
             
                            manager.reload_agent()
         | 
| 475 477 | 
             
                            emit_info(f"Active agent reloaded with pinned model '{model_name}'")
         | 
| 476 | 
            -
             | 
| 478 | 
            +
             | 
| 477 479 | 
             
                        return True
         | 
| 478 | 
            -
             | 
| 480 | 
            +
             | 
| 479 481 | 
             
                    except Exception as e:
         | 
| 480 482 | 
             
                        emit_error(f"Failed to pin model to agent '{agent_name}': {e}")
         | 
| 481 483 | 
             
                        return True
         | 
| @@ -147,9 +147,9 @@ def get_prompt_with_active_model(base: str = ">>> "): | |
| 147 147 |  | 
| 148 148 | 
             
                # Check if current agent has a pinned model
         | 
| 149 149 | 
             
                agent_model = None
         | 
| 150 | 
            -
                if current_agent and hasattr(current_agent,  | 
| 150 | 
            +
                if current_agent and hasattr(current_agent, "get_model_name"):
         | 
| 151 151 | 
             
                    agent_model = current_agent.get_model_name()
         | 
| 152 | 
            -
             | 
| 152 | 
            +
             | 
| 153 153 | 
             
                # Determine which model to display
         | 
| 154 154 | 
             
                if agent_model and agent_model != global_model:
         | 
| 155 155 | 
             
                    # Show both models when they differ
         | 
    
        code_puppy/config.py
    CHANGED
    
    | @@ -492,4 +492,4 @@ def save_command_to_history(command: str): | |
| 492 492 | 
             
                    error_msg = (
         | 
| 493 493 | 
             
                        f"❌ An unexpected error occurred while saving command history: {str(e)}"
         | 
| 494 494 | 
             
                    )
         | 
| 495 | 
            -
                    direct_console.print(f"[bold red]{error_msg}[/bold red]")
         | 
| 495 | 
            +
                    direct_console.print(f"[bold red]{error_msg}[/bold red]")
         | 
    
        code_puppy/model_factory.py
    CHANGED
    
    | @@ -95,9 +95,20 @@ class ModelFactory: | |
| 95 95 | 
             
                            config = json.load(f)
         | 
| 96 96 |  | 
| 97 97 | 
             
                    if pathlib.Path(EXTRA_MODELS_FILE).exists():
         | 
| 98 | 
            -
                         | 
| 99 | 
            -
                             | 
| 100 | 
            -
             | 
| 98 | 
            +
                        try:
         | 
| 99 | 
            +
                            with open(EXTRA_MODELS_FILE, "r") as f:
         | 
| 100 | 
            +
                                extra_config = json.load(f)
         | 
| 101 | 
            +
                                config.update(extra_config)
         | 
| 102 | 
            +
                        except json.JSONDecodeError as e:
         | 
| 103 | 
            +
                            logging.getLogger(__name__).warning(
         | 
| 104 | 
            +
                                f"Failed to load extra models config from {EXTRA_MODELS_FILE}: Invalid JSON - {e}\n"
         | 
| 105 | 
            +
                                f"Please check your extra_models.json file for syntax errors."
         | 
| 106 | 
            +
                            )
         | 
| 107 | 
            +
                        except Exception as e:
         | 
| 108 | 
            +
                            logging.getLogger(__name__).warning(
         | 
| 109 | 
            +
                                f"Failed to load extra models config from {EXTRA_MODELS_FILE}: {e}\n"
         | 
| 110 | 
            +
                                f"The extra models configuration will be ignored."
         | 
| 111 | 
            +
                            )
         | 
| 101 112 | 
             
                    return config
         | 
| 102 113 |  | 
| 103 114 | 
             
                @staticmethod
         | 
| @@ -20,7 +20,6 @@ import json_repair | |
| 20 20 | 
             
            from pydantic import BaseModel
         | 
| 21 21 | 
             
            from pydantic_ai import RunContext
         | 
| 22 22 |  | 
| 23 | 
            -
            from code_puppy.callbacks import on_delete_file, on_edit_file
         | 
| 24 23 | 
             
            from code_puppy.messaging import emit_error, emit_info, emit_warning
         | 
| 25 24 | 
             
            from code_puppy.tools.common import _find_best_window, generate_group_id
         | 
| 26 25 |  | 
| @@ -567,9 +566,9 @@ def register_edit_file(agent): | |
| 567 566 | 
             
                        except Exception as e:
         | 
| 568 567 | 
             
                            return {
         | 
| 569 568 | 
             
                                "success": False,
         | 
| 570 | 
            -
                                "path":  | 
| 569 | 
            +
                                "path": "Not retrievable in Payload",
         | 
| 571 570 | 
             
                                "message": f"edit_file call failed: {str(e)} - this means the tool failed to parse your inputs. Refer to the following examples: {parse_error_message}",
         | 
| 572 | 
            -
                                "changed": False
         | 
| 571 | 
            +
                                "changed": False,
         | 
| 573 572 | 
             
                            }
         | 
| 574 573 |  | 
| 575 574 | 
             
                    # Call _edit_file which will extract file_path from payload and handle group_id generation
         | 
| @@ -262,29 +262,35 @@ class ChatView(VerticalScroll): | |
| 262 262 | 
             
                        separator = "\n"
         | 
| 263 263 |  | 
| 264 264 | 
             
                    # Handle content concatenation carefully to preserve Rich objects
         | 
| 265 | 
            -
                    if hasattr(last_message.content, "__rich_console__") or hasattr( | 
| 265 | 
            +
                    if hasattr(last_message.content, "__rich_console__") or hasattr(
         | 
| 266 | 
            +
                        message.content, "__rich_console__"
         | 
| 267 | 
            +
                    ):
         | 
| 266 268 | 
             
                        # If either content is a Rich object, convert both to text and concatenate
         | 
| 267 269 | 
             
                        from io import StringIO
         | 
| 268 270 | 
             
                        from rich.console import Console
         | 
| 269 | 
            -
             | 
| 271 | 
            +
             | 
| 270 272 | 
             
                        # Convert existing content to string
         | 
| 271 273 | 
             
                        if hasattr(last_message.content, "__rich_console__"):
         | 
| 272 274 | 
             
                            string_io = StringIO()
         | 
| 273 | 
            -
                            temp_console = Console( | 
| 275 | 
            +
                            temp_console = Console(
         | 
| 276 | 
            +
                                file=string_io, width=80, legacy_windows=False, markup=False
         | 
| 277 | 
            +
                            )
         | 
| 274 278 | 
             
                            temp_console.print(last_message.content)
         | 
| 275 279 | 
             
                            existing_content = string_io.getvalue().rstrip("\n")
         | 
| 276 280 | 
             
                        else:
         | 
| 277 281 | 
             
                            existing_content = str(last_message.content)
         | 
| 278 | 
            -
             | 
| 282 | 
            +
             | 
| 279 283 | 
             
                        # Convert new content to string
         | 
| 280 284 | 
             
                        if hasattr(message.content, "__rich_console__"):
         | 
| 281 285 | 
             
                            string_io = StringIO()
         | 
| 282 | 
            -
                            temp_console = Console( | 
| 286 | 
            +
                            temp_console = Console(
         | 
| 287 | 
            +
                                file=string_io, width=80, legacy_windows=False, markup=False
         | 
| 288 | 
            +
                            )
         | 
| 283 289 | 
             
                            temp_console.print(message.content)
         | 
| 284 290 | 
             
                            new_content = string_io.getvalue().rstrip("\n")
         | 
| 285 291 | 
             
                        else:
         | 
| 286 292 | 
             
                            new_content = str(message.content)
         | 
| 287 | 
            -
             | 
| 293 | 
            +
             | 
| 288 294 | 
             
                        # Combine as plain text
         | 
| 289 295 | 
             
                        last_message.content = existing_content + separator + new_content
         | 
| 290 296 | 
             
                    else:
         | 
| @@ -1,12 +1,12 @@ | |
| 1 1 | 
             
            code_puppy/__init__.py,sha256=ehbM1-wMjNmOXk_DBhhJECFyBv2dRHwwo7ucjHeM68E,107
         | 
| 2 2 | 
             
            code_puppy/__main__.py,sha256=pDVssJOWP8A83iFkxMLY9YteHYat0EyWDQqMkKHpWp4,203
         | 
| 3 | 
            -
            code_puppy/agent.py,sha256= | 
| 3 | 
            +
            code_puppy/agent.py,sha256=wCARhq7PcD38c4l83fuXm4Us_6c1TXVa0U7TnBnNPEY,8064
         | 
| 4 4 | 
             
            code_puppy/callbacks.py,sha256=6wYB6K_fGSCkKKEFaYOYkJT45WaV5W_NhUIzcvVH_nU,5060
         | 
| 5 | 
            -
            code_puppy/config.py,sha256= | 
| 5 | 
            +
            code_puppy/config.py,sha256=J8XU0iOPtfzrkDD49b4TdrdHoQmW2kaP-25PPbGGdKU,16386
         | 
| 6 6 | 
             
            code_puppy/http_utils.py,sha256=BAvt4hed7fVMXglA7eS9gOb08h2YTuOyai6VmQq09fg,3432
         | 
| 7 7 | 
             
            code_puppy/main.py,sha256=tYLfhUjPTJ-4S1r-pr-jSbn6kIU1iYvt2Z8lxI7zDFY,22220
         | 
| 8 8 | 
             
            code_puppy/message_history_processor.py,sha256=aV-vcRcOQJPZPlrokB4CaLMxEU3Y4nDiabb9Ov_sJeU,15933
         | 
| 9 | 
            -
            code_puppy/model_factory.py,sha256= | 
| 9 | 
            +
            code_puppy/model_factory.py,sha256=z9vQbcGllgMwU0On8rPvzYxkygW2Uyd3NJmRzbKv-is,13759
         | 
| 10 10 | 
             
            code_puppy/models.json,sha256=iXmLZGflnQcu2DRh4WUlgAhoXdvoxUc7KBhB8YxawXM,3088
         | 
| 11 11 | 
             
            code_puppy/reopenable_async_client.py,sha256=4UJRaMp5np8cbef9F0zKQ7TPKOfyf5U-Kv-0zYUWDho,8274
         | 
| 12 12 | 
             
            code_puppy/round_robin_model.py,sha256=SEN3VSwTgC5wHjx2sZsHQLPWOycf4jGwzB-EydgqkdY,5643
         | 
| @@ -16,20 +16,20 @@ code_puppy/summarization_agent.py,sha256=kos4_YK-l_YjYRq4Fs4X5YoTUbmAcDhhPqefL-r | |
| 16 16 | 
             
            code_puppy/version_checker.py,sha256=bjLDmgGPrl7XnYwX1u13O8uFlsfikV90PK6nbA9Z9QU,1150
         | 
| 17 17 | 
             
            code_puppy/agents/__init__.py,sha256=SwtHGNG1GIgDBv7y3EGIXOXEWrG_Ou7fEknNgFbrHv8,594
         | 
| 18 18 | 
             
            code_puppy/agents/agent_code_puppy.py,sha256=sbuQxLzlkMbPOyLbILbXOAHecRsxbFdQt13HJ_GEqQo,7972
         | 
| 19 | 
            -
            code_puppy/agents/agent_creator_agent.py,sha256= | 
| 19 | 
            +
            code_puppy/agents/agent_creator_agent.py,sha256=chxZlvvl_12ol1d9V2WF7cjE1Px9d-S6NEH3CaKg_lc,23270
         | 
| 20 20 | 
             
            code_puppy/agents/agent_manager.py,sha256=nXvro6fpX8KA-NedRoVJuhJW966trrePOrH4eAnqq40,17034
         | 
| 21 21 | 
             
            code_puppy/agents/agent_orchestrator.json,sha256=Iqnc0p6ICoAlUTMkEsi1XXMXJi4pdxVnWZUMaih6s5o,1267
         | 
| 22 22 | 
             
            code_puppy/agents/base_agent.py,sha256=XYSff6IQX9Z6C7hPVbN_YXC2xfjwd268e2jtG3ZGnVk,3450
         | 
| 23 23 | 
             
            code_puppy/agents/json_agent.py,sha256=y6AYE3Fx9LhmemcPzt46d7359MNnkGIjU83YBGNer2g,4533
         | 
| 24 24 | 
             
            code_puppy/agents/runtime_manager.py,sha256=fUOBpmETo3wTyLc5wWBfGKSX1HFRQWSpuwxYAOyA-_8,10059
         | 
| 25 25 | 
             
            code_puppy/command_line/__init__.py,sha256=y7WeRemfYppk8KVbCGeAIiTuiOszIURCDjOMZv_YRmU,45
         | 
| 26 | 
            -
            code_puppy/command_line/command_handler.py,sha256= | 
| 26 | 
            +
            code_puppy/command_line/command_handler.py,sha256=gdsOR04CIkUQjSMJtvrKDdAQNe6cF8JcsTObN-XfTLE,24414
         | 
| 27 27 | 
             
            code_puppy/command_line/file_path_completion.py,sha256=gw8NpIxa6GOpczUJRyh7VNZwoXKKn-yvCqit7h2y6Gg,2931
         | 
| 28 28 | 
             
            code_puppy/command_line/load_context_completion.py,sha256=6eZxV6Bs-EFwZjN93V8ZDZUC-6RaWxvtZk-04Wtikyw,2240
         | 
| 29 29 | 
             
            code_puppy/command_line/meta_command_handler.py,sha256=80aK5JQOaqjt149qBmSsM02uy2Cikkee8zaQnu5u2KQ,5712
         | 
| 30 30 | 
             
            code_puppy/command_line/model_picker_completion.py,sha256=adxp3NZaDV67YqaGv0SG7WVvOTXN0UwkkLqxTsknAvs,4126
         | 
| 31 31 | 
             
            code_puppy/command_line/motd.py,sha256=PEdkp3ZnydVfvd7mNJylm8YyFNUKg9jmY6uwkA1em8c,2152
         | 
| 32 | 
            -
            code_puppy/command_line/prompt_toolkit_completion.py,sha256= | 
| 32 | 
            +
            code_puppy/command_line/prompt_toolkit_completion.py,sha256=PLb1Yt_65iQI2mzPEPxPsSaRww5Ur951Qn-K-TLMCGQ,10006
         | 
| 33 33 | 
             
            code_puppy/command_line/utils.py,sha256=7eyxDHjPjPB9wGDJQQcXV_zOsGdYsFgI0SGCetVmTqE,1251
         | 
| 34 34 | 
             
            code_puppy/command_line/mcp/__init__.py,sha256=0-OQuwjq_pLiTVJ1_NrirVwdRerghyKs_MTZkwPC7YY,315
         | 
| 35 35 | 
             
            code_puppy/command_line/mcp/add_command.py,sha256=RghGmOCjwwYJfrbLiV5UZojMA4-FNPlM04LKci0rpAw,6415
         | 
| @@ -78,16 +78,16 @@ code_puppy/messaging/spinner/textual_spinner.py,sha256=Omx9A-FSPkxYDMYgBXgYMBQnK | |
| 78 78 | 
             
            code_puppy/plugins/__init__.py,sha256=fksDqMUiXPJ5WNuMsYsVR8ulueQRCXPlvECEyicHPtQ,1312
         | 
| 79 79 | 
             
            code_puppy/tools/__init__.py,sha256=YiiXRqxU1BEJ5t0Oe163lSqOneI9sKtwDW0swCPgBt4,2119
         | 
| 80 80 | 
             
            code_puppy/tools/agent_tools.py,sha256=bHMrFIbYRhuubR41G_XdLsk3cUKWfIPl2O4bVzo2pE0,5591
         | 
| 81 | 
            -
            code_puppy/tools/command_runner.py,sha256= | 
| 81 | 
            +
            code_puppy/tools/command_runner.py,sha256=6mGO90xks2OwJCEvwrsrNf3lRfcKXrMeLbkJEpX5bMw,20857
         | 
| 82 82 | 
             
            code_puppy/tools/common.py,sha256=pL-9xcRs3rxU7Fl9X9EUgbDp2-csh2LLJ5DHH_KAHKY,10596
         | 
| 83 | 
            -
            code_puppy/tools/file_modifications.py,sha256= | 
| 83 | 
            +
            code_puppy/tools/file_modifications.py,sha256=EaDWcv6gi8wAvpgyeJdKSKPWg9fTpZoEkxQiLCE6rn4,23218
         | 
| 84 84 | 
             
            code_puppy/tools/file_operations.py,sha256=Cxa5bqbVNwgViSdBjwGOrqWmtxBPhQRjDBepgt2Xuxk,30852
         | 
| 85 85 | 
             
            code_puppy/tools/tools_content.py,sha256=bsBqW-ppd1XNAS_g50B3UHDQBWEALC1UneH6-afz1zo,2365
         | 
| 86 86 | 
             
            code_puppy/tui/__init__.py,sha256=XesAxIn32zLPOmvpR2wIDxDAnnJr81a5pBJB4cZp1Xs,321
         | 
| 87 87 | 
             
            code_puppy/tui/app.py,sha256=nPOzwlusjdWzBfu__EbC3Q0etkPrqRq-2g-mk4IcfG4,39378
         | 
| 88 88 | 
             
            code_puppy/tui/messages.py,sha256=zQoToWI0eWdT36NEsY6RdCFzcDfAmfvoPlHv8jiCbgo,720
         | 
| 89 89 | 
             
            code_puppy/tui/components/__init__.py,sha256=uj5pnk3s6SEN3SbFI0ZnzaA2KK1NNg8TfUj6U-Z732U,455
         | 
| 90 | 
            -
            code_puppy/tui/components/chat_view.py,sha256= | 
| 90 | 
            +
            code_puppy/tui/components/chat_view.py,sha256=NfyNXuN2idPht1rKJB4YhHVXb1AIRNO5q_nLdt8Ocug,19913
         | 
| 91 91 | 
             
            code_puppy/tui/components/command_history_modal.py,sha256=pUPEQvoCWa2iUnuMgNwO22y8eUbyw0HpcPH3wAosHvU,7097
         | 
| 92 92 | 
             
            code_puppy/tui/components/copy_button.py,sha256=E4-OJYk5YNzDf-E81NyiVGKsTRPrUX-RnQ8qFuVnabw,4375
         | 
| 93 93 | 
             
            code_puppy/tui/components/custom_widgets.py,sha256=pnjkB3ZNa5lwSrAXUFlhN9AHNh4uMTpSap8AdbpecKw,1986
         | 
| @@ -104,9 +104,9 @@ code_puppy/tui/screens/help.py,sha256=eJuPaOOCp7ZSUlecearqsuX6caxWv7NQszUh0tZJjB | |
| 104 104 | 
             
            code_puppy/tui/screens/mcp_install_wizard.py,sha256=xqwN5omltMkfxWZwXj3D2PbXbtrxUi1dT0XT77oxOKk,27685
         | 
| 105 105 | 
             
            code_puppy/tui/screens/settings.py,sha256=GMpv-qa08rorAE9mj3AjmqjZFPhmeJ_GWd-DBHG6iAA,10671
         | 
| 106 106 | 
             
            code_puppy/tui/screens/tools.py,sha256=3pr2Xkpa9Js6Yhf1A3_wQVRzFOui-KDB82LwrsdBtyk,1715
         | 
| 107 | 
            -
            code_puppy-0.0. | 
| 108 | 
            -
            code_puppy-0.0. | 
| 109 | 
            -
            code_puppy-0.0. | 
| 110 | 
            -
            code_puppy-0.0. | 
| 111 | 
            -
            code_puppy-0.0. | 
| 112 | 
            -
            code_puppy-0.0. | 
| 107 | 
            +
            code_puppy-0.0.164.data/data/code_puppy/models.json,sha256=iXmLZGflnQcu2DRh4WUlgAhoXdvoxUc7KBhB8YxawXM,3088
         | 
| 108 | 
            +
            code_puppy-0.0.164.dist-info/METADATA,sha256=3mQaqHuxj9zoChbe-Q5477PK05cpaOCpxUEdjh0lZwA,19567
         | 
| 109 | 
            +
            code_puppy-0.0.164.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
         | 
| 110 | 
            +
            code_puppy-0.0.164.dist-info/entry_points.txt,sha256=d8YkBvIUxF-dHNJAj-x4fPEqizbY5d_TwvYpc01U5kw,58
         | 
| 111 | 
            +
            code_puppy-0.0.164.dist-info/licenses/LICENSE,sha256=31u8x0SPgdOq3izJX41kgFazWsM43zPEF9eskzqbJMY,1075
         | 
| 112 | 
            +
            code_puppy-0.0.164.dist-info/RECORD,,
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         |