File: decorators.py

package info (click to toggle)
dirsearch 0.4.3-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 748 kB
  • sloc: python: 3,131; makefile: 4; sh: 1
file content (59 lines) | stat: -rwxr-xr-x 1,702 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# -*- coding: utf-8 -*-
#  This program is free software; you can redistribute it and/or modify
#  it under the terms of the GNU General Public License as published by
#  the Free Software Foundation; either version 2 of the License, or
#  (at your option) any later version.
#
#  This program is distributed in the hope that it will be useful,
#  but WITHOUT ANY WARRANTY; without even the implied warranty of
#  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
#  GNU General Public License for more details.
#
#  You should have received a copy of the GNU General Public License
#  along with this program; if not, write to the Free Software
#  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
#  MA 02110-1301, USA.
#
#  Author: Mauro Soria

import threading

from functools import wraps
from time import time

_lock = threading.Lock()
_cache = {}
_cache_lock = threading.Lock()


def cached(timeout=100):
    def _cached(func):
        @wraps(func)
        def with_caching(*args, **kwargs):
            key = id(func)
            for arg in args:
                key += id(arg)
            for k, v in kwargs:
                key += id(k) + id(v)

            # If it was cached and the cache timeout hasn't been reached
            if key in _cache and time() - _cache[key][0] < timeout:
                return _cache[key][1]

            with _cache_lock:
                result = func(*args, **kwargs)
                _cache[key] = (time(), result)

            return result

        return with_caching

    return _cached


def locked(func):
    def with_locking(*args, **kwargs):
        with _lock:
            return func(*args, **kwargs)

    return with_locking