Commit 4d7fbe25 authored by Robert Bradshaw's avatar Robert Bradshaw

Allow old_style_globals to be set via a directive.

parent 2a581a2b
...@@ -208,12 +208,12 @@ builtin_function_table = [ ...@@ -208,12 +208,12 @@ builtin_function_table = [
# Put in namespace append optimization. # Put in namespace append optimization.
BuiltinFunction('__Pyx_PyObject_Append', "OO", "O", "__Pyx_PyObject_Append"), BuiltinFunction('__Pyx_PyObject_Append', "OO", "O", "__Pyx_PyObject_Append"),
# This is conditionally looked up based on a compiler directive.
BuiltinFunction('__Pyx_globals', "", "O", "__Pyx_Globals",
utility_code=globals_utility_code),
] ]
if not Options.old_style_globals:
builtin_function_table.append(
BuiltinFunction('globals', "", "O", "__Pyx_Globals",
utility_code=globals_utility_code))
# Builtin types # Builtin types
# bool # bool
......
...@@ -103,6 +103,8 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): ...@@ -103,6 +103,8 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
self.scope.merge_in(scope) self.scope.merge_in(scope)
def analyse_declarations(self, env): def analyse_declarations(self, env):
if self.directives:
env.old_style_globals = self.directives['old_style_globals']
if not Options.docstrings: if not Options.docstrings:
env.doc = self.doc = None env.doc = self.doc = None
elif Options.embed_pos_in_docstring: elif Options.embed_pos_in_docstring:
......
...@@ -106,7 +106,7 @@ embed = None ...@@ -106,7 +106,7 @@ embed = None
# In previous iterations of Cython, globals() gave the first non-Cython module # In previous iterations of Cython, globals() gave the first non-Cython module
# globals in the call stack. Sage relies on this behavior for variable injection. # globals in the call stack. Sage relies on this behavior for variable injection.
old_style_globals = False old_style_globals = ShouldBeFromDirective('old_style_globals')
# Allows cimporting from a pyx file without a pxd file. # Allows cimporting from a pyx file without a pxd file.
cimport_from_pyx = False cimport_from_pyx = False
...@@ -173,6 +173,7 @@ _directive_defaults = { ...@@ -173,6 +173,7 @@ _directive_defaults = {
'c_string_encoding': '', 'c_string_encoding': '',
'type_version_tag': True, # enables Py_TPFLAGS_HAVE_VERSION_TAG on extension types 'type_version_tag': True, # enables Py_TPFLAGS_HAVE_VERSION_TAG on extension types
'unraisable_tracebacks': False, 'unraisable_tracebacks': False,
'old_style_globals': False,
# set __file__ and/or __path__ to known source/target path at import time (instead of not having them available) # set __file__ and/or __path__ to known source/target path at import time (instead of not having them available)
'set_initial_path' : None, # SOURCEFILE or "/full/path/to/module" 'set_initial_path' : None, # SOURCEFILE or "/full/path/to/module"
...@@ -304,6 +305,9 @@ directive_scopes = { # defaults to available everywhere ...@@ -304,6 +305,9 @@ directive_scopes = { # defaults to available everywhere
'c_string_encoding': ('module',), 'c_string_encoding': ('module',),
'type_version_tag': ('module', 'cclass'), 'type_version_tag': ('module', 'cclass'),
'language_level': ('module',), 'language_level': ('module',),
# globals() could conceivably be controlled at a finer granularity,
# but that would complicate the implementation
'old_style_globals': ('module',),
} }
......
...@@ -1034,6 +1034,7 @@ class ModuleScope(Scope): ...@@ -1034,6 +1034,7 @@ class ModuleScope(Scope):
is_module_scope = 1 is_module_scope = 1
has_import_star = 0 has_import_star = 0
is_cython_builtin = 0 is_cython_builtin = 0
old_style_globals = 0
def __init__(self, name, parent_module, context): def __init__(self, name, parent_module, context):
from . import Builtin from . import Builtin
...@@ -1128,6 +1129,9 @@ class ModuleScope(Scope): ...@@ -1128,6 +1129,9 @@ class ModuleScope(Scope):
for entry in self.cached_builtins: for entry in self.cached_builtins:
if entry.name == name: if entry.name == name:
return entry return entry
if name == 'globals' and not self.old_style_globals:
return self.outer_scope.lookup('__Pyx_globals')
else:
entry = self.declare(None, None, py_object_type, pos, 'private') entry = self.declare(None, None, py_object_type, pos, 'private')
if Options.cache_builtins and name not in Code.uncachable_builtins: if Options.cache_builtins and name not in Code.uncachable_builtins:
entry.is_builtin = 1 entry.is_builtin = 1
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment