v440 2.0.0.dev11__tar.gz → 2.0.0.dev13__tar.gz

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.
Files changed (33) hide show
  1. {v440-2.0.0.dev11/src/v440.egg-info → v440-2.0.0.dev13}/PKG-INFO +1 -1
  2. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/pyproject.toml +1 -1
  3. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/_utils/SimpleQualifierParser.py +36 -30
  4. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/_utils/VList.py +8 -2
  5. v440-2.0.0.dev13/src/v440/_utils/WList.py +15 -0
  6. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/_utils/utils.py +0 -8
  7. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/core/Base.py +4 -6
  8. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/core/Pre.py +5 -7
  9. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/core/Qualification.py +4 -6
  10. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/core/Version.py +8 -10
  11. {v440-2.0.0.dev11 → v440-2.0.0.dev13/src/v440.egg-info}/PKG-INFO +1 -1
  12. v440-2.0.0.dev11/src/v440/_utils/WList.py +0 -11
  13. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/LICENSE.txt +0 -0
  14. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/MANIFEST.in +0 -0
  15. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/README.rst +0 -0
  16. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/setup.cfg +0 -0
  17. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/__init__.py +0 -0
  18. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/_utils/Digest.py +0 -0
  19. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/_utils/Pattern.py +0 -0
  20. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/_utils/__init__.py +0 -0
  21. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/core/Local.py +0 -0
  22. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/core/Public.py +0 -0
  23. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/core/Release.py +0 -0
  24. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/core/VersionError.py +0 -0
  25. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/core/__init__.py +0 -0
  26. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/tests/__init__.py +0 -0
  27. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/tests/test_testdata.py +0 -0
  28. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/tests/test_version.py +0 -0
  29. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440/tests/testdata.toml +0 -0
  30. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440.egg-info/SOURCES.txt +0 -0
  31. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440.egg-info/dependency_links.txt +0 -0
  32. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440.egg-info/requires.txt +0 -0
  33. {v440-2.0.0.dev11 → v440-2.0.0.dev13}/src/v440.egg-info/top_level.txt +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: v440
3
- Version: 2.0.0.dev11
3
+ Version: 2.0.0.dev13
4
4
  Summary: This project provides mutable version objects in accordance with PEP440.
5
5
  Author-email: Johannes <johannes.programming@gmail.com>
6
6
  License: The MIT License (MIT)
@@ -34,7 +34,7 @@ keywords = []
34
34
  name = "v440"
35
35
  readme = "README.rst"
36
36
  requires-python = ">=3.11"
37
- version = "2.0.0.dev11"
37
+ version = "2.0.0.dev13"
38
38
 
39
39
  [project.license]
40
40
  file = "LICENSE.txt"
@@ -1,6 +1,5 @@
1
1
  from __future__ import annotations
2
2
 
3
- import dataclasses
4
3
  from typing import *
5
4
 
6
5
  from v440._utils import utils
@@ -10,11 +9,8 @@ from v440._utils.Pattern import Pattern
10
9
  __all__ = ["SimpleQualifierParser"]
11
10
 
12
11
 
13
- @dataclasses.dataclass(frozen=True)
14
12
  class SimpleQualifierParser:
15
- keysforlist: tuple = ()
16
- keysforstr: tuple = ()
17
- allow_len_1: bool = False
13
+ __slots__ = ("_keysforlist", "_keysforstr", "_allow_len_1")
18
14
 
19
15
  __call__ = Digest("__call__")
20
16
 
@@ -31,7 +27,7 @@ class SimpleQualifierParser:
31
27
  @__call__.overload(list)
32
28
  def __call__(self: Self, value: list) -> Any:
33
29
  v: list = list(map(utils.segment, value))
34
- n = self.nbylist(v)
30
+ n: Any = self.nbylist(v)
35
31
  if isinstance(n, str):
36
32
  raise TypeError
37
33
  return n
@@ -50,41 +46,51 @@ class SimpleQualifierParser:
50
46
  else:
51
47
  return int(n)
52
48
 
