from .topology import UndirectedTopology

class Ring(UndirectedTopology):
    def __init__(self, n_clients:int = None, reorder = None):
        super().__init__(n_clients)
        self.reorder = reorder
        self.__create_topology()

    
    def __create_topology(self):
        if self.reorder is None:
            for i in range(self.n_clients):
                self.__insert_edge__(i, (i + 1) % self.n_clients)
        else:
            sorted_clients = sorted(range(self.n_clients), key=lambda x: self.reorder[x])
            for j in range(self.n_clients):
                self.__insert_edge__(sorted_clients[j], sorted_clients[(j + 1) % self.n_clients])
