]> git.openstreetmap.org Git - osqa.git/blobdiff - forum/modules/decorators.py
resolves OSQA-729, encode OpenID query dict using the django smart unicode utility...
[osqa.git] / forum / modules / decorators.py
index 11af9e3d1c4c1cd49e60b04db024a9344f7269f9..05af3a6014119b72e8741ed8c07515a760ecedcc 100644 (file)
-import inspect\r
-\r
-class DecoratableObject(object):\r
-    MODE_OVERRIDE = 0\r
-    MODE_PARAMS = 1\r
-    MODE_RESULT = 2\r
-\r
-    def __init__(self, fn, is_method=False):\r
-        self._callable = fn\r
-        self.is_method = is_method\r
-\r
-        self._params_decoration = None\r
-        self._result_decoration = None\r
-\r
-    def _decorate(self, fn, mode, **kwargs):\r
-        if mode == self.MODE_OVERRIDE:\r
-            self._decorate_full(fn, **kwargs)\r
-        elif mode == self.MODE_PARAMS:\r
-            self._decorate_params(fn)\r
-        elif mode == self.MODE_RESULT:\r
-            self._decorate_result(fn, **kwargs)\r
-\r
-    def _decorate_full(self, fn, needs_origin=True):\r
-        origin = self._callable\r
-\r
-        if needs_origin:\r
-            if self.is_method:\r
-                self._callable = lambda inst, *args, **kwargs: fn(inst, origin, *args, **kwargs)\r
-            else:\r
-                self._callable = lambda *args, **kwargs: fn(origin, *args, **kwargs)\r
-        else:\r
-            self._callable = fn\r
-\r
-    def _decorate_params(self, fn):\r
-        if not self._params_decoration:\r
-            self._params_decoration = []\r
-\r
-        self._params_decoration.append(fn)\r
-\r
-    def _decorate_result(self, fn, needs_params=False):\r
-        if not self._result_decoration:\r
-            self._result_decoration = []\r
-\r
-        fn._needs_params = needs_params\r
-        self._result_decoration.append(fn)\r
-\r
-    def __call__(self, *args, **kwargs):\r
-        if self._params_decoration:\r
-            for dec in self._params_decoration:\r
-                try:\r
-                    args, kwargs = dec(*args, **kwargs)\r
-                except ReturnImediatelyException, e:\r
-                    return e.ret\r
-\r
-        res = self._callable(*args, **kwargs)\r
-\r
-        if self._result_decoration:\r
-            for dec in self._result_decoration:\r
-                if dec._needs_params:\r
-                    res = dec(res, *args, **kwargs)\r
-                else:\r
-                    res = dec(res)\r
-\r
-        return res\r
-\r
-class ReturnImediatelyException(Exception):\r
-    def __init__(self, ret):\r
-        super(Exception, self).__init__()\r
-        self.ret = ret\r
-\r
-def _check_decoratable(origin, install=True):\r
-    if not hasattr(origin, '_decoratable_obj'):\r
-        if inspect.ismethod(origin) and not hasattr(origin, '_decoratable_obj'):\r
-            decoratable = DecoratableObject(origin)\r
-\r
-            def decoratable_method(self, *args, **kwargs):\r
-                return decoratable(self, *args, **kwargs)\r
-\r
-            decoratable_method._decoratable_obj = decoratable\r
-\r
-            def decoratable_decorate(fn, mode, **kwargs):\r
-                decoratable._decorate(fn, mode, **kwargs)\r
-\r
-            decoratable_method._decorate = decoratable_decorate\r
-\r
-            if install:\r
-                setattr(origin.im_class, origin.__name__, decoratable_method)\r
-\r
-            return decoratable_method\r
-                \r
-        elif inspect.isfunction(origin):\r
-            decoratable = DecoratableObject(origin)\r
-\r
-            def decorated(*args, **kwargs):\r
-                return decoratable(*args, **kwargs)\r
-\r
-            decorated._decoratable_obj = decoratable\r
-\r
-            if install:\r
-                setattr(inspect.getmodule(origin), origin.__name__, decorated)\r
-\r
-            decorated.__name__ = origin.__name__\r
-            decorated.__module__ = origin.__module__\r
-\r
-            return decorated\r
-\r
-    return origin\r
-\r
-\r
-def decorate(origin, needs_origin=True):\r
-    origin = _check_decoratable(origin)\r
-\r
-    def decorator(fn):\r
-        origin._decoratable_obj._decorate(fn, DecoratableObject.MODE_OVERRIDE, needs_origin=needs_origin)\r
-        \r
-    return decorator\r
-\r
-\r
-def _decorate_params(origin):\r
-    origin = _check_decoratable(origin)\r
-\r
-    def decorator(fn):\r
-        origin._decoratable_obj._decorate(fn, DecoratableObject.MODE_PARAMS)\r
-\r
-    return decorator\r
-\r
-decorate.params = _decorate_params\r
-\r
-def _decorate_result(origin, needs_params=False):\r
-    origin = _check_decoratable(origin)\r
-\r
-    def decorator(fn):\r
-        origin._decoratable_obj._decorate(fn, DecoratableObject.MODE_RESULT, needs_params=needs_params)\r
-\r
-    return decorator\r
-\r
-decorate.result = _decorate_result\r
-\r
-def _decorate_with(fn):\r
-    def decorator(origin):\r
-        origin = _check_decoratable(origin)\r
-        origin._decoratable_obj._decorate(fn, DecoratableObject.MODE_OVERRIDE, needs_origin=True)\r
-        return origin\r
-    return decorator\r
-\r
-decorate.withfn = _decorate_with\r
-\r
-def _decorate_result_with(fn, needs_params=False):\r
-    def decorator(origin):\r
-        origin = _check_decoratable(origin)\r
-        origin._decoratable_obj._decorate(fn, DecoratableObject.MODE_RESULT, needs_params=needs_params)\r
-        return origin\r
-    return decorator\r
-\r
-decorate.result.withfn = _decorate_result_with\r
-\r
-def _decorate_params_with(fn):\r
-    def decorator(origin):\r
-        origin = _check_decoratable(origin)\r
-        origin._decoratable_obj._decorate(fn, DecoratableObject.MODE_PARAMS)\r
-        return origin\r
-    return decorator\r
-\r
+import inspect
+
+class DecoratableObject(object):
+    MODE_OVERRIDE = 0
+    MODE_PARAMS = 1
+    MODE_RESULT = 2
+
+    def __init__(self, fn, is_method=False):
+        self._callable = fn
+        self.is_method = is_method
+
+        self._params_decoration = None
+        self._result_decoration = None
+
+    def _decorate(self, fn, mode, **kwargs):
+        if mode == self.MODE_OVERRIDE:
+            self._decorate_full(fn, **kwargs)
+        elif mode == self.MODE_PARAMS:
+            self._decorate_params(fn)
+        elif mode == self.MODE_RESULT:
+            self._decorate_result(fn, **kwargs)
+
+    def _decorate_full(self, fn, needs_origin=True):
+        origin = self._callable
+
+        if needs_origin:
+            if self.is_method:
+                self._callable = lambda inst, *args, **kwargs: fn(inst, origin, *args, **kwargs)
+            else:
+                self._callable = lambda *args, **kwargs: fn(origin, *args, **kwargs)
+        else:
+            self._callable = fn
+
+    def _decorate_params(self, fn):
+        if not self._params_decoration:
+            self._params_decoration = []
+
+        self._params_decoration.append(fn)
+
+    def _decorate_result(self, fn, needs_params=False):
+        if not self._result_decoration:
+            self._result_decoration = []
+
+        fn._needs_params = needs_params
+        self._result_decoration.append(fn)
+
+    def __call__(self, *args, **kwargs):
+        if self._params_decoration:
+            for dec in self._params_decoration:
+                try:
+                    args, kwargs = dec(*args, **kwargs)
+                except ReturnImediatelyException, e:
+                    return e.ret
+
+        res = self._callable(*args, **kwargs)
+
+        if self._result_decoration:
+            for dec in self._result_decoration:
+                if dec._needs_params:
+                    res = dec(res, *args, **kwargs)
+                else:
+                    res = dec(res)
+
+        return res
+
+class ReturnImediatelyException(Exception):
+    def __init__(self, ret):
+        super(Exception, self).__init__()
+        self.ret = ret
+
+def _check_decoratable(origin, install=True):
+    if not hasattr(origin, '_decoratable_obj'):
+        if inspect.ismethod(origin) and not hasattr(origin, '_decoratable_obj'):
+            decoratable = DecoratableObject(origin)
+
+            def decoratable_method(self, *args, **kwargs):
+                return decoratable(self, *args, **kwargs)
+
+            decoratable_method._decoratable_obj = decoratable
+
+            def decoratable_decorate(fn, mode, **kwargs):
+                decoratable._decorate(fn, mode, **kwargs)
+
+            decoratable_method._decorate = decoratable_decorate
+
+            if install:
+                setattr(origin.im_class, origin.__name__, decoratable_method)
+
+            return decoratable_method
+                
+        elif inspect.isfunction(origin):
+            decoratable = DecoratableObject(origin)
+
+            def decorated(*args, **kwargs):
+                return decoratable(*args, **kwargs)
+
+            decorated._decoratable_obj = decoratable
+
+            if install:
+                setattr(inspect.getmodule(origin), origin.__name__, decorated)
+
+            decorated.__name__ = origin.__name__
+            decorated.__module__ = origin.__module__
+
+            return decorated
+
+    return origin
+
+
+def decorate(origin, needs_origin=True):
+    origin = _check_decoratable(origin)
+
+    def decorator(fn):
+        origin._decoratable_obj._decorate(fn, DecoratableObject.MODE_OVERRIDE, needs_origin=needs_origin)
+        
+    return decorator
+
+
+def _decorate_params(origin):
+    origin = _check_decoratable(origin)
+
+    def decorator(fn):
+        origin._decoratable_obj._decorate(fn, DecoratableObject.MODE_PARAMS)
+
+    return decorator
+
+decorate.params = _decorate_params
+
+def _decorate_result(origin, needs_params=False):
+    origin = _check_decoratable(origin)
+
+    def decorator(fn):
+        origin._decoratable_obj._decorate(fn, DecoratableObject.MODE_RESULT, needs_params=needs_params)
+
+    return decorator
+
+decorate.result = _decorate_result
+
+def _decorate_with(fn):
+    def decorator(origin):
+        origin = _check_decoratable(origin)
+        origin._decoratable_obj._decorate(fn, DecoratableObject.MODE_OVERRIDE, needs_origin=True)
+        return origin
+    return decorator
+
+decorate.withfn = _decorate_with
+
+def _decorate_result_with(fn, needs_params=False):
+    def decorator(origin):
+        origin = _check_decoratable(origin)
+        origin._decoratable_obj._decorate(fn, DecoratableObject.MODE_RESULT, needs_params=needs_params)
+        return origin
+    return decorator
+
+decorate.result.withfn = _decorate_result_with
+
+def _decorate_params_with(fn):
+    def decorator(origin):
+        origin = _check_decoratable(origin)
+        origin._decoratable_obj._decorate(fn, DecoratableObject.MODE_PARAMS)
+        return origin
+    return decorator
+
 decorate.params.withfn = _decorate_params_with
\ No newline at end of file