Compare commits

..

No commits in common. "a156aaa81cc89d73b345bbbf0b5935e2ade4ea86" and "0031e87db44a9c6e0dbc96e6936f50d428ec5d07" have entirely different histories.

2 changed files with 9 additions and 25 deletions

View File

@ -85,18 +85,18 @@ def dir(obj=None):
if obj is None: if obj is None:
return list(globals().keys()) return list(globals().keys())
if hasattr(obj, "__dir__"):
return obj.__dir__()
attributes = set() attributes = set()
# Set object attributes.
if not isinstance(obj, type):
if hasattr(obj, "__dir__"):
return sorted(obj.__dir__())
attributes.update(dir(type(obj)))
if hasattr(obj, "__dict__"): if hasattr(obj, "__dict__"):
attributes.update(obj.__dict__.keys()) attributes.update(obj.__dict__.keys())
if hasattr(obj, "__base__") and obj.__base__ is not None: # Set type attributes.
attributes.update(dir(obj.__base__)) if not isinstance(obj, type):
if hasattr(type(obj), "__dict__"):
attributes.update(type(obj).__dict__.keys())
return sorted(attributes) return sorted(attributes)

View File

@ -50,19 +50,3 @@ assert not all([False, False])
assert list(enumerate([1,2,3])) == [(0,1), (1,2), (2,3)] assert list(enumerate([1,2,3])) == [(0,1), (1,2), (2,3)]
assert list(enumerate([1,2,3], 1)) == [(1,1), (2,2), (3,3)] assert list(enumerate([1,2,3], 1)) == [(1,1), (2,2), (3,3)]
assert "__name__" in dir()
class Base:
def inherited(): ...
class Test(Base):
cls_attr = 'a'
def __init__(self):
self.self_attr = 1
assert {"self_attr", "cls_attr", "inherited"}.issubset(dir(Test()))
class CustomDir:
def __dir__(self):
return ["custom"]
assert ["custom"] == dir(CustomDir())