o
    \hk                     @   s   d Z ddlmZmZmZmZmZmZ ddlm	Z	m
Z
mZmZmZmZmZmZmZmZ g dZG dd deZG dd deZG d	d
 d
eZG dd deZdS )z
    pygments.lexers.grammar_notation
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

    Lexers for grammar notations like BNF.

    :copyright: Copyright 2006-2025 by the Pygments team, see AUTHORS.
    :license: BSD, see LICENSE for details.
    )
RegexLexerbygroupsincludethisusingwords)
CommentKeywordLiteralNameNumberOperatorPunctuationStringText
Whitespace)BnfLexer	AbnfLexer	JsgfLexerPegLexerc                   @   sX   e Zd ZdZdZdgZdgZdgZdZdZ	dd	e
eejefd
efdefdefgiZdS )r   a#  
    This lexer is for grammar notations which are similar to
    original BNF.

    In order to maximize a number of targets of this lexer,
    let's decide some designs:

    * We don't distinguish `Terminal Symbol`.

    * We do assume that `NonTerminal Symbol` are always enclosed
      with arrow brackets.

    * We do assume that `NonTerminal Symbol` may include
      any printable characters except arrow brackets and ASCII 0x20.
      This assumption is for `RBNF <http://www.rfc-base.org/txt/rfc-5511.txt>`_.

    * We do assume that target notation doesn't support comment.

    * We don't distinguish any operators and punctuation except
      `::=`.

    Though these decision making might cause too minimal highlighting
    and you might be disappointed, but it is reasonable for us.
    BNFbnfz*.bnfz
text/x-bnfz6https://en.wikipedia.org/wiki/Backus%E2%80%93Naur_form2.1rootz(<)([ -;=?-~]+)(>)z::=z[^<>:]+.N)__name__
__module____qualname____doc__namealiases	filenames	mimetypesurlversion_addedr   r   r   Classr   r   tokens r'   r'   c/home/air/segue/gemini/backup/venv/lib/python3.10/site-packages/pygments/lexers/grammar_notation.pyr      s"    r   c                   @   s   e Zd ZdZdZdZdgZdgZdgZdZ	dZ
d	d
ejfdefdefdefdefdefdefdefdefdefdefdefee
ddefdejfdefdefdefdefgiZdS )r   zj
    Lexer for IETF 7405 ABNF.

    (Updates `5234 <http://www.ietf.org/rfc/rfc5234.txt>`_) grammars.
    ABNFz#http://www.ietf.org/rfc/rfc7405.txtabnfz*.abnfztext/x-abnfr   )ALPHABITCHARCRCRLFCTLDIGITDQUOTEHEXDIGHTABLFLWSPOCTETSPVCHARWSPr   z;.*$z(%[si])?"[^"]*"z%b[01]+\-[01]+\bz%b[01]+(\.[01]+)*\bz%d[0-9]+\-[0-9]+\bz%d[0-9]+(\.[0-9]+)*\bz%x[0-9a-fA-F]+\-[0-9a-fA-F]+\bz!%x[0-9a-fA-F]+(\.[0-9a-fA-F]+)*\bz\b[0-9]+\*[0-9]+z
\b[0-9]+\*z\b[0-9]+\*\bsuffixz[a-zA-Z][a-zA-Z0-9-]*\bz(=/|=|/)z[\[\]()]\s+r   N)r   r   r   r   r   r#   r    r!   r"   r$   _core_rulesr   Singler
   r   r   r	   r   r%   r   r   r   r&   r'   r'   r'   r(   r   B   s<    r   c                   @   s  e Zd ZdZdZdZdgZdgZg dZdZ	e
de
d	gd
ejdfdejfdejfgdejfdefdefdefdejfdejdfdejdfedddejfdejdfdeeejefdedfdefgdejd fd!ejfd"ejfgd#ejd fd!ejfd$ejfgded fdefd%efd&ejfgd'ed fd(efdefd)eejeefd*ej fgd+ejd fd,eeejeej!ee"e#d-d.fd/eejej!fd0ejfgd1eeejfe
d	d2ejfgd3	Z$d4S )5r   z.
    For JSpeech Grammar Format grammars.
    JSGFzhttps://www.w3.org/TR/jsgf/jsgfz*.jsgf)zapplication/jsgfzapplication/x-jsgfz	text/jsgfz2.2commentsnon-commentsz
/\*\*(?!/)documentation commentz/\*[\w\W]*?\*/z//.*$z\A#JSGF[^;]*r?   ;z[=|()\[\]*+]z/[^/]+/"stringz\{tag)importpublicr<   r=   z	grammar\bgrammar namez(<)(NULL|VOID)(>)<rulenamez\w+|[^\s;=|()\[\]*+/"{<\w]+z#popz\\.z[^\\"]+z\}z[^\\}]+\.z[^;\s.]+>r;   z([^.>]+)(\s*)(\.)z[^.>]+z\*/zH^(\s*)(\*?)(\s*)(@(?:example|see))(\s+)([\w\W]*?(?=(?:^\s*\*?\s*@|\*/)))example)statez(^\s*\*?\s*)(@\S*)z[^*\n@]+|\w|\Wz(\n\s*)(\*)r   )	r   rD   rE   rI   rJ   rM   rO   rF   rR   N)%r   r   r   r   r   r#   r    r!   r"   r$   r   r   	MultilinerA   Preprocr   r   r   r   Floatr   DoubleOtherr   r	   Reservedr   r   Builtinr   Escape	NamespaceConstantSpecialr   r   r&   r'   r'   r'   r(   r      s    







r   c                   @   s|   e Zd ZdZdZdZdgZdgZdgZdZ	dd	e
jfd
efdefdefdeeeefdejfdejfdejfdefg	iZdS )r   u  
    This lexer is for Parsing Expression Grammars (PEG).

    Various implementations of PEG have made different decisions
    regarding the syntax, so let's try to be accommodating:

    * `<-`, `←`, `:`, and `=` are all accepted as rule operators.

    * Both `|` and `/` are choice operators.

    * `^`, `↑`, and `~` are cut operators.

    * A single `a-z` character immediately before a string, or
      multiple `a-z` characters following a string, are part of the
      string (e.g., `r"..."` or `"..."ilmsuxa`).
    PEGz#https://bford.info/pub/lang/peg.pdfpegz*.pegz
text/x-pegz2.6r   z#.*$u   <-|[←:=/|&!?*+^↑~]z[()]rP   z (\[)([^\]]*(?:\\.[^\]\\]*)*)(\])z$[a-z]?"[^"\\]*(?:\\.[^"\\]*)*"[a-z]*z$[a-z]?'[^'\\]*(?:\\.[^'\\]*)*'[a-z]*u#   [^\s<←:=/|&!?*+\^↑~()\[\]"\'#]+r   N)r   r   r   r   r   r#   r    r!   r"   r$   r   rA   r   r   r	   r   r   rW   r   r%   r   r&   r'   r'   r'   r(   r      s,    
r   N)r   pygments.lexerr   r   r   r   r   r   pygments.tokenr   r	   r
   r   r   r   r   r   r   r   __all__r   r   r   r   r'   r'   r'   r(   <module>   s     
00BM