aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/mesonlib.py
diff options
context:
space:
mode:
authorJussi Pakkanen <jpakkane@gmail.com>2019-09-26 00:08:57 +0300
committerGitHub <noreply@github.com>2019-09-26 00:08:57 +0300
commit0993c57ce626e2cb125b662414df3a5113a9707d (patch)
tree193379f19b5f11c84f43071060fbffd010defbf0 /mesonbuild/mesonlib.py
parent74d5136e5945bb73e19a78783432ad24f75c3b21 (diff)
parentf745e8fc4d45e97fc3861e5ea435ee0709a19885 (diff)
downloadmeson-0993c57ce626e2cb125b662414df3a5113a9707d.zip
meson-0993c57ce626e2cb125b662414df3a5113a9707d.tar.gz
meson-0993c57ce626e2cb125b662414df3a5113a9707d.tar.bz2
Merge pull request #5958 from keszybz/caching-cleanup
Caching cleanup
Diffstat (limited to 'mesonbuild/mesonlib.py')
-rw-r--r--mesonbuild/mesonlib.py15
1 files changed, 14 insertions, 1 deletions
diff --git a/mesonbuild/mesonlib.py b/mesonbuild/mesonlib.py
index 5df7311..1adc752 100644
--- a/mesonbuild/mesonlib.py
+++ b/mesonbuild/mesonlib.py
@@ -20,7 +20,7 @@ import time
import platform, subprocess, operator, os, shlex, shutil, re
import collections
from enum import Enum
-from functools import lru_cache
+from functools import lru_cache, update_wrapper
import typing
import uuid
@@ -1496,6 +1496,19 @@ def get_wine_shortpath(winecmd, wine_paths):
return wine_path.strip(';')
+def run_once(func):
+ ret = []
+
+ def wrapper(*args, **kwargs):
+ if ret:
+ return ret[0]
+
+ val = func(*args, **kwargs)
+ ret.append(val)
+ return val
+
+ return update_wrapper(wrapper, func)
+
class OptionProxy:
def __init__(self, value):