from recognizers.automata.automaton import Symbol
from recognizers.grammars.grammar import Nonterminal
from recognizers.grammars.context_free_grammar import (
    ContextFreeGrammarContainer,
    Production
)

def unmarked_reversal_cfg() -> ContextFreeGrammarContainer:
    a, b = map(Symbol, range(2))
    S, A, B, C, D = map(Nonterminal, range(5))
    M = ContextFreeGrammarContainer(
        num_nonterminals=5,
        alphabet_size=2,
        start_symbol=S
    )
    M.add_production(Production(S, ()))
    M.add_production(Production(S, (C, A)))
    M.add_production(Production(C, (A, S)))
    M.add_production(Production(S, (D, B)))
    M.add_production(Production(D, (B, S)))
    M.add_production(Production(A, (a,)))
    M.add_production(Production(B, (b,)))

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