Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
Pyston
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
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
Pyston
Commits
20ae1f2b
Commit
20ae1f2b
authored
Aug 28, 2015
by
Kevin Modzelewski
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Parse exec's more like normal code
parent
5c70bb30
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
58 additions
and
58 deletions
+58
-58
src/analysis/scoping_analysis.cpp
src/analysis/scoping_analysis.cpp
+8
-7
src/codegen/ast_interpreter.cpp
src/codegen/ast_interpreter.cpp
+3
-0
src/codegen/irgen/hooks.cpp
src/codegen/irgen/hooks.cpp
+23
-48
src/core/ast.h
src/core/ast.h
+1
-1
src/core/options.cpp
src/core/options.cpp
+1
-0
src/core/options.h
src/core/options.h
+2
-1
src/runtime/builtin_modules/pyston.cpp
src/runtime/builtin_modules/pyston.cpp
+1
-0
test/tests/del_closure_var_syntax_error.py
test/tests/del_closure_var_syntax_error.py
+6
-0
test/tests/global_and_local.py
test/tests/global_and_local.py
+7
-1
test/tests/name_forcing_syntax_error.py
test/tests/name_forcing_syntax_error.py
+6
-0
No files found.
src/analysis/scoping_analysis.cpp
View file @
20ae1f2b
...
@@ -171,8 +171,6 @@ private:
...
@@ -171,8 +171,6 @@ private:
bool
globals_from_module
;
bool
globals_from_module
;
public:
public:
EvalExprScopeInfo
(
bool
globals_from_module
)
:
globals_from_module
(
globals_from_module
)
{}
EvalExprScopeInfo
(
AST
*
node
,
bool
globals_from_module
)
:
globals_from_module
(
globals_from_module
)
{
EvalExprScopeInfo
(
AST
*
node
,
bool
globals_from_module
)
:
globals_from_module
(
globals_from_module
)
{
// Find all the global statements in the node's scope (not delving into FuncitonDefs
// Find all the global statements in the node's scope (not delving into FuncitonDefs
// or ClassDefs) and put the names in `forced_globals`.
// or ClassDefs) and put the names in `forced_globals`.
...
@@ -959,21 +957,24 @@ ScopingAnalysis::ScopingAnalysis(AST* ast, bool globals_from_module)
...
@@ -959,21 +957,24 @@ ScopingAnalysis::ScopingAnalysis(AST* ast, bool globals_from_module)
:
parent_module
(
NULL
),
globals_from_module
(
globals_from_module
)
{
:
parent_module
(
NULL
),
globals_from_module
(
globals_from_module
)
{
switch
(
ast
->
type
)
{
switch
(
ast
->
type
)
{
case
AST_TYPE
:
:
Module
:
case
AST_TYPE
:
:
Module
:
assert
(
globals_from_module
);
scopes
[
ast
]
=
new
ModuleScopeInfo
();
interned_strings
=
static_cast
<
AST_Module
*>
(
ast
)
->
interned_strings
.
get
();
interned_strings
=
static_cast
<
AST_Module
*>
(
ast
)
->
interned_strings
.
get
();
parent_module
=
static_cast
<
AST_Module
*>
(
ast
);
break
;
break
;
case
AST_TYPE
:
:
Expression
:
case
AST_TYPE
:
:
Expression
:
scopes
[
ast
]
=
new
EvalExprScopeInfo
(
globals_from_module
);
interned_strings
=
static_cast
<
AST_Expression
*>
(
ast
)
->
interned_strings
.
get
();
interned_strings
=
static_cast
<
AST_Expression
*>
(
ast
)
->
interned_strings
.
get
();
break
;
break
;
case
AST_TYPE
:
:
Suite
:
case
AST_TYPE
:
:
Suite
:
scopes
[
ast
]
=
new
EvalExprScopeInfo
(
ast
,
globals_from_module
);
interned_strings
=
static_cast
<
AST_Suite
*>
(
ast
)
->
interned_strings
.
get
();
interned_strings
=
static_cast
<
AST_Suite
*>
(
ast
)
->
interned_strings
.
get
();
break
;
break
;
default:
default:
RELEASE_ASSERT
(
0
,
"%d"
,
ast
->
type
);
RELEASE_ASSERT
(
0
,
"%d"
,
ast
->
type
);
}
}
if
(
globals_from_module
)
{
assert
(
ast
->
type
==
AST_TYPE
::
Module
);
scopes
[
ast
]
=
new
ModuleScopeInfo
();
parent_module
=
static_cast
<
AST_Module
*>
(
ast
);
}
else
{
scopes
[
ast
]
=
new
EvalExprScopeInfo
(
ast
,
globals_from_module
);
}
}
}
}
}
src/codegen/ast_interpreter.cpp
View file @
20ae1f2b
...
@@ -1011,6 +1011,9 @@ Value ASTInterpreter::createFunction(AST* node, AST_arguments* args, const std::
...
@@ -1011,6 +1011,9 @@ Value ASTInterpreter::createFunction(AST* node, AST_arguments* args, const std::
u
.
d
.
s
=
defaults
.
size
()
-
1
;
u
.
d
.
s
=
defaults
.
size
()
-
1
;
bool
takes_closure
;
bool
takes_closure
;
if
(
!
LAZY_SCOPING_ANALYSIS
)
source_info
->
scoping
->
getScopeInfoForNode
(
node
);
// Optimization: when compiling a module, it's nice to not have to run analyses into the
// Optimization: when compiling a module, it's nice to not have to run analyses into the
// entire module's source code.
// entire module's source code.
// If we call getScopeInfoForNode, that will trigger an analysis of that function tree,
// If we call getScopeInfoForNode, that will trigger an analysis of that function tree,
...
...
src/codegen/irgen/hooks.cpp
View file @
20ae1f2b
...
@@ -370,10 +370,7 @@ static CLFunction* compileForEvalOrExec(AST* source, std::vector<AST_stmt*> body
...
@@ -370,10 +370,7 @@ static CLFunction* compileForEvalOrExec(AST* source, std::vector<AST_stmt*> body
return
cl_f
;
return
cl_f
;
}
}
// TODO: CPython parses execs as Modules, not as Suites. This is probably not too hard to change,
static
AST_Module
*
parseExec
(
llvm
::
StringRef
source
,
bool
interactive
=
false
)
{
// but is non-trivial since we will later decide some things (ex in scoping_analysis) based off
// the type of the root ast node.
static
AST_Suite
*
parseExec
(
llvm
::
StringRef
source
,
bool
interactive
=
false
)
{
// TODO error message if parse fails or if it isn't an expr
// TODO error message if parse fails or if it isn't an expr
// TODO should have a cleaner interface that can parse the Expression directly
// TODO should have a cleaner interface that can parse the Expression directly
// TODO this memory leaks
// TODO this memory leaks
...
@@ -393,13 +390,11 @@ static AST_Suite* parseExec(llvm::StringRef source, bool interactive = false) {
...
@@ -393,13 +390,11 @@ static AST_Suite* parseExec(llvm::StringRef source, bool interactive = false) {
}
}
}
}
AST_Suite
*
parsedSuite
=
new
AST_Suite
(
std
::
move
(
parsedModule
->
interned_strings
));
return
parsedModule
;
parsedSuite
->
body
=
std
::
move
(
parsedModule
->
body
);
return
parsedSuite
;
}
}
static
CLFunction
*
compileExec
(
AST_
Suite
*
parsedSuit
e
,
BoxedString
*
fn
,
PyCompilerFlags
*
flags
)
{
static
CLFunction
*
compileExec
(
AST_
Module
*
parsedModul
e
,
BoxedString
*
fn
,
PyCompilerFlags
*
flags
)
{
return
compileForEvalOrExec
(
parsed
Suite
,
parsedSuit
e
->
body
,
fn
,
flags
);
return
compileForEvalOrExec
(
parsed
Module
,
parsedModul
e
->
body
,
fn
,
flags
);
}
}
static
AST_Expression
*
parseEval
(
llvm
::
StringRef
source
)
{
static
AST_Expression
*
parseEval
(
llvm
::
StringRef
source
)
{
...
@@ -520,9 +515,9 @@ Box* compile(Box* source, Box* fn, Box* type, Box** _args) {
...
@@ -520,9 +515,9 @@ Box* compile(Box* source, Box* fn, Box* type, Box** _args) {
CLFunction
*
cl
;
CLFunction
*
cl
;
if
(
type_str
->
s
()
==
"exec"
||
type_str
->
s
()
==
"single"
)
{
if
(
type_str
->
s
()
==
"exec"
||
type_str
->
s
()
==
"single"
)
{
// TODO: CPython parses execs as Modules
// TODO: CPython parses execs as Modules
if
(
parsed
->
type
!=
AST_TYPE
::
Suit
e
)
if
(
parsed
->
type
!=
AST_TYPE
::
Modul
e
)
raiseExcHelper
(
TypeError
,
"expected
Suit
e node, got %s"
,
boxAst
(
parsed
)
->
cls
->
tp_name
);
raiseExcHelper
(
TypeError
,
"expected
Modul
e node, got %s"
,
boxAst
(
parsed
)
->
cls
->
tp_name
);
cl
=
compileExec
(
static_cast
<
AST_
Suit
e
*>
(
parsed
),
filename_str
,
&
pcf
);
cl
=
compileExec
(
static_cast
<
AST_
Modul
e
*>
(
parsed
),
filename_str
,
&
pcf
);
}
else
if
(
type_str
->
s
()
==
"eval"
)
{
}
else
if
(
type_str
->
s
()
==
"eval"
)
{
if
(
parsed
->
type
!=
AST_TYPE
::
Expression
)
if
(
parsed
->
type
!=
AST_TYPE
::
Expression
)
raiseExcHelper
(
TypeError
,
"expected Expression node, got %s"
,
boxAst
(
parsed
)
->
cls
->
tp_name
);
raiseExcHelper
(
TypeError
,
"expected Expression node, got %s"
,
boxAst
(
parsed
)
->
cls
->
tp_name
);
...
@@ -534,7 +529,7 @@ Box* compile(Box* source, Box* fn, Box* type, Box** _args) {
...
@@ -534,7 +529,7 @@ Box* compile(Box* source, Box* fn, Box* type, Box** _args) {
return
(
Box
*
)
cl
->
getCode
();
return
(
Box
*
)
cl
->
getCode
();
}
}
static
Box
*
evalMain
(
Box
*
boxedCode
,
Box
*
globals
,
Box
*
locals
,
PyCompilerFlags
*
flag
s
)
{
static
void
pickGlobalsAndLocals
(
Box
*&
globals
,
Box
*&
local
s
)
{
if
(
globals
==
None
)
if
(
globals
==
None
)
globals
=
NULL
;
globals
=
NULL
;
...
@@ -561,6 +556,19 @@ static Box* evalMain(Box* boxedCode, Box* globals, Box* locals, PyCompilerFlags*
...
@@ -561,6 +556,19 @@ static Box* evalMain(Box* boxedCode, Box* globals, Box* locals, PyCompilerFlags*
assert
(
globals
&&
(
globals
->
cls
==
module_cls
||
globals
->
cls
==
dict_cls
));
assert
(
globals
&&
(
globals
->
cls
==
module_cls
||
globals
->
cls
==
dict_cls
));
if
(
globals
)
{
// From CPython (they set it to be f->f_builtins):
Box
*
globals_dict
=
globals
;
if
(
globals
->
cls
==
module_cls
)
globals_dict
=
globals
->
getAttrWrapper
();
if
(
PyDict_GetItemString
(
globals_dict
,
"__builtins__"
)
==
NULL
)
PyDict_SetItemString
(
globals_dict
,
"__builtins__"
,
builtins_module
);
}
}
static
Box
*
evalMain
(
Box
*
boxedCode
,
Box
*
globals
,
Box
*
locals
,
PyCompilerFlags
*
flags
)
{
pickGlobalsAndLocals
(
globals
,
locals
);
if
(
boxedCode
->
cls
==
unicode_cls
)
{
if
(
boxedCode
->
cls
==
unicode_cls
)
{
boxedCode
=
PyUnicode_AsUTF8String
(
boxedCode
);
boxedCode
=
PyUnicode_AsUTF8String
(
boxedCode
);
if
(
!
boxedCode
)
if
(
!
boxedCode
)
...
@@ -606,40 +614,7 @@ Box* execMain(Box* boxedCode, Box* globals, Box* locals, PyCompilerFlags* flags)
...
@@ -606,40 +614,7 @@ Box* execMain(Box* boxedCode, Box* globals, Box* locals, PyCompilerFlags* flags)
locals
=
t
->
elts
[
2
];
locals
=
t
->
elts
[
2
];
}
}
if
(
globals
==
None
)
pickGlobalsAndLocals
(
globals
,
locals
);
globals
=
NULL
;
if
(
locals
==
None
)
locals
=
NULL
;
if
(
locals
==
NULL
)
{
locals
=
globals
;
}
if
(
locals
==
NULL
)
{
locals
=
fastLocalsToBoxedLocals
();
}
if
(
globals
==
NULL
)
globals
=
getGlobals
();
BoxedModule
*
module
=
getCurrentModule
();
if
(
globals
&&
globals
->
cls
==
attrwrapper_cls
&&
unwrapAttrWrapper
(
globals
)
==
module
)
globals
=
module
;
if
(
globals
->
cls
==
attrwrapper_cls
)
globals
=
unwrapAttrWrapper
(
globals
);
assert
(
globals
&&
(
globals
->
cls
==
module_cls
||
globals
->
cls
==
dict_cls
));
if
(
globals
)
{
// From CPython (they set it to be f->f_builtins):
Box
*
globals_dict
=
globals
;
if
(
globals
->
cls
==
module_cls
)
globals_dict
=
globals
->
getAttrWrapper
();
if
(
PyDict_GetItemString
(
globals_dict
,
"__builtins__"
)
==
NULL
)
PyDict_SetItemString
(
globals_dict
,
"__builtins__"
,
builtins_module
);
}
if
(
boxedCode
->
cls
==
unicode_cls
)
{
if
(
boxedCode
->
cls
==
unicode_cls
)
{
boxedCode
=
PyUnicode_AsUTF8String
(
boxedCode
);
boxedCode
=
PyUnicode_AsUTF8String
(
boxedCode
);
...
@@ -650,7 +625,7 @@ Box* execMain(Box* boxedCode, Box* globals, Box* locals, PyCompilerFlags* flags)
...
@@ -650,7 +625,7 @@ Box* execMain(Box* boxedCode, Box* globals, Box* locals, PyCompilerFlags* flags)
CLFunction
*
cl
;
CLFunction
*
cl
;
if
(
boxedCode
->
cls
==
str_cls
)
{
if
(
boxedCode
->
cls
==
str_cls
)
{
AST_Suite
*
parsed
=
parseExec
(
static_cast
<
BoxedString
*>
(
boxedCode
)
->
s
());
auto
parsed
=
parseExec
(
static_cast
<
BoxedString
*>
(
boxedCode
)
->
s
());
static
BoxedString
*
string_string
=
internStringImmortal
(
"<string>"
);
static
BoxedString
*
string_string
=
internStringImmortal
(
"<string>"
);
cl
=
compileExec
(
parsed
,
string_string
,
flags
);
cl
=
compileExec
(
parsed
,
string_string
,
flags
);
}
else
if
(
boxedCode
->
cls
==
code_cls
)
{
}
else
if
(
boxedCode
->
cls
==
code_cls
)
{
...
...
src/core/ast.h
View file @
20ae1f2b
...
@@ -1204,7 +1204,7 @@ public:
...
@@ -1204,7 +1204,7 @@ public:
virtual
bool
visit_excepthandler
(
AST_ExceptHandler
*
node
)
{
return
false
;
}
virtual
bool
visit_excepthandler
(
AST_ExceptHandler
*
node
)
{
return
false
;
}
virtual
bool
visit_exec
(
AST_Exec
*
node
)
{
return
false
;
}
virtual
bool
visit_exec
(
AST_Exec
*
node
)
{
return
false
;
}
virtual
bool
visit_expr
(
AST_Expr
*
node
)
{
return
false
;
}
virtual
bool
visit_expr
(
AST_Expr
*
node
)
{
return
false
;
}
virtual
bool
visit_expr
(
AST_Expression
*
node
)
{
return
false
;
}
virtual
bool
visit_expr
ession
(
AST_Expression
*
node
)
{
return
false
;
}
virtual
bool
visit_suite
(
AST_Suite
*
node
)
{
return
false
;
}
virtual
bool
visit_suite
(
AST_Suite
*
node
)
{
return
false
;
}
virtual
bool
visit_extslice
(
AST_ExtSlice
*
node
)
{
return
false
;
}
virtual
bool
visit_extslice
(
AST_ExtSlice
*
node
)
{
return
false
;
}
virtual
bool
visit_for
(
AST_For
*
node
)
{
return
false
;
}
virtual
bool
visit_for
(
AST_For
*
node
)
{
return
false
;
}
...
...
src/core/options.cpp
View file @
20ae1f2b
...
@@ -82,6 +82,7 @@ bool ENABLE_PYSTON_PASSES = 1 && _GLOBAL_ENABLE;
...
@@ -82,6 +82,7 @@ bool ENABLE_PYSTON_PASSES = 1 && _GLOBAL_ENABLE;
bool
ENABLE_TYPE_FEEDBACK
=
1
&&
_GLOBAL_ENABLE
;
bool
ENABLE_TYPE_FEEDBACK
=
1
&&
_GLOBAL_ENABLE
;
bool
ENABLE_RUNTIME_ICS
=
1
&&
_GLOBAL_ENABLE
;
bool
ENABLE_RUNTIME_ICS
=
1
&&
_GLOBAL_ENABLE
;
bool
ENABLE_JIT_OBJECT_CACHE
=
1
&&
_GLOBAL_ENABLE
;
bool
ENABLE_JIT_OBJECT_CACHE
=
1
&&
_GLOBAL_ENABLE
;
bool
LAZY_SCOPING_ANALYSIS
=
1
;
bool
ENABLE_FRAME_INTROSPECTION
=
1
;
bool
ENABLE_FRAME_INTROSPECTION
=
1
;
bool
BOOLS_AS_I64
=
ENABLE_FRAME_INTROSPECTION
;
bool
BOOLS_AS_I64
=
ENABLE_FRAME_INTROSPECTION
;
...
...
src/core/options.h
View file @
20ae1f2b
...
@@ -44,7 +44,8 @@ extern bool SHOW_DISASM, FORCE_INTERPRETER, FORCE_OPTIMIZE, PROFILE, DUMPJIT, TR
...
@@ -44,7 +44,8 @@ extern bool SHOW_DISASM, FORCE_INTERPRETER, FORCE_OPTIMIZE, PROFILE, DUMPJIT, TR
extern
bool
ENABLE_ICS
,
ENABLE_ICGENERICS
,
ENABLE_ICGETITEMS
,
ENABLE_ICSETITEMS
,
ENABLE_ICDELITEMS
,
ENABLE_ICBINEXPS
,
extern
bool
ENABLE_ICS
,
ENABLE_ICGENERICS
,
ENABLE_ICGETITEMS
,
ENABLE_ICSETITEMS
,
ENABLE_ICDELITEMS
,
ENABLE_ICBINEXPS
,
ENABLE_ICNONZEROS
,
ENABLE_ICCALLSITES
,
ENABLE_ICSETATTRS
,
ENABLE_ICGETATTRS
,
ENALBE_ICDELATTRS
,
ENABLE_ICGETGLOBALS
,
ENABLE_ICNONZEROS
,
ENABLE_ICCALLSITES
,
ENABLE_ICSETATTRS
,
ENABLE_ICGETATTRS
,
ENALBE_ICDELATTRS
,
ENABLE_ICGETGLOBALS
,
ENABLE_SPECULATION
,
ENABLE_OSR
,
ENABLE_LLVMOPTS
,
ENABLE_INLINING
,
ENABLE_REOPT
,
ENABLE_PYSTON_PASSES
,
ENABLE_SPECULATION
,
ENABLE_OSR
,
ENABLE_LLVMOPTS
,
ENABLE_INLINING
,
ENABLE_REOPT
,
ENABLE_PYSTON_PASSES
,
ENABLE_TYPE_FEEDBACK
,
ENABLE_FRAME_INTROSPECTION
,
ENABLE_RUNTIME_ICS
,
ENABLE_JIT_OBJECT_CACHE
;
ENABLE_TYPE_FEEDBACK
,
ENABLE_FRAME_INTROSPECTION
,
ENABLE_RUNTIME_ICS
,
ENABLE_JIT_OBJECT_CACHE
,
LAZY_SCOPING_ANALYSIS
;
// Due to a temporary LLVM limitation, represent bools as i64's instead of i1's.
// Due to a temporary LLVM limitation, represent bools as i64's instead of i1's.
extern
bool
BOOLS_AS_I64
;
extern
bool
BOOLS_AS_I64
;
...
...
src/runtime/builtin_modules/pyston.cpp
View file @
20ae1f2b
...
@@ -45,6 +45,7 @@ static Box* setOption(Box* option, Box* value) {
...
@@ -45,6 +45,7 @@ static Box* setOption(Box* option, Box* value) {
else
CHECK
(
SPECULATION_THRESHOLD
);
else
CHECK
(
SPECULATION_THRESHOLD
);
else
CHECK
(
ENABLE_ICS
);
else
CHECK
(
ENABLE_ICS
);
else
CHECK
(
ENABLE_ICGETATTRS
);
else
CHECK
(
ENABLE_ICGETATTRS
);
else
CHECK
(
LAZY_SCOPING_ANALYSIS
);
else
raiseExcHelper
(
ValueError
,
"unknown option name '%s"
,
option_string
->
data
());
else
raiseExcHelper
(
ValueError
,
"unknown option name '%s"
,
option_string
->
data
());
return
None
;
return
None
;
...
...
test/tests/del_closure_var_syntax_error.py
View file @
20ae1f2b
try
:
import
__pyston__
__pyston__
.
setOption
(
"LAZY_SCOPING_ANALYSIS"
,
0
)
except
ImportError
:
pass
cases
=
[
cases
=
[
"""
"""
...
...
test/tests/global_and_local.py
View file @
20ae1f2b
# I would have expected this to be valid, but cPython and pypy err out saying "name 'x' is local and global"
# I would have expected this to be valid, but cPython and pypy err out saying "name 'x' is local and global"
try
:
import
__pyston__
__pyston__
.
setOption
(
"LAZY_SCOPING_ANALYSIS"
,
0
)
except
ImportError
:
pass
try
:
try
:
exec
"""
exec
"""
x = 1
x = 1
...
@@ -40,7 +46,7 @@ except SyntaxError as e:
...
@@ -40,7 +46,7 @@ except SyntaxError as e:
try
:
try
:
exec
"""
exec
"""
def f(*kwargs):
def f(*
*
kwargs):
global kwargs
global kwargs
print "calling"
print "calling"
...
...
test/tests/name_forcing_syntax_error.py
View file @
20ae1f2b
...
@@ -4,6 +4,12 @@
...
@@ -4,6 +4,12 @@
# The logic beyond this error message is oddly complicated.
# The logic beyond this error message is oddly complicated.
try
:
import
__pyston__
__pyston__
.
setOption
(
"LAZY_SCOPING_ANALYSIS"
,
0
)
except
ImportError
:
pass
cases
=
[
cases
=
[
# protip: delete this first """ to get your editor to syntax-highlight the code
# protip: delete this first """ to get your editor to syntax-highlight the code
...
...
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