53
- def __post_init__(self: Self) -> None:
54
- if type(self.allow_len_1) is not bool:
55
- raise TypeError
56
- if type(self.keysforlist) is not tuple:
57
- raise TypeError
58
- if type(self.keysforstr) is not tuple:
59
- raise TypeError
60
- keys = self.keysforlist + self.keysforstr
61
- for k in keys:
62
- if k is None:
63
- continue
64
- if type(k) is str:
65
- continue
66
- raise TypeError
49
+ def __init__(
50
+ self: Self,
51
+ keysforlist: Iterable = (),
52
+ keysforstr: Iterable = (),
53
+ allow_len_1: Any = False,
54
+ ) -> None:
55
+ self._keysforlist = tuple(map(str, keysforlist))
56
+ self._keysforstr = tuple(map(self.optstr, keysforstr))
57
+ self._allow_len_1 = bool(allow_len_1)
58
+
59
+ @property
60
+ def allow_len_1(self: Self) -> tuple:
61
+ return self._allow_len_1
62
+
63
+ @property
64
+ def keysforlist(self: Self) -> tuple:
65
+ return self._keysforlist
66
+
67
+ @property
68
+ def keysforstr(self: Self) -> tuple:
69
+ return self._keysforstr
67
70
 
68
71
  def nbylist(self: Self, value: Any, /) -> Any:
69
72
  if len(value) == 2:
70
- l, n = value
71
- if l not in self.keysforlist:
72
- raise ValueError
73
- return n
73
+ if value[0] in self.keysforlist:
74
+ return value[1]
74
75
  if len(value) == 1:
75
- n = value[0]
76
- if not self.allow_len_1:
77
- raise ValueError
78
- return n
76
+ if self.allow_len_1:
77
+ return value[0]
79
78
  raise ValueError
80
79
 
80
+ @classmethod
81
+ def optstr(cls: type, value: Any) -> Optional[str]:
82
+ if value is None:
83
+ return
84
+ else:
85
+ return str(value)
86
+
81
87
 
82
- POST = SimpleQualifierParser(
88
+ POST: SimpleQualifierParser = SimpleQualifierParser(
83
89
  keysforlist=("post", "rev", "r", ""),
84
90
  keysforstr=(None, "post", "rev", "r"),
85
91
  allow_len_1=True,
86
92
  )
87
- DEV = SimpleQualifierParser(
93
+ DEV: SimpleQualifierParser = SimpleQualifierParser(
88
94
  keysforlist=("dev",),
89
95
  keysforstr=(None, "dev"),
90
96
  )
@@ -2,10 +2,16 @@ from typing import *
2
2
 
3
3
  from datahold import OkayList
4
4
 
5
- from v440._utils import utils
6
5
  from v440.core.VersionError import VersionError
7
6
 
8
7
 
8
+ def clone(value: Any) -> Any:
9
+ if isinstance(value, VList):
10
+ return list(map(clone, value))
11
+ else:
12
+ return value
13
+
14
+
9
15
  class VList(OkayList):
10
16
  def __eq__(self: Self, other: Any) -> bool:
11
17
  "This magic method implements self==other."
@@ -53,7 +59,7 @@ class VList(OkayList):
53
59
  def __setattr__(self: Self, name: str, value: Any) -> Any:
54
60
  if name not in type(self).__annotations__.keys():
55
61
  return object.__setattr__(self, name, value)
56
- backup: list = utils.clone(self)
62
+ backup: list = clone(self)
57
63
  exc: BaseException
58
64
  try:
59
65
  object.__setattr__(self, name, value)
@@ -0,0 +1,15 @@
1
+ from typing import *
2
+
3
+ from v440._utils.VList import VList
4
+
5
+ __all__ = ["WList"]
6
+
7
+
8
+ class WList(VList):
9
+ @property
10
+ def data(self: Self) -> list:
11
+ return list(self._data)
12
+
13
+ @data.setter
14
+ def data(self: Self, value: Any) -> None:
15
+ self._data = value
@@ -5,17 +5,9 @@ import string
5
5
  from typing import *
6
6
 
7
7
  from v440._utils.Digest import Digest
8
- from v440._utils.VList import VList
9
8
  from v440.core.VersionError import VersionError
10
9
 
11
10
 
12
- def clone(value: Any) -> Any:
13
- if isinstance(value, VList):
14
- return list(map(clone, value))
15
- else:
16
- return value
17
-
18
-
19
11
  def literal(value: Any, /) -> str:
20
12
  v: Any = segment(value)
21
13
  if type(v) is str:
@@ -80,11 +80,11 @@ class Base(WList):
80
80
  return self.format()
81
81
 
82
82
  @property
83
- def data(self: Self) -> list:
84
- return [self.epoch, self.release]
83
+ def _data(self: Self) -> tuple:
84
+ return self.epoch, self.release
85
85
 
86
- @data.setter
87
- def data(self: Self, value: Any) -> None:
86
+ @_data.setter
87
+ def _data(self: Self, value: Any) -> None:
88
88
  self.epoch, self.release = parse_data(value)
89
89
 
90
90
  @property
@@ -109,5 +109,3 @@ class Base(WList):
109
109
  @release.setter
110
110
  def release(self: Self, value: Any) -> None:
111
111
  self._release.data = value
112
-
113
- _data = data # why is this necessary?
@@ -83,14 +83,12 @@ class Pre(WList):
83
83
  return ans
84
84
 
85
85
  @property
86
- def data(self: Self) -> list:
87
- return [self._phase, self._subphase]
86
+ def _data(self: Self) -> tuple:
87
+ return self._phase, self._subphase
88
88
 
89
- @data.setter
90
- def data(self: Self, value: Any) -> None:
89
+ @_data.setter
90
+ def _data(self: Self, value: Any) -> None:
91
91
  self._phase, self._subphase = parse_data(value)
92
92
 
93
93
  def isempty(self: Self) -> bool:
94
- return self._data == [None, None]
95
-
96
- _data = data
94
+ return set(self._data) == {None}
@@ -99,11 +99,11 @@ class Qualification(WList):
99
99
  return ans
100
100
 
101
101
  @property
102
- def data(self: Self) -> list:
103
- return [self.pre, self.post, self.dev]
102
+ def _data(self: Self) -> tuple:
103
+ return self.pre, self.post, self.dev
104
104
 
105
- @data.setter
106
- def data(self: Self, value: Any) -> None:
105
+ @_data.setter
106
+ def _data(self: Self, value: Any) -> None:
107
107
  self.pre, self.post, self.dev = parse_data(value)
108
108
 
109
109
  @property
@@ -141,5 +141,3 @@ class Qualification(WList):
141
141
  @pre.setter
142
142
  def pre(self: Self, value: Any) -> None:
143
143
  self._pre.data = value
144
-
145
- _data = data
@@ -61,6 +61,14 @@ class Version(WList):
61
61
  def __str__(self: Self) -> str:
62
62
  return self.format()
63
63
 
64
+ @property
65
+ def _data(self: Self) -> tuple:
66
+ return (self.public, self.local)
67
+
68
+ @_data.setter
69
+ def _data(self: Self, value: Any) -> None:
70
+ self.public, self.local = parse_data(value)
71
+
64
72
  @property
65
73
  def base(self: Self) -> Base:
66
74
  return self.public.base
@@ -69,14 +77,6 @@ class Version(WList):
69
77
  def base(self: Self, value: Any) -> None:
70
78
  self.base.data = value
71
79
 
72
- @property
73
- def data(self: Self) -> str:
74
- return [self.public, self.local]
75
-
76
- @data.setter
77
- def data(self: Self, value: Any) -> None:
78
- self.public, self.local = parse_data(value)
79
-
80
80
  @property
81
81
  def dev(self: Self) -> Optional[int]:
82
82
  return self.qualification.dev
@@ -172,5 +172,3 @@ class Version(WList):
172
172
  m: str = "%r is not a property"
173
173
  m %= x
174
174
  raise AttributeError(m)
175
-
176
- _data = data
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: v440
3
- Version: 2.0.0.dev11
3
+ Version: 2.0.0.dev13
4
4
  Summary: This project provides mutable version objects in accordance with PEP440.
5
5
  Author-email: Johannes <johannes.programming@gmail.com>
6
6
  License: The MIT License (MIT)
@@ -1,11 +0,0 @@
1
- from typing import *
2
-
3
- from v440._utils import utils
4
- from v440._utils.VList import VList
5
- from v440.core.VersionError import VersionError
6
-
7
- __all__ = ["WList"]
8
-
9
-
10
- class WList(VList):
11
- pass
File without changes
File without changes
File without changes
File without changes