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
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Gwenaël Samain
cython
Commits
8dbe6a2d
Commit
8dbe6a2d
authored
May 06, 2010
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
parser: rename p_simple_expr to p_test, following Python grammar
parent
8efa5df2
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
52 additions
and
59 deletions
+52
-59
Cython/Compiler/Parsing.py
Cython/Compiler/Parsing.py
+52
-59
No files found.
Cython/Compiler/Parsing.py
View file @
8dbe6a2d
...
@@ -87,25 +87,6 @@ def p_binop_expr(s, ops, p_sub_expr):
...
@@ -87,25 +87,6 @@ def p_binop_expr(s, ops, p_sub_expr):
n1
.
truedivision
=
None
# unknown
n1
.
truedivision
=
None
# unknown
return
n1
return
n1
#expression: or_test [if or_test else test] | lambda_form
# actually:
#test: or_test ['if' or_test 'else' test] | lambdef
def
p_simple_expr
(
s
):
if
s
.
sy
==
'lambda'
:
return
p_lambdef
(
s
)
pos
=
s
.
position
()
expr
=
p_or_test
(
s
)
if
s
.
sy
==
'if'
:
s
.
next
()
test
=
p_or_test
(
s
)
s
.
expect
(
'else'
)
other
=
p_test
(
s
)
return
ExprNodes
.
CondExprNode
(
pos
,
test
=
test
,
true_val
=
expr
,
false_val
=
other
)
else
:
return
expr
#lambdef: 'lambda' [varargslist] ':' test
#lambdef: 'lambda' [varargslist] ':' test
def
p_lambdef
(
s
,
allow_conditional
=
True
):
def
p_lambdef
(
s
,
allow_conditional
=
True
):
...
@@ -120,7 +101,7 @@ def p_lambdef(s, allow_conditional=True):
...
@@ -120,7 +101,7 @@ def p_lambdef(s, allow_conditional=True):
s
,
terminator
=
':'
,
annotated
=
False
)
s
,
terminator
=
':'
,
annotated
=
False
)
s
.
expect
(
':'
)
s
.
expect
(
':'
)
if
allow_conditional
:
if
allow_conditional
:
expr
=
p_
simple_expr
(
s
)
expr
=
p_
test
(
s
)
else
:
else
:
expr
=
p_test_nocond
(
s
)
expr
=
p_test_nocond
(
s
)
return
ExprNodes
.
LambdaNode
(
return
ExprNodes
.
LambdaNode
(
...
@@ -133,10 +114,21 @@ def p_lambdef(s, allow_conditional=True):
...
@@ -133,10 +114,21 @@ def p_lambdef(s, allow_conditional=True):
def
p_lambdef_nocond
(
s
):
def
p_lambdef_nocond
(
s
):
return
p_lambdef
(
s
,
allow_conditional
=
False
)
return
p_lambdef
(
s
,
allow_conditional
=
False
)
#test: or_test | lambdef
#test: or_test
['if' or_test 'else' test]
| lambdef
def
p_test
(
s
):
def
p_test
(
s
):
return
p_or_test
(
s
)
if
s
.
sy
==
'lambda'
:
return
p_lambdef
(
s
)
pos
=
s
.
position
()
expr
=
p_or_test
(
s
)
if
s
.
sy
==
'if'
:
s
.
next
()
test
=
p_or_test
(
s
)
s
.
expect
(
'else'
)
other
=
p_test
(
s
)
return
ExprNodes
.
CondExprNode
(
pos
,
test
=
test
,
true_val
=
expr
,
false_val
=
other
)
else
:
return
expr
#test_nocond: or_test | lambdef_nocond
#test_nocond: or_test | lambdef_nocond
...
@@ -319,7 +311,7 @@ def p_sizeof(s):
...
@@ -319,7 +311,7 @@ def p_sizeof(s):
# If it is actually a type, but parsable as an expression,
# If it is actually a type, but parsable as an expression,
# we treat it as an expression here.
# we treat it as an expression here.
if
looking_at_expr
(
s
):
if
looking_at_expr
(
s
):
operand
=
p_
simple_expr
(
s
)
operand
=
p_
test
(
s
)
node
=
ExprNodes
.
SizeofVarNode
(
pos
,
operand
=
operand
)
node
=
ExprNodes
.
SizeofVarNode
(
pos
,
operand
=
operand
)
else
:
else
:
base_type
=
p_c_base_type
(
s
)
base_type
=
p_c_base_type
(
s
)
...
@@ -397,9 +389,9 @@ def p_call(s, function):
...
@@ -397,9 +389,9 @@ def p_call(s, function):
s
.
error
(
"only one star-arg parameter allowed"
,
s
.
error
(
"only one star-arg parameter allowed"
,
pos
=
s
.
position
())
pos
=
s
.
position
())
s
.
next
()
s
.
next
()
star_arg
=
p_
simple_expr
(
s
)
star_arg
=
p_
test
(
s
)
else
:
else
:
arg
=
p_
simple_expr
(
s
)
arg
=
p_
test
(
s
)
if
s
.
sy
==
'='
:
if
s
.
sy
==
'='
:
s
.
next
()
s
.
next
()
if
not
arg
.
is_name
:
if
not
arg
.
is_name
:
...
@@ -407,7 +399,7 @@ def p_call(s, function):
...
@@ -407,7 +399,7 @@ def p_call(s, function):
pos
=
arg
.
pos
)
pos
=
arg
.
pos
)
encoded_name
=
EncodedString
(
arg
.
name
)
encoded_name
=
EncodedString
(
arg
.
name
)
keyword
=
ExprNodes
.
IdentifierStringNode
(
arg
.
pos
,
value
=
encoded_name
)
keyword
=
ExprNodes
.
IdentifierStringNode
(
arg
.
pos
,
value
=
encoded_name
)
arg
=
p_
simple_expr
(
s
)
arg
=
p_
test
(
s
)
keyword_args
.
append
((
keyword
,
arg
))
keyword_args
.
append
((
keyword
,
arg
))
else
:
else
:
if
keyword_args
:
if
keyword_args
:
...
@@ -426,7 +418,7 @@ def p_call(s, function):
...
@@ -426,7 +418,7 @@ def p_call(s, function):
positional_args
=
[
p_genexp
(
s
,
positional_args
[
0
])
]
positional_args
=
[
p_genexp
(
s
,
positional_args
[
0
])
]
elif
s
.
sy
==
'**'
:
elif
s
.
sy
==
'**'
:
s
.
next
()
s
.
next
()
starstar_arg
=
p_
simple_expr
(
s
)
starstar_arg
=
p_
test
(
s
)
if
s
.
sy
==
','
:
if
s
.
sy
==
','
:
s
.
next
()
s
.
next
()
s
.
expect
(
')'
)
s
.
expect
(
')'
)
...
@@ -518,7 +510,7 @@ def p_slice_element(s, follow_set):
...
@@ -518,7 +510,7 @@ def p_slice_element(s, follow_set):
# Simple expression which may be missing iff
# Simple expression which may be missing iff
# it is followed by something in follow_set.
# it is followed by something in follow_set.
if
s
.
sy
not
in
follow_set
:
if
s
.
sy
not
in
follow_set
:
return
p_
simple_expr
(
s
)
return
p_
test
(
s
)
else
:
else
:
return
None
return
None
...
@@ -774,7 +766,7 @@ def p_list_maker(s):
...
@@ -774,7 +766,7 @@ def p_list_maker(s):
if
s
.
sy
==
']'
:
if
s
.
sy
==
']'
:
s
.
expect
(
']'
)
s
.
expect
(
']'
)
return
ExprNodes
.
ListNode
(
pos
,
args
=
[])
return
ExprNodes
.
ListNode
(
pos
,
args
=
[])
expr
=
p_
simple_expr
(
s
)
expr
=
p_
test
(
s
)
if
s
.
sy
==
'for'
:
if
s
.
sy
==
'for'
:
target
=
ExprNodes
.
ListNode
(
pos
,
args
=
[])
target
=
ExprNodes
.
ListNode
(
pos
,
args
=
[])
append
=
ExprNodes
.
ComprehensionAppendNode
(
append
=
ExprNodes
.
ComprehensionAppendNode
(
...
@@ -828,7 +820,7 @@ def p_dict_or_set_maker(s):
...
@@ -828,7 +820,7 @@ def p_dict_or_set_maker(s):
if
s
.
sy
==
'}'
:
if
s
.
sy
==
'}'
:
s
.
next
()
s
.
next
()
return
ExprNodes
.
DictNode
(
pos
,
key_value_pairs
=
[])
return
ExprNodes
.
DictNode
(
pos
,
key_value_pairs
=
[])
item
=
p_
simple_expr
(
s
)
item
=
p_
test
(
s
)
if
s
.
sy
==
','
or
s
.
sy
==
'}'
:
if
s
.
sy
==
','
or
s
.
sy
==
'}'
:
# set literal
# set literal
values
=
[
item
]
values
=
[
item
]
...
@@ -836,7 +828,7 @@ def p_dict_or_set_maker(s):
...
@@ -836,7 +828,7 @@ def p_dict_or_set_maker(s):
s
.
next
()
s
.
next
()
if
s
.
sy
==
'}'
:
if
s
.
sy
==
'}'
:
break
break
values
.
append
(
p_
simple_expr
(
s
)
)
values
.
append
(
p_
test
(
s
)
)
s
.
expect
(
'}'
)
s
.
expect
(
'}'
)
return
ExprNodes
.
SetNode
(
pos
,
args
=
values
)
return
ExprNodes
.
SetNode
(
pos
,
args
=
values
)
elif
s
.
sy
==
'for'
:
elif
s
.
sy
==
'for'
:
...
@@ -852,7 +844,7 @@ def p_dict_or_set_maker(s):
...
@@ -852,7 +844,7 @@ def p_dict_or_set_maker(s):
# dict literal or comprehension
# dict literal or comprehension
key
=
item
key
=
item
s
.
next
()
s
.
next
()
value
=
p_
simple_expr
(
s
)
value
=
p_
test
(
s
)
if
s
.
sy
==
'for'
:
if
s
.
sy
==
'for'
:
# dict comprehension
# dict comprehension
target
=
ExprNodes
.
DictNode
(
pos
,
key_value_pairs
=
[])
target
=
ExprNodes
.
DictNode
(
pos
,
key_value_pairs
=
[])
...
@@ -870,9 +862,9 @@ def p_dict_or_set_maker(s):
...
@@ -870,9 +862,9 @@ def p_dict_or_set_maker(s):
s
.
next
()
s
.
next
()
if
s
.
sy
==
'}'
:
if
s
.
sy
==
'}'
:
break
break
key
=
p_
simple_expr
(
s
)
key
=
p_
test
(
s
)
s
.
expect
(
':'
)
s
.
expect
(
':'
)
value
=
p_
simple_expr
(
s
)
value
=
p_
test
(
s
)
items
.
append
(
items
.
append
(
ExprNodes
.
DictItemNode
(
key
.
pos
,
key
=
key
,
value
=
value
))
ExprNodes
.
DictItemNode
(
key
.
pos
,
key
=
key
,
value
=
value
))
s
.
expect
(
'}'
)
s
.
expect
(
'}'
)
...
@@ -893,7 +885,7 @@ def p_backquote_expr(s):
...
@@ -893,7 +885,7 @@ def p_backquote_expr(s):
def
p_simple_expr_list
(
s
):
def
p_simple_expr_list
(
s
):
exprs
=
[]
exprs
=
[]
while
s
.
sy
not
in
expr_terminators
:
while
s
.
sy
not
in
expr_terminators
:
expr
=
p_
simple_expr
(
s
)
expr
=
p_
test
(
s
)
exprs
.
append
(
expr
)
exprs
.
append
(
expr
)
if
s
.
sy
!=
','
:
if
s
.
sy
!=
','
:
break
break
...
@@ -902,7 +894,7 @@ def p_simple_expr_list(s):
...
@@ -902,7 +894,7 @@ def p_simple_expr_list(s):
def
p_expr
(
s
):
def
p_expr
(
s
):
pos
=
s
.
position
()
pos
=
s
.
position
()
expr
=
p_
simple_expr
(
s
)
expr
=
p_
test
(
s
)
if
s
.
sy
==
','
:
if
s
.
sy
==
','
:
s
.
next
()
s
.
next
()
exprs
=
[
expr
]
+
p_simple_expr_list
(
s
)
exprs
=
[
expr
]
+
p_simple_expr_list
(
s
)
...
@@ -1000,7 +992,7 @@ def p_print_statement(s):
...
@@ -1000,7 +992,7 @@ def p_print_statement(s):
s
.
next
()
s
.
next
()
if
s
.
sy
==
'>>'
:
if
s
.
sy
==
'>>'
:
s
.
next
()
s
.
next
()
stream
=
p_
simple_expr
(
s
)
stream
=
p_
test
(
s
)
if
s
.
sy
==
','
:
if
s
.
sy
==
','
:
s
.
next
()
s
.
next
()
ends_with_comma
=
s
.
sy
in
(
'NEWLINE'
,
'EOF'
)
ends_with_comma
=
s
.
sy
in
(
'NEWLINE'
,
'EOF'
)
...
@@ -1008,13 +1000,13 @@ def p_print_statement(s):
...
@@ -1008,13 +1000,13 @@ def p_print_statement(s):
stream
=
None
stream
=
None
args
=
[]
args
=
[]
if
s
.
sy
not
in
(
'NEWLINE'
,
'EOF'
):
if
s
.
sy
not
in
(
'NEWLINE'
,
'EOF'
):
args
.
append
(
p_
simple_expr
(
s
))
args
.
append
(
p_
test
(
s
))
while
s
.
sy
==
','
:
while
s
.
sy
==
','
:
s
.
next
()
s
.
next
()
if
s
.
sy
in
(
'NEWLINE'
,
'EOF'
):
if
s
.
sy
in
(
'NEWLINE'
,
'EOF'
):
ends_with_comma
=
1
ends_with_comma
=
1
break
break
args
.
append
(
p_
simple_expr
(
s
))
args
.
append
(
p_
test
(
s
))
arg_tuple
=
ExprNodes
.
TupleNode
(
pos
,
args
=
args
)
arg_tuple
=
ExprNodes
.
TupleNode
(
pos
,
args
=
args
)
return
Nodes
.
PrintStatNode
(
pos
,
return
Nodes
.
PrintStatNode
(
pos
,
arg_tuple
=
arg_tuple
,
stream
=
stream
,
arg_tuple
=
arg_tuple
,
stream
=
stream
,
...
@@ -1027,10 +1019,10 @@ def p_exec_statement(s):
...
@@ -1027,10 +1019,10 @@ def p_exec_statement(s):
args
=
[
p_bit_expr
(
s
)
]
args
=
[
p_bit_expr
(
s
)
]
if
s
.
sy
==
'in'
:
if
s
.
sy
==
'in'
:
s
.
next
()
s
.
next
()
args
.
append
(
p_
simple_expr
(
s
))
args
.
append
(
p_
test
(
s
))
if
s
.
sy
==
','
:
if
s
.
sy
==
','
:
s
.
next
()
s
.
next
()
args
.
append
(
p_
simple_expr
(
s
))
args
.
append
(
p_
test
(
s
))
else
:
else
:
error
(
pos
,
"'exec' currently requires a target mapping (globals/locals)"
)
error
(
pos
,
"'exec' currently requires a target mapping (globals/locals)"
)
return
Nodes
.
ExecStatNode
(
pos
,
args
=
args
)
return
Nodes
.
ExecStatNode
(
pos
,
args
=
args
)
...
@@ -1039,6 +1031,7 @@ def p_del_statement(s):
...
@@ -1039,6 +1031,7 @@ def p_del_statement(s):
# s.sy == 'del'
# s.sy == 'del'
pos
=
s
.
position
()
pos
=
s
.
position
()
s
.
next
()
s
.
next
()
# FIXME: 'exprlist' in Python
args
=
p_simple_expr_list
(
s
)
args
=
p_simple_expr_list
(
s
)
return
Nodes
.
DelStatNode
(
pos
,
args
=
args
)
return
Nodes
.
DelStatNode
(
pos
,
args
=
args
)
...
@@ -1079,13 +1072,13 @@ def p_raise_statement(s):
...
@@ -1079,13 +1072,13 @@ def p_raise_statement(s):
exc_value
=
None
exc_value
=
None
exc_tb
=
None
exc_tb
=
None
if
s
.
sy
not
in
statement_terminators
:
if
s
.
sy
not
in
statement_terminators
:
exc_type
=
p_
simple_expr
(
s
)
exc_type
=
p_
test
(
s
)
if
s
.
sy
==
','
:
if
s
.
sy
==
','
:
s
.
next
()
s
.
next
()
exc_value
=
p_
simple_expr
(
s
)
exc_value
=
p_
test
(
s
)
if
s
.
sy
==
','
:
if
s
.
sy
==
','
:
s
.
next
()
s
.
next
()
exc_tb
=
p_
simple_expr
(
s
)
exc_tb
=
p_
test
(
s
)
if
exc_type
or
exc_value
or
exc_tb
:
if
exc_type
or
exc_value
or
exc_tb
:
return
Nodes
.
RaiseStatNode
(
pos
,
return
Nodes
.
RaiseStatNode
(
pos
,
exc_type
=
exc_type
,
exc_type
=
exc_type
,
...
@@ -1229,10 +1222,10 @@ def p_assert_statement(s):
...
@@ -1229,10 +1222,10 @@ def p_assert_statement(s):
# s.sy == 'assert'
# s.sy == 'assert'
pos
=
s
.
position
()
pos
=
s
.
position
()
s
.
next
()
s
.
next
()
cond
=
p_
simple_expr
(
s
)
cond
=
p_
test
(
s
)
if
s
.
sy
==
','
:
if
s
.
sy
==
','
:
s
.
next
()
s
.
next
()
value
=
p_
simple_expr
(
s
)
value
=
p_
test
(
s
)
else
:
else
:
value
=
None
value
=
None
return
Nodes
.
AssertStatNode
(
pos
,
cond
=
cond
,
value
=
value
)
return
Nodes
.
AssertStatNode
(
pos
,
cond
=
cond
,
value
=
value
)
...
@@ -1253,7 +1246,7 @@ def p_if_statement(s):
...
@@ -1253,7 +1246,7 @@ def p_if_statement(s):
def
p_if_clause
(
s
):
def
p_if_clause
(
s
):
pos
=
s
.
position
()
pos
=
s
.
position
()
test
=
p_
simple_expr
(
s
)
test
=
p_
test
(
s
)
body
=
p_suite
(
s
)
body
=
p_suite
(
s
)
return
Nodes
.
IfClauseNode
(
pos
,
return
Nodes
.
IfClauseNode
(
pos
,
condition
=
test
,
body
=
body
)
condition
=
test
,
body
=
body
)
...
@@ -1269,7 +1262,7 @@ def p_while_statement(s):
...
@@ -1269,7 +1262,7 @@ def p_while_statement(s):
# s.sy == 'while'
# s.sy == 'while'
pos
=
s
.
position
()
pos
=
s
.
position
()
s
.
next
()
s
.
next
()
test
=
p_
simple_expr
(
s
)
test
=
p_
test
(
s
)
body
=
p_suite
(
s
)
body
=
p_suite
(
s
)
else_clause
=
p_else_clause
(
s
)
else_clause
=
p_else_clause
(
s
)
return
Nodes
.
WhileStatNode
(
pos
,
return
Nodes
.
WhileStatNode
(
pos
,
...
@@ -1399,10 +1392,10 @@ def p_except_clause(s):
...
@@ -1399,10 +1392,10 @@ def p_except_clause(s):
exc_type
=
None
exc_type
=
None
exc_value
=
None
exc_value
=
None
if
s
.
sy
!=
':'
:
if
s
.
sy
!=
':'
:
exc_type
=
p_
simple_expr
(
s
)
exc_type
=
p_
test
(
s
)
if
s
.
sy
==
','
or
(
s
.
sy
==
'IDENT'
and
s
.
systring
==
'as'
):
if
s
.
sy
==
','
or
(
s
.
sy
==
'IDENT'
and
s
.
systring
==
'as'
):
s
.
next
()
s
.
next
()
exc_value
=
p_
simple_expr
(
s
)
exc_value
=
p_
test
(
s
)
elif
s
.
sy
==
'IDENT'
and
s
.
systring
==
'as'
:
elif
s
.
sy
==
'IDENT'
and
s
.
systring
==
'as'
:
# Py3 syntax requires a name here
# Py3 syntax requires a name here
s
.
next
()
s
.
next
()
...
@@ -1717,7 +1710,7 @@ def p_positional_and_keyword_args(s, end_sy_set, templates = None):
...
@@ -1717,7 +1710,7 @@ def p_positional_and_keyword_args(s, end_sy_set, templates = None):
s
.
next
()
# s.sy is '='
s
.
next
()
# s.sy is '='
s
.
next
()
s
.
next
()
if
looking_at_expr
(
s
):
if
looking_at_expr
(
s
):
arg
=
p_
simple_expr
(
s
)
arg
=
p_
test
(
s
)
else
:
else
:
base_type
=
p_c_base_type
(
s
,
templates
=
templates
)
base_type
=
p_c_base_type
(
s
,
templates
=
templates
)
declarator
=
p_c_declarator
(
s
,
empty
=
1
)
declarator
=
p_c_declarator
(
s
,
empty
=
1
)
...
@@ -1731,7 +1724,7 @@ def p_positional_and_keyword_args(s, end_sy_set, templates = None):
...
@@ -1731,7 +1724,7 @@ def p_positional_and_keyword_args(s, end_sy_set, templates = None):
else
:
else
:
if
looking_at_expr
(
s
):
if
looking_at_expr
(
s
):
arg
=
p_
simple_expr
(
s
)
arg
=
p_
test
(
s
)
else
:
else
:
base_type
=
p_c_base_type
(
s
,
templates
=
templates
)
base_type
=
p_c_base_type
(
s
,
templates
=
templates
)
declarator
=
p_c_declarator
(
s
,
empty
=
1
)
declarator
=
p_c_declarator
(
s
,
empty
=
1
)
...
@@ -2065,7 +2058,7 @@ def p_c_simple_declarator(s, ctx, empty, is_type, cmethod_flag,
...
@@ -2065,7 +2058,7 @@ def p_c_simple_declarator(s, ctx, empty, is_type, cmethod_flag,
cname
=
p_opt_cname
(
s
)
cname
=
p_opt_cname
(
s
)
if
name
!=
"operator"
and
s
.
sy
==
'='
and
assignable
:
if
name
!=
"operator"
and
s
.
sy
==
'='
and
assignable
:
s
.
next
()
s
.
next
()
rhs
=
p_
simple_expr
(
s
)
rhs
=
p_
test
(
s
)
else
:
else
:
if
nonempty
:
if
nonempty
:
error
(
s
.
position
(),
"Empty declarator"
)
error
(
s
.
position
(),
"Empty declarator"
)
...
@@ -2131,7 +2124,7 @@ def p_exception_value_clause(s):
...
@@ -2131,7 +2124,7 @@ def p_exception_value_clause(s):
if
s
.
sy
==
'?'
:
if
s
.
sy
==
'?'
:
exc_check
=
1
exc_check
=
1
s
.
next
()
s
.
next
()
exc_val
=
p_
simple_expr
(
s
)
exc_val
=
p_
test
(
s
)
return
exc_val
,
exc_check
return
exc_val
,
exc_check
c_arg_list_terminators
=
(
'*'
,
'**'
,
'.'
,
')'
)
c_arg_list_terminators
=
(
'*'
,
'**'
,
'.'
,
')'
)
...
@@ -2188,7 +2181,7 @@ def p_c_arg_decl(s, ctx, in_pyfunc, cmethod_flag = 0, nonempty = 0,
...
@@ -2188,7 +2181,7 @@ def p_c_arg_decl(s, ctx, in_pyfunc, cmethod_flag = 0, nonempty = 0,
not_none
=
kind
==
'not'
not_none
=
kind
==
'not'
if
annotated
and
s
.
sy
==
':'
:
if
annotated
and
s
.
sy
==
':'
:
s
.
next
()
s
.
next
()
annotation
=
p_
simple_expr
(
s
)
annotation
=
p_
test
(
s
)
if
s
.
sy
==
'='
:
if
s
.
sy
==
'='
:
s
.
next
()
s
.
next
()
if
'pxd'
in
s
.
level
:
if
'pxd'
in
s
.
level
:
...
@@ -2197,7 +2190,7 @@ def p_c_arg_decl(s, ctx, in_pyfunc, cmethod_flag = 0, nonempty = 0,
...
@@ -2197,7 +2190,7 @@ def p_c_arg_decl(s, ctx, in_pyfunc, cmethod_flag = 0, nonempty = 0,
default
=
ExprNodes
.
BoolNode
(
1
)
default
=
ExprNodes
.
BoolNode
(
1
)
s
.
next
()
s
.
next
()
else
:
else
:
default
=
p_
simple_expr
(
s
)
default
=
p_
test
(
s
)
return
Nodes
.
CArgDeclNode
(
pos
,
return
Nodes
.
CArgDeclNode
(
pos
,
base_type
=
base_type
,
base_type
=
base_type
,
declarator
=
declarator
,
declarator
=
declarator
,
...
@@ -2328,7 +2321,7 @@ def p_c_enum_item(s, items):
...
@@ -2328,7 +2321,7 @@ def p_c_enum_item(s, items):
value
=
None
value
=
None
if
s
.
sy
==
'='
:
if
s
.
sy
==
'='
:
s
.
next
()
s
.
next
()
value
=
p_
simple_expr
(
s
)
value
=
p_
test
(
s
)
items
.
append
(
Nodes
.
CEnumDefItemNode
(
pos
,
items
.
append
(
Nodes
.
CEnumDefItemNode
(
pos
,
name
=
name
,
cname
=
cname
,
value
=
value
))
name
=
name
,
cname
=
cname
,
value
=
value
))
...
@@ -2485,7 +2478,7 @@ def p_def_statement(s, decorators=None):
...
@@ -2485,7 +2478,7 @@ def p_def_statement(s, decorators=None):
return_type_annotation
=
None
return_type_annotation
=
None
if
s
.
sy
==
'->'
:
if
s
.
sy
==
'->'
:
s
.
next
()
s
.
next
()
return_type_annotation
=
p_
simple_expr
(
s
)
return_type_annotation
=
p_
test
(
s
)
doc
,
body
=
p_suite
(
s
,
Ctx
(
level
=
'function'
),
with_doc
=
1
)
doc
,
body
=
p_suite
(
s
,
Ctx
(
level
=
'function'
),
with_doc
=
1
)
return
Nodes
.
DefNode
(
pos
,
name
=
name
,
args
=
args
,
return
Nodes
.
DefNode
(
pos
,
name
=
name
,
args
=
args
,
star_arg
=
star_arg
,
starstar_arg
=
starstar_arg
,
star_arg
=
star_arg
,
starstar_arg
=
starstar_arg
,
...
@@ -2518,7 +2511,7 @@ def p_py_arg_decl(s):
...
@@ -2518,7 +2511,7 @@ def p_py_arg_decl(s):
annotation
=
None
annotation
=
None
if
s
.
sy
==
':'
:
if
s
.
sy
==
':'
:
s
.
next
()
s
.
next
()
annotation
=
p_
simple_expr
(
s
)
annotation
=
p_
test
(
s
)
return
Nodes
.
PyArgDeclNode
(
pos
,
name
=
name
,
annotation
=
annotation
)
return
Nodes
.
PyArgDeclNode
(
pos
,
name
=
name
,
annotation
=
annotation
)
def
p_class_statement
(
s
,
decorators
):
def
p_class_statement
(
s
,
decorators
):
...
...
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