import random

from utils import construct_bits_string

from simple_counter.State import State


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
    states = list(construct_bits_string(s, players))
    initial_states = [0] * players
    for i in range(players):
        if int(states[i]) == 0:
            # No Vote
            initial_states[i] = float(State.NoVote.value)
        if int(states[i]) == 1:
            # Vote
            initial_states[i] = float(State.Vote.value)

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

def step_envs(envs, actions, players):
    this_func = "Counter: step_envs"
    for i, env in enumerate(envs):
        # update state machine
        # action = map_action_idx_to_value(actions[i])
        #BECAREFUL!: MAY need to map action idx to value
        env.transit(actions[0]) #FIXME!: Don't use actions[0] but use actions[i]
        env.states = actions[:] # Doesn't matter since we don't use it
        env._done = True

def map_action_idx_to_value(action):
    if action == 0:
        return int(State.Selected.value)
    else:
        return int(State.NoSelected.value)