[ Avaa Bypassed ]




Upload:

Command:

hmhc3928@18.117.74.47: ~ $
�
p��fc@sEdZddlZddlmZmZdejfd��YZdS(s�Convert graminit.[ch] spit out by pgen to Python code.

Pgen is the Python parser generator.  It is useful to quickly create a
parser from a grammar file in Python's grammar notation.  But I don't
want my parsers to be written in C (yet), so I'm translating the
parsing tables to Python data structures and writing a Python parse
engine.

Note that the token numbers are constants determined by the standard
Python tokenizer.  The standard token module defines these numbers and
their names (the names are not used much).  The token numbers are
hardcoded into the Python tokenizer and into pgen.  A Python
implementation of the Python tokenizer is also available, in the
standard tokenize module.

On the other hand, symbol numbers (representing the grammar's
non-terminals) are assigned by pgen based on the actual grammar
input.

Note: this module is pretty much obsolete; the pgen module generates
equivalent grammar tables directly from the Grammar.txt input file
without having to invoke the Python pgen C program.

i����N(tgrammarttokent	ConvertercBs2eZdZd�Zd�Zd�Zd�ZRS(s2Grammar subclass that reads classic pgen output files.

    The run() method reads the tables as produced by the pgen parser
    generator, typically contained in two C files, graminit.h and
    graminit.c.  The other methods are for internal use only.

    See the base class for more documentation.

    cCs(|j|�|j|�|j�dS(s<Load the grammar tables from the text files written by pgen.N(tparse_graminit_htparse_graminit_ct
finish_off(tselft
graminit_ht
graminit_c((s*/usr/lib64/python2.7/lib2to3/pgen2/conv.pytrun/s

c	Csyt|�}Wn#tk
r5}d||fGHtSXi|_i|_d}x�|D]�}|d7}tjd|�}|r�|j�r�d|||j�fGHqU|j�\}}t	|�}||jks�t
�||jks�t
�||j|<||j|<qUWtS(s�Parse the .h file written by pgen.  (Internal)

        This file is a sequence of #define statements defining the
        nonterminals of the grammar as numbers.  We build two tables
        mapping the numbers to names and back.

        sCan't open %s: %siis^#define\s+(\w+)\s+(\d+)$s%s(%s): can't parse %s(topentIOErrortFalset
symbol2numbert
number2symboltretmatchtstriptgroupstinttAssertionErrortTrue(	Rtfilenametfterrtlinenotlinetmotsymboltnumber((s*/usr/lib64/python2.7/lib2to3/pgen2/conv.pyR5s*		

	
c!Cs�	yt|�}Wn#tk
r5}d||fGHtSXd}|d|j�}}|dksqt||f��|d|j�}}|dks�t||f��|d|j�}}i}g}x�|jd�r�xC|jd�r tjd|�}|st||f��tt	|j
��\}	}
}g}x�t|�D]u}
|d|j�}}tjd|�}|s�t||f��tt	|j
��\}}|j||f�qHW|d|j�}}|d	ks�t||f��|||	|
f<|d|j�}}q�Wtjd
|�}|sKt||f��tt	|j
��\}}|t
|�ks�t||f��g}x�t|�D]�}
|d|j�}}tjd|�}|s�t||f��tt	|j
��\}}	}
||	|
f}|t
|�ks6t||f��|j|�q�W|j|�|d|j�}}|d	ks�t||f��|d|j�}}q�W||_i}tjd|�}|s�t||f��t	|jd��}x�t|�D]�}|d|j�}}tjd
|�}|sFt||f��|jd�}tt	|jdddd��\}}}}|j||ks�t||f��|j||ks�t||f��|dks�t||f��||}|t
|�kst||f��|d|j�}}tjd|�}|sYt||f��i}t|jd��}x`t|�D]R\}}t|�}x7td�D])}|d|>@r�d||d|<q�q�Wq�W||f||<q�W|d|j�}}|d	ks t||f��||_g}|d|j�}}tjd|�}|spt||f��t	|jd��}x�t|�D]�}|d|j�}}tjd|�}|s�t||f��|j
�\}}t	|�}|dkrd}nt|�}|j||f�q�W|d|j�}}|d	ksdt||f��||_|d|j�}}|dks�t||f��|d|j�}}tjd|�}|s�t||f��t	|jd��}|t
|j�kst�|d|j�}}|dksHt||f��|d|j�}}tjd|�}|s�t||f��t	|jd��}|t
|j�ks�t||f��|d|j�}}tjd|�}|s	t||f��t	|jd��} | |jks<	t||f��| |_|d|j�}}|d	ksz	t||f��y|d|j�}}Wntk
r�	nXds�	t||f��dS(s�Parse the .c file written by pgen.  (Internal)

        The file looks as follows.  The first two lines are always this:

        #include "pgenheaders.h"
        #include "grammar.h"

        After that come four blocks:

        1) one or more state definitions
        2) a table defining dfas
        3) a table defining labels
        4) a struct defining the grammar

        A state definition has the following form:
        - one or more arc arrays, each of the form:
          static arc arcs_<n>_<m>[<k>] = {
                  {<i>, <j>},
                  ...
          };
        - followed by a state array, of the form:
          static state states_<s>[<t>] = {
                  {<k>, arcs_<n>_<m>},
                  ...
          };

        sCan't open %s: %siis#include "pgenheaders.h"
s#include "grammar.h"
sstatic arc s)static arc arcs_(\d+)_(\d+)\[(\d+)\] = {$s\s+{(\d+), (\d+)},$s};
s'static state states_(\d+)\[(\d+)\] = {$s\s+{(\d+), arcs_(\d+)_(\d+)},$sstatic dfa dfas\[(\d+)\] = {$s0\s+{(\d+), "(\w+)", (\d+), (\d+), states_(\d+),$iiiis\s+("(?:\\\d\d\d)*")},$is!static label labels\[(\d+)\] = {$s\s+{(\d+), (0|"\w+")},$t0sgrammar _PyParser_Grammar = {
s
\s+(\d+),$s	dfas,
s\s+{(\d+), labels},$s	\s+(\d+)$N(R
RRtnextRt
startswithRRtmapRRtrangetappendtlentstatestgroupR
Rtevalt	enumeratetordtdfastNonetlabelststartt
StopIteration(!RRRRRRtallarcsR%Rtntmtktarcst_titjtstttstateR*tndfasRRtxtytztfirstt	rawbitsettctbyteR,tnlabelsR-((s*/usr/lib64/python2.7/lib2to3/pgen2/conv.pyRTs�		$$
			-%%
$			'!	
cCs�i|_i|_xjt|j�D]Y\}\}}|tjkr_|dk	r_||j|<q"|dkr"||j|<q"q"WdS(s1Create additional useful structures.  (Internal).N(tkeywordsttokensR(R,RtNAMER+(Rtilabelttypetvalue((s*/usr/lib64/python2.7/lib2to3/pgen2/conv.pyR�s		"(t__name__t
__module__t__doc__R	RRR(((s*/usr/lib64/python2.7/lib2to3/pgen2/conv.pyR$s
				�(RKRtpgen2RRtGrammarR(((s*/usr/lib64/python2.7/lib2to3/pgen2/conv.pyt<module>s

Filemanager

Name Type Size Permission Actions
.__init__.pyo.40009 File 174 B 0644
.grammar.pyo.40009 File 5.87 KB 0644
.token.pyo.40009 File 2.22 KB 0644
__init__.py File 143 B 0644
__init__.pyc File 174 B 0644
__init__.pyo File 174 B 0644
conv.py File 9.4 KB 0644
conv.pyc File 8 KB 0644
conv.pyo File 6.87 KB 0644
driver.py File 5.04 KB 0644
driver.pyc File 5.26 KB 0644
driver.pyo File 5.2 KB 0644
grammar.py File 5.24 KB 0644
grammar.pyc File 5.87 KB 0644
grammar.pyo File 5.87 KB 0644
literals.py File 1.58 KB 0644
literals.pyc File 1.97 KB 0644
literals.pyo File 1.74 KB 0644
parse.py File 7.86 KB 0644
parse.pyc File 7.07 KB 0644
parse.pyo File 7.03 KB 0644
pgen.py File 13.46 KB 0644
pgen.pyc File 11.89 KB 0644
pgen.pyo File 11.3 KB 0644
token.py File 1.21 KB 0755
token.pyc File 2.22 KB 0644
token.pyo File 2.22 KB 0644
tokenize.py File 18.66 KB 0644
tokenize.pyc File 16.46 KB 0644
tokenize.pyo File 16.37 KB 0644