from veoplace.utils.render import render


def output_variable_regions(**kwargs):
    prompt = []
    sorted_first_macros = kwargs['first_macros']
    history = kwargs['history']
    macro_data = kwargs['macro_data']
    grid_size = kwargs['grid_size']
    num_macro_placed = kwargs['num_macro_placed']
    node_pos = kwargs['node_pos']
    color_config = kwargs['color_config']
    canvas_width = kwargs['canvas_width']
    canvas_height = kwargs['canvas_height']
    example_output = ""

    if history:
        example_output += (
                "## HISTORY SUMMARY\n\n"
                "- **Placement Archetypes by Color Group:**\n"
                "\t- [Identify 2-3 distinct placement strategies that appeared across episodes for major color groups]\n"
                "\t- [For each archetype: one representative episode + coordinates + wirelength]\n"
                "\t- [Note which strategy performed best and why]\n\n"
                "- **Largest Macros Analysis:**\n"
                "\t- [Compare placement of largest macros in best vs worst episodes]\n"
                "\t- [Include coordinates and metrics only when there's clear performance difference]\n\n"
                "- **Spatial Patterns:**\n"
                "\t- [Any adjacency, spacing, or positioning patterns that consistently helped performance]\n"
                "\t- [If no consistent pattern found, explain why patterns varied]\n\n"
                "- **Standard Cell Distribution:**\n"
                "\t- [Observe light blue standard cells in canvas images - note where they cluster or get blocked]\n"
                "\t- [Which macro arrangements allowed standard cells to spread evenly vs get congested?]\n\n"
                "- **Key Principles (at least 3):**\n"
                "\t- [Concise placement rules derived from analysis above]\n"
                "\t- [Cite evidence from history; if evidence is weak, mark as \"hypothesis\"]\n\n"
        )
    else:
        example_output += (
                "## CURRENT CANVAS STATE\n\n"
                "- Current layout: [describe what's on the canvas]\n"
                "- Available space: [describe open areas that can fit macros]\n\n"
        )

    example_output += (
            "## STRATEGY\n\n"
            "- **Overall Plan:** [2-3 sentences describing your placement approach]\n"
    )
    if history:
        example_output += (
                "- **Improvement on Best Archetype:** [Propose exactly one concrete change to the best pattern (e.g., shift position, adjust spacing, try different canvas region); if evidence is weak, label it \"exploratory\" but still commit]\n"
        )
    example_output += (
            "- **Color Group Organization:** [How different color groups will be distributed across the canvas]\n"
            "- **Wirelength Rationale:** [Why this arrangement minimizes wirelength]\n\n"
    )

    example_output += (
            "## REGIONS\n\n"
            "- [List regions in DECREASING SIZE ORDER (largest macros first) to avoid overlaps]\n"
            "- [Format: MACRO_NAME (W x H): (x1,y1) to (x2,y2)]\n\n"
            "Example format:\n\n"
            "\t- ABC (30x20): (120,200) to (150,220)\n"
            "\t- DEF (20x16): (45,310) to (65,326)\n"
            "\t- RST (8x12): (280,150) to (288,162)\n"
    )

    prompt.append("# IMPORTANT OUTPUT FORMAT:\n")
    prompt.append(
            f"1. ALL COORDINATES MUST BE INTEGERS BETWEEN 0 and {grid_size}\n"
            f"2. ALL REGIONS MUST HAVE NON-ZERO WIDTH AND HEIGHT (x2 > x1 and y2 > y1)\n"
            "3. THE ORIENTATION OF MACROS CANNOT BE CHANGED. DO NOT TRY TO ROTATE MACROS.\n"
            "4. ALL REGIONS MUST BE LARGE ENOUGH TO FIT THE MACRO WHILE STILL BEING WITHIN THE BOUNDS OF THE CANVAS. FOR EXAMPLE, IF A MACRO SIZE IS 3.1x4.2, THE REGION MUST BE AT LEAST 4x5.\n"
    )

    prompt.append(
            "5. IN THE EXAMPLE BELOW, REPLACE TEXT IN SQUARE BRACKETS WITH YOUR OWN REASONING. DO NOT COPY THE TEXT INSIDE THE BRACKETS.\n"
            f"6. FOLLOW THIS EXAMPLE FORMAT EXACTLY (without the dashed lines): \n\n---\n\n{example_output}\n\n---\n\n"
            "7. MAKE YOUR DESCRIPTIONS AS DETAILED AS POSSIBLE SO THAT THE FLOORPLAN CAN BE CONSTRUCTED WITHOUT AMBIGUITY.\n\n"
    )

    # -------------------------------------------------------------------------
    # 7) Current Canvas State
    # -------------------------------------------------------------------------
    prompt.append("# Current Canvas State\n")
    prompt.append("## Macros Currently Placed:\n\n")
    if num_macro_placed == 0:
        prompt.append("- No macros have been placed yet.\n")
    else:
        for i in range(num_macro_placed):
            m_data = macro_data[i]
            short_name = m_data["name"]
            long_name = m_data["full_name"]
            width = round(m_data["width"], 1)
            height = round(m_data["height"], 1)
            x, y, *_ = node_pos[long_name]
            max_x = x + width
            max_y = y + height
            prompt.append(
                    f"- {short_name} from ({x},{y}) to ({max_x},{max_y})\n")

    prompt.append("\n\n### Current Canvas Image\n")
    current_canvas_image = render(
            node_pos=node_pos,
            color_config=color_config,
            grid=grid_size,
            max_width=canvas_width,
            max_height=canvas_height,
            return_bytes=False
    )
    prompt.append(current_canvas_image)
    prompt.append("\n\n")

    # Please provide your suggestions below
    prompt.append("Please provide your suggestions below\n")

    kwargs.update({
            'macro_data': macro_data
    })
    return prompt, kwargs


