from src.utils import underscore_to_pascalcase

PLAN_AGENT_STATEMENT = '''You are the PLAN AGENT in a multi-stage code generation system.

Your only job is to:
Produce a clear, step-by-step implementation plan that the CODE AGENT can follow directly, without requiring any guessing about missing details.

'''

DRAFT_PLAN_INSTRUCTION = '''
You must resolve any ambiguities in the inputs and turn them into explicit, actionable steps.

---

### GLOBAL RULES

1. Do not write any code. Output only plans and descriptions.
2. Always produce a numbered, ordered list of steps.
3. Each step must be small enough for the CODE AGENT to implement in a single edit.
4. Explicitly state all assumptions, such as shapes, data types, APIs, memory layout, and edge cases.
5. Avoid vague verbs like "handle" or "optimize" without explaining the specific method or approach.

---

You must output a single JSON object with the following exact structure:

{
    "step1": {
        "action": "A clear description of what the CODE AGENT must implement in this step.",
        "details": "All essential details for this step, including formulas, loops, memory access patterns, and APIs."
    },
    "step2": {
        "action": "A clear description of what the CODE AGENT must implement in this step.",
        "details": "All essential details for this step, including formulas, loops, memory access patterns, and APIs."
    },
    ...
}

Additionally, include a [DO_NOT] section listing actions the CODE AGENT must avoid, such as:
- Do not change public function signatures.
- Do not allocate extra global memory.
- etc.

---

### STYLE GUIDELINES

- Output must be valid JSON only. Do not include extra text, commentary, or markdown.
- Be concrete and deterministic: avoid terms like "maybe", "try", or "it might be good to".
- Each step should be small, specific, and implementable in one edit.
- Aim for 5 to 15 steps in the plan, avoiding overly broad or minimal steps.
- Group related work into the same step (e.g., implement a forward pass in one step, rather than splitting into variable renames).
- Ensure later steps logically depend on earlier ones to form a coherent chain.'''

def generate_draft_plan_template(arc_src, example_arc_src, example_new_arc_src, op, example_op):
    op = op + '_custom'
    example_op = example_op + '_custom'
    prompt = PLAN_AGENT_STATEMENT
    ### INPUTS YOU RECEIVE
    prompt += f'''
### INPUTS YOU RECEIVE

You will be given:
- TASK: A natural language description of what to implement. Specifically, it will describe an architecture with a kernel name {op} (in PascalCase: {underscore_to_pascalcase(op)}), as shown in the Python code snippet:
```python
{arc_src}
```
The overall task is to replace relevant PyTorch operators in the architecture named "Model" with custom AscendC kernels. Your plan should guide this transformation.
'''
    if example_arc_src and example_new_arc_src:
        prompt+=f'''
- REF_IMPL: A reference implementation that may be partial or not exactly similar to the task. It serves as an example to illustrate the expected transformation using custom AscendC operators. For instance, an original architecture with kernel name `{example_op}`:
```python
{example_arc_src}
```
    And its transformed version using custom AscendC kernels, which includes six embedded Python strings: `project_json_src`, `host_tiling_src`, `host_operator_src`, `kernel_src`, `python_bind_src`, and `model_src`. Note that the kernel function name in `kernel_src` must exactly match the provided kernel name, while the operator definitions in `project_json_src` and `host_operator_src` should correspond to the kernel name in PascalCase:
{example_new_arc_src}
'''
    prompt += DRAFT_PLAN_INSTRUCTION
    return prompt