retracesoftware-utils 0.2.3__cp312-cp312-musllinux_1_2_x86_64.whl → 0.2.11__cp312-cp312-musllinux_1_2_x86_64.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of retracesoftware-utils might be problematic. Click here for more details.
- _retracesoftware_utils_debug.cpython-312-x86_64-linux-musl.so +0 -0
- _retracesoftware_utils_release.cpython-312-x86_64-linux-musl.so +0 -0
- retracesoftware/utils/__init__.py +172 -0
- {retracesoftware_utils-0.2.3.dist-info → retracesoftware_utils-0.2.11.dist-info}/METADATA +1 -1
- retracesoftware_utils-0.2.11.dist-info/RECORD +8 -0
- retracesoftware_utils-0.2.3.data/purelib/retracesoftware/utils.py +0 -162
- retracesoftware_utils-0.2.3.dist-info/RECORD +0 -7
- retracesoftware_utils.cpython-312-x86_64-linux-musl.so +0 -0
- {retracesoftware_utils-0.2.3.dist-info → retracesoftware_utils-0.2.11.dist-info}/WHEEL +0 -0
|
Binary file
|
|
Binary file
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
"""
|
|
2
|
+
retracesoftware.utils - Runtime selectable release/debug builds
|
|
3
|
+
|
|
4
|
+
Set RETRACE_DEBUG=1 to use the debug build with symbols and assertions.
|
|
5
|
+
"""
|
|
6
|
+
import os
|
|
7
|
+
import weakref
|
|
8
|
+
import threading
|
|
9
|
+
from collections import UserDict
|
|
10
|
+
from typing import Callable, Any, Dict
|
|
11
|
+
from contextlib import contextmanager
|
|
12
|
+
from types import ModuleType
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
def _is_truthy_env(v):
|
|
16
|
+
if v is None:
|
|
17
|
+
return False
|
|
18
|
+
return v.strip().lower() in {"1", "true", "yes", "y", "on"}
|
|
19
|
+
|
|
20
|
+
_DEBUG_MODE = _is_truthy_env(os.getenv("RETRACE_DEBUG"))
|
|
21
|
+
|
|
22
|
+
_backend_mod: ModuleType
|
|
23
|
+
__backend__: str
|
|
24
|
+
|
|
25
|
+
try:
|
|
26
|
+
if _DEBUG_MODE:
|
|
27
|
+
import _retracesoftware_utils_debug as _backend_mod # type: ignore
|
|
28
|
+
__backend__ = "native-debug"
|
|
29
|
+
else:
|
|
30
|
+
import _retracesoftware_utils_release as _backend_mod # type: ignore
|
|
31
|
+
__backend__ = "native-release"
|
|
32
|
+
except Exception:
|
|
33
|
+
raise ImportError("Failed to load retracesoftware_utils native extension")
|
|
34
|
+
|
|
35
|
+
# Expose debug mode flag
|
|
36
|
+
DEBUG_MODE = _DEBUG_MODE and __backend__.startswith("native")
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
def __getattr__(name: str) -> Any:
|
|
40
|
+
return getattr(_backend_mod, name)
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
def _export_public(mod: ModuleType) -> None:
|
|
44
|
+
g = globals()
|
|
45
|
+
for k, v in mod.__dict__.items():
|
|
46
|
+
if k.startswith("_"):
|
|
47
|
+
continue
|
|
48
|
+
g[k] = v
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
_export_public(_backend_mod)
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
# ---------------------------------------------------------------------------
|
|
55
|
+
# High-level API (convenience wrappers around C++ extension)
|
|
56
|
+
# ---------------------------------------------------------------------------
|
|
57
|
+
|
|
58
|
+
def typeflags(cls):
|
|
59
|
+
bits = _backend_mod.type_flags(cls)
|
|
60
|
+
result = set()
|
|
61
|
+
for name, value in _backend_mod.TypeFlags.items():
|
|
62
|
+
if (value & bits) != 0:
|
|
63
|
+
result.add(name)
|
|
64
|
+
return result
|
|
65
|
+
|
|
66
|
+
|
|
67
|
+
def is_method_descriptor(obj):
|
|
68
|
+
return 'Py_TPFLAGS_METHOD_DESCRIPTOR' in typeflags(type(obj))
|
|
69
|
+
|
|
70
|
+
|
|
71
|
+
def flags(cls: type):
|
|
72
|
+
f = _backend_mod.type_flags(cls)
|
|
73
|
+
s = set()
|
|
74
|
+
for name, value in _backend_mod.TypeFlags.items():
|
|
75
|
+
if (f & value) != 0:
|
|
76
|
+
s.add(name)
|
|
77
|
+
f = f & ~value
|
|
78
|
+
if f != 0:
|
|
79
|
+
s.add(f)
|
|
80
|
+
return s
|
|
81
|
+
|
|
82
|
+
|
|
83
|
+
class WithoutFlags:
|
|
84
|
+
def __init__(self, cls, *flags):
|
|
85
|
+
self.cls = cls
|
|
86
|
+
self.flags = flags
|
|
87
|
+
|
|
88
|
+
def __enter__(self):
|
|
89
|
+
self.saved = _backend_mod.type_flags(self.cls)
|
|
90
|
+
flags = self.saved
|
|
91
|
+
for flag in self.flags:
|
|
92
|
+
flags = flags & ~_backend_mod.TypeFlags[flag]
|
|
93
|
+
_backend_mod.set_type_flags(self.cls, flags)
|
|
94
|
+
return self.cls
|
|
95
|
+
|
|
96
|
+
def __exit__(self, *args):
|
|
97
|
+
_backend_mod.set_type_flags(self.cls, self.saved)
|
|
98
|
+
|
|
99
|
+
|
|
100
|
+
class WithFlags:
|
|
101
|
+
def __init__(self, cls, *flags):
|
|
102
|
+
self.cls = cls
|
|
103
|
+
self.flags = flags
|
|
104
|
+
|
|
105
|
+
def __enter__(self):
|
|
106
|
+
self.saved = _backend_mod.type_flags(self.cls)
|
|
107
|
+
flags = self.saved
|
|
108
|
+
for flag in self.flags:
|
|
109
|
+
flags |= _backend_mod.TypeFlags[flag]
|
|
110
|
+
_backend_mod.set_type_flags(self.cls, flags)
|
|
111
|
+
return self.cls
|
|
112
|
+
|
|
113
|
+
def __exit__(self, *args):
|
|
114
|
+
_backend_mod.set_type_flags(self.cls, self.saved)
|
|
115
|
+
|
|
116
|
+
|
|
117
|
+
def wrap_func_with_overrides(func, **overrides):
|
|
118
|
+
"""
|
|
119
|
+
Return a new function identical to `func` but with selected global names
|
|
120
|
+
overridden by keyword arguments.
|
|
121
|
+
"""
|
|
122
|
+
import builtins as _builtins
|
|
123
|
+
import types
|
|
124
|
+
|
|
125
|
+
orig = getattr(func, "__func__", func)
|
|
126
|
+
g = dict(orig.__globals__)
|
|
127
|
+
g.setdefault("__builtins__", _builtins.__dict__)
|
|
128
|
+
g.update(overrides)
|
|
129
|
+
|
|
130
|
+
return types.FunctionType(
|
|
131
|
+
orig.__code__, g, orig.__name__, orig.__defaults__, orig.__closure__
|
|
132
|
+
)
|
|
133
|
+
|
|
134
|
+
|
|
135
|
+
def update(obj, name, f, *args, **kwargs):
|
|
136
|
+
value = getattr(obj, name)
|
|
137
|
+
setattr(obj, name, f(value, *args, **kwargs))
|
|
138
|
+
|
|
139
|
+
|
|
140
|
+
class InterceptDict(dict):
|
|
141
|
+
def __init__(self, backing: Dict, on_set: Callable[[str, Any], Any]):
|
|
142
|
+
super().__init__()
|
|
143
|
+
self.backing = backing
|
|
144
|
+
self.on_set = on_set
|
|
145
|
+
self.move_from_backing()
|
|
146
|
+
|
|
147
|
+
def move_from_backing(self):
|
|
148
|
+
for key, value in self.backing.items():
|
|
149
|
+
super().__setitem__(key, self.on_set(key, value))
|
|
150
|
+
self.backing.clear()
|
|
151
|
+
|
|
152
|
+
def __getitem__(self, key):
|
|
153
|
+
self.move_from_backing()
|
|
154
|
+
return super().__getitem__(key)
|
|
155
|
+
|
|
156
|
+
def __setitem__(self, key: str, value: Any) -> None:
|
|
157
|
+
self.move_from_backing()
|
|
158
|
+
super().__setitem__(key, self.on_set(key, value))
|
|
159
|
+
|
|
160
|
+
|
|
161
|
+
def map_values(f, m):
|
|
162
|
+
return {k: f(v) for k, v in m.items()}
|
|
163
|
+
|
|
164
|
+
|
|
165
|
+
@contextmanager
|
|
166
|
+
def on_set(dict, on_set):
|
|
167
|
+
_backend_mod.intercept_dict_set(dict, on_set)
|
|
168
|
+
yield
|
|
169
|
+
_backend_mod.intercept_dict_set(dict, None)
|
|
170
|
+
|
|
171
|
+
|
|
172
|
+
__all__ = sorted([k for k in globals().keys() if not k.startswith("_")])
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: retracesoftware_utils
|
|
3
|
-
Version: 0.2.
|
|
3
|
+
Version: 0.2.11
|
|
4
4
|
Keywords: functional,programming,c-extension,utilities,performance
|
|
5
5
|
Author-Email: Retrace Software <info@retracesoftware.com>
|
|
6
6
|
Maintainer-Email: Retrace Software <info@retracesoftware.com>
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
_retracesoftware_utils_release.cpython-312-x86_64-linux-musl.so,sha256=vPqxEKl5qkhec94d-WJ9J2GRksoinmQao1Pvas8U3hA,258017
|
|
2
|
+
_retracesoftware_utils_debug.cpython-312-x86_64-linux-musl.so,sha256=4GrSCAasCLPtR5OS1iqXOegJNp3emlL91hQxbyrt2Ds,2904233
|
|
3
|
+
retracesoftware_utils-0.2.11.dist-info/WHEEL,sha256=PuxF06zqt6StR18dSsi7ZHKFOMFeYLG-JlgbnnYKuhs,98
|
|
4
|
+
retracesoftware_utils-0.2.11.dist-info/METADATA,sha256=BWcByveGWxJ5qjcCd9Yx68--7QTff4UcBiDMVDh_KfY,764
|
|
5
|
+
retracesoftware_utils-0.2.11.dist-info/RECORD,,
|
|
6
|
+
retracesoftware/utils/__init__.py,sha256=qxVskvjP9nDJ922awMqFQDk2zvcoUSB47MwUk8upBws,4585
|
|
7
|
+
retracesoftware_utils.libs/libstdc++-496613c0.so.6.0.32,sha256=AwZhL5WFT99I2Q6vIxXOhW7qddfuOZ1xecxiP9QTVY4,3494361
|
|
8
|
+
retracesoftware_utils.libs/libgcc_s-a3a07607.so.1,sha256=5ptIUeAzZweNZrFehN0_Bb5B0FcJgux7NbAFoU8vwwo,148041
|
|
@@ -1,162 +0,0 @@
|
|
|
1
|
-
import retracesoftware_utils as _utils
|
|
2
|
-
from retracesoftware_utils import *
|
|
3
|
-
import weakref
|
|
4
|
-
import threading
|
|
5
|
-
from collections import UserDict
|
|
6
|
-
from typing import Callable, Any
|
|
7
|
-
from contextlib import contextmanager
|
|
8
|
-
|
|
9
|
-
def typeflags(cls):
|
|
10
|
-
|
|
11
|
-
bits = _utils.type_flags(cls)
|
|
12
|
-
|
|
13
|
-
result = set()
|
|
14
|
-
|
|
15
|
-
for name,value in _utils.TypeFlags.items():
|
|
16
|
-
if (value & bits) != 0:
|
|
17
|
-
result.add(name)
|
|
18
|
-
|
|
19
|
-
return result
|
|
20
|
-
|
|
21
|
-
def is_method_descriptor(obj):
|
|
22
|
-
return 'Py_TPFLAGS_METHOD_DESCRIPTOR' in typeflags(type(obj))
|
|
23
|
-
|
|
24
|
-
def flags(cls : type):
|
|
25
|
-
f = _utils.type_flags(cls)
|
|
26
|
-
|
|
27
|
-
s = set()
|
|
28
|
-
|
|
29
|
-
for name,value in _utils.TypeFlags.items():
|
|
30
|
-
if (f & value) != 0:
|
|
31
|
-
s.add(name)
|
|
32
|
-
f = f & ~value
|
|
33
|
-
|
|
34
|
-
if f != 0:
|
|
35
|
-
s.add(f)
|
|
36
|
-
|
|
37
|
-
return s
|
|
38
|
-
|
|
39
|
-
class WithoutFlags:
|
|
40
|
-
|
|
41
|
-
def __init__(self, cls , *flags):
|
|
42
|
-
self.cls = cls
|
|
43
|
-
self.flags = flags
|
|
44
|
-
|
|
45
|
-
def __enter__(self):
|
|
46
|
-
self.saved = utils.type_flags(self.cls)
|
|
47
|
-
flags = self.saved
|
|
48
|
-
|
|
49
|
-
for flag in self.flags:
|
|
50
|
-
flags = flags & ~_utils.TypeFlags[flag]
|
|
51
|
-
|
|
52
|
-
_utils.set_type_flags(self.cls, flags)
|
|
53
|
-
return self.cls
|
|
54
|
-
|
|
55
|
-
def __exit__(self, *args):
|
|
56
|
-
_utils.set_type_flags(self.cls, self.saved)
|
|
57
|
-
|
|
58
|
-
class WithFlags:
|
|
59
|
-
|
|
60
|
-
def __init__(self, cls , *flags):
|
|
61
|
-
self.cls = cls
|
|
62
|
-
self.flags = flags
|
|
63
|
-
|
|
64
|
-
def __enter__(self):
|
|
65
|
-
self.saved = _utils.type_flags(self.cls)
|
|
66
|
-
flags = self.saved
|
|
67
|
-
|
|
68
|
-
for flag in self.flags:
|
|
69
|
-
flags |= _utils.TypeFlags[flag]
|
|
70
|
-
|
|
71
|
-
_utils.set_type_flags(self.cls, flags)
|
|
72
|
-
return self.cls
|
|
73
|
-
|
|
74
|
-
def __exit__(self, *args):
|
|
75
|
-
_utils.set_type_flags(self.cls, self.saved)
|
|
76
|
-
|
|
77
|
-
def wrap_func_with_overrides(func, **overrides):
|
|
78
|
-
"""
|
|
79
|
-
Return a new function identical to `func` but with selected global names
|
|
80
|
-
overridden by keyword arguments.
|
|
81
|
-
|
|
82
|
-
Example:
|
|
83
|
-
new_func = wrap_func_with_overrides(old_func, exec=my_exec, print=my_print)
|
|
84
|
-
"""
|
|
85
|
-
|
|
86
|
-
import builtins as _builtins
|
|
87
|
-
import types
|
|
88
|
-
|
|
89
|
-
# Unwrap bound method if needed
|
|
90
|
-
orig = getattr(func, "__func__", func)
|
|
91
|
-
|
|
92
|
-
# Clone globals so we don't mutate the original module dict
|
|
93
|
-
g = dict(orig.__globals__)
|
|
94
|
-
g.setdefault("__builtins__", _builtins.__dict__)
|
|
95
|
-
g.update(overrides)
|
|
96
|
-
|
|
97
|
-
# Recreate the function
|
|
98
|
-
return types.FunctionType(
|
|
99
|
-
orig.__code__, g, orig.__name__, orig.__defaults__, orig.__closure__
|
|
100
|
-
)
|
|
101
|
-
|
|
102
|
-
def update(obj, name, f, *args, **kwargs):
|
|
103
|
-
value = getattr(obj, name)
|
|
104
|
-
setattr(obj, name, f(value, *args, **kwargs))
|
|
105
|
-
|
|
106
|
-
from typing import Dict, Any
|
|
107
|
-
|
|
108
|
-
class InterceptDict(dict):
|
|
109
|
-
def __init__(self, backing: Dict, on_set: Callable[[str, Any], Any]):
|
|
110
|
-
"""
|
|
111
|
-
A dictionary-like class that wraps an existing dictionary and calls a callback
|
|
112
|
-
to potentially modify values before they are added or updated.
|
|
113
|
-
|
|
114
|
-
Args:
|
|
115
|
-
underlying_dict: The existing dictionary to wrap and modify directly.
|
|
116
|
-
on_set: Function that takes (key, value) and returns the value to store.
|
|
117
|
-
*args: Iterable of key-value pairs to update the underlying dict.
|
|
118
|
-
**kwargs: Keyword arguments to update the underlying dict.
|
|
119
|
-
"""
|
|
120
|
-
super().__init__()
|
|
121
|
-
self.backing = backing
|
|
122
|
-
self.on_set = on_set
|
|
123
|
-
self.move_from_backing()
|
|
124
|
-
# self.fallback = initial
|
|
125
|
-
|
|
126
|
-
# store the dict version on the backing object
|
|
127
|
-
|
|
128
|
-
# Process additional items through the callback
|
|
129
|
-
# updates = dict(*args, **kwargs)
|
|
130
|
-
# for key, value in updates.items():
|
|
131
|
-
# modified_value = self.on_set(key, value)
|
|
132
|
-
# self._dict[key] = modified_value
|
|
133
|
-
|
|
134
|
-
def move_from_backing(self):
|
|
135
|
-
for key,value in self.backing.items():
|
|
136
|
-
super().__setitem__(key, self.on_set(key, value))
|
|
137
|
-
self.backing.clear()
|
|
138
|
-
|
|
139
|
-
def __getitem__(self, key):
|
|
140
|
-
self.move_from_backing()
|
|
141
|
-
return super().__getitem__(key)
|
|
142
|
-
|
|
143
|
-
def __setitem__(self, key: str, value: Any) -> None:
|
|
144
|
-
"""Set an item in the underlying dict, modifying the value via callback."""
|
|
145
|
-
self.move_from_backing()
|
|
146
|
-
super().__setitem__(key, self.on_set(key, value))
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
# def update(self, *args, **kwargs) -> None:
|
|
150
|
-
# """Update the underlying dict, processing values through the callback."""
|
|
151
|
-
# updates = dict(*args, **kwargs)
|
|
152
|
-
# for key, value in updates.items():
|
|
153
|
-
# self._dict[key] = self.on_set(key, value)
|
|
154
|
-
|
|
155
|
-
def map_values(f, m):
|
|
156
|
-
return {k: f(v) for k,v in m.items()}
|
|
157
|
-
|
|
158
|
-
@contextmanager
|
|
159
|
-
def on_set(dict, on_set):
|
|
160
|
-
_utils.intercept_dict_set(dict, on_set)
|
|
161
|
-
yield
|
|
162
|
-
_utils.intercept_dict_set(dict, None)
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
retracesoftware_utils.cpython-312-x86_64-linux-musl.so,sha256=f6vtpDAZbb_-dAgNuOvnCB_Z5jJDTbghSoV5oysOuaI,253841
|
|
2
|
-
retracesoftware_utils-0.2.3.data/purelib/retracesoftware/utils.py,sha256=oEvg-rvTXwum-rLKQ626ihr3A4XILdi-H3gGjnTTh9A,4641
|
|
3
|
-
retracesoftware_utils.libs/libstdc++-496613c0.so.6.0.32,sha256=AwZhL5WFT99I2Q6vIxXOhW7qddfuOZ1xecxiP9QTVY4,3494361
|
|
4
|
-
retracesoftware_utils.libs/libgcc_s-a3a07607.so.1,sha256=5ptIUeAzZweNZrFehN0_Bb5B0FcJgux7NbAFoU8vwwo,148041
|
|
5
|
-
retracesoftware_utils-0.2.3.dist-info/WHEEL,sha256=PuxF06zqt6StR18dSsi7ZHKFOMFeYLG-JlgbnnYKuhs,98
|
|
6
|
-
retracesoftware_utils-0.2.3.dist-info/METADATA,sha256=N7xxk5Cnhpk4oNVdgkHg9UBDeWutVVeM7WP758e2fcI,763
|
|
7
|
-
retracesoftware_utils-0.2.3.dist-info/RECORD,,
|
|
Binary file
|
|
File without changes
|