import random

from distributed_locking.State import State
from utils import construct_bits_string


def reset_envs(envs, players, input=None):
    for env in envs:
        env.my_reset()

    if input is None:
        s = random.randint(0, 2 ** players - 1)
    else:
        s = input.get_init()
    states = list(construct_bits_string(s, players))
    initial_states = [0] * players
    for i in range(players):
        if int(states[i]) == 0:
            # no need lock
            initial_states[i] = int(State.NoNeed.value)
        if int(states[i]) == 1:
            # need lock
            initial_states[i] = int(State.Need.value)

    for i, env in enumerate(envs):
        env.initial_states = initial_states[:]
        env.state_machine.set_initial(initial_states[i])
        env.states = [i] + initial_states[:]

def step_envs(envs, actions, players, input=None):
    this_func = "step_envs"
    for i, env in enumerate(envs):
        # update state machine
        env.transit(actions[i])
        env.states = [i] + actions[:]
        env._done = True
