# -*- coding: utf-8 -*-
"""
get_v2_highlight_coords.py

Utility to return the coordinates to highlight for
  · Error correction codewords
  · Remainder bits (7 bits)
in Version-2 QR (25×25).
Supports 4 levels: ec_level='L'|'M'|'Q'|'H'.
"""


def get_v2_highlight_coords(ec_level: str = "L"):
    ec_level = ec_level.upper()
    if ec_level not in ("L", "M", "Q", "H"):
        raise ValueError("ec_level must be one of 'L', 'M', 'Q', 'H'")

    DATA_CW = {
        "L": 34,
        "M": 28,
        "Q": 22,
        "H": 16
    }  # data code-words

    data_bits = DATA_CW[ec_level] * 8

    N = 4 * 2 + 17  # 25
    F = [[False] * N for _ in range(N)]

    def reserve(r, c, h, w):
        for i in range(r, r + h):
            for j in range(c, c + w):
                if 0 <= i < N and 0 <= j < N:
                    F[i][j] = True

    def finder(r, c):
        reserve(r, c, 7, 7)
        reserve(r - 1, c - 1, 9, 1)
        reserve(r - 1, c + 7, 9, 1)
        reserve(r - 1, c - 1, 1, 9)
        reserve(r + 7, c - 1, 1, 9)

    finder(0, 0)
    finder(0, N - 7)
    finder(N - 7, 0)

    for i in range(N):  # timing
        F[6][i] = F[i][6] = True

    for r in (6, 18):  # alignment
        for c in (6, 18):
            if (r, c) not in [(6, 6), (6, N - 7), (N - 7, 6)]:
                reserve(r - 2, c - 2, 5, 5)

    F[N - 8][8] = True  # dark module

    # format-info (copy-1)
    for c in range(9):
        if c != 6:
            F[8][c] = True
    for r in range(8):
        if r != 6:
            F[r][8] = True
    # format-info (copy-2)
    for c in range(N - 8, N):  # row 8, col 17-24
        F[8][c] = True
    for r in range(N - 7, N):  # col 8, row 18-24
        F[r][8] = True

    order, col, upward = [], N - 1, True
    while col > 0:
        if col == 6:
            col -= 1
        rows = range(N - 1, -1, -1) if upward else range(N)
        for r in rows:
            for dc in (0, -1):
                c = col + dc
                if not F[r][c]:
                    order.append((r, c))
        upward, col = not upward, col - 2

    start = data_bits
    end = start + ecc_bits + REM_BITS  # ECC + remainder


# --------------------------------------------------------------------------
if __name__ == "__main__":
    from utils import highlight

    dummy = (
        "111111100110101100111111110000010001100011010000011011101011101000101011"
        "101101110100111001100101110110111010001011110010111011000001001011101001"
        "000001111111101010101010111111100000000111111100000000001110111110101100"
        "011000100110101010010101010100011100010111110010101010100111000100000001"
        "111111000000101010100001110001110100000110100100011001111000111011111110"
        "000010011001111010100011111011000010001010100110001111101111110010000000"
        "010101000100011001111111101100110110101011110000010111111001000110101011"
        "101011011100111111010101110100000100000001100010111010101011000000100011"
        "0000010100011111001010101111111010111101110011011"
    )

    for lvl in ("L", "M", "Q", "H"):
        pos = get_v2_highlight_coords(lvl)
        img = highlight(dummy, pos)
        img.save(f"ecc_rem_V2_{lvl}.png")
        print(f"saved ecc_rem_V2_{lvl}.png ({lvl} level)")

    pos = get_v2_highlight_coords()
    img = highlight(dummy, pos)
    img.save("ecc_plus_rem_highlight.png")
    print(f"highlighted {len(pos)} modules → ecc_plus_rem_highlight.png")
