import os, sys

from app.streaming import RTXConnector

sys.path.append(os.path.join(os.environ.get("SUMO_HOME"), "tools"))

from app.logdata import info
from app.routing.CustomRouter import CustomRouter
from app.network.Network import Network
from app.simulation.Simulation import Simulation
from app.streaming import RTXForword
from colorama import Fore
from app.sumo import SUMOConnector, SUMODependency
from app import Config
import traci, sys, os
# import thread
import time


# uuid4()
def start(processID, parallelMode,useGUI):
    """ main entry point into the application """
    Config.processID = processID    # 并行
    Config.parallelMode = parallelMode
    Config.sumoUseGUI = useGUI  # 是否使用sumogui

    info('#####################################', Fore.CYAN)
    info('#      Starting CrowdNav v0.2       #', Fore.CYAN)
    info('#####################################', Fore.CYAN)

    # Check if sumo is installed and available
    SUMODependency.SUMOcheckDeps()
    info('# SUMO-Dependency check OK!', Fore.GREEN)

    # Load the sumo map we are using into Python
    Network.loadNetwork()
    info(Fore.GREEN + "# Map loading OK! " + Fore.RESET)
    info(Fore.CYAN + "# Nodes: " + str(Network.nodesCount()) + " / Edges: " + str(Network.edgesCount()) + Fore.RESET)

    # After the network is loaded, we init the router
    # # 每个node及其可到达的相邻node，及其所对应的egde
    CustomRouter.init()
    info(Fore.GREEN + "# Init the router OK!" + Fore.RESET)
    # Start sumo in the background 连接sumo
    SUMOConnector.start()
    info("\n# SUMO-Application started OK!", Fore.GREEN)
    # Start the simulation 开始仿真步骤
    Simulation.start()
    # Simulation ended, so we shutdown  仿真结束shutdown


def end():
    info(Fore.RED + '# Shutdown' + Fore.RESET)
    traci.close()
    sys.stdout.flush()