# veoplace/utils/render import render  ← already present above

def output_recall_test(**kwargs):
    """
    Final instruction block for the *verbatim-recall* ablation.
    It mirrors the structure of `output_variable_regions` so that
    prompt length and formatting remain comparable.
    """
    # ---------------- context shortcuts ---------------------------------
    target_episode_index = kwargs['target_episode_index']  # 1-based
    macros_to_recall = kwargs['macros_to_recall']  # full-length list
    short_names = kwargs['node_name_to_short_name']
    grid_size = kwargs['grid_size']
    num_macro_placed = kwargs['num_macro_placed']
    node_pos = kwargs['node_pos']  # current canvas
    color_config = kwargs['color_config']
    canvas_width = kwargs['canvas_width']
    canvas_height = kwargs['canvas_height']

    prompt = []

    # --------------------------------------------------------------------
    # 1) High-level task
    # --------------------------------------------------------------------
    prompt.append("## TASK OVERVIEW\n\n")
    prompt.append(
            f"You have just read a chronological history of placement episodes "
            f"(Episode #1 … Episode #{target_episode_index + 1}).\n\n"
            f"**Your job is *memory recall*: reproduce the full macro placement "
            f"that appeared in Episode #{target_episode_index + 1}.**\n\n"
            "Do *not* invent new placements or optimise them.  Simply copy the "
            "coordinates exactly as they appeared in the reference episode.\n\n"
    )

    # --------------------------------------------------------------------
    # 2) Current canvas snapshot   (kept for parity)
    # --------------------------------------------------------------------
    prompt.append("### Current Canvas State (for reference only)\n")
    if num_macro_placed == 0:
        prompt.append("- No macros have been placed yet in this run.\n")
    else:
        prompt.append("The following macros are already fixed on the canvas:\n")
        for macro_name, (x, y, w, h, *_) in node_pos.items():
            short = short_names[macro_name]
            prompt.append(
                    f"- {short}: placed from ({x},{y}) to ({x + w},{y + h})\n"
            )
    prompt.append("\n\n")

    prompt.append("### Canvas Image\n")
    prompt.append(render(
            node_pos=node_pos,
            color_config=color_config,
            grid=grid_size,
            max_width=canvas_width,
            max_height=canvas_height,
            return_bytes=False
    ))
    prompt.append("\n\n")

    # --------------------------------------------------------------------
    # 3) Response format (mirrors variable-regions “IMPORTANT OUTPUT FORMAT”)
    # --------------------------------------------------------------------
    prompt.append("# IMPORTANT OUTPUT FORMAT\n")
    prompt.append(
            "1. Provide **one line per macro** in the *exact* order listed below.\n"
            "2. Use integer grid coordinates.\n"
            "3. Format each line like:  `SHORT_NAME: (x1, y1) to (x2, y2)` "
            "where (x1, y1) is bottom-left and (x2, y2) is top-right.\n\n"
    )

    # --------------------------------------------------------------------
    # 4) Template lines to be filled by the VLM
    # --------------------------------------------------------------------
    prompt.append("## COORDINATES TO RECALL\n")
    for macro_name in macros_to_recall:
        short = short_names[macro_name]
        prompt.append(f"- {short}: ( , ) to ( , )\n")  # blank slots

    prompt.append("\nPlease fill in the blanks above using Episode "
                  f"#{target_episode_index + 1}.\n")

    # --------------------------------------------------------------------
    # 5) Return (same signature as other output_* functions)
    # --------------------------------------------------------------------
    return prompt, kwargs
