Commit 4f05de43 authored by Stefan Behnel's avatar Stefan Behnel

ticket #685: implement no-arg dir()

parent 69cd1c34
...@@ -1750,25 +1750,35 @@ class TransformBuiltinMethods(EnvTransform): ...@@ -1750,25 +1750,35 @@ class TransformBuiltinMethods(EnvTransform):
error(node.pos, u"'%s' not a valid cython attribute or is being used incorrectly" % attribute) error(node.pos, u"'%s' not a valid cython attribute or is being used incorrectly" % attribute)
return node return node
def visit_SimpleCallNode(self, node): def _inject_locals(self, node, func_name):
# locals()/dir() builtins
lenv = self.current_env()
entry = lenv.lookup_here(func_name)
if entry:
# not the builtin
return node
max_args_count = {'dir': 1, 'locals': 0}[func_name]
if len(node.args) > max_args_count:
error(self.pos, "Builtin '%s()' called with wrong number of args, expected %d, got %d" % (
func_name, max_args_count, len(node.args)))
return node
pos = node.pos
if func_name =='locals':
items = [ ExprNodes.DictItemNode(pos,
key=ExprNodes.StringNode(pos, value=var),
value=ExprNodes.NameNode(pos, name=var))
for var in lenv.entries ]
return ExprNodes.DictNode(pos, key_value_pairs=items)
else:
items = [ ExprNodes.StringNode(pos, value=var)
for var in lenv.entries ]
return ExprNodes.ListNode(pos, args=items)
# locals builtin def visit_SimpleCallNode(self, node):
if isinstance(node.function, ExprNodes.NameNode): if isinstance(node.function, ExprNodes.NameNode):
if node.function.name == 'locals': func_name = node.function.name
lenv = self.current_env() if func_name in ('dir', 'locals'):
entry = lenv.lookup_here('locals') return self._inject_locals(node, func_name)
if entry:
# not the builtin 'locals'
return node
if len(node.args) > 0:
error(self.pos, "Builtin 'locals()' called with wrong number of args, expected 0, got %d" % len(node.args))
return node
pos = node.pos
items = [ ExprNodes.DictItemNode(pos,
key=ExprNodes.StringNode(pos, value=var),
value=ExprNodes.NameNode(pos, name=var))
for var in lenv.entries ]
return ExprNodes.DictNode(pos, key_value_pairs=items)
# cython.foo # cython.foo
function = node.function.as_cython_attribute() function = node.function.as_cython_attribute()
......
__doc__ = u""" # mode: run
>>> sorted( get_locals(1,2,3, k=5) .items()) # tag: builtins, locals, dir
[('args', (2, 3)), ('kwds', {'k': 5}), ('x', 1), ('y', 'hi'), ('z', 5)]
"""
def get_locals(x, *args, **kwds): def get_locals(x, *args, **kwds):
"""
>>> sorted( get_locals(1,2,3, k=5) .items())
[('args', (2, 3)), ('kwds', {'k': 5}), ('x', 1), ('y', 'hi'), ('z', 5)]
"""
cdef int z = 5 cdef int z = 5
y = "hi" y = "hi"
return locals() return locals()
def get_dir(x, *args, **kwds):
"""
>>> sorted( get_dir(1,2,3, k=5) )
['args', 'kwds', 'x', 'y', 'z']
"""
cdef int z = 5
y = "hi"
return dir()
def in_locals(x, *args, **kwds): def in_locals(x, *args, **kwds):
""" """
>>> in_locals('z') >>> in_locals('z')
...@@ -22,6 +32,19 @@ def in_locals(x, *args, **kwds): ...@@ -22,6 +32,19 @@ def in_locals(x, *args, **kwds):
y = "hi" y = "hi"
return x in locals() return x in locals()
def in_dir(x, *args, **kwds):
"""
>>> in_dir('z')
True
>>> in_dir('args')
True
>>> in_dir('X')
False
"""
cdef int z = 5
y = "hi"
return x in dir()
def sorted(it): def sorted(it):
l = list(it) l = list(it)
l.sort() l.sort()
......
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