mirror of https://github.com/django/django.git
Try to save memory and time when using lazy objects by refering to their function via the closure, and not making it an attribute on each instance.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@17360 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
05a3ecbf96
commit
4a92059b08
|
@ -66,7 +66,6 @@ def lazy(func, *resultclasses):
|
||||||
__dispatch = None
|
__dispatch = None
|
||||||
|
|
||||||
def __init__(self, args, kw):
|
def __init__(self, args, kw):
|
||||||
self.__func = func
|
|
||||||
self.__args = args
|
self.__args = args
|
||||||
self.__kw = kw
|
self.__kw = kw
|
||||||
if self.__dispatch is None:
|
if self.__dispatch is None:
|
||||||
|
@ -75,7 +74,7 @@ def lazy(func, *resultclasses):
|
||||||
def __reduce__(self):
|
def __reduce__(self):
|
||||||
return (
|
return (
|
||||||
_lazy_proxy_unpickle,
|
_lazy_proxy_unpickle,
|
||||||
(self.__func, self.__args, self.__kw) + resultclasses
|
(func, self.__args, self.__kw) + resultclasses
|
||||||
)
|
)
|
||||||
|
|
||||||
def __prepare_class__(cls):
|
def __prepare_class__(cls):
|
||||||
|
@ -100,13 +99,13 @@ def lazy(func, *resultclasses):
|
||||||
cls.__str__ = cls.__str_cast
|
cls.__str__ = cls.__str_cast
|
||||||
__prepare_class__ = classmethod(__prepare_class__)
|
__prepare_class__ = classmethod(__prepare_class__)
|
||||||
|
|
||||||
def __promise__(cls, klass, funcname, func):
|
def __promise__(cls, klass, funcname, method):
|
||||||
# Builds a wrapper around some magic method and registers that magic
|
# Builds a wrapper around some magic method and registers that magic
|
||||||
# method for the given type and method name.
|
# method for the given type and method name.
|
||||||
def __wrapper__(self, *args, **kw):
|
def __wrapper__(self, *args, **kw):
|
||||||
# Automatically triggers the evaluation of a lazy value and
|
# Automatically triggers the evaluation of a lazy value and
|
||||||
# applies the given magic method of the result type.
|
# applies the given magic method of the result type.
|
||||||
res = self.__func(*self.__args, **self.__kw)
|
res = func(*self.__args, **self.__kw)
|
||||||
for t in type(res).mro():
|
for t in type(res).mro():
|
||||||
if t in self.__dispatch:
|
if t in self.__dispatch:
|
||||||
return self.__dispatch[t][funcname](res, *args, **kw)
|
return self.__dispatch[t][funcname](res, *args, **kw)
|
||||||
|
@ -114,23 +113,23 @@ def lazy(func, *resultclasses):
|
||||||
|
|
||||||
if klass not in cls.__dispatch:
|
if klass not in cls.__dispatch:
|
||||||
cls.__dispatch[klass] = {}
|
cls.__dispatch[klass] = {}
|
||||||
cls.__dispatch[klass][funcname] = func
|
cls.__dispatch[klass][funcname] = method
|
||||||
return __wrapper__
|
return __wrapper__
|
||||||
__promise__ = classmethod(__promise__)
|
__promise__ = classmethod(__promise__)
|
||||||
|
|
||||||
def __unicode_cast(self):
|
def __unicode_cast(self):
|
||||||
return self.__func(*self.__args, **self.__kw)
|
return func(*self.__args, **self.__kw)
|
||||||
|
|
||||||
def __str_cast(self):
|
def __str_cast(self):
|
||||||
return str(self.__func(*self.__args, **self.__kw))
|
return str(func(*self.__args, **self.__kw))
|
||||||
|
|
||||||
def __cmp__(self, rhs):
|
def __cmp__(self, rhs):
|
||||||
if self._delegate_str:
|
if self._delegate_str:
|
||||||
s = str(self.__func(*self.__args, **self.__kw))
|
s = str(func(*self.__args, **self.__kw))
|
||||||
elif self._delegate_unicode:
|
elif self._delegate_unicode:
|
||||||
s = unicode(self.__func(*self.__args, **self.__kw))
|
s = unicode(func(*self.__args, **self.__kw))
|
||||||
else:
|
else:
|
||||||
s = self.__func(*self.__args, **self.__kw)
|
s = func(*self.__args, **self.__kw)
|
||||||
if isinstance(rhs, Promise):
|
if isinstance(rhs, Promise):
|
||||||
return -cmp(rhs, s)
|
return -cmp(rhs, s)
|
||||||
else:
|
else:
|
||||||
|
|
Loading…
Reference in New Issue