"""
Common Prompt Components Library
Modular prompt components that can be flexibly imported and assembled by different Agents
"""

# =============================================================================
# SHARED PROMPT COMPONENTS FOR ALL AGENTS
# =============================================================================

TASK_CONTEXT = """
<TASK_CONTEXT>
# Multi-Agent Collaborative System
## **System Overview**
* This is a sophisticated multi-agent collaborative system designed for complex Verilog HDL code generation
* Specialized agents work in coordinated pipeline to ensure high-quality, synthesizable code output
* Each agent has specific responsibilities within the overall code generation workflow

## **System Purpose**
Generate functionally correct Verilog code from long technical document descriptions.

## **Agent Roles**
* **Summarize Agent**: Converts long document sections into indexed, concise summaries
* **Planner Agent**: Creates final code framework and decomposes into subtasks with document assignments
* **RTL Agent**: Generates code segments using assigned documents, task descriptions, and pseudocode
* **Merge Agent**: Combines subtask results into final complete code
* **Section Selector Agent**: Allocates document sections to agents based on specific requirements (merge/debug)
* **Syntax Debug Agent**: Creates debug operations from syntax errors, error messages, and documents
* **Semantic Debug Agent**: Creates debug operations from semantic errors, error messages, and documents

## **Simulation Environment**
* **Pre-built Submodules**: All required submodules in document are pre-built in other files - only instantiate them
* **Target File**: Final code will be written to {task_name}_top.v with module name {task_name}
* **Integration**: Code will integrate with other existing submodule files using verilator compiler
* **Error Handling**: Error line numbers may not correspond exactly to your specific file location
* **Testing**: Comprehensive syntax and semantic verification applied to all generated code
</TASK_CONTEXT>
"""


DEBUG_OPERATIONS_FORMAT = """
<DEBUG_OPERATIONS>
# Debug Operations Format

## **Supported Operations**
Two operations supported for clear logic maintenance:

### **Operation 1: "delete_block"**
* **Purpose**: Delete inclusive line range
* **Required Fields**:
  - `start_line` (1-based starting line number)
  - `end_line` (1-based ending line number, inclusive)

### **Operation 2: "add_block"**
* **Purpose**: Insert multiple lines at specified position
* **Required Fields**:
  - `line` (insertion position)
  - `content` (array of strings to insert)
* **Position Rules**:
  - line=0: Insert at file beginning
  - line=N: Insert after line N
  - line=last_line_number: Insert at file end

## **Operation Guidelines**
* All line numbers are 1-based
* delete_block includes start_line and end_line in deletion
* add_block inserts AFTER specified line (line=0 inserts at beginning)
* **No** overlapping editing lines between operations
* Operations will be executed in reverse line order to prevent conflicts
* Fix all errors comprehensively in one response
</DEBUG_OPERATIONS>
"""

DEBUG_JSON_OUTPUT_FORMAT = """
<DEBUG_OUTPUT_FORMAT>
# JSON Output Format

## **Required JSON Structure**
Provide fixes in JSON format after analysis:

```json
{{
  "description": "Brief description of all fixes",
  "fixes": [
    {{
      "operation": "operation_type",
      ...other_parameters
    }},
    ...
  ]
}}
```
</DEBUG_OUTPUT_FORMAT>
"""

DEBUG_ANALYSIS_GUIDE = """
<DEBUG_ANALYSIS_GUIDE>
# Analysis Process

## **Systematic Approach**
Think through fixes systematically before providing solutions:
1. **Error Analysis**: Examine error messages and code structure carefully
2. **Root Cause**: Identify fundamental issue causes
3. **Fix Strategy**: Plan comprehensive correction approach
4. **Solution Implementation**: Provide specific, targeted fixes

## **Important Note**
* Only the LAST JSON block from your response is extracted
* Include complete analysis before JSON output
</DEBUG_ANALYSIS_GUIDE>
"""

RTL_CODING_STANDARDS = """
<RTL_CODING_STANDARDS>
# Verilog RTL Coding Standards

## **Basic Verilog Coding Standards**
* **Syntax**: Use correct and synthesizable Verilog syntax
* **Signal Declaration**: Every signal should be declared explicitly before use. Declare every signal assigned inside an always block as reg.
* **Blocking and Non-Blocking Assignments**: Use <= (non-blocking) for synchronous always @(posedge clk) blocks; Use = (blocking) for asynchronous always @(*) blocks. Never mix = and <= in the same procedural block.
* **Include Files**: Use `include "file_name.v" to include file **in the beginning of the whole code**, **DO NOT** include file in module body, **DO NOT** include file that is not mentioned in the document.

## **Macro Usage**
* **Macro Format**: All variables in documents are macros - use `MACRO_NAME format
* **Correct Syntax**: Always use backtick prefix: `MACRO_NAME
* **Bit Width**: Use `[`MACRO_NAME-1:0]` for bit ranges
* **Conditional Compilation**: Use `ifdef MACRO_NAME and `ifndef MACRO_NAME
* **No Quotes**: Never use "MACRO_NAME" or `MACRO_NAME`
* **Include Files**: Use `include "file_name.v" to include the macros you need.
* **Macro vs. Parameter**: Macro Reference: Always use the backtick prefix: `MACRO_NAME. Parameter Reference: Never use a backtick—simply state: PARAMETER_NAME

## **Module Instantiation Rules**
* **No Trailing Comma**: NEVER add comma after the last port connection
* **Conditional Ports First**: Place `ifdef/`ifndef conditional ports before regular ports. This can help you avoid comma after the last undefined port connection
* **Correct Example**: initialize the conditional ports first, then the regular ports, like this:
```verilog
module_nama u_module_name (
`ifdef MACRO_NAME
    .condition_port_1(condition_port_1),
    .condition_port_2(condition_port_2),
`endif
    .regular_port_1(regular_port_1),
    .regular_port_2(regular_port_2)
);
```
* **Incorrect Example**: other wrong examples, like these:
```verilog
module_nama u_module_name (
    .regular_port_1(regular_port_1),
    .regular_port_2(regular_port_2), // this comma will cause compile error when MACRO_NAME is not defined
`ifdef MACRO_NAME
    .condition_port_1(condition_port_1),
    .condition_port_2(condition_port_2),
`endif
);
```
```verilog
module_nama u_module_name (
    .regular_port_1(regular_port_1),
    .regular_port_2(regular_port_2)
`ifdef MACRO_NAME
    , // this syntax is very dangerous, easy to cause coding bug.
    .condition_port_1(condition_port_1),
    .condition_port_2(condition_port_2)
`endif
);
```

## **Synthesizable Code Only**
* **No Functions**: Never use `function` declarations
* **No Tasks**: Avoid `task` declarations
* **No File I/O**: No `$fopen`, `$fclose`, `$readmemh`, `$writememh`
* **No Display**: No `$display`, `$monitor`, `$strobe`, `$time`
* **No Time Constructs**: No `#delay`, `wait()`, `forever` loops
* **No Initial Blocks**: Avoid `initial` blocks (except memory initialization)

## **Interface Compliance**
* **Documentation Follow**: Strictly follow interface specifications in documentation
* **Port Matching**: Verify all port connections match submodule specifications
* **Signal Routing**: Ensure proper signal connectivity between modules
</RTL_CODING_STANDARDS>
"""

