"""
数据模型定义
包含Pin、Net和Segment等数据结构
"""
from dataclasses import dataclass
from typing import List


@dataclass
class Pin:
    """表示一个引脚"""
    name: str
    cell_id: str
    absolute_x: int
    absolute_y: int
    net: str
    cell_y_min: int  # cell的y最小值
    cell_y_max: int  # cell的y最大值


@dataclass
class Net:
    """表示一个线网"""
    name: str
    pins: List[Pin]
    track: int = -1  # 分配的轨道编号
    layer: int = 1   # 分配的金属层，从METAL1开始

    
@dataclass
class Segment:
    """表示一个水平线段"""
    net_name: str
    x_start: int
    x_end: int
    track: int
    layer: int