retracesoftware-utils 0.2.5__cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl → 0.2.11__cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.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.

@@ -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.5
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,6 @@
1
+ _retracesoftware_utils_debug.cpython-312-aarch64-linux-gnu.so,sha256=7MpnxSROKB431por57q48PCo4DqQWCxCPqZkWxv8JbU,3119112
2
+ _retracesoftware_utils_release.cpython-312-aarch64-linux-gnu.so,sha256=1zqyFD24wXPZcjmV1-jAYdohHKmdC_DQtsJiDeoU_go,380776
3
+ retracesoftware/utils/__init__.py,sha256=qxVskvjP9nDJ922awMqFQDk2zvcoUSB47MwUk8upBws,4585
4
+ retracesoftware_utils-0.2.11.dist-info/WHEEL,sha256=ZPInqmoV0ASPMOQ0bb26_WmRflzUKSKcBoAb2iDqeyo,139
5
+ retracesoftware_utils-0.2.11.dist-info/METADATA,sha256=BWcByveGWxJ5qjcCd9Yx68--7QTff4UcBiDMVDh_KfY,764
6
+ retracesoftware_utils-0.2.11.dist-info/RECORD,,
@@ -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,5 +0,0 @@
1
- retracesoftware_utils.cpython-312-aarch64-linux-gnu.so,sha256=vp09Wn2Q19CfSQT8qjgwMfrVEOBzbxq2zizBB1IYidc,380240
2
- retracesoftware_utils-0.2.5.data/purelib/retracesoftware/utils.py,sha256=oEvg-rvTXwum-rLKQ626ihr3A4XILdi-H3gGjnTTh9A,4641
3
- retracesoftware_utils-0.2.5.dist-info/WHEEL,sha256=ZPInqmoV0ASPMOQ0bb26_WmRflzUKSKcBoAb2iDqeyo,139
4
- retracesoftware_utils-0.2.5.dist-info/METADATA,sha256=PoO5SABlDQpwdd2rR3JhrI2YeQr6Hk1q2MeopspWNqU,763
5
- retracesoftware_utils-0.2.5.dist-info/RECORD,,