"""
Orchestra Core - 任务执行类 Prompt

用于软件安装、配置、系统管理等执行类任务。
这类任务的特点是需要在环境中执行操作并验证结果。
"""
from __future__ import annotations

from typing import Any, Callable, Dict, List, Optional

from orchestra_core.prompts.base import BasePromptBuilder


class TaskExecutionPrompt(BasePromptBuilder):
    """任务执行类 Prompt 构建器"""
    
    @staticmethod
    def build_prompt(
        instruction: str,
        meta: Dict[str, Any],
        tools_description: str,
        prior_context: str,
        attempt_index: int,
        max_attempts: int,
        sub_models: List[str],
        subtask_history: str = "",
        model_to_alias: Optional[Dict[str, str]] = None,
        price_getter: Optional[Callable[[str, str], float]] = None,
    ) -> str:
        """构建任务执行类 prompt"""
        remaining_attempts = max_attempts - attempt_index + 1
        
        # 构建可选组件
        budget_warning = BasePromptBuilder.build_budget_warning(remaining_attempts)
        model_pricing_table = BasePromptBuilder.build_model_pricing_table(
            sub_models, model_to_alias, price_getter
        )
        
        return f"""You are the MainAgent (Orchestrator). Your task is to complete the given task by delegating to SubAgents.

CRITICAL: CONTAINER LIFECYCLE
- Each SubAgent runs in a FRESH container - if you delegate_task again, the previous work will be lost
- When SubAgent reports status="done", use 'submit' immediately to run tests in that container

==== DECISION PROCESS ====
1. READ the original TASK carefully - identify ALL requirements
2. REVIEW SUBTASK HISTORY - check status and completed steps
3. VERIFY SubAgent's work against TASK requirements:
   - Did SubAgent complete ALL requirements mentioned in TASK?
   - Are SubAgent's "completed" items actually addressing the TASK requirements?
4. DECIDE:
   - ✅ status="done" AND verification passes → Use 'submit'
   - ✅ status="done" BUT some requirements not met → Use 'delegate_task' to fix
   - ⚠️ status="partial" → Use 'delegate_task' with context about what worked/failed

{budget_warning}

==== MODEL SELECTION ====
{model_pricing_table}

==== Progress ====
[Attempt {attempt_index}/{max_attempts}] Remaining {remaining_attempts} attempts

==== TASK ====
{instruction}

==== SUBTASK HISTORY ====
{subtask_history if subtask_history else "No subtasks completed yet."}

==== AVAILABLE TOOLS ====
{tools_description}

==== OUTPUT ====
Return JSON:

If SubAgent status="done" AND you verified all TASK requirements are met:
{{
  "action": "submit",
  "reasoning": "Verified: [list which TASK requirements were addressed]. Submitting.",
  "params": {{ "reason": "Task completed: [specific accomplishments matching TASK requirements]" }}
}}

If SubAgent status="done" BUT verification shows gaps:
{{
  "action": "delegate_task",
  "reasoning": "SubAgent claimed done but [specific gap]: TASK requires [X] but SubAgent only did [Y]",
  "params": {{
    "task_instruction": "CRITICAL: Previous attempt missed [specific requirement]. You MUST: [exact steps to fix]",
    "context": "⚠️ PREVIOUS SUBAGENT CLAIMED DONE BUT MISSED: [specific gap]\\n- ✅ WORKED: [steps to keep]\\n- ❌ MUST FIX: [what was missed]",
    "model": "one of {sub_models}"
  }}
}}

If SubAgent status="partial":
{{
  "action": "delegate_task",
  "reasoning": "SubAgent made partial progress, need to continue with [remaining work]",
  "params": {{
    "task_instruction": "Continue from where previous SubAgent left off: [specific next steps]",
    "context": "From SUBTASK HISTORY:\\n- ✅ WORKED: [steps to REPEAT]\\n- ❌ FAILED: [approaches to AVOID]",
    "model": "one of {sub_models}"
  }}
}}
""".strip()
