omdev 0.0.0.dev236__py3-none-any.whl → 0.0.0.dev238__py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
omdev/.manifests.json CHANGED
@@ -291,7 +291,7 @@
291
291
  "module": ".tools.git.messages",
292
292
  "attr": "_TIMESTAMP_GIT_MESSAGE_GENERATOR_MANIFEST",
293
293
  "file": "omdev/tools/git/messages.py",
294
- "line": 75,
294
+ "line": 85,
295
295
  "value": {
296
296
  "$.tools.git.messages.GitMessageGeneratorManifest": {
297
297
  "mod_name": "omdev.tools.git.messages",
@@ -431,6 +431,18 @@
431
431
  }
432
432
  }
433
433
  },
434
+ {
435
+ "module": ".tools.shadow",
436
+ "attr": "_CLI_MODULE",
437
+ "file": "omdev/tools/shadow.py",
438
+ "line": 64,
439
+ "value": {
440
+ "$.cli.types.CliModule": {
441
+ "cmd_name": "shadow",
442
+ "mod_name": "omdev.tools.shadow"
443
+ }
444
+ }
445
+ },
434
446
  {
435
447
  "module": ".tools.sqlrepl",
436
448
  "attr": "_CLI_MODULE",
omdev/home/configs.py ADDED
@@ -0,0 +1,13 @@
1
+ import os.path
2
+
3
+ from omlish.configs.shadow import MangledFilesShadowConfigs
4
+ from omlish.configs.shadow import ShadowConfigs
5
+
6
+ from .paths import get_home_dir
7
+
8
+
9
+ def get_shadow_configs() -> ShadowConfigs:
10
+ return MangledFilesShadowConfigs(
11
+ os.path.join(get_home_dir(), 'shadow'),
12
+ create=True,
13
+ )
omdev/manifests/build.py CHANGED
@@ -3,6 +3,7 @@
3
3
  TODO:
4
4
  - verify classes instantiate
5
5
  - embed in pyproject
6
+ - roundtrip flexibility regarding json-ness - tuples vs lists vs sets vs frozensets etc
6
7
 
7
8
  See (entry_points):
8
9
  - https://github.com/pytest-dev/pluggy/blob/main/src/pluggy/_manager.py#L405
@@ -43,7 +44,13 @@ T = ta.TypeVar('T')
43
44
 
44
45
  MANIFEST_MAGIC_KEY = '@omlish-manifest'
45
46
 
46
- _MANIFEST_GLOBAL_PAT = re.compile(r'^(?P<name>[A-Za-z_][A-Za-z0-9_]*)\s*=.*')
47
+ _MANIFEST_GLOBAL_PATS = tuple(re.compile(p) for p in [
48
+ # _FOO_MANIFEST = FooManifest(...
49
+ r'^(?P<name>[A-Za-z_][A-Za-z0-9_]*)\s*=.*',
50
+
51
+ # class _FOO_MANIFEST(StaticFooManifest): ...
52
+ r'^class (?P<name>[A-Za-z_][A-Za-z0-9_]*)\s*(\(|$)',
53
+ ])
47
54
 
48
55
 
49
56
  def _dump_module_manifests(spec: str, *attrs: str) -> None:
@@ -59,13 +66,17 @@ def _dump_module_manifests(spec: str, *attrs: str) -> None:
59
66
  manifest = getattr(mod, attr)
60
67
 
61
68
  if dc.is_dataclass(manifest):
69
+ # Support static dataclasses
70
+ if isinstance(manifest, type):
71
+ manifest = manifest()
72
+
62
73
  cls = type(manifest)
63
- manifest_json = json.dumps(dc.asdict(manifest)) # type: ignore
74
+ manifest_json = json.dumps(dc.asdict(manifest))
64
75
  manifest_dct = json.loads(manifest_json)
65
76
 
66
- rt_manifest = cls(**manifest_dct) # type: ignore
77
+ rt_manifest = cls(**manifest_dct)
67
78
  if rt_manifest != manifest:
68
- raise Exception(f'Manifest failed to roundtrip: {manifest} -> {manifest_dct} != {rt_manifest}')
79
+ raise Exception(f'Manifest failed to roundtrip: {manifest} => {manifest_dct} != {rt_manifest}')
69
80
 
70
81
  key = f'${cls.__module__}.{cls.__qualname__}'
71
82
  out[attr] = {key: manifest_dct}
@@ -146,7 +157,11 @@ class ManifestBuilder:
146
157
  lines = src.splitlines(keepends=True)
147
158
  for i, l in enumerate(lines):
148
159
  if l.startswith('# ' + MANIFEST_MAGIC_KEY):
149
- if (m := _MANIFEST_GLOBAL_PAT.match(nl := lines[i + 1])) is None:
160
+ nl = lines[i + 1]
161
+ for pat in _MANIFEST_GLOBAL_PATS:
162
+ if (m := pat.match(nl)) is not None:
163
+ break
164
+ else:
150
165
  raise Exception(nl)
151
166
 
152
167
  origins.append(ManifestOrigin(
omdev/pip.py CHANGED
@@ -1,23 +1,16 @@
1
1
  import importlib.metadata
2
- import io
2
+ import json
3
3
  import sys
4
4
  import typing as ta
5
5
  import urllib.request
6
6
 
7
7
  from omlish import check
8
- from omlish import lang
9
8
 
10
9
  from .packaging.names import canonicalize_name
11
10
  from .packaging.requires import RequiresVariable
12
11
  from .packaging.requires import parse_requirement
13
12
 
14
13
 
15
- if ta.TYPE_CHECKING:
16
- import xml.etree.ElementTree as ET # noqa
17
- else:
18
- ET = lang.proxy_import('xml.etree.ElementTree')
19
-
20
-
21
14
  ##
22
15
 
23
16
 
@@ -30,11 +23,11 @@ def lookup_latest_package_version(
30
23
  pypi_url: str = DEFAULT_PYPI_URL,
31
24
  ) -> str:
32
25
  pkg_name = check.non_empty_str(package)
33
- with urllib.request.urlopen(f'{pypi_url.rstrip("/")}/rss/project/{pkg_name}/releases.xml') as resp: # noqa
34
- rss = resp.read()
35
- doc = ET.parse(io.BytesIO(rss)) # noqa
36
- latest = check.not_none(doc.find('./channel/item/title')).text
37
- return check.non_empty_str(latest)
26
+ with urllib.request.urlopen(f'{pypi_url.rstrip("/")}/pypi/{pkg_name}/json') as resp: # noqa
27
+ buf = resp.read()
28
+ # https://github.com/python/cpython/blob/51d4bf1e0e5349090da72721c865b6c2b28277f3/Tools/scripts/checkpip.py
29
+ dct = json.loads(buf.decode('utf-8'))
30
+ return check.non_empty_str(dct['info']['version'])
38
31
 
39
32
 
40
33
  ##
omdev/tools/git/cli.py CHANGED
@@ -13,6 +13,7 @@ from omlish import cached
13
13
  from omlish import check
14
14
  from omlish import lang
15
15
  from omlish.argparse import all as ap
16
+ from omlish.configs.processing.merging import merge_configs
16
17
  from omlish.formats import json
17
18
  from omlish.formats import yaml
18
19
  from omlish.logs import all as logs
@@ -20,7 +21,9 @@ from omlish.subprocesses.sync import subprocesses
20
21
 
21
22
  from ...git.status import GitStatusItem
22
23
  from ...git.status import get_git_status
24
+ from ...home.configs import get_shadow_configs
23
25
  from ...home.paths import get_home_dir
26
+ from . import consts
24
27
  from .messages import GitMessageGenerator
25
28
  from .messages import TimestampGitMessageGenerator
26
29
  from .messages import load_message_generator_manifests
@@ -74,23 +77,42 @@ class Cli(ap.Cli):
74
77
  return os.path.join(get_home_dir(), 'tools', 'git.yml')
75
78
 
76
79
  @cached.function
77
- def load_config(self) -> Config:
80
+ def load_home_config_content(self) -> ta.Any:
78
81
  try:
79
82
  with open(self.config_file_path()) as f:
80
83
  buf = f.read()
81
84
  except FileNotFoundError:
82
85
  return self.Config()
83
86
 
84
- dct = yaml.safe_load(buf)
87
+ return yaml.safe_load(buf) or {}
88
+
89
+ class _NOT_SET(lang.Marker): # noqa
90
+ pass
91
+
92
+ def load_config(self, path: str | type[_NOT_SET] | None = _NOT_SET) -> Config:
93
+ dct = self.load_home_config_content() or {}
94
+
95
+ if path is not self._NOT_SET:
96
+ if path is None:
97
+ path = os.getcwd()
98
+ shadow_cfg = get_shadow_configs().get_shadow_config(check.isinstance(path, str)) or {}
99
+ dct = merge_configs(dct, shadow_cfg.get('git', {}))
100
+
85
101
  return msh.unmarshal(dct, self.Config)
86
102
 
87
- @ap.cmd()
103
+ @ap.cmd(
104
+ ap.arg('dir', nargs='?'),
105
+ )
88
106
  def print_cfg(self) -> None:
89
- cfg = self.load_config()
107
+ cfg = self.load_config(self._args.dir)
90
108
  print(yaml.dump(msh.marshal(cfg)))
91
109
 
92
110
  #
93
111
 
112
+ _time_fmt: str = ap.arg_('--time-fmt', default=consts.DEFAULT_TIME_FMT)
113
+
114
+ # Commands
115
+
94
116
  @ap.cmd()
95
117
  def blob_sizes(self) -> None:
96
118
  # https://stackoverflow.com/a/42544963
@@ -232,10 +254,40 @@ class Cli(ap.Cli):
232
254
 
233
255
  # Lazy helpers
234
256
 
257
+ @ap.cmd(
258
+ ap.arg('-g', '--message-generator', nargs='?'),
259
+ ap.arg('dir', nargs='*'),
260
+ aliases=['gcm'],
261
+ )
262
+ def generate_commit_message(self) -> None:
263
+ def run(cwd: str | None) -> None:
264
+ st = get_git_status(cwd=cwd)
265
+
266
+ if not (st.has_staged or st.has_dirty):
267
+ return
268
+
269
+ mg_cls: type[GitMessageGenerator] = TimestampGitMessageGenerator
270
+ if (mg_name := self.args.message_generator) is None:
271
+ mg_name = self.load_config(cwd).default_message_generator
272
+ if mg_name is not None:
273
+ mg_cls = load_message_generator_manifests_map()[mg_name].load_cls()
274
+ mg = mg_cls()
275
+
276
+ mgr = mg.generate_commit_message(GitMessageGenerator.GenerateCommitMessageArgs(
277
+ cwd=cwd,
278
+ time_fmt=self._time_fmt,
279
+ ))
280
+ print(mgr.msg)
281
+
282
+ if not self.args.dir:
283
+ run(None)
284
+ else:
285
+ for d in self.args.dir:
286
+ run(d)
287
+
235
288
  @ap.cmd(
236
289
  ap.arg('-m', '--message', nargs='?'),
237
290
  ap.arg('-g', '--message-generator', nargs='?'),
238
- ap.arg('--time-fmt', default=GitMessageGenerator.GenerateCommitMessageArgs.DEFAULT_TIME_FMT),
239
291
  ap.arg('--dry-run', action='store_true'),
240
292
  ap.arg('-y', '--no-confirmation', action='store_true'),
241
293
  ap.arg('dir', nargs='*'),
@@ -261,14 +313,14 @@ class Cli(ap.Cli):
261
313
  else:
262
314
  mg_cls: type[GitMessageGenerator] = TimestampGitMessageGenerator
263
315
  if (mg_name := self.args.message_generator) is None:
264
- mg_name = self.load_config().default_message_generator
316
+ mg_name = self.load_config(cwd).default_message_generator
265
317
  if mg_name is not None:
266
318
  mg_cls = load_message_generator_manifests_map()[mg_name].load_cls()
267
319
  mg = mg_cls()
268
320
 
269
321
  mgr = mg.generate_commit_message(GitMessageGenerator.GenerateCommitMessageArgs(
270
322
  cwd=cwd,
271
- time_fmt=self.args.time_fmt,
323
+ time_fmt=self._time_fmt,
272
324
  ))
273
325
  if mgr.confirm and not self._args.no_confirmation:
274
326
  print(mgr.msg)
@@ -0,0 +1 @@
1
+ DEFAULT_TIME_FMT = '%Y-%m-%dT%H:%M:%SZ'
@@ -1,14 +1,17 @@
1
1
  import abc
2
- import dataclasses as dc
3
2
  import os
4
3
  import typing as ta
5
4
 
6
5
  from omlish import cached
7
6
  from omlish import check
7
+ from omlish import dataclasses as dc
8
8
  from omlish import lang
9
9
  from omlish.manifests import load as manifest_load
10
10
  from omlish.manifests.base import ModAttrManifest
11
11
  from omlish.manifests.base import NameAliasesManifest
12
+ from omlish.manifests.static import StaticModAttrManifest
13
+
14
+ from . import consts
12
15
 
13
16
 
14
17
  ##
@@ -19,7 +22,7 @@ class GitMessageGenerator(abc.ABC):
19
22
  class GenerateCommitMessageArgs:
20
23
  cwd: str | None = None
21
24
 
22
- DEFAULT_TIME_FMT: ta.ClassVar[str] = '%Y-%m-%dT%H:%M:%SZ'
25
+ DEFAULT_TIME_FMT: ta.ClassVar[str] = consts.DEFAULT_TIME_FMT
23
26
  time_fmt: str = DEFAULT_TIME_FMT
24
27
 
25
28
  @dc.dataclass(frozen=True, kw_only=True)
@@ -42,6 +45,13 @@ class GitMessageGeneratorManifest(NameAliasesManifest, ModAttrManifest):
42
45
  return check.issubclass(self.load(), GitMessageGenerator)
43
46
 
44
47
 
48
+ class StaticGitMessageGeneratorManifest(StaticModAttrManifest, GitMessageGeneratorManifest, abc.ABC):
49
+ pass
50
+
51
+
52
+ #
53
+
54
+
45
55
  @cached.function
46
56
  def load_message_generator_manifests() -> ta.Sequence[GitMessageGeneratorManifest]:
47
57
  ldr = manifest_load.MANIFEST_LOADER
@@ -73,9 +83,7 @@ class TimestampGitMessageGenerator(GitMessageGenerator):
73
83
 
74
84
 
75
85
  # @omlish-manifest
76
- _TIMESTAMP_GIT_MESSAGE_GENERATOR_MANIFEST = GitMessageGeneratorManifest(
77
- mod_name=__name__,
78
- attr_name='TimestampGitMessageGenerator',
79
- name='timestamp',
80
- aliases=['ts'],
81
- )
86
+ class _TIMESTAMP_GIT_MESSAGE_GENERATOR_MANIFEST(StaticGitMessageGeneratorManifest): # noqa
87
+ attr_name = 'TimestampGitMessageGenerator'
88
+ name = 'timestamp'
89
+ aliases = ['ts'] # noqa
omdev/tools/shadow.py ADDED
@@ -0,0 +1,73 @@
1
+ """
2
+ TODO:
3
+ - 'edit', default cwd - use git's
4
+ - git var GIT_EDITOR
5
+ - delete?
6
+ - 'purge'?
7
+ - 'validate' - at least formats
8
+ """
9
+ import os.path
10
+ import shutil
11
+
12
+ from omlish import check
13
+ from omlish.argparse import all as ap
14
+ from omlish.configs.shadow import FileShadowConfigs
15
+
16
+ from ..cli.types import CliModule
17
+ from ..home.configs import get_shadow_configs
18
+
19
+
20
+ ##
21
+
22
+
23
+ class ShadowCli(ap.Cli):
24
+ def _get_shadow_file(self, path: str | None = None) -> str:
25
+ if (path := self._args.path) is None:
26
+ path = os.getcwd()
27
+ file_scs = check.isinstance(get_shadow_configs(), FileShadowConfigs)
28
+ shd_file = file_scs.get_shadow_config_file_path(path)
29
+ return shd_file
30
+
31
+ #
32
+
33
+ @ap.cmd(
34
+ ap.arg('path', nargs='?'),
35
+ )
36
+ def edit(self) -> None:
37
+ shd_file = self._get_shadow_file(self._args.path)
38
+ os.makedirs(os.path.dirname(shd_file), exist_ok=True)
39
+ os.execl(check.not_none(shutil.which('vim')), 'vim', shd_file)
40
+
41
+ @ap.cmd(
42
+ ap.arg('path', nargs='?'),
43
+ )
44
+ def show(self) -> None:
45
+ shd_file = self._get_shadow_file(self._args.path)
46
+ try:
47
+ with open(shd_file) as f:
48
+ buf = f.read()
49
+ except FileNotFoundError:
50
+ return
51
+ print(buf)
52
+
53
+ @ap.cmd(
54
+ ap.arg('path', nargs='?'),
55
+ )
56
+ def which(self) -> None:
57
+ shd_file = self._get_shadow_file(self._args.path)
58
+ print(shd_file)
59
+
60
+
61
+ ##
62
+
63
+
64
+ # @omlish-manifest
65
+ _CLI_MODULE = CliModule('shadow', __name__)
66
+
67
+
68
+ def _main() -> None:
69
+ ShadowCli().cli_run_and_exit()
70
+
71
+
72
+ if __name__ == '__main__':
73
+ _main()
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: omdev
3
- Version: 0.0.0.dev236
3
+ Version: 0.0.0.dev238
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.dev236
15
+ Requires-Dist: omlish==0.0.0.dev238
16
16
  Provides-Extra: all
17
17
  Requires-Dist: black~=25.1; extra == "all"
18
18
  Requires-Dist: pycparser~=2.22; extra == "all"
@@ -1,4 +1,4 @@
1
- omdev/.manifests.json,sha256=kbXBVJQiDXr0p1RGZBjb3sJhl8kgPdRjz8tbbn-_i2k,9545
1
+ omdev/.manifests.json,sha256=NP2sLr8MwlA0AKzDiFihSzLlqzYFENtN4MsjwQLPit4,9798
2
2
  omdev/__about__.py,sha256=Iect_SBD2EXgx7QcFGiOqTHkOWD-bWOyvzgReDOY4Es,1214
3
3
  omdev/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
4
4
  omdev/bracepy.py,sha256=I8EdqtDvxzAi3I8TuMEW-RBfwXfqKbwp06CfOdj3L1o,2743
@@ -6,7 +6,7 @@ omdev/classdot.py,sha256=YOvgy6x295I_8NKBbBlRVd3AN7Osirm_Lqt4Wj0j9rY,1631
6
6
  omdev/cmake.py,sha256=oBAp1K8h-iCDd9uCn-OpNpZ6n36oYFkWLIiTyQw4irU,4573
7
7
  omdev/findimports.py,sha256=2t8QP852saEEJFeXySEzhi_nxRSxghlkXz2jVdvy08M,2392
8
8
  omdev/imgur.py,sha256=Uyz8nkORlhfXXK5Sty16tX8ro8s-b7LrxjOECv4_sB0,3005
9
- omdev/pip.py,sha256=7cZ_IOpekQvgPm_gKnX3Pr8xjqUid50PPScTlZCYVlM,2118
9
+ omdev/pip.py,sha256=PqzAWDO_CbiZvXzJAZcCkFqWynUDls1jIgBWlrswQyA,2012
10
10
  omdev/tagstrings.py,sha256=zIP7nzcsZf5te0lphu6k36ND_cOvNFRg00neoTcoCs8,5484
11
11
  omdev/amalg/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
12
12
  omdev/amalg/__main__.py,sha256=1sZH8SLAueWxMxK9ngvndUW3L_rw7f-s_jK3ZP1yAH8,170
@@ -119,6 +119,7 @@ omdev/git/revisions.py,sha256=XJDs4LAnSuETSUpV6Nv_4iDFqdzMHSixWgrH8UiP09w,1171
119
119
  omdev/git/shallow.py,sha256=pu2Dro9P7oUa-cpFkcscbay1bM6jLFfV5mevICzbjcE,2530
120
120
  omdev/git/status.py,sha256=7KKiNSgEa93TsLp54xshwEuVO-3hRiUItBEBnen-8Gg,8111
121
121
  omdev/home/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
122
+ omdev/home/configs.py,sha256=Vg7fo6UuhMxhW_6pPg-jgVysJBpQJpLPTkJ8wHl2W_c,315
122
123
  omdev/home/paths.py,sha256=UJMIIxvDooOOJpCjfN4gn038BtPTGXWZ-prr3NeWbLY,402
123
124
  omdev/home/secrets.py,sha256=a460IvsgaJoaeXMnhcsvi11g15rrg8QhPQUcZTxFbs0,800
124
125
  omdev/interp/__init__.py,sha256=Y3l4WY4JRi2uLG6kgbGp93fuGfkxkKwZDvhsa0Rwgtk,15
@@ -154,7 +155,7 @@ omdev/magic/prepare.py,sha256=V5jYT2AeFmazzPwk9sNismSouLwFXEoik6FwKcWCNUY,589
154
155
  omdev/magic/styles.py,sha256=YQ-HgwfvFWPj-o_705E7A-yehEn1G1hRNLPWpeWCK0U,605
155
156
  omdev/manifests/__init__.py,sha256=Y3l4WY4JRi2uLG6kgbGp93fuGfkxkKwZDvhsa0Rwgtk,15
156
157
  omdev/manifests/__main__.py,sha256=JqyVDyV7_jo-NZ3wSs5clDU_xCMlxzJv-XFohoZWQ7E,174
157
- omdev/manifests/build.py,sha256=yX0QM6c60aauiF-8oDxrXhkrhhwHcRw_qft_IIW6LD8,8767
158
+ omdev/manifests/build.py,sha256=KDDB1pAWeR8NPLr43SScfrQvleI48SYuTKeYOrbNM9I,9232
158
159
  omdev/manifests/main.py,sha256=7zRlyE0BDPqITEbChlTBRGulAvG1nUZPHXrerNExriE,2126
159
160
  omdev/mypy/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
160
161
  omdev/mypy/debug.py,sha256=WcZw-3Z1njg_KFGqi3DB6RuqbBa3dLArJnjVCuY1Mn0,3003
@@ -232,11 +233,13 @@ omdev/tools/notebook.py,sha256=q1YMGwM1skHv-dPbtT_cM7UOGFNiMEAxjr6rr6rbobk,3494
232
233
  omdev/tools/pip.py,sha256=eBD41hp-V3thGfhUBM3Erxl4CSG-5LG6Szo1sA76P2k,3459
233
234
  omdev/tools/prof.py,sha256=hQakAsViJD4gLJpLLZnTkOqmTDAwM48Nx5q-O_aFlYM,1467
234
235
  omdev/tools/qr.py,sha256=tm68lPwEAkEwIL2sUKPKBYfwwPtjVWG1DBZwur8_jY8,1737
236
+ omdev/tools/shadow.py,sha256=lkjnlv82rJImMrQgRdxBbxNo-CeJZGXdwi6YUnyJjiQ,1601
235
237
  omdev/tools/sqlrepl.py,sha256=wAjrfXNrRV63-NJCC2HlGQnFh7lUH0bHMnOjYotQqFs,5753
236
238
  omdev/tools/git/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
237
239
  omdev/tools/git/__main__.py,sha256=gI87SBUgTkKUcUM-RtZWnei-UUDDqzbr5aPztb-gvbE,168
238
- omdev/tools/git/cli.py,sha256=9D9sKnm--2T_XEoMUWZXAzPBMtlKJk7qGCLt0Avl34Y,10088
239
- omdev/tools/git/messages.py,sha256=zFKw4gMBU2vpTqs0CkwUVyZIdCQ_j0ZPUJTZrp2llqc,2207
240
+ omdev/tools/git/cli.py,sha256=g1ViLqisliuQbacZg3Vr3MaMd4Acxlv79L8pqv8aMTI,11768
241
+ omdev/tools/git/consts.py,sha256=JuXivUNDkNhM4pe97icjRVAKM8cNRbrODquHINNKqOE,40
242
+ omdev/tools/git/messages.py,sha256=NWztIK0nAKJIOVzuVQcR_5LHZUgqyVkrOlpl7dFLMdU,2424
240
243
  omdev/tools/json/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
241
244
  omdev/tools/json/__main__.py,sha256=wqpkN_NsQyNwKW4qjVj8ADJ4_C98KhrFBtE-Z1UamfU,168
242
245
  omdev/tools/json/cli.py,sha256=EubIMT-n2XsjWBZjSy2fWXqijlwrIhLsfbkg3SZzi28,9586
@@ -248,9 +251,9 @@ omdev/tools/json/rendering.py,sha256=tMcjOW5edfozcMSTxxvF7WVTsbYLoe9bCKFh50qyaGw
248
251
  omdev/tools/pawk/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
249
252
  omdev/tools/pawk/__main__.py,sha256=VCqeRVnqT1RPEoIrqHFSu4PXVMg4YEgF4qCQm90-eRI,66
250
253
  omdev/tools/pawk/pawk.py,sha256=zsEkfQX0jF5bn712uqPAyBSdJt2dno1LH2oeSMNfXQI,11424
251
- omdev-0.0.0.dev236.dist-info/LICENSE,sha256=B_hVtavaA8zCYDW99DYdcpDLKz1n3BBRjZrcbv8uG8c,1451
252
- omdev-0.0.0.dev236.dist-info/METADATA,sha256=UuDRY3-O9mz5L5kSV5UCK8csUNCLJF9-jO-CZhFeWX0,1636
253
- omdev-0.0.0.dev236.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
254
- omdev-0.0.0.dev236.dist-info/entry_points.txt,sha256=dHLXFmq5D9B8qUyhRtFqTGWGxlbx3t5ejedjrnXNYLU,33
255
- omdev-0.0.0.dev236.dist-info/top_level.txt,sha256=1nr7j30fEWgLYHW3lGR9pkdHkb7knv1U1ES1XRNVQ6k,6
256
- omdev-0.0.0.dev236.dist-info/RECORD,,
254
+ omdev-0.0.0.dev238.dist-info/LICENSE,sha256=B_hVtavaA8zCYDW99DYdcpDLKz1n3BBRjZrcbv8uG8c,1451
255
+ omdev-0.0.0.dev238.dist-info/METADATA,sha256=T1Z_cz17NghFGv-YnOzJyS7g54np8JAFspfwEggIHKI,1636
256
+ omdev-0.0.0.dev238.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
257
+ omdev-0.0.0.dev238.dist-info/entry_points.txt,sha256=dHLXFmq5D9B8qUyhRtFqTGWGxlbx3t5ejedjrnXNYLU,33
258
+ omdev-0.0.0.dev238.dist-info/top_level.txt,sha256=1nr7j30fEWgLYHW3lGR9pkdHkb7knv1U1ES1XRNVQ6k,6
259
+ omdev-0.0.0.dev238.dist-info/RECORD,,