Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
nexedi
cython
Commits
b7c62368
Commit
b7c62368
authored
Aug 21, 2014
by
Robert Bradshaw
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Parse files with standard Python grammar.
parent
17b20862
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
78 additions
and
7 deletions
+78
-7
Cython/Compiler/Main.py
Cython/Compiler/Main.py
+5
-1
Cython/Compiler/Options.py
Cython/Compiler/Options.py
+2
-3
Cython/Parser/ConcreteSyntaxTree.pyx
Cython/Parser/ConcreteSyntaxTree.pyx
+71
-3
No files found.
Cython/Compiler/Main.py
View file @
b7c62368
...
@@ -304,7 +304,7 @@ class Context(object):
...
@@ -304,7 +304,7 @@ class Context(object):
s
=
PyrexScanner
(
f
,
source_desc
,
source_encoding
=
f
.
encoding
,
s
=
PyrexScanner
(
f
,
source_desc
,
source_encoding
=
f
.
encoding
,
scope
=
scope
,
context
=
self
)
scope
=
scope
,
context
=
self
)
tree
=
Parsing
.
p_module
(
s
,
pxd
,
full_module_name
)
tree
=
Parsing
.
p_module
(
s
,
pxd
,
full_module_name
)
if
O
ptions
.
formal_grammar
:
if
self
.
o
ptions
.
formal_grammar
:
try
:
try
:
from
..Parser
import
ConcreteSyntaxTree
from
..Parser
import
ConcreteSyntaxTree
except
ImportError
:
except
ImportError
:
...
@@ -482,6 +482,7 @@ class CompilationOptions(object):
...
@@ -482,6 +482,7 @@ class CompilationOptions(object):
compiler_directives dict Overrides for pragma options (see Options.py)
compiler_directives dict Overrides for pragma options (see Options.py)
evaluate_tree_assertions boolean Test support: evaluate parse tree assertions
evaluate_tree_assertions boolean Test support: evaluate parse tree assertions
language_level integer The Python language level: 2 or 3
language_level integer The Python language level: 2 or 3
formal_grammar boolean Parse the file with the formal grammar
cplus boolean Compile as c++ code
cplus boolean Compile as c++ code
"""
"""
...
@@ -511,6 +512,8 @@ class CompilationOptions(object):
...
@@ -511,6 +512,8 @@ class CompilationOptions(object):
options
[
'compiler_directives'
]
=
directives
options
[
'compiler_directives'
]
=
directives
if
'language_level'
in
directives
and
'language_level'
not
in
kw
:
if
'language_level'
in
directives
and
'language_level'
not
in
kw
:
options
[
'language_level'
]
=
int
(
directives
[
'language_level'
])
options
[
'language_level'
]
=
int
(
directives
[
'language_level'
])
if
'formal_grammar'
in
directives
and
'formal_grammar'
not
in
kw
:
options
[
'formal_grammar'
]
=
directives
[
'formal_grammar'
]
if
'cache'
in
options
:
if
'cache'
in
options
:
if
options
[
'cache'
]
is
True
:
if
options
[
'cache'
]
is
True
:
options
[
'cache'
]
=
os
.
path
.
expanduser
(
"~/.cycache"
)
options
[
'cache'
]
=
os
.
path
.
expanduser
(
"~/.cycache"
)
...
@@ -689,6 +692,7 @@ default_options = dict(
...
@@ -689,6 +692,7 @@ default_options = dict(
relative_path_in_code_position_comments
=
True
,
relative_path_in_code_position_comments
=
True
,
c_line_in_traceback
=
True
,
c_line_in_traceback
=
True
,
language_level
=
2
,
language_level
=
2
,
formal_grammar
=
False
,
gdb_debug
=
False
,
gdb_debug
=
False
,
compile_time_env
=
None
,
compile_time_env
=
None
,
common_utility_include_dir
=
None
,
common_utility_include_dir
=
None
,
...
...
Cython/Compiler/Options.py
View file @
b7c62368
...
@@ -80,9 +80,6 @@ closure_freelist_size = 8
...
@@ -80,9 +80,6 @@ closure_freelist_size = 8
# Should tp_clear() set object fields to None instead of clearing them to NULL?
# Should tp_clear() set object fields to None instead of clearing them to NULL?
clear_to_none
=
True
clear_to_none
=
True
# Should we try parsing files with the formal grammar (experimental)?
formal_grammar
=
True
# Declare compiler directives
# Declare compiler directives
directive_defaults
=
{
directive_defaults
=
{
...
@@ -150,6 +147,8 @@ directive_defaults = {
...
@@ -150,6 +147,8 @@ directive_defaults = {
# experimental, subject to change
# experimental, subject to change
'binding'
:
None
,
'binding'
:
None
,
'freelist'
:
0
,
'freelist'
:
0
,
'formal_grammar'
:
False
,
}
}
# Extra warning directives
# Extra warning directives
...
...
Cython/Parser/ConcreteSyntaxTree.pyx
View file @
b7c62368
cdef
extern
from
"graminit.c"
:
cdef
extern
from
"graminit.c"
:
ctypedef
struct
grammar
:
pass
pass
cdef
grammar
_PyParser_Grammar
cdef
int
Py_file_input
def
p_module
(
source
):
cdef
extern
from
"node.h"
:
print
"Using formal grammar to parse"
,
source
ctypedef
struct
node
void
PyNode_Free
(
node
*
)
int
NCH
(
node
*
)
node
*
CHILD
(
node
*
,
int
)
node
*
RCHILD
(
node
*
,
int
)
short
TYPE
(
node
*
)
char
*
STR
(
node
*
)
cdef
extern
from
"parsetok.h"
:
ctypedef
struct
perrdetail
:
pass
cdef
void
PyParser_SetError
(
perrdetail
*
err
)
except
*
cdef
node
*
PyParser_ParseStringFlagsFilenameEx
(
const
char
*
s
,
const
char
*
filename
,
grammar
*
g
,
int
start
,
perrdetail
*
err_ret
,
int
*
flags
)
import
distutils.sysconfig
import
os
def
extract_names
(
path
):
# All parse tree types are #defined in these files as ints.
type_names
=
{}
for
line
in
open
(
path
):
if
line
.
startswith
(
'#define'
):
try
:
_
,
name
,
value
=
line
.
strip
().
split
()
type_names
[
int
(
value
)]
=
name
except
:
pass
return
type_names
cdef
dict
type_names
=
{}
cdef
print_tree
(
node
*
n
,
indent
=
""
):
if
not
type_names
:
type_names
.
update
(
extract_names
(
os
.
path
.
join
(
distutils
.
sysconfig
.
get_python_inc
(),
'token.h'
)))
type_names
.
update
(
extract_names
(
os
.
path
.
join
(
os
.
path
.
dirname
(
__file__
),
'graminit.h'
)))
print
indent
,
type_names
.
get
(
TYPE
(
n
),
'unknown'
),
<
object
>
STR
(
n
)
if
NCH
(
n
)
==
0
else
NCH
(
n
)
indent
+=
" "
for
i
in
range
(
NCH
(
n
)):
print_tree
(
CHILD
(
n
,
i
),
indent
)
def
p_module
(
path
):
cdef
perrdetail
err
cdef
int
flags
cdef
node
*
n
source
=
open
(
path
).
read
()
n
=
PyParser_ParseStringFlagsFilenameEx
(
source
,
path
,
&
_PyParser_Grammar
,
Py_file_input
,
&
err
,
&
flags
)
if
n
:
print_tree
(
n
)
PyNode_Free
(
n
)
else
:
PyParser_SetError
(
&
err
)
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment