omdev 0.0.0.dev78__py3-none-any.whl → 0.0.0.dev79__py3-none-any.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 omdev might be problematic. Click here for more details.

omdev/.manifests.json CHANGED
@@ -30,7 +30,7 @@
30
30
  "line": 62,
31
31
  "value": {
32
32
  "$.cli.types.CliModule": {
33
- "cmd_name": "classdot",
33
+ "cmd_name": "py/classdot",
34
34
  "mod_name": "omdev.classdot"
35
35
  }
36
36
  }
@@ -102,7 +102,7 @@
102
102
  "line": 11,
103
103
  "value": {
104
104
  "$.cli.types.CliModule": {
105
- "cmd_name": "execrss",
105
+ "cmd_name": "py/execrss",
106
106
  "mod_name": "omdev.scripts.execrss"
107
107
  }
108
108
  }
@@ -114,7 +114,7 @@
114
114
  "line": 7,
115
115
  "value": {
116
116
  "$.cli.types.CliModule": {
117
- "cmd_name": "exectime",
117
+ "cmd_name": "py/exectime",
118
118
  "mod_name": "omdev.scripts.exectime"
119
119
  }
120
120
  }
@@ -126,7 +126,7 @@
126
126
  "line": 481,
127
127
  "value": {
128
128
  "$.cli.types.CliModule": {
129
- "cmd_name": "importtrace",
129
+ "cmd_name": "py/importtrace",
130
130
  "mod_name": "omdev.scripts.importtrace"
131
131
  }
132
132
  }
@@ -162,7 +162,7 @@
162
162
  "line": 166,
163
163
  "value": {
164
164
  "$.cli.types.CliModule": {
165
- "cmd_name": "importscan",
165
+ "cmd_name": "py/importscan",
166
166
  "mod_name": "omdev.tools.importscan"
167
167
  }
168
168
  }
@@ -174,7 +174,7 @@
174
174
  "line": 148,
175
175
  "value": {
176
176
  "$.cli.types.CliModule": {
177
- "cmd_name": "mkrelimp",
177
+ "cmd_name": "py/mkrelimp",
178
178
  "mod_name": "omdev.tools.mkrelimp"
179
179
  }
180
180
  }
omdev/classdot.py CHANGED
@@ -60,7 +60,7 @@ def _main() -> None:
60
60
 
61
61
 
62
62
  # @omlish-manifest
63
- _CLI_MODULE = CliModule('classdot', __name__)
63
+ _CLI_MODULE = CliModule('py/classdot', __name__)
64
64
 
65
65
 
66
66
  if __name__ == '__main__':
omdev/cli/main.py CHANGED
@@ -1,16 +1,19 @@
1
1
  """
2
2
  TODO:
3
+ - py/foo - root command 'py'
3
4
  - cache ldr.discover() somehow if in uvx/pipx - very slow
4
5
  - <venv-root>/.omdev-cli-manifest-cache.json - {pkg_name: manifests_json}
5
6
  - allow manually specifying manifest packages
6
7
  """
7
8
  import argparse
9
+ import dataclasses as dc
8
10
  import os
9
11
  import runpy
10
12
  import sys
11
13
  import typing as ta
12
14
 
13
15
  from omlish import check
16
+ from omlish.lite.cached import cached_nullary
14
17
 
15
18
  from ..manifests.load import ManifestLoader
16
19
  from .types import CliCmd
@@ -38,6 +41,139 @@ _CLI_FUNCS: ta.Sequence[CliFunc] = [
38
41
  ##
39
42
 
40
43
 
44
+ StrTuple: ta.TypeAlias = tuple[str, ...]
45
+ RecStrMap: ta.TypeAlias = ta.Mapping[str, ta.Union[str, 'RecStrMap']]
46
+ RecCmdMap: ta.TypeAlias = ta.Mapping[str, ta.Union[CliCmd, 'RecCmdMap']]
47
+
48
+
49
+ class CliCmdSet:
50
+ def __init__(self, cmds: ta.Iterable[CliCmd]) -> None:
51
+ super().__init__()
52
+
53
+ self._cmds = list(cmds)
54
+
55
+ @dc.dataclass(frozen=True)
56
+ class Entry:
57
+ cmd: CliCmd
58
+
59
+ exec_paths: ta.Sequence[StrTuple] # len > 1, len([0]) > 1
60
+ help_path: StrTuple | None
61
+
62
+ def _make_entry(self, cmd: CliCmd) -> Entry:
63
+ help_path: StrTuple | None
64
+
65
+ if isinstance(cmd.cmd_name, str):
66
+ ns = [cmd.cmd_name]
67
+ else:
68
+ ns = list(cmd.cmd_name)
69
+ exec_paths = [tuple(n.split('/')) for n in ns]
70
+
71
+ if isinstance(cmd.cmd_name, str) and cmd.cmd_name[0] == '_':
72
+ help_path = None
73
+
74
+ elif isinstance(cmd, CliFunc):
75
+ help_path = ('-', *exec_paths[0])
76
+
77
+ elif isinstance(cmd, CliModule):
78
+ help_path = (cmd.mod_name.partition('.')[0], *exec_paths[0])
79
+
80
+ else:
81
+ raise TypeError(cmd)
82
+
83
+ return CliCmdSet.Entry(
84
+ cmd,
85
+
86
+ exec_paths=exec_paths,
87
+ help_path=help_path,
88
+ )
89
+
90
+ @cached_nullary
91
+ def entries(self) -> ta.Sequence[Entry]:
92
+ return [self._make_entry(c) for c in self._cmds]
93
+
94
+ @cached_nullary
95
+ def exec_tree(self) -> RecCmdMap:
96
+ d: dict = {}
97
+ for e in self.entries():
98
+ for ep in e.exec_paths:
99
+ c = d
100
+ for p in ep[:-1]:
101
+ n = c.setdefault(p, {})
102
+ if not isinstance(n, dict):
103
+ raise NameError(e) # noqa
104
+ c = n
105
+
106
+ h = ep[-1]
107
+ if h in c:
108
+ raise NameError(e) # noqa
109
+
110
+ c[h] = e.cmd
111
+
112
+ return d
113
+
114
+ @cached_nullary
115
+ def help_tree(self) -> RecStrMap:
116
+ d: dict = {}
117
+ for e in self.entries():
118
+ if not e.help_path:
119
+ continue
120
+
121
+ c = d
122
+ for p in e.help_path[:-1]:
123
+ n = c.setdefault(p, {})
124
+ if not isinstance(n, dict):
125
+ raise NameError(e) # noqa
126
+ c = n
127
+
128
+ h = e.help_path[-1]
129
+ if h in c:
130
+ raise NameError(e)
131
+
132
+ if isinstance(e.cmd.cmd_name, str):
133
+ l = [e.cmd.cmd_name]
134
+ else:
135
+ l = list(e.cmd.cmd_name)
136
+
137
+ s = (
138
+ f'{l[0].split("/")[-1]}'
139
+ f'{(" (" + ", ".join(l[1:]) + ")") if len(l) > 1 else ""}'
140
+ )
141
+
142
+ c[h] = s
143
+
144
+ return d
145
+
146
+ class SelectedCmd(ta.NamedTuple):
147
+ cmd: CliCmd
148
+ args: ta.Sequence[str]
149
+
150
+ class InvalidCmd(ta.NamedTuple):
151
+ path: ta.Sequence[str]
152
+
153
+ def select_cmd(self, args: ta.Sequence[str]) -> SelectedCmd | InvalidCmd:
154
+ check.not_isinstance(args, str)
155
+
156
+ d = self.exec_tree()
157
+ for i in range(len(args)):
158
+ n = args[i]
159
+ if n not in d:
160
+ return CliCmdSet.InvalidCmd(args[:i + 1])
161
+
162
+ c = d[n]
163
+
164
+ if isinstance(c, CliCmd):
165
+ return CliCmdSet.SelectedCmd(c, args[i + 1:])
166
+ elif isinstance(c, ta.Mapping):
167
+ d = c
168
+ else:
169
+ raise TypeError(c)
170
+
171
+ return CliCmdSet.InvalidCmd([])
172
+
173
+
174
+ ##
175
+
176
+
41
177
  def _build_arg_parser() -> argparse.ArgumentParser:
42
178
  parser = argparse.ArgumentParser()
43
179
  parser.add_argument('--cli-pkg-root', action='append')
@@ -47,9 +183,7 @@ def _build_arg_parser() -> argparse.ArgumentParser:
47
183
  return parser
48
184
 
49
185
 
50
- def _build_cmd_dct(args: ta.Any) -> ta.Mapping[str, CliCmd]:
51
- ccs: list[CliCmd] = []
52
-
186
+ def _build_cmd_set(args: ta.Any) -> CliCmdSet:
53
187
  ldr = ManifestLoader.from_entry_point(globals())
54
188
 
55
189
  pkgs: list[str] = []
@@ -70,62 +204,49 @@ def _build_cmd_dct(args: ta.Any) -> ta.Mapping[str, CliCmd]:
70
204
  if not pkgs:
71
205
  scan_pkg_root(os.getcwd())
72
206
 
73
- for m in ldr.load(*pkgs, only=[CliModule]):
74
- ccs.append(check.isinstance(m.value, CliModule))
207
+ #
75
208
 
76
- ccs.extend(_CLI_FUNCS)
209
+ lst: list[CliCmd] = []
77
210
 
78
- dct: dict[str, CliCmd] = {}
79
- for cc in ccs:
80
- for cn in [cc.cmd_name] if isinstance(cc.cmd_name, str) else cc.cmd_name:
81
- if cn in dct:
82
- raise NameError(cc)
83
- dct[cn] = cc
211
+ for m in ldr.load(*pkgs, only=[CliModule]):
212
+ lst.append(check.isinstance(m.value, CliModule))
84
213
 
85
- return dct
214
+ lst.extend(_CLI_FUNCS)
86
215
 
216
+ #
87
217
 
88
- def _select_cmd(args: ta.Any, cmds: ta.Mapping[str, CliCmd]) -> CliCmd | int:
89
- cmd = args.cmd
90
- if cmd and cmd in cmds:
91
- return cmds[cmd]
218
+ return CliCmdSet(lst)
92
219
 
220
+
221
+ def _select_cmd(args: ta.Any, cmds: CliCmdSet) -> CliCmdSet.SelectedCmd | int:
93
222
  def print_err(*args, **kwargs): # noqa
94
223
  print(*args, **kwargs, file=sys.stderr)
95
224
 
96
- if cmd:
97
- print_err(f'Invalid command: {cmd}\n')
225
+ if args.cmd:
226
+ sel_cmd = cmds.select_cmd([args.cmd, *args.args])
227
+ if isinstance(sel_cmd, CliCmdSet.SelectedCmd):
228
+ return sel_cmd
229
+ elif isinstance(sel_cmd, CliCmdSet.InvalidCmd):
230
+ print_err(f'Invalid command: {" ".join(sel_cmd.path)}\n')
231
+ else:
232
+ raise TypeError(sel_cmd)
98
233
  rc = 1
99
234
  else:
100
235
  rc = 0
101
236
 
102
- mset = set()
103
- mdct: dict = {}
104
- for cc in cmds.values():
105
- if id(cc) in mset:
106
- continue
107
- mset.add(id(cc))
108
- if isinstance(cc.cmd_name, str) and cc.cmd_name[0] == '_':
109
- continue
110
- if isinstance(cc, CliFunc):
111
- mdct.setdefault('-', []).append(cc)
112
- elif isinstance(cc, CliModule):
113
- mdct.setdefault(cc.mod_name.partition('.')[0], []).append(cc)
114
- else:
115
- raise TypeError(cc)
116
-
117
237
  print_err('Subcommands:\n')
118
- for m, l in sorted(mdct.items(), key=lambda t: (t[0] == '-', t[0])):
119
- print_err(f' {m}')
120
- for cc in sorted(l, key=lambda c: c.primary_name):
121
- if isinstance(cc.cmd_name, str):
122
- print_err(f' {cc.cmd_name}')
238
+
239
+ def rec(d, pfx=''):
240
+ for k, v in sorted(d.items(), key=lambda t: t[0]):
241
+ if isinstance(v, str):
242
+ print_err(pfx + v)
123
243
  else:
124
- print_err(
125
- f' {cc.cmd_name[0]}'
126
- f'{(" (" + ", ".join(cc.cmd_name[1:]) + ")") if len(cc.cmd_name) > 1 else ""}',
127
- )
128
- print_err()
244
+ print_err(pfx + k)
245
+ rec(v, pfx + ' ')
246
+ if not pfx:
247
+ print_err('')
248
+
249
+ rec(cmds.help_tree())
129
250
 
130
251
  return rc
131
252
 
@@ -135,23 +256,23 @@ def _main() -> ta.Any:
135
256
  args = parser.parse_args()
136
257
 
137
258
  def inner():
138
- cmds = _build_cmd_dct(args)
259
+ cmds = _build_cmd_set(args)
139
260
  sel = _select_cmd(args, cmds)
140
261
 
141
- match sel:
142
- case int():
143
- return sel
262
+ if isinstance(sel, int):
263
+ return sel
144
264
 
145
- case CliModule() as cm:
146
- sys.argv = [args.cmd, *(args.args or ())]
147
- runpy._run_module_as_main(cm.mod_name) # type: ignore # noqa
148
- return 0
265
+ cmd = sel.cmd
266
+ if isinstance(cmd, CliModule):
267
+ sys.argv = [args.cmd, *(sel.args or ())]
268
+ runpy._run_module_as_main(cmd.mod_name) # type: ignore # noqa
269
+ return 0
149
270
 
150
- case CliFunc() as cf:
151
- return cf.fn(*(args.args or ()))
271
+ elif isinstance(cmd, CliFunc):
272
+ return cmd.fn(*(sel.args or ()))
152
273
 
153
- case _:
154
- raise TypeError(sel)
274
+ else:
275
+ raise TypeError(cmd)
155
276
 
156
277
  if args.cli_debug:
157
278
  from omlish.diag.debug import debugging_on_exception
omdev/scripts/execrss.py CHANGED
@@ -10,7 +10,7 @@ def _get_rss() -> int:
10
10
 
11
11
  # @omlish-manifest
12
12
  _CLI_MODULE = {'$omdev.cli.types.CliModule': {
13
- 'cmd_name': 'execrss',
13
+ 'cmd_name': 'py/execrss',
14
14
  'mod_name': __name__,
15
15
  }}
16
16
 
omdev/scripts/exectime.py CHANGED
@@ -6,7 +6,7 @@ import time
6
6
 
7
7
  # @omlish-manifest
8
8
  _CLI_MODULE = {'$omdev.cli.types.CliModule': {
9
- 'cmd_name': 'exectime',
9
+ 'cmd_name': 'py/exectime',
10
10
  'mod_name': __name__,
11
11
  }}
12
12
 
@@ -480,7 +480,7 @@ class SqliteWriter:
480
480
 
481
481
  # @omlish-manifest
482
482
  _CLI_MODULE = {'$omdev.cli.types.CliModule': {
483
- 'cmd_name': 'importtrace',
483
+ 'cmd_name': 'py/importtrace',
484
484
  'mod_name': __name__,
485
485
  }}
486
486
 
omdev/tools/importscan.py CHANGED
@@ -164,7 +164,7 @@ def run(
164
164
 
165
165
 
166
166
  # @omlish-manifest
167
- _CLI_MODULE = CliModule('importscan', __name__)
167
+ _CLI_MODULE = CliModule('py/importscan', __name__)
168
168
 
169
169
 
170
170
  def _main() -> None:
omdev/tools/mkrelimp.py CHANGED
@@ -146,7 +146,7 @@ class Processor:
146
146
 
147
147
 
148
148
  # @omlish-manifest
149
- _CLI_MODULE = CliModule('mkrelimp', __name__)
149
+ _CLI_MODULE = CliModule('py/mkrelimp', __name__)
150
150
 
151
151
 
152
152
  def _main() -> None:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: omdev
3
- Version: 0.0.0.dev78
3
+ Version: 0.0.0.dev79
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.dev78
15
+ Requires-Dist: omlish ==0.0.0.dev79
16
16
  Provides-Extra: all
17
17
  Requires-Dist: black ~=24.10 ; extra == 'all'
18
18
  Requires-Dist: pycparser ~=2.22 ; extra == 'all'
@@ -1,8 +1,8 @@
1
- omdev/.manifests.json,sha256=qqGdjl5ipGAzn3N24XuhpvfczMlYD__3pV1gFHXw4AY,5228
1
+ omdev/.manifests.json,sha256=CGQCoFACCwUKKkXg9CROAN6kW-x0HuQkYKoBVmRXTDU,5246
2
2
  omdev/__about__.py,sha256=do_MjpnIpB_DX4GL4VV9gFQzs6bkoyDIYu29yB3rYxw,1131
3
3
  omdev/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
4
4
  omdev/bracepy.py,sha256=HwBK5XmlOsF_juTel25fRLJK9vHSJCWXuCc-OZlevRQ,2619
5
- omdev/classdot.py,sha256=K0YMTngaC6uuEKhDb95tFzW33Re_YEdgIWBBeze4PTI,1628
5
+ omdev/classdot.py,sha256=YOvgy6x295I_8NKBbBlRVd3AN7Osirm_Lqt4Wj0j9rY,1631
6
6
  omdev/cmake.py,sha256=Diy2ry65806dQP125DAstD3w46z_wszMH7PwC2-6iik,4578
7
7
  omdev/findimports.py,sha256=P8v4I1tm6g-PEWJiNwAKxErvWwL-Nop83vAuwq1kR5A,2246
8
8
  omdev/findmagic.py,sha256=DhBYHHP_dzwM5pIh21xnQPnkZ2YmAXCjithsr7X0ScU,2357
@@ -63,7 +63,7 @@ omdev/cli/__main__.py,sha256=mOJpgc07o0r5luQ1DlX4tk2PqZkgmbwPbdzJ3KmtjgQ,138
63
63
  omdev/cli/_pathhack.py,sha256=MCkajFbzP55Nak4DAy2s-4WH_ol15ejyTatvhLfne90,1478
64
64
  omdev/cli/clicli.py,sha256=ShTlK2vjFPqnyF9SPTwXd4nRyb6XjCVPQIT4PTGdTL4,2879
65
65
  omdev/cli/install.py,sha256=C-W171YlIHt4Cfok-nWSMbHwWhqF_PFqq2HixFttYx8,4460
66
- omdev/cli/main.py,sha256=fQL-KdKZDmw00d8vtgxGmUc9Pp3dnhW1BW-Pzu6JPX0,4172
66
+ omdev/cli/main.py,sha256=nD3bW3MkI0KuDSLpX_PTnl-lBnm4hIxVqczvvMHtupo,7058
67
67
  omdev/cli/managers.py,sha256=BV98_n30Jj63OJrFgRoVZRfICxMLXEZKoEn4rMj9LV4,1160
68
68
  omdev/cli/types.py,sha256=bqKw9SbtBtAip2vF9v4khh0CqKG6LBr6n9VzWBz7AJE,474
69
69
  omdev/interp/__init__.py,sha256=Y3l4WY4JRi2uLG6kgbGp93fuGfkxkKwZDvhsa0Rwgtk,15
@@ -103,9 +103,9 @@ omdev/pyproject/pkg.py,sha256=rNKzJOIgPDrtT2i14Pebldoboz45w00sKb5l_kYFaRI,14562
103
103
  omdev/pyproject/reqs.py,sha256=8feZ71YnGzwKbLK4zO28CDQeNcZIIuq6cnkBhs6M-7E,2406
104
104
  omdev/scripts/__init__.py,sha256=MKCvUAEQwsIvwLixwtPlpBqmkMXLCnjjXyAXvVpDwVk,91
105
105
  omdev/scripts/bumpversion.py,sha256=Kn7fo73Hs8uJh3Hi3EIyLOlzLPWAC6dwuD_lZ3cIzuY,1064
106
- omdev/scripts/execrss.py,sha256=d6purJqU99OkMcNxCS1kG2CMfSsw7wjnvBQW7SjyJ70,448
107
- omdev/scripts/exectime.py,sha256=LRVIJsnvGYUqH-zfCdFnrQCZv1KLXJPtWBWplXMDwhI,407
108
- omdev/scripts/importtrace.py,sha256=4ozdphT4VuP8L0kE0HmGMyWaWHnXg1KEukbET4pFgJU,14064
106
+ omdev/scripts/execrss.py,sha256=hJTWBig_-XqKIj1DphYTfeVDtdQTM1XUl-Hvzs2x9iY,451
107
+ omdev/scripts/exectime.py,sha256=dBdn3KV2jR6tCrzGvb9dTl2uGe2vNpLxmHMtExmnaiM,410
108
+ omdev/scripts/importtrace.py,sha256=Jbo3Yk2RAbE8_tJ97iTcVNpoxCJxrRb2tl1W_CV3NG0,14067
109
109
  omdev/scripts/interp.py,sha256=2poCQ_45tO0-X16KeoxiAyuTfltSjnPETejlYEm9VY4,71527
110
110
  omdev/scripts/pyproject.py,sha256=nWbnMyGwrfzcTcnvUFGP9wxIu3rlUyxQYhkq64UXIrA,158084
111
111
  omdev/toml/__init__.py,sha256=Y3l4WY4JRi2uLG6kgbGp93fuGfkxkKwZDvhsa0Rwgtk,15
@@ -114,16 +114,16 @@ omdev/toml/writer.py,sha256=lk3on3YXVbWuLJa-xsOzOhs1bBAT1vXqw4mBbluZl_w,3040
114
114
  omdev/tools/__init__.py,sha256=iVJAOQ0viGTQOm0DLX4uZLro-9jOioYJGLg9s0kDx1A,78
115
115
  omdev/tools/dockertools.py,sha256=k2BrVvFYwyGov064CPHd_HWo9aqR1zHc2UeEsVwPth4,6827
116
116
  omdev/tools/gittools.py,sha256=1Oa2AgdZIJZ2eusso9yFzkd9zLWH3d4lTiVFzwg0uDM,3808
117
- omdev/tools/importscan.py,sha256=vxOMdAABShqt5-G3n6DGHopCZ5uGgciThY0MCa5W0mA,4066
118
- omdev/tools/mkrelimp.py,sha256=fwt4GWzenuLNVtzdK2uaJJTSuJbUVJZquF5adwAwlPg,4051
117
+ omdev/tools/importscan.py,sha256=QeGjR3UGcuuuDUiisFuAXWHlcKJScGxGEcU6tfOh2CM,4069
118
+ omdev/tools/mkrelimp.py,sha256=wsJAjTIf3nqcSfnT9TkDpS1VUOoM9W2Az5tZdWuzyLM,4054
119
119
  omdev/tools/nbtools.py,sha256=M8Xi_gfZdlahnyFLtp0RBgYZPSHWQStMMDYZc71Zync,3494
120
120
  omdev/tools/piptools.py,sha256=-jR5q3w4sHqntxCLExFCBNIARB788FUsAbJ62PK2sBU,2774
121
121
  omdev/tools/proftools.py,sha256=8ZU9x_Dq8eT2ZFwU9sJpDIvxcIn9qBc8y2ELKPb5e5M,1382
122
122
  omdev/tools/rsttool.py,sha256=suwsfseUf8GH8rYmYygTUdif-Jk_bX1g9fYRLXaKkmM,1340
123
123
  omdev/tools/sqlrepl.py,sha256=tmFZh80-xsGM62dyQ7_UGLebChrj7IHbIPYBWDJMgVk,5741
124
- omdev-0.0.0.dev78.dist-info/LICENSE,sha256=B_hVtavaA8zCYDW99DYdcpDLKz1n3BBRjZrcbv8uG8c,1451
125
- omdev-0.0.0.dev78.dist-info/METADATA,sha256=98R5viqCGLx0896u-4zH3LyIN55taK5qAQNgv2XGoQg,1492
126
- omdev-0.0.0.dev78.dist-info/WHEEL,sha256=OVMc5UfuAQiSplgO0_WdW7vXVGAt9Hdd6qtN4HotdyA,91
127
- omdev-0.0.0.dev78.dist-info/entry_points.txt,sha256=dHLXFmq5D9B8qUyhRtFqTGWGxlbx3t5ejedjrnXNYLU,33
128
- omdev-0.0.0.dev78.dist-info/top_level.txt,sha256=1nr7j30fEWgLYHW3lGR9pkdHkb7knv1U1ES1XRNVQ6k,6
129
- omdev-0.0.0.dev78.dist-info/RECORD,,
124
+ omdev-0.0.0.dev79.dist-info/LICENSE,sha256=B_hVtavaA8zCYDW99DYdcpDLKz1n3BBRjZrcbv8uG8c,1451
125
+ omdev-0.0.0.dev79.dist-info/METADATA,sha256=sKZ845yEhL8q0_6_dW11F69Rupd9w9mzQ42afWVAvJA,1492
126
+ omdev-0.0.0.dev79.dist-info/WHEEL,sha256=OVMc5UfuAQiSplgO0_WdW7vXVGAt9Hdd6qtN4HotdyA,91
127
+ omdev-0.0.0.dev79.dist-info/entry_points.txt,sha256=dHLXFmq5D9B8qUyhRtFqTGWGxlbx3t5ejedjrnXNYLU,33
128
+ omdev-0.0.0.dev79.dist-info/top_level.txt,sha256=1nr7j30fEWgLYHW3lGR9pkdHkb7knv1U1ES1XRNVQ6k,6
129
+ omdev-0.0.0.dev79.dist-info/RECORD,,