#! -*- coding: utf-8
from .dynamic_graph import DynamicGraph

__all__ = ["get_graph"]


def get_graph(name: str, nnode: int, *args, **kwargs) -> DynamicGraph:
    if name == "BaseGraph":
        from .base_graph import BaseGraph
        return BaseGraph(nnode, *args, **kwargs)
    elif name == "ExpBaseGraph":
        from .exp_base_graph import ExpBaseGraph
        return ExpBaseGraph(nnode, *args, **kwargs)
    elif name == "Ring":
        from .ring import Ring
        return Ring(nnode, *args, **kwargs)
    elif name == "ExponentialGraph":
        from .exponential_graph import ExponentialGraph
        return ExponentialGraph(nnode, *args, **kwargs)
    elif name == "OnePeerExponentialGraph":
        from .one_peer_exponential_graph import OnePeerExponentialGraph
        return OnePeerExponentialGraph(nnode, *args, **kwargs)
    elif name == "KPeerExponentialGraph":
        from .k_peer_exponential_graph import KPeerExponentialGraph
        return KPeerExponentialGraph(nnode, *args, **kwargs)
    elif name == "GeneralizedKPeerExponentialGraph":
        from .generalized_k_peer_exponential_graph import \
            GeneralizedKPeerExponentialGraph
        return GeneralizedKPeerExponentialGraph(nnode, *args, **kwargs)
    elif name == "HalfRandomGraph":
        from .half_random_graph import HalfRandomGraph
        return HalfRandomGraph(nnode, *args, **kwargs)
    elif name == "BipartileRandomMatchGraph":
        from .bipartite_random_match_graph import BipartileRandomMatchGraph
        return BipartileRandomMatchGraph(nnode, *args, **kwargs)
    elif name == "KpartileRandomMatchGraph":
        from .kpartite_random_match_graph import KpartileRandomMatchGraph
        return KpartileRandomMatchGraph(nnode, *args, **kwargs)
    elif name == "Grid":
        from .grid import Grid
        return Grid(nnode, *args, **kwargs)
    elif name == "Torus":
        from .torus import Torus
        return Torus(nnode, *args, **kwargs)
    elif name == "RandomKGraph":
        from .random_k_graph import RandomKGraph
        return RandomKGraph(nnode, *args, **kwargs)
    elif name == "Matcha":
        from .matcha import Matcha
        return Matcha(nnode, *args, **kwargs)
    elif name == "SparseExpGraph":
        from .sparse_exp_graph import SparseExpGraph
        return SparseExpGraph(nnode, *args, **kwargs)
    else:
        raise ValueError(f"Unsupported graph: {name}")
