omdev 0.0.0.dev234__py3-none-any.whl → 0.0.0.dev236__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": 54,
294
+ "line": 75,
295
295
  "value": {
296
296
  "$.tools.git.messages.GitMessageGeneratorManifest": {
297
297
  "mod_name": "omdev.tools.git.messages",
omdev/cmake.py CHANGED
@@ -45,7 +45,6 @@ class Target(abc.ABC):
45
45
 
46
46
  @dc.dataclass(frozen=True)
47
47
  class Library(Target):
48
-
49
48
  @property
50
49
  def command_name(self) -> str:
51
50
  return 'add_library'
@@ -53,7 +52,6 @@ class Library(Target):
53
52
 
54
53
  @dc.dataclass(frozen=True)
55
54
  class StaticLibrary(Library):
56
-
57
55
  @property
58
56
  def command_extra(self) -> ta.Sequence[str]:
59
57
  return ['STATIC']
@@ -61,7 +59,6 @@ class StaticLibrary(Library):
61
59
 
62
60
  @dc.dataclass(frozen=True)
63
61
  class ModuleLibrary(Library):
64
-
65
62
  @property
66
63
  def command_extra(self) -> ta.Sequence[str]:
67
64
  return ['MODULE']
@@ -69,14 +66,12 @@ class ModuleLibrary(Library):
69
66
 
70
67
  @dc.dataclass(frozen=True)
71
68
  class Executable(Target):
72
-
73
69
  @property
74
70
  def command_name(self) -> str:
75
71
  return 'add_executable'
76
72
 
77
73
 
78
74
  class CmakeGen:
79
-
80
75
  def __init__(
81
76
  self,
82
77
  out: ta.TextIO,
omdev/scripts/ci.py CHANGED
@@ -1732,6 +1732,9 @@ def is_in_github_actions() -> bool:
1732
1732
  ########################################
1733
1733
  # ../../../omlish/argparse/cli.py
1734
1734
  """
1735
+ FIXME:
1736
+ - exit_on_error lol
1737
+
1735
1738
  TODO:
1736
1739
  - default command
1737
1740
  - auto match all underscores to hyphens
@@ -1759,6 +1762,10 @@ def argparse_arg(*args, **kwargs) -> ArgparseArg:
1759
1762
  return ArgparseArg(args, kwargs)
1760
1763
 
1761
1764
 
1765
+ def argparse_arg_(*args, **kwargs) -> ta.Any:
1766
+ return argparse_arg(*args, **kwargs)
1767
+
1768
+
1762
1769
  #
1763
1770
 
1764
1771
 
omdev/scripts/interp.py CHANGED
@@ -2127,6 +2127,9 @@ class SpecifierSet(BaseSpecifier):
2127
2127
  ########################################
2128
2128
  # ../../../omlish/argparse/cli.py
2129
2129
  """
2130
+ FIXME:
2131
+ - exit_on_error lol
2132
+
2130
2133
  TODO:
2131
2134
  - default command
2132
2135
  - auto match all underscores to hyphens
@@ -2154,6 +2157,10 @@ def argparse_arg(*args, **kwargs) -> ArgparseArg:
2154
2157
  return ArgparseArg(args, kwargs)
2155
2158
 
2156
2159
 
2160
+ def argparse_arg_(*args, **kwargs) -> ta.Any:
2161
+ return argparse_arg(*args, **kwargs)
2162
+
2163
+
2157
2164
  #
2158
2165
 
2159
2166
 
@@ -3785,6 +3785,9 @@ class RequirementsRewriter:
3785
3785
  ########################################
3786
3786
  # ../../../omlish/argparse/cli.py
3787
3787
  """
3788
+ FIXME:
3789
+ - exit_on_error lol
3790
+
3788
3791
  TODO:
3789
3792
  - default command
3790
3793
  - auto match all underscores to hyphens
@@ -3812,6 +3815,10 @@ def argparse_arg(*args, **kwargs) -> ArgparseArg:
3812
3815
  return ArgparseArg(args, kwargs)
3813
3816
 
3814
3817
 
3818
+ def argparse_arg_(*args, **kwargs) -> ta.Any:
3819
+ return argparse_arg(*args, **kwargs)
3820
+
3821
+
3815
3822
  #
3816
3823
 
3817
3824
 
omdev/tools/git/cli.py CHANGED
@@ -1,42 +1,56 @@
1
+ # ruff: noqa: UP006 UP007
1
2
  """
2
3
  TODO:
3
4
  - https://github.com/vegardit/bash-funk/blob/main/docs/git.md
4
5
  """
6
+ import dataclasses as dc
5
7
  import os
6
8
  import re
7
- import subprocess
8
9
  import typing as ta
9
10
  import urllib.parse
10
11
 
12
+ from omlish import cached
11
13
  from omlish import check
14
+ from omlish import lang
12
15
  from omlish.argparse import all as ap
13
16
  from omlish.formats import json
17
+ from omlish.formats import yaml
14
18
  from omlish.logs import all as logs
19
+ from omlish.subprocesses.sync import subprocesses
15
20
 
16
21
  from ...git.status import GitStatusItem
17
22
  from ...git.status import get_git_status
23
+ from ...home.paths import get_home_dir
24
+ from .messages import GitMessageGenerator
18
25
  from .messages import TimestampGitMessageGenerator
19
26
  from .messages import load_message_generator_manifests
27
+ from .messages import load_message_generator_manifests_map
28
+
29
+
30
+ if ta.TYPE_CHECKING:
31
+ from omlish import marshal as msh
32
+ else:
33
+ msh = lang.proxy_import('omlish.marshal')
20
34
 
21
35
 
22
36
  ##
23
37
 
24
38
 
25
39
  def rev_parse(rev: str) -> str:
26
- return subprocess.check_output(['git', 'rev-parse', rev]).decode().strip()
40
+ return subprocesses.check_output('git', 'rev-parse', rev).decode().strip()
27
41
 
28
42
 
29
43
  def get_first_commit_of_day(rev: str) -> str | None:
30
- commit_date = subprocess.check_output([
44
+ commit_date = subprocesses.check_output(
31
45
  'git', 'show', '-s', '--format=%ci', rev,
32
- ]).decode().strip().split(' ')[0]
46
+ ).decode().strip().split(' ')[0]
33
47
 
34
- first_commit = subprocess.check_output([
48
+ first_commit = subprocesses.check_output(
35
49
  'git', 'rev-list', '--reverse', '--max-parents=1',
36
50
  '--since', f'{commit_date} 00:00:00',
37
51
  '--until', f'{commit_date} 23:59:59',
38
52
  rev,
39
- ]).decode().strip().splitlines()
53
+ ).decode().strip().splitlines()
40
54
 
41
55
  # Return the first commit (if there is any)
42
56
  if first_commit:
@@ -46,10 +60,41 @@ def get_first_commit_of_day(rev: str) -> str | None:
46
60
 
47
61
 
48
62
  class Cli(ap.Cli):
63
+ @dc.dataclass(frozen=True, kw_only=True)
64
+ class Config:
65
+ default_message_generator: str | None = None
66
+
67
+ _config_file_path_arg: ta.Optional[str] = ap.arg_('-c', '--config-file-path', nargs='?')
68
+
69
+ @cached.function
70
+ def config_file_path(self) -> str:
71
+ if (arg := self._config_file_path_arg) is not None:
72
+ return os.path.expanduser(arg)
73
+ else:
74
+ return os.path.join(get_home_dir(), 'tools', 'git.yml')
75
+
76
+ @cached.function
77
+ def load_config(self) -> Config:
78
+ try:
79
+ with open(self.config_file_path()) as f:
80
+ buf = f.read()
81
+ except FileNotFoundError:
82
+ return self.Config()
83
+
84
+ dct = yaml.safe_load(buf)
85
+ return msh.unmarshal(dct, self.Config)
86
+
87
+ @ap.cmd()
88
+ def print_cfg(self) -> None:
89
+ cfg = self.load_config()
90
+ print(yaml.dump(msh.marshal(cfg)))
91
+
92
+ #
93
+
49
94
  @ap.cmd()
50
95
  def blob_sizes(self) -> None:
51
96
  # https://stackoverflow.com/a/42544963
52
- subprocess.check_call( # noqa
97
+ subprocesses.check_call( # noqa
53
98
  "git rev-list --objects --all | "
54
99
  "git cat-file --batch-check='%(objecttype) %(objectname) %(objectsize) %(rest)' | "
55
100
  "sed -n 's/^blob //p' | "
@@ -61,7 +106,7 @@ class Cli(ap.Cli):
61
106
 
62
107
  @ap.cmd()
63
108
  def commits_by_date(self) -> None:
64
- subprocess.check_call(['git log --date=short --pretty=format:%ad | sort | uniq -c'], shell=True) # noqa
109
+ subprocesses.check_call('git log --date=short --pretty=format:%ad | sort | uniq -c', shell=True) # noqa
65
110
 
66
111
  #
67
112
 
@@ -84,14 +129,14 @@ class Cli(ap.Cli):
84
129
 
85
130
  os.makedirs(user, 0o755, exist_ok=True)
86
131
 
87
- subprocess.check_call([
132
+ subprocesses.check_call(
88
133
  'git',
89
134
  'clone',
90
135
  *self.unknown_args,
91
136
  *self.args.args,
92
137
  f'git@github.com:{user}/{repo}.git',
93
138
  os.path.join(user, repo),
94
- ])
139
+ )
95
140
 
96
141
  out_dir = os.path.join(user, repo)
97
142
 
@@ -99,13 +144,13 @@ class Cli(ap.Cli):
99
144
  parsed = urllib.parse.urlparse(self.args.repo)
100
145
  out_dir = parsed.path.split('/')[-1]
101
146
 
102
- subprocess.check_call([
147
+ subprocesses.check_call(
103
148
  'git',
104
149
  'clone',
105
150
  *self.unknown_args,
106
151
  *self.args.args,
107
152
  self.args.repo,
108
- ])
153
+ )
109
154
 
110
155
  finally:
111
156
  print(out_dir)
@@ -126,7 +171,7 @@ class Cli(ap.Cli):
126
171
  os.execvp('git', ['git', 'diff', *(['--stat'] if self.args.stat else []), base_rev, rev])
127
172
 
128
173
  elif self.args.github or self.args.open:
129
- rm_url = subprocess.check_output(['git', 'remote', 'get-url', 'origin']).decode('utf-8').strip()
174
+ rm_url = subprocesses.check_output('git', 'remote', 'get-url', 'origin').decode('utf-8').strip()
130
175
 
131
176
  if rm_url.startswith(git_pfx := 'git@github.com:'):
132
177
  s = rm_url[len(git_pfx):]
@@ -142,7 +187,7 @@ class Cli(ap.Cli):
142
187
  gh_url = f'https://github.com/{user}/{repo}/compare/{base_rev}...{rev}#files_bucket'
143
188
 
144
189
  if self.args.open:
145
- subprocess.check_call(['open', gh_url])
190
+ subprocesses.check_call('open', gh_url)
146
191
  else:
147
192
  print(gh_url)
148
193
 
@@ -189,25 +234,50 @@ class Cli(ap.Cli):
189
234
 
190
235
  @ap.cmd(
191
236
  ap.arg('-m', '--message', nargs='?'),
192
- ap.arg('--time-fmt', default=TimestampGitMessageGenerator.DEFAULT_TIME_FMT),
237
+ ap.arg('-g', '--message-generator', nargs='?'),
238
+ ap.arg('--time-fmt', default=GitMessageGenerator.GenerateCommitMessageArgs.DEFAULT_TIME_FMT),
239
+ ap.arg('--dry-run', action='store_true'),
240
+ ap.arg('-y', '--no-confirmation', action='store_true'),
193
241
  ap.arg('dir', nargs='*'),
194
242
  aliases=['acp'],
195
243
  )
196
244
  def add_commit_push(self) -> None:
197
245
  def run(cwd: str | None) -> None:
246
+ def check_call(*cmd: str) -> None:
247
+ if self.args.dry_run:
248
+ print(cmd)
249
+ else:
250
+ subprocesses.check_call(*cmd, cwd=cwd)
251
+
198
252
  st = get_git_status(cwd=cwd)
199
253
 
200
254
  if st.has_dirty:
201
- subprocess.check_call(['git', 'add', '.'], cwd=cwd)
255
+ check_call('git', 'add', '.')
202
256
 
203
257
  if st.has_staged or st.has_dirty:
204
258
  if self.args.message is not None:
205
259
  msg = self.args.message
206
- else:
207
- msg = TimestampGitMessageGenerator(self.args.time_fmt).generate_commit_message()
208
- subprocess.check_call(['git', 'commit', '-m', msg], cwd=cwd)
209
260
 
210
- subprocess.check_call(['git', 'push'], cwd=cwd)
261
+ else:
262
+ mg_cls: type[GitMessageGenerator] = TimestampGitMessageGenerator
263
+ if (mg_name := self.args.message_generator) is None:
264
+ mg_name = self.load_config().default_message_generator
265
+ if mg_name is not None:
266
+ mg_cls = load_message_generator_manifests_map()[mg_name].load_cls()
267
+ mg = mg_cls()
268
+
269
+ mgr = mg.generate_commit_message(GitMessageGenerator.GenerateCommitMessageArgs(
270
+ cwd=cwd,
271
+ time_fmt=self.args.time_fmt,
272
+ ))
273
+ if mgr.confirm and not self._args.no_confirmation:
274
+ print(mgr.msg)
275
+ input()
276
+ msg = mgr.msg
277
+
278
+ check_call('git', 'commit', '-m', msg)
279
+
280
+ check_call('git', 'push')
211
281
 
212
282
  if not self.args.dir:
213
283
  run(None)
@@ -221,8 +291,8 @@ class Cli(ap.Cli):
221
291
  )
222
292
  def pull_submodule_update(self) -> None:
223
293
  def run(cwd: str | None) -> None:
224
- subprocess.check_call(['git', 'pull'], cwd=cwd)
225
- subprocess.check_call(['git', 'submodule', 'update'], cwd=cwd)
294
+ subprocesses.check_call('git', 'pull', cwd=cwd)
295
+ subprocesses.check_call('git', 'submodule', 'update', cwd=cwd)
226
296
 
227
297
  if not self.args.dir:
228
298
  run(None)
@@ -4,16 +4,32 @@ import os
4
4
  import typing as ta
5
5
 
6
6
  from omlish import cached
7
+ from omlish import check
7
8
  from omlish import lang
8
9
  from omlish.manifests import load as manifest_load
10
+ from omlish.manifests.base import ModAttrManifest
11
+ from omlish.manifests.base import NameAliasesManifest
9
12
 
10
13
 
11
14
  ##
12
15
 
13
16
 
14
17
  class GitMessageGenerator(abc.ABC):
18
+ @dc.dataclass(frozen=True, kw_only=True)
19
+ class GenerateCommitMessageArgs:
20
+ cwd: str | None = None
21
+
22
+ DEFAULT_TIME_FMT: ta.ClassVar[str] = '%Y-%m-%dT%H:%M:%SZ'
23
+ time_fmt: str = DEFAULT_TIME_FMT
24
+
25
+ @dc.dataclass(frozen=True, kw_only=True)
26
+ class GenerateCommitMessageResult:
27
+ msg: str
28
+
29
+ confirm: bool = False
30
+
15
31
  @abc.abstractmethod
16
- def generate_commit_message(self) -> str:
32
+ def generate_commit_message(self, args: GenerateCommitMessageArgs) -> GenerateCommitMessageResult:
17
33
  raise NotImplementedError
18
34
 
19
35
 
@@ -21,11 +37,9 @@ class GitMessageGenerator(abc.ABC):
21
37
 
22
38
 
23
39
  @dc.dataclass(frozen=True, kw_only=True)
24
- class GitMessageGeneratorManifest:
25
- mod_name: str
26
- attr_name: str
27
- name: str
28
- aliases: ta.Collection[str] | None = None
40
+ class GitMessageGeneratorManifest(NameAliasesManifest, ModAttrManifest):
41
+ def load_cls(self) -> type[GitMessageGenerator]:
42
+ return check.issubclass(self.load(), GitMessageGenerator)
29
43
 
30
44
 
31
45
  @cached.function
@@ -36,16 +50,23 @@ def load_message_generator_manifests() -> ta.Sequence[GitMessageGeneratorManifes
36
50
  return [mf.value for mf in mfs]
37
51
 
38
52
 
53
+ @cached.function
54
+ def load_message_generator_manifests_map() -> ta.Mapping[str, GitMessageGeneratorManifest]:
55
+ return GitMessageGeneratorManifest.build_name_dict(load_message_generator_manifests())
56
+
57
+
39
58
  ##
40
59
 
41
60
 
42
61
  @dc.dataclass(frozen=True)
43
62
  class TimestampGitMessageGenerator(GitMessageGenerator):
44
- DEFAULT_TIME_FMT: ta.ClassVar[str] = '%Y-%m-%d %H:%M:%S'
45
- time_fmt: str = DEFAULT_TIME_FMT
46
-
47
- def generate_commit_message(self) -> str:
48
- return lang.utcnow().strftime(self.time_fmt)
63
+ def generate_commit_message(
64
+ self,
65
+ args: GitMessageGenerator.GenerateCommitMessageArgs,
66
+ ) -> GitMessageGenerator.GenerateCommitMessageResult:
67
+ return GitMessageGenerator.GenerateCommitMessageResult(
68
+ msg=lang.utcnow().strftime(args.time_fmt),
69
+ )
49
70
 
50
71
 
51
72
  #
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: omdev
3
- Version: 0.0.0.dev234
3
+ Version: 0.0.0.dev236
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.dev234
15
+ Requires-Dist: omlish==0.0.0.dev236
16
16
  Provides-Extra: all
17
17
  Requires-Dist: black~=25.1; extra == "all"
18
18
  Requires-Dist: pycparser~=2.22; extra == "all"
@@ -1,9 +1,9 @@
1
- omdev/.manifests.json,sha256=-gFNSfj9LiUN5Wg47Jr9VVSd-Mhmhy8KMHhjmd_9RO0,9545
1
+ omdev/.manifests.json,sha256=kbXBVJQiDXr0p1RGZBjb3sJhl8kgPdRjz8tbbn-_i2k,9545
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
5
5
  omdev/classdot.py,sha256=YOvgy6x295I_8NKBbBlRVd3AN7Osirm_Lqt4Wj0j9rY,1631
6
- omdev/cmake.py,sha256=Diy2ry65806dQP125DAstD3w46z_wszMH7PwC2-6iik,4578
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
9
  omdev/pip.py,sha256=7cZ_IOpekQvgPm_gKnX3Pr8xjqUid50PPScTlZCYVlM,2118
@@ -208,12 +208,12 @@ omdev/pyproject/resources/docker-dev.sh,sha256=DHkz5D18jok_oDolfg2mqrvGRWFoCe9GQ
208
208
  omdev/pyproject/resources/python.sh,sha256=rFaN4SiJ9hdLDXXsDTwugI6zsw6EPkgYMmtacZeTbvw,749
209
209
  omdev/scripts/__init__.py,sha256=MKCvUAEQwsIvwLixwtPlpBqmkMXLCnjjXyAXvVpDwVk,91
210
210
  omdev/scripts/bumpversion.py,sha256=Kn7fo73Hs8uJh3Hi3EIyLOlzLPWAC6dwuD_lZ3cIzuY,1064
211
- omdev/scripts/ci.py,sha256=lyiGw7uIqs3e3Dac0xDB46m_albQZlYQR-i2iCXv_FA,162362
211
+ omdev/scripts/ci.py,sha256=BdITcdZfxdqPGOcITwDkhNnjeORKgzW5UaTj5aSauc4,162480
212
212
  omdev/scripts/execrss.py,sha256=mR0G0wERBYtQmVIn63lCIIFb5zkCM6X_XOENDFYDBKc,651
213
213
  omdev/scripts/exectime.py,sha256=S2O4MgtzTsFOY2IUJxsrnOIame9tEFc6aOlKP-F1JSg,1541
214
214
  omdev/scripts/importtrace.py,sha256=oa7CtcWJVMNDbyIEiRHej6ICfABfErMeo4_haIqe18Q,14041
215
- omdev/scripts/interp.py,sha256=tBIiJAd5OLBhvhuH_Lj7uFGWreJQjHSVr-2MgqTGYPo,150419
216
- omdev/scripts/pyproject.py,sha256=aMmQuIMRxULdnDmecIGiSBgDtfnzpSSNILXRjYJbRkI,258112
215
+ omdev/scripts/interp.py,sha256=H_WWqQ6ULe5cc976Q_9h2rhNTiKB0vg5PYJGBXWnfFY,150537
216
+ omdev/scripts/pyproject.py,sha256=6g3NmQfUaxtLhEizAEyewmuhjlEyQht_u9QTIkWMeJs,258230
217
217
  omdev/scripts/slowcat.py,sha256=lssv4yrgJHiWfOiHkUut2p8E8Tq32zB-ujXESQxFFHY,2728
218
218
  omdev/scripts/tmpexec.py,sha256=WTYcf56Tj2qjYV14AWmV8SfT0u6Y8eIU6cKgQRvEK3c,1442
219
219
  omdev/tokens/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -235,8 +235,8 @@ omdev/tools/qr.py,sha256=tm68lPwEAkEwIL2sUKPKBYfwwPtjVWG1DBZwur8_jY8,1737
235
235
  omdev/tools/sqlrepl.py,sha256=wAjrfXNrRV63-NJCC2HlGQnFh7lUH0bHMnOjYotQqFs,5753
236
236
  omdev/tools/git/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
237
237
  omdev/tools/git/__main__.py,sha256=gI87SBUgTkKUcUM-RtZWnei-UUDDqzbr5aPztb-gvbE,168
238
- omdev/tools/git/cli.py,sha256=0MwnDO4V-i3jvtCd9W0VR9LJjicY2_WoKq47_UhqNAA,7762
239
- omdev/tools/git/messages.py,sha256=gcXjzBUFOcL8Kia5x-t8jyN-aBLcHVhnfJX-lxXiQ3I,1299
238
+ omdev/tools/git/cli.py,sha256=9D9sKnm--2T_XEoMUWZXAzPBMtlKJk7qGCLt0Avl34Y,10088
239
+ omdev/tools/git/messages.py,sha256=zFKw4gMBU2vpTqs0CkwUVyZIdCQ_j0ZPUJTZrp2llqc,2207
240
240
  omdev/tools/json/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
241
241
  omdev/tools/json/__main__.py,sha256=wqpkN_NsQyNwKW4qjVj8ADJ4_C98KhrFBtE-Z1UamfU,168
242
242
  omdev/tools/json/cli.py,sha256=EubIMT-n2XsjWBZjSy2fWXqijlwrIhLsfbkg3SZzi28,9586
@@ -248,9 +248,9 @@ omdev/tools/json/rendering.py,sha256=tMcjOW5edfozcMSTxxvF7WVTsbYLoe9bCKFh50qyaGw
248
248
  omdev/tools/pawk/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
249
249
  omdev/tools/pawk/__main__.py,sha256=VCqeRVnqT1RPEoIrqHFSu4PXVMg4YEgF4qCQm90-eRI,66
250
250
  omdev/tools/pawk/pawk.py,sha256=zsEkfQX0jF5bn712uqPAyBSdJt2dno1LH2oeSMNfXQI,11424
251
- omdev-0.0.0.dev234.dist-info/LICENSE,sha256=B_hVtavaA8zCYDW99DYdcpDLKz1n3BBRjZrcbv8uG8c,1451
252
- omdev-0.0.0.dev234.dist-info/METADATA,sha256=jYQg7Y-n7e6R8dy6ffJ5pVsrT0WIAPcyc4mUyHtpiEs,1636
253
- omdev-0.0.0.dev234.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
254
- omdev-0.0.0.dev234.dist-info/entry_points.txt,sha256=dHLXFmq5D9B8qUyhRtFqTGWGxlbx3t5ejedjrnXNYLU,33
255
- omdev-0.0.0.dev234.dist-info/top_level.txt,sha256=1nr7j30fEWgLYHW3lGR9pkdHkb7knv1U1ES1XRNVQ6k,6
256
- omdev-0.0.0.dev234.dist-info/RECORD,,
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,,