from recognizers.automata.automaton import State, Symbol
from recognizers.automata.reserved import ReservedSymbol
from recognizers.automata.pushdown_automaton import (
    PushdownAutomatonContainer,
    PushdownAutomatonTransition,
    StackSymbol
)

def unmarked_reversal_pda() -> PushdownAutomatonContainer:
    q0, q1, q2 = map(State, range(3))
    a, b = map(Symbol, range(2))
    S, A, B = map(StackSymbol, range(3))
    M = PushdownAutomatonContainer(
        num_states=3,
        alphabet_size=2,
        stack_alphabet_size=3,
        initial_state=q0,
        initial_stack_symbol=S,
        accept_state=q2
    )
    M.add_transition(PushdownAutomatonTransition(q0, a, q1, S, (A,)))
    M.add_transition(PushdownAutomatonTransition(q0, b, q1, S, (B,)))
    M.add_transition(PushdownAutomatonTransition(q0, ReservedSymbol.EPSILON, q2, S, ()))
    M.add_transition(PushdownAutomatonTransition(q1, a, q1, A, (A, A)))
    M.add_transition(PushdownAutomatonTransition(q1, a, q1, B, (B, A)))
    M.add_transition(PushdownAutomatonTransition(q1, b, q1, A, (A, B)))
    M.add_transition(PushdownAutomatonTransition(q1, b, q1, B, (B, B)))
    M.add_transition(PushdownAutomatonTransition(q1, a, q2, A, ()))
    M.add_transition(PushdownAutomatonTransition(q1, b, q2, B, ()))
    M.add_transition(PushdownAutomatonTransition(q2, a, q2, A, ()))
    M.add_transition(PushdownAutomatonTransition(q2, b, q2, B, ()))

    alphabet = [str(x) for x in list(range(M._alphabet_size))]
    return M, alphabet
