import segno
import numpy as np
from utils import highlight

def count_qr_cell_differences(data1: str,
                              data2: str,
                              version: int = 3,
                              error_correction: str = "L",
                              mask_pattern: int = 0) -> int:
    """
    Generate two QR codes for the given strings and count how many modules differ.
    """
    # Generate QR codes
    qr1 = segno.make(data1,
                     version=version,
                     error=error_correction,
                     mask=mask_pattern,
                     boost_error=False)
    qr2 = segno.make(data2,
                     version=version,
                     error=error_correction,
                     mask=mask_pattern,
                     boost_error=False)

    # Convert to flattened binary arrays
    m1 = np.array(qr1.matrix, dtype=int).flatten()
    m2 = np.array(qr2.matrix, dtype=int).flatten()
    
    highlighted_cells = [(20, 28), (10, 5), (2, 15), (15, 4), (24, 16), (16, 17)]
    image = highlight(m1, position_2d=highlighted_cells, scale_factor=10)
    image.save("highlighted_qr_cells.png")

    # Count differing cells
    return int(np.count_nonzero(m1 ^ m2))


if __name__ == "__main__":
    data_a = "example.com"
    data_b = "exampla.com"
    diff_cells = count_qr_cell_differences(data_a, data_b)
    print(f"Number of differing modules between “{data_a}” and “{data_b}”: {diff_cells}")

