omdev 0.0.0.dev214__py3-none-any.whl → 0.0.0.dev216__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- omdev/scripts/ci.py +3 -3
- omdev/scripts/interp.py +1 -1
- omdev/scripts/pyproject.py +80 -13
- omdev/tools/json/formats.py +4 -0
- {omdev-0.0.0.dev214.dist-info → omdev-0.0.0.dev216.dist-info}/METADATA +2 -2
- {omdev-0.0.0.dev214.dist-info → omdev-0.0.0.dev216.dist-info}/RECORD +10 -10
- {omdev-0.0.0.dev214.dist-info → omdev-0.0.0.dev216.dist-info}/LICENSE +0 -0
- {omdev-0.0.0.dev214.dist-info → omdev-0.0.0.dev216.dist-info}/WHEEL +0 -0
- {omdev-0.0.0.dev214.dist-info → omdev-0.0.0.dev216.dist-info}/entry_points.txt +0 -0
- {omdev-0.0.0.dev214.dist-info → omdev-0.0.0.dev216.dist-info}/top_level.txt +0 -0
omdev/scripts/ci.py
CHANGED
@@ -167,7 +167,7 @@ def asyncio_once(fn: CallableT) -> CallableT:
|
|
167
167
|
return ta.cast(CallableT, inner)
|
168
168
|
|
169
169
|
|
170
|
-
def
|
170
|
+
def drain_asyncio_tasks(loop=None):
|
171
171
|
if loop is None:
|
172
172
|
loop = asyncio.get_running_loop()
|
173
173
|
|
@@ -182,7 +182,7 @@ def draining_asyncio_tasks() -> ta.Iterator[None]:
|
|
182
182
|
yield
|
183
183
|
finally:
|
184
184
|
if loop is not None:
|
185
|
-
|
185
|
+
drain_asyncio_tasks(loop) # noqa
|
186
186
|
|
187
187
|
|
188
188
|
async def asyncio_wait_concurrent(
|
@@ -2563,7 +2563,7 @@ TODO:
|
|
2563
2563
|
|
2564
2564
|
STANDARD_LOG_FORMAT_PARTS = [
|
2565
2565
|
('asctime', '%(asctime)-15s'),
|
2566
|
-
('process', 'pid=%(process)
|
2566
|
+
('process', 'pid=%(process)s'),
|
2567
2567
|
('thread', 'tid=%(thread)x'),
|
2568
2568
|
('levelname', '%(levelname)s'),
|
2569
2569
|
('name', '%(name)s'),
|
omdev/scripts/interp.py
CHANGED
@@ -3500,7 +3500,7 @@ TODO:
|
|
3500
3500
|
|
3501
3501
|
STANDARD_LOG_FORMAT_PARTS = [
|
3502
3502
|
('asctime', '%(asctime)-15s'),
|
3503
|
-
('process', 'pid=%(process)
|
3503
|
+
('process', 'pid=%(process)s'),
|
3504
3504
|
('thread', 'tid=%(thread)x'),
|
3505
3505
|
('levelname', '%(levelname)s'),
|
3506
3506
|
('name', '%(name)s'),
|
omdev/scripts/pyproject.py
CHANGED
@@ -4962,6 +4962,7 @@ inj = InjectionApi()
|
|
4962
4962
|
TODO:
|
4963
4963
|
- pickle stdlib objs? have to pin to 3.8 pickle protocol, will be cross-version
|
4964
4964
|
- literals
|
4965
|
+
- Options.sequence_cls = list, mapping_cls = dict, ... - def with_mutable_containers() -> Options
|
4965
4966
|
"""
|
4966
4967
|
|
4967
4968
|
|
@@ -5114,21 +5115,55 @@ class IterableObjMarshaler(ObjMarshaler):
|
|
5114
5115
|
@dc.dataclass(frozen=True)
|
5115
5116
|
class FieldsObjMarshaler(ObjMarshaler):
|
5116
5117
|
ty: type
|
5117
|
-
|
5118
|
+
|
5119
|
+
@dc.dataclass(frozen=True)
|
5120
|
+
class Field:
|
5121
|
+
att: str
|
5122
|
+
key: str
|
5123
|
+
m: ObjMarshaler
|
5124
|
+
|
5125
|
+
omit_if_none: bool = False
|
5126
|
+
|
5127
|
+
fs: ta.Sequence[Field]
|
5128
|
+
|
5118
5129
|
non_strict: bool = False
|
5119
5130
|
|
5131
|
+
#
|
5132
|
+
|
5133
|
+
_fs_by_att: ta.ClassVar[ta.Mapping[str, Field]]
|
5134
|
+
_fs_by_key: ta.ClassVar[ta.Mapping[str, Field]]
|
5135
|
+
|
5136
|
+
def __post_init__(self) -> None:
|
5137
|
+
fs_by_att: dict = {}
|
5138
|
+
fs_by_key: dict = {}
|
5139
|
+
for f in self.fs:
|
5140
|
+
check.not_in(check.non_empty_str(f.att), fs_by_att)
|
5141
|
+
check.not_in(check.non_empty_str(f.key), fs_by_key)
|
5142
|
+
fs_by_att[f.att] = f
|
5143
|
+
fs_by_key[f.key] = f
|
5144
|
+
self.__dict__['_fs_by_att'] = fs_by_att
|
5145
|
+
self.__dict__['_fs_by_key'] = fs_by_key
|
5146
|
+
|
5147
|
+
#
|
5148
|
+
|
5120
5149
|
def marshal(self, o: ta.Any, ctx: 'ObjMarshalContext') -> ta.Any:
|
5121
|
-
|
5122
|
-
|
5123
|
-
|
5124
|
-
|
5150
|
+
d = {}
|
5151
|
+
for f in self.fs:
|
5152
|
+
mv = f.m.marshal(getattr(o, f.att), ctx)
|
5153
|
+
if mv is None and f.omit_if_none:
|
5154
|
+
continue
|
5155
|
+
d[f.key] = mv
|
5156
|
+
return d
|
5125
5157
|
|
5126
5158
|
def unmarshal(self, o: ta.Any, ctx: 'ObjMarshalContext') -> ta.Any:
|
5127
|
-
|
5128
|
-
|
5129
|
-
|
5130
|
-
|
5131
|
-
|
5159
|
+
kw = {}
|
5160
|
+
for k, v in o.items():
|
5161
|
+
if (f := self._fs_by_key.get(k)) is None:
|
5162
|
+
if not (self.non_strict or ctx.options.non_strict_fields):
|
5163
|
+
raise KeyError(k)
|
5164
|
+
continue
|
5165
|
+
kw[f.att] = f.m.unmarshal(v, ctx)
|
5166
|
+
return self.ty(**kw)
|
5132
5167
|
|
5133
5168
|
|
5134
5169
|
@dc.dataclass(frozen=True)
|
@@ -5263,6 +5298,22 @@ def register_single_field_type_obj_marshaler(fld, ty=None):
|
|
5263
5298
|
##
|
5264
5299
|
|
5265
5300
|
|
5301
|
+
class ObjMarshalerFieldMetadata:
|
5302
|
+
def __new__(cls, *args, **kwargs): # noqa
|
5303
|
+
raise TypeError
|
5304
|
+
|
5305
|
+
|
5306
|
+
class OBJ_MARSHALER_FIELD_KEY(ObjMarshalerFieldMetadata): # noqa
|
5307
|
+
pass
|
5308
|
+
|
5309
|
+
|
5310
|
+
class OBJ_MARSHALER_OMIT_IF_NONE(ObjMarshalerFieldMetadata): # noqa
|
5311
|
+
pass
|
5312
|
+
|
5313
|
+
|
5314
|
+
##
|
5315
|
+
|
5316
|
+
|
5266
5317
|
class ObjMarshalerManager:
|
5267
5318
|
def __init__(
|
5268
5319
|
self,
|
@@ -5322,14 +5373,30 @@ class ObjMarshalerManager:
|
|
5322
5373
|
if dc.is_dataclass(ty):
|
5323
5374
|
return FieldsObjMarshaler(
|
5324
5375
|
ty,
|
5325
|
-
|
5376
|
+
[
|
5377
|
+
FieldsObjMarshaler.Field(
|
5378
|
+
att=f.name,
|
5379
|
+
key=check.non_empty_str(fk),
|
5380
|
+
m=rec(f.type),
|
5381
|
+
omit_if_none=check.isinstance(f.metadata.get(OBJ_MARSHALER_OMIT_IF_NONE, False), bool),
|
5382
|
+
)
|
5383
|
+
for f in dc.fields(ty)
|
5384
|
+
if (fk := f.metadata.get(OBJ_MARSHALER_FIELD_KEY, f.name)) is not None
|
5385
|
+
],
|
5326
5386
|
non_strict=non_strict_fields,
|
5327
5387
|
)
|
5328
5388
|
|
5329
5389
|
if issubclass(ty, tuple) and hasattr(ty, '_fields'):
|
5330
5390
|
return FieldsObjMarshaler(
|
5331
5391
|
ty,
|
5332
|
-
|
5392
|
+
[
|
5393
|
+
FieldsObjMarshaler.Field(
|
5394
|
+
att=p.name,
|
5395
|
+
key=p.name,
|
5396
|
+
m=rec(p.annotation),
|
5397
|
+
)
|
5398
|
+
for p in inspect.signature(ty).parameters.values()
|
5399
|
+
],
|
5333
5400
|
non_strict=non_strict_fields,
|
5334
5401
|
)
|
5335
5402
|
|
@@ -5673,7 +5740,7 @@ TODO:
|
|
5673
5740
|
|
5674
5741
|
STANDARD_LOG_FORMAT_PARTS = [
|
5675
5742
|
('asctime', '%(asctime)-15s'),
|
5676
|
-
('process', 'pid=%(process)
|
5743
|
+
('process', 'pid=%(process)s'),
|
5677
5744
|
('thread', 'tid=%(thread)x'),
|
5678
5745
|
('levelname', '%(levelname)s'),
|
5679
5746
|
('name', '%(name)s'),
|
omdev/tools/json/formats.py
CHANGED
@@ -18,6 +18,7 @@ if ta.TYPE_CHECKING:
|
|
18
18
|
import yaml
|
19
19
|
|
20
20
|
from omlish.formats import dotenv
|
21
|
+
from omlish.formats import json5
|
21
22
|
from omlish.formats import props
|
22
23
|
from omlish.formats import xml
|
23
24
|
|
@@ -29,6 +30,7 @@ else:
|
|
29
30
|
yaml = lang.proxy_import('yaml')
|
30
31
|
|
31
32
|
dotenv = lang.proxy_import('omlish.formats.dotenv')
|
33
|
+
json5 = lang.proxy_import('omlish.formats.json5')
|
32
34
|
props = lang.proxy_import('omlish.formats.props')
|
33
35
|
xml = lang.proxy_import('omlish.formats.xml')
|
34
36
|
|
@@ -45,6 +47,8 @@ class Format:
|
|
45
47
|
class Formats(enum.Enum):
|
46
48
|
JSON = Format(['json'], json.load)
|
47
49
|
|
50
|
+
JSON5 = Format(['json5'], lambda f: json5.loads(f.read()))
|
51
|
+
|
48
52
|
YAML = Format(['yaml', 'yml'], lambda f: yaml.safe_load(f))
|
49
53
|
|
50
54
|
TOML = Format(['toml'], lambda f: tomllib.loads(f.read()))
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.2
|
2
2
|
Name: omdev
|
3
|
-
Version: 0.0.0.
|
3
|
+
Version: 0.0.0.dev216
|
4
4
|
Summary: omdev
|
5
5
|
Author: wrmsr
|
6
6
|
License: BSD-3-Clause
|
@@ -12,7 +12,7 @@ Classifier: Operating System :: OS Independent
|
|
12
12
|
Classifier: Operating System :: POSIX
|
13
13
|
Requires-Python: >=3.12
|
14
14
|
License-File: LICENSE
|
15
|
-
Requires-Dist: omlish==0.0.0.
|
15
|
+
Requires-Dist: omlish==0.0.0.dev216
|
16
16
|
Provides-Extra: all
|
17
17
|
Requires-Dist: black~=24.10; extra == "all"
|
18
18
|
Requires-Dist: pycparser~=2.22; extra == "all"
|
@@ -174,12 +174,12 @@ omdev/pyproject/resources/docker-dev.sh,sha256=DHkz5D18jok_oDolfg2mqrvGRWFoCe9GQ
|
|
174
174
|
omdev/pyproject/resources/python.sh,sha256=jvrwddYw2KNttpuImLbdCdJK0HsUNMrHtTnmLvhxQxg,757
|
175
175
|
omdev/scripts/__init__.py,sha256=MKCvUAEQwsIvwLixwtPlpBqmkMXLCnjjXyAXvVpDwVk,91
|
176
176
|
omdev/scripts/bumpversion.py,sha256=Kn7fo73Hs8uJh3Hi3EIyLOlzLPWAC6dwuD_lZ3cIzuY,1064
|
177
|
-
omdev/scripts/ci.py,sha256=
|
177
|
+
omdev/scripts/ci.py,sha256=DFrHVKNDkEFLsjx8FnJaNL3hGCAJQmZKY8fIQzMRJl8,108884
|
178
178
|
omdev/scripts/execrss.py,sha256=mR0G0wERBYtQmVIn63lCIIFb5zkCM6X_XOENDFYDBKc,651
|
179
179
|
omdev/scripts/exectime.py,sha256=sFb376GflU6s9gNX-2-we8hgH6w5MuQNS9g6i4SqJIo,610
|
180
180
|
omdev/scripts/importtrace.py,sha256=oa7CtcWJVMNDbyIEiRHej6ICfABfErMeo4_haIqe18Q,14041
|
181
|
-
omdev/scripts/interp.py,sha256=
|
182
|
-
omdev/scripts/pyproject.py,sha256=
|
181
|
+
omdev/scripts/interp.py,sha256=eEYBvLuFmkdHkH_pt7ti6kOKGJThWPL93o54fNRQKyY,141849
|
182
|
+
omdev/scripts/pyproject.py,sha256=Ngd9rPI4aeEOBwvwbJVxJh6Z-XXF3NrP6qctOMVkspo,245593
|
183
183
|
omdev/scripts/slowcat.py,sha256=lssv4yrgJHiWfOiHkUut2p8E8Tq32zB-ujXESQxFFHY,2728
|
184
184
|
omdev/scripts/tmpexec.py,sha256=WTYcf56Tj2qjYV14AWmV8SfT0u6Y8eIU6cKgQRvEK3c,1442
|
185
185
|
omdev/tokens/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
@@ -203,7 +203,7 @@ omdev/tools/sqlrepl.py,sha256=wAjrfXNrRV63-NJCC2HlGQnFh7lUH0bHMnOjYotQqFs,5753
|
|
203
203
|
omdev/tools/json/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
204
204
|
omdev/tools/json/__main__.py,sha256=wqpkN_NsQyNwKW4qjVj8ADJ4_C98KhrFBtE-Z1UamfU,168
|
205
205
|
omdev/tools/json/cli.py,sha256=EubIMT-n2XsjWBZjSy2fWXqijlwrIhLsfbkg3SZzi28,9586
|
206
|
-
omdev/tools/json/formats.py,sha256=
|
206
|
+
omdev/tools/json/formats.py,sha256=RgtPdcs294o9n9czjafHppg1iSzD-olsIc3v8ApM9Os,1908
|
207
207
|
omdev/tools/json/io.py,sha256=sfj2hJS9Hy3aUR8a_lLzOrYcmL9fSKyvOHiofdUASsI,1427
|
208
208
|
omdev/tools/json/parsing.py,sha256=YOeTRY6Gd89EfcHvqXO5PRWJ3IgRCpNnI54Lb_N3v2k,2183
|
209
209
|
omdev/tools/json/processing.py,sha256=iFm5VqaxJ97WHaun2ed7NEjMxhFeJqf28bLNfoDJft0,1209
|
@@ -211,9 +211,9 @@ omdev/tools/json/rendering.py,sha256=tMcjOW5edfozcMSTxxvF7WVTsbYLoe9bCKFh50qyaGw
|
|
211
211
|
omdev/tools/pawk/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
212
212
|
omdev/tools/pawk/__main__.py,sha256=VCqeRVnqT1RPEoIrqHFSu4PXVMg4YEgF4qCQm90-eRI,66
|
213
213
|
omdev/tools/pawk/pawk.py,sha256=zsEkfQX0jF5bn712uqPAyBSdJt2dno1LH2oeSMNfXQI,11424
|
214
|
-
omdev-0.0.0.
|
215
|
-
omdev-0.0.0.
|
216
|
-
omdev-0.0.0.
|
217
|
-
omdev-0.0.0.
|
218
|
-
omdev-0.0.0.
|
219
|
-
omdev-0.0.0.
|
214
|
+
omdev-0.0.0.dev216.dist-info/LICENSE,sha256=B_hVtavaA8zCYDW99DYdcpDLKz1n3BBRjZrcbv8uG8c,1451
|
215
|
+
omdev-0.0.0.dev216.dist-info/METADATA,sha256=UBydS_2HxF-TLeA1eKWNJGOkfiGsNiuIKH2mv-u5pVk,1638
|
216
|
+
omdev-0.0.0.dev216.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
|
217
|
+
omdev-0.0.0.dev216.dist-info/entry_points.txt,sha256=dHLXFmq5D9B8qUyhRtFqTGWGxlbx3t5ejedjrnXNYLU,33
|
218
|
+
omdev-0.0.0.dev216.dist-info/top_level.txt,sha256=1nr7j30fEWgLYHW3lGR9pkdHkb7knv1U1ES1XRNVQ6k,6
|
219
|
+
omdev-0.0.0.dev216.dist-info/RECORD,,
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|