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

def marked_reversal_cfg() -> ContextFreeGrammarContainer:
    a, b, m = map(Symbol, range(3))
    S, A, B, C, D = map(Nonterminal, range(5))
    M = ContextFreeGrammarContainer(
        num_nonterminals=5,
        alphabet_size=3,
        start_symbol=S
    )
    M.add_production(Production(S, (m,)))
    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
