aboutsummaryrefslogtreecommitdiff
path: root/etc/compile-by-zinc/memoize.py
blob: d5908390d5855f16de54770841cae36341700595 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

# from http://code.activestate.com/recipes/578231-probably-the-fastest-memoization-decorator-in-the-/

__all__ = ["memoize"]

def memoize(f):
    """ Memoization decorator for a function taking one or more arguments. """
    class memodict(dict):
        def __getitem__(self, *key, **kwkey):
            return dict.__getitem__(self, (tuple(key), tuple((k, kwkey[k]) for k in sorted(kwkey.keys()))))

        def __missing__(self, key):
            args, kwargs = key
            self[key] = ret = f(*args, **dict(kwargs))
            return ret

    return memodict().__getitem__