str-to-obj 2023.11__py3-none-any.whl → 2025.1__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.
- str_to_obj/__init__.py +64 -32
- str_to_obj/api/catalog.py +58 -0
- str_to_obj/api/type.py +58 -0
- str_to_obj/catalog/boolean.py +99 -0
- str_to_obj/catalog/callable.py +99 -0
- str_to_obj/catalog/choices.py +101 -0
- str_to_obj/catalog/collection.py +175 -0
- str_to_obj/catalog/number.py +142 -0
- str_to_obj/catalog/path.py +117 -0
- str_to_obj/interface/console.py +59 -37
- str_to_obj/main.py +76 -36
- str_to_obj/runtime/type.py +58 -0
- str_to_obj/runtime/value.py +56 -0
- str_to_obj/task/casting.py +88 -59
- str_to_obj/task/comparison.py +58 -36
- str_to_obj/task/inspection.py +59 -35
- str_to_obj/type/annotation.py +61 -43
- str_to_obj/type/hint.py +59 -38
- str_to_obj/type/hint_tree.py +122 -63
- str_to_obj/type/type.py +121 -0
- str_to_obj/type/value.py +69 -0
- str_to_obj/version.py +54 -34
- {str_to_obj-2023.11.dist-info → str_to_obj-2025.1.dist-info}/METADATA +90 -48
- str_to_obj-2025.1.dist-info/RECORD +26 -0
- {str_to_obj-2023.11.dist-info → str_to_obj-2025.1.dist-info}/WHEEL +1 -1
- str_to_obj-2023.11.dist-info/RECORD +0 -14
- {str_to_obj-2023.11.dist-info → str_to_obj-2025.1.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,175 @@
|
|
1
|
+
"""
|
2
|
+
Copyright CNRS/Inria/UniCA
|
3
|
+
Contributor(s): Eric Debreuve (eric.debreuve@cnrs.fr) since 2023
|
4
|
+
SEE COPYRIGHT NOTICE BELOW
|
5
|
+
"""
|
6
|
+
|
7
|
+
import dataclasses as d
|
8
|
+
import types as t
|
9
|
+
import typing as h
|
10
|
+
|
11
|
+
from logger_36 import LOGGER
|
12
|
+
from str_to_obj.type.annotation import annotation_t
|
13
|
+
from str_to_obj.type.hint import any_hint_h
|
14
|
+
from str_to_obj.type.type import type_t
|
15
|
+
|
16
|
+
|
17
|
+
@d.dataclass(slots=True, repr=False, eq=False)
|
18
|
+
class collection_t(annotation_t):
|
19
|
+
ACCEPTED_TYPES: h.ClassVar[tuple[type, ...]] = (list, set, tuple)
|
20
|
+
|
21
|
+
# Items of any type but None.
|
22
|
+
ANY_ITEMS_TYPES: h.ClassVar[h.Any | tuple[h.Any, ...]] = h.Any
|
23
|
+
ANY_LENGTH: h.ClassVar[tuple[int, ...]] = (0,)
|
24
|
+
|
25
|
+
items_types: any_hint_h | tuple[any_hint_h, ...] | type_t | tuple[type_t, ...] = (
|
26
|
+
ANY_ITEMS_TYPES
|
27
|
+
)
|
28
|
+
lengths: int | tuple[int, ...] = ANY_LENGTH
|
29
|
+
|
30
|
+
def __post_init__(self) -> None:
|
31
|
+
""""""
|
32
|
+
original_item_types = self.items_types
|
33
|
+
original_lengths = self.lengths
|
34
|
+
|
35
|
+
if isinstance(self.items_types, h.Sequence):
|
36
|
+
items_types = []
|
37
|
+
for stripe in self.items_types:
|
38
|
+
if isinstance(stripe, type_t):
|
39
|
+
items_types.append(stripe)
|
40
|
+
else:
|
41
|
+
items_types.append(type_t.NewForHint(stripe))
|
42
|
+
self.items_types = items_types
|
43
|
+
elif not isinstance(self.items_types, type_t):
|
44
|
+
self.items_types = type_t.NewForHint(self.items_types)
|
45
|
+
|
46
|
+
if isinstance(self.lengths, int):
|
47
|
+
self.lengths = (self.lengths,)
|
48
|
+
else:
|
49
|
+
self.lengths = tuple(sorted(self.lengths))
|
50
|
+
|
51
|
+
with LOGGER.AddedContextLevel("Collection Annotation"):
|
52
|
+
if isinstance(self.items_types, h.Sequence):
|
53
|
+
if max(self.lengths) > self.items_types.__len__():
|
54
|
+
LOGGER.StageIssue(
|
55
|
+
f'Allowed length(s) ("{original_lengths}") must not exceed '
|
56
|
+
f"the length of the item types sequence "
|
57
|
+
f'("{original_item_types}")'
|
58
|
+
)
|
59
|
+
if self.lengths != self.__class__.ANY_LENGTH:
|
60
|
+
for length in self.lengths:
|
61
|
+
if (not isinstance(length, int)) or (length < 0):
|
62
|
+
LOGGER.StageIssue(
|
63
|
+
f"Invalid length in {self.lengths}",
|
64
|
+
actual=length,
|
65
|
+
expected="strictly positive integer",
|
66
|
+
)
|
67
|
+
|
68
|
+
@classmethod
|
69
|
+
def NewForType(
|
70
|
+
cls,
|
71
|
+
stripe: any_hint_h | tuple[any_hint_h, ...] | type_t | tuple[type_t, ...],
|
72
|
+
/,
|
73
|
+
) -> h.Self:
|
74
|
+
""""""
|
75
|
+
if not isinstance(stripe, (type_t | tuple[type_t, ...])):
|
76
|
+
stripe = type_t.NewForHint(stripe)
|
77
|
+
|
78
|
+
if stripe.type not in cls.ACCEPTED_TYPES:
|
79
|
+
with LOGGER.AddedContextLevel("Collection Annotation"):
|
80
|
+
LOGGER.StageIssue(
|
81
|
+
f"Invalid type",
|
82
|
+
actual=stripe.type.__name__,
|
83
|
+
expected=", ".join(_elm.__name__ for _elm in cls.ACCEPTED_TYPES),
|
84
|
+
)
|
85
|
+
return collection_t()
|
86
|
+
|
87
|
+
if stripe.elements is None:
|
88
|
+
return collection_t()
|
89
|
+
|
90
|
+
if (n_elements := stripe.elements.__len__()) == 1:
|
91
|
+
return collection_t(items_types=stripe.elements[0], lengths=1)
|
92
|
+
|
93
|
+
if (n_elements == 2) and (stripe.elements[1].type is t.EllipsisType):
|
94
|
+
return collection_t(items_types=stripe.elements[0], lengths=cls.ANY_LENGTH)
|
95
|
+
|
96
|
+
return collection_t(items_types=stripe.elements, lengths=n_elements)
|
97
|
+
|
98
|
+
def ValueIssues(self, value: list | set | tuple | h.Any, /) -> list[str]:
|
99
|
+
""""""
|
100
|
+
issues = annotation_t.ValueIssues(self, value)
|
101
|
+
if issues.__len__() > 0:
|
102
|
+
return issues
|
103
|
+
|
104
|
+
if (self.lengths != self.__class__.ANY_LENGTH) and (
|
105
|
+
value.__len__() not in self.lengths
|
106
|
+
):
|
107
|
+
return [
|
108
|
+
f"{value}: Sequence of invalid length; "
|
109
|
+
f"Expected={' or '.join(map(str, self.lengths))}."
|
110
|
+
]
|
111
|
+
|
112
|
+
if isinstance(self.items_types, h.Sequence):
|
113
|
+
if value.__len__() > self.items_types.__len__():
|
114
|
+
return [
|
115
|
+
f"{value}: Sequence too long. "
|
116
|
+
f"Expected=At most {self.items_types.__len__()} element(s)."
|
117
|
+
]
|
118
|
+
|
119
|
+
output = []
|
120
|
+
for stripe, element in zip(self.items_types, value):
|
121
|
+
output.extend(stripe.ValueIssues(element))
|
122
|
+
return output
|
123
|
+
|
124
|
+
stripe: type_t = self.items_types
|
125
|
+
output = []
|
126
|
+
for element in value:
|
127
|
+
output.extend(stripe.ValueIssues(element))
|
128
|
+
return output
|
129
|
+
|
130
|
+
|
131
|
+
"""
|
132
|
+
COPYRIGHT NOTICE
|
133
|
+
|
134
|
+
This software is governed by the CeCILL license under French law and
|
135
|
+
abiding by the rules of distribution of free software. You can use,
|
136
|
+
modify and/ or redistribute the software under the terms of the CeCILL
|
137
|
+
license as circulated by CEA, CNRS and INRIA at the following URL
|
138
|
+
"http://www.cecill.info".
|
139
|
+
|
140
|
+
As a counterpart to the access to the source code and rights to copy,
|
141
|
+
modify and redistribute granted by the license, users are provided only
|
142
|
+
with a limited warranty and the software's author, the holder of the
|
143
|
+
economic rights, and the successive licensors have only limited
|
144
|
+
liability.
|
145
|
+
|
146
|
+
In this respect, the user's attention is drawn to the risks associated
|
147
|
+
with loading, using, modifying and/or developing or reproducing the
|
148
|
+
software by the user in light of its specific status of free software,
|
149
|
+
that may mean that it is complicated to manipulate, and that also
|
150
|
+
therefore means that it is reserved for developers and experienced
|
151
|
+
professionals having in-depth computer knowledge. Users are therefore
|
152
|
+
encouraged to load and test the software's suitability as regards their
|
153
|
+
requirements in conditions enabling the security of their systems and/or
|
154
|
+
data to be ensured and, more generally, to use and operate it in the
|
155
|
+
same conditions as regards security.
|
156
|
+
|
157
|
+
The fact that you are presently reading this means that you have had
|
158
|
+
knowledge of the CeCILL license and that you accept its terms.
|
159
|
+
|
160
|
+
SEE LICENCE NOTICE: file README-LICENCE-utf8.txt at project source root.
|
161
|
+
|
162
|
+
This software is being developed by Eric Debreuve, a CNRS employee and
|
163
|
+
member of team Morpheme.
|
164
|
+
Team Morpheme is a joint team between Inria, CNRS, and UniCA.
|
165
|
+
It is hosted by the Centre Inria d'Université Côte d'Azur, Laboratory
|
166
|
+
I3S, and Laboratory iBV.
|
167
|
+
|
168
|
+
CNRS: https://www.cnrs.fr/index.php/en
|
169
|
+
Inria: https://www.inria.fr/en/
|
170
|
+
UniCA: https://univ-cotedazur.eu/
|
171
|
+
Centre Inria d'Université Côte d'Azur: https://www.inria.fr/en/centre/sophia/
|
172
|
+
I3S: https://www.i3s.unice.fr/en/
|
173
|
+
iBV: http://ibv.unice.fr/
|
174
|
+
Team Morpheme: https://team.inria.fr/morpheme/
|
175
|
+
"""
|
@@ -0,0 +1,142 @@
|
|
1
|
+
"""
|
2
|
+
Copyright CNRS/Inria/UniCA
|
3
|
+
Contributor(s): Eric Debreuve (eric.debreuve@cnrs.fr) since 2023
|
4
|
+
SEE COPYRIGHT NOTICE BELOW
|
5
|
+
"""
|
6
|
+
|
7
|
+
import dataclasses as d
|
8
|
+
import typing as h
|
9
|
+
|
10
|
+
from logger_36 import LOGGER
|
11
|
+
from str_to_obj.type.annotation import annotation_t
|
12
|
+
|
13
|
+
number_h = int | float
|
14
|
+
|
15
|
+
|
16
|
+
@d.dataclass(slots=True, repr=False, eq=False)
|
17
|
+
class number_t(annotation_t):
|
18
|
+
INFINITY_NEG: h.ClassVar[float] = -float("inf")
|
19
|
+
INFINITY_POS: h.ClassVar[float] = float("inf")
|
20
|
+
INFINITE_PRECISION: h.ClassVar[float] = 0.0
|
21
|
+
|
22
|
+
ACCEPTED_TYPES: h.ClassVar[tuple[type, ...]] = (int, float)
|
23
|
+
min: number_h = INFINITY_NEG
|
24
|
+
max: number_h = INFINITY_POS
|
25
|
+
min_inclusive: bool = True
|
26
|
+
max_inclusive: bool = True
|
27
|
+
precision: number_h = INFINITE_PRECISION
|
28
|
+
|
29
|
+
def __post_init__(self) -> None:
|
30
|
+
""""""
|
31
|
+
stripe = self.__class__
|
32
|
+
|
33
|
+
with LOGGER.AddedContextLevel("Number Annotation"):
|
34
|
+
if (self.min != stripe.INFINITY_NEG) and not isinstance(
|
35
|
+
self.min, number_h.__args__
|
36
|
+
):
|
37
|
+
LOGGER.StageIssue(
|
38
|
+
f"Invalid type for min value {self.min}",
|
39
|
+
actual=type(self.min).__name__,
|
40
|
+
expected=number_h,
|
41
|
+
)
|
42
|
+
if (self.max != stripe.INFINITY_POS) and not isinstance(
|
43
|
+
self.max, number_h.__args__
|
44
|
+
):
|
45
|
+
LOGGER.StageIssue(
|
46
|
+
f"Invalid type for max value {self.max}",
|
47
|
+
actual=type(self.max).__name__,
|
48
|
+
expected=number_h,
|
49
|
+
)
|
50
|
+
if (self.precision != stripe.INFINITE_PRECISION) and not isinstance(
|
51
|
+
self.precision, number_h.__args__
|
52
|
+
):
|
53
|
+
LOGGER.StageIssue(
|
54
|
+
f"Invalid type for precision {self.precision}",
|
55
|
+
actual=type(self.precision).__name__,
|
56
|
+
expected=number_h,
|
57
|
+
)
|
58
|
+
if self.precision < 0:
|
59
|
+
LOGGER.StageIssue(f"Invalid, negative precision {self.precision}")
|
60
|
+
if (self.min > self.max) or (
|
61
|
+
(self.min == self.max)
|
62
|
+
and not (self.min_inclusive and self.max_inclusive)
|
63
|
+
):
|
64
|
+
if self.min_inclusive:
|
65
|
+
opening = "["
|
66
|
+
else:
|
67
|
+
opening = "]"
|
68
|
+
if self.max_inclusive:
|
69
|
+
closing = "]"
|
70
|
+
else:
|
71
|
+
closing = "["
|
72
|
+
LOGGER.StageIssue(
|
73
|
+
f"Empty value interval {opening}{self.min},{self.max}{closing}"
|
74
|
+
)
|
75
|
+
|
76
|
+
def ValueIssues(self, value: number_h, /) -> list[str]:
|
77
|
+
""""""
|
78
|
+
issues = annotation_t.ValueIssues(self, value)
|
79
|
+
if issues.__len__() > 0:
|
80
|
+
return issues
|
81
|
+
|
82
|
+
if self.min <= value <= self.max:
|
83
|
+
if ((value == self.min) and not self.min_inclusive) or (
|
84
|
+
(value == self.max) and not self.max_inclusive
|
85
|
+
):
|
86
|
+
return [f"{value}: Value outside prescribed interval."]
|
87
|
+
|
88
|
+
if (self.precision != self.__class__.INFINITE_PRECISION) and (
|
89
|
+
self.precision * int(value / self.precision) != value
|
90
|
+
):
|
91
|
+
return [f"{value}: Value of higher precision than the prescribed one."]
|
92
|
+
|
93
|
+
return []
|
94
|
+
else:
|
95
|
+
return [f"{value}: Value outside prescribed interval."]
|
96
|
+
|
97
|
+
|
98
|
+
"""
|
99
|
+
COPYRIGHT NOTICE
|
100
|
+
|
101
|
+
This software is governed by the CeCILL license under French law and
|
102
|
+
abiding by the rules of distribution of free software. You can use,
|
103
|
+
modify and/ or redistribute the software under the terms of the CeCILL
|
104
|
+
license as circulated by CEA, CNRS and INRIA at the following URL
|
105
|
+
"http://www.cecill.info".
|
106
|
+
|
107
|
+
As a counterpart to the access to the source code and rights to copy,
|
108
|
+
modify and redistribute granted by the license, users are provided only
|
109
|
+
with a limited warranty and the software's author, the holder of the
|
110
|
+
economic rights, and the successive licensors have only limited
|
111
|
+
liability.
|
112
|
+
|
113
|
+
In this respect, the user's attention is drawn to the risks associated
|
114
|
+
with loading, using, modifying and/or developing or reproducing the
|
115
|
+
software by the user in light of its specific status of free software,
|
116
|
+
that may mean that it is complicated to manipulate, and that also
|
117
|
+
therefore means that it is reserved for developers and experienced
|
118
|
+
professionals having in-depth computer knowledge. Users are therefore
|
119
|
+
encouraged to load and test the software's suitability as regards their
|
120
|
+
requirements in conditions enabling the security of their systems and/or
|
121
|
+
data to be ensured and, more generally, to use and operate it in the
|
122
|
+
same conditions as regards security.
|
123
|
+
|
124
|
+
The fact that you are presently reading this means that you have had
|
125
|
+
knowledge of the CeCILL license and that you accept its terms.
|
126
|
+
|
127
|
+
SEE LICENCE NOTICE: file README-LICENCE-utf8.txt at project source root.
|
128
|
+
|
129
|
+
This software is being developed by Eric Debreuve, a CNRS employee and
|
130
|
+
member of team Morpheme.
|
131
|
+
Team Morpheme is a joint team between Inria, CNRS, and UniCA.
|
132
|
+
It is hosted by the Centre Inria d'Université Côte d'Azur, Laboratory
|
133
|
+
I3S, and Laboratory iBV.
|
134
|
+
|
135
|
+
CNRS: https://www.cnrs.fr/index.php/en
|
136
|
+
Inria: https://www.inria.fr/en/
|
137
|
+
UniCA: https://univ-cotedazur.eu/
|
138
|
+
Centre Inria d'Université Côte d'Azur: https://www.inria.fr/en/centre/sophia/
|
139
|
+
I3S: https://www.i3s.unice.fr/en/
|
140
|
+
iBV: http://ibv.unice.fr/
|
141
|
+
Team Morpheme: https://team.inria.fr/morpheme/
|
142
|
+
"""
|
@@ -0,0 +1,117 @@
|
|
1
|
+
"""
|
2
|
+
Copyright CNRS/Inria/UniCA
|
3
|
+
Contributor(s): Eric Debreuve (eric.debreuve@cnrs.fr) since 2023
|
4
|
+
SEE COPYRIGHT NOTICE BELOW
|
5
|
+
"""
|
6
|
+
|
7
|
+
import dataclasses as d
|
8
|
+
import typing as h
|
9
|
+
from enum import Enum as enum_t
|
10
|
+
from pathlib import Path as pl_path_t
|
11
|
+
|
12
|
+
from str_to_obj.type.annotation import annotation_t
|
13
|
+
from str_to_obj.type.hint import annotated_hint_t
|
14
|
+
|
15
|
+
|
16
|
+
class path_type_e(enum_t):
|
17
|
+
document = 1
|
18
|
+
folder = 2
|
19
|
+
any = 3
|
20
|
+
|
21
|
+
|
22
|
+
class path_purpose_e(enum_t):
|
23
|
+
input = 1
|
24
|
+
output = 2
|
25
|
+
any = 3
|
26
|
+
|
27
|
+
|
28
|
+
@d.dataclass(slots=True, repr=False, eq=False)
|
29
|
+
class path_t(annotation_t):
|
30
|
+
|
31
|
+
ACCEPTED_TYPES: h.ClassVar[tuple[type, ...]] = (pl_path_t,)
|
32
|
+
|
33
|
+
type_: path_type_e
|
34
|
+
purpose: path_purpose_e
|
35
|
+
|
36
|
+
@classmethod
|
37
|
+
def NewAnnotatedType(
|
38
|
+
cls, type_: path_type_e, purpose: path_purpose_e, /
|
39
|
+
) -> annotated_hint_t:
|
40
|
+
""""""
|
41
|
+
return h.Annotated[pl_path_t, cls(type_=type_, purpose=purpose)]
|
42
|
+
|
43
|
+
def ValueIssues(self, value: pl_path_t | h.Any, /) -> list[str]:
|
44
|
+
"""
|
45
|
+
None: Unspecified path.
|
46
|
+
"""
|
47
|
+
issues = annotation_t.ValueIssues(self, value)
|
48
|
+
if issues.__len__() > 0:
|
49
|
+
return issues
|
50
|
+
|
51
|
+
if self.purpose is not path_purpose_e.input:
|
52
|
+
return []
|
53
|
+
|
54
|
+
if value.exists():
|
55
|
+
if self.type_ is path_type_e.any:
|
56
|
+
if value.is_file() or value.is_dir():
|
57
|
+
return []
|
58
|
+
else:
|
59
|
+
return [f"{value}: Not a valid file or folder."]
|
60
|
+
|
61
|
+
if (self.type_ is path_type_e.document) and value.is_file():
|
62
|
+
return []
|
63
|
+
|
64
|
+
if (self.type_ is path_type_e.folder) and value.is_dir():
|
65
|
+
return []
|
66
|
+
|
67
|
+
return [
|
68
|
+
f"{value}: Non-existent file or folder, or file for folder, "
|
69
|
+
f"or folder for file."
|
70
|
+
]
|
71
|
+
|
72
|
+
|
73
|
+
"""
|
74
|
+
COPYRIGHT NOTICE
|
75
|
+
|
76
|
+
This software is governed by the CeCILL license under French law and
|
77
|
+
abiding by the rules of distribution of free software. You can use,
|
78
|
+
modify and/ or redistribute the software under the terms of the CeCILL
|
79
|
+
license as circulated by CEA, CNRS and INRIA at the following URL
|
80
|
+
"http://www.cecill.info".
|
81
|
+
|
82
|
+
As a counterpart to the access to the source code and rights to copy,
|
83
|
+
modify and redistribute granted by the license, users are provided only
|
84
|
+
with a limited warranty and the software's author, the holder of the
|
85
|
+
economic rights, and the successive licensors have only limited
|
86
|
+
liability.
|
87
|
+
|
88
|
+
In this respect, the user's attention is drawn to the risks associated
|
89
|
+
with loading, using, modifying and/or developing or reproducing the
|
90
|
+
software by the user in light of its specific status of free software,
|
91
|
+
that may mean that it is complicated to manipulate, and that also
|
92
|
+
therefore means that it is reserved for developers and experienced
|
93
|
+
professionals having in-depth computer knowledge. Users are therefore
|
94
|
+
encouraged to load and test the software's suitability as regards their
|
95
|
+
requirements in conditions enabling the security of their systems and/or
|
96
|
+
data to be ensured and, more generally, to use and operate it in the
|
97
|
+
same conditions as regards security.
|
98
|
+
|
99
|
+
The fact that you are presently reading this means that you have had
|
100
|
+
knowledge of the CeCILL license and that you accept its terms.
|
101
|
+
|
102
|
+
SEE LICENCE NOTICE: file README-LICENCE-utf8.txt at project source root.
|
103
|
+
|
104
|
+
This software is being developed by Eric Debreuve, a CNRS employee and
|
105
|
+
member of team Morpheme.
|
106
|
+
Team Morpheme is a joint team between Inria, CNRS, and UniCA.
|
107
|
+
It is hosted by the Centre Inria d'Université Côte d'Azur, Laboratory
|
108
|
+
I3S, and Laboratory iBV.
|
109
|
+
|
110
|
+
CNRS: https://www.cnrs.fr/index.php/en
|
111
|
+
Inria: https://www.inria.fr/en/
|
112
|
+
UniCA: https://univ-cotedazur.eu/
|
113
|
+
Centre Inria d'Université Côte d'Azur: https://www.inria.fr/en/centre/sophia/
|
114
|
+
I3S: https://www.i3s.unice.fr/en/
|
115
|
+
iBV: http://ibv.unice.fr/
|
116
|
+
Team Morpheme: https://team.inria.fr/morpheme/
|
117
|
+
"""
|
str_to_obj/interface/console.py
CHANGED
@@ -1,38 +1,13 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
#
|
12
|
-
# As a counterpart to the access to the source code and rights to copy,
|
13
|
-
# modify and redistribute granted by the license, users are provided only
|
14
|
-
# with a limited warranty and the software's author, the holder of the
|
15
|
-
# economic rights, and the successive licensors have only limited
|
16
|
-
# liability.
|
17
|
-
#
|
18
|
-
# In this respect, the user's attention is drawn to the risks associated
|
19
|
-
# with loading, using, modifying and/or developing or reproducing the
|
20
|
-
# software by the user in light of its specific status of free software,
|
21
|
-
# that may mean that it is complicated to manipulate, and that also
|
22
|
-
# therefore means that it is reserved for developers and experienced
|
23
|
-
# professionals having in-depth computer knowledge. Users are therefore
|
24
|
-
# encouraged to load and test the software's suitability as regards their
|
25
|
-
# requirements in conditions enabling the security of their systems and/or
|
26
|
-
# data to be ensured and, more generally, to use and operate it in the
|
27
|
-
# same conditions as regards security.
|
28
|
-
#
|
29
|
-
# The fact that you are presently reading this means that you have had
|
30
|
-
# knowledge of the CeCILL license and that you accept its terms.
|
31
|
-
|
32
|
-
from typing import Any, Sequence
|
33
|
-
|
34
|
-
|
35
|
-
def TypeAsRichStr(value: Any, /, *, prefix: str = "") -> str:
|
1
|
+
"""
|
2
|
+
Copyright CNRS/Inria/UniCA
|
3
|
+
Contributor(s): Eric Debreuve (eric.debreuve@cnrs.fr) since 2023
|
4
|
+
SEE COPYRIGHT NOTICE BELOW
|
5
|
+
"""
|
6
|
+
|
7
|
+
import typing as h
|
8
|
+
|
9
|
+
|
10
|
+
def TypeAsRichStr(value: h.Any, /, *, prefix: str = "") -> str:
|
36
11
|
"""
|
37
12
|
Richer alternative (however, causes troubles with packages like TensorFlow):
|
38
13
|
Additional parameter: relative_to_home: bool = True
|
@@ -46,10 +21,57 @@ def TypeAsRichStr(value: Any, /, *, prefix: str = "") -> str:
|
|
46
21
|
return f"[yellow]{prefix}{type(value).__name__}[/]"
|
47
22
|
|
48
23
|
|
49
|
-
def NameValueTypeAsRichStr(name: str, value: Any, /, *, separator: str = "=") -> str:
|
24
|
+
def NameValueTypeAsRichStr(name: str, value: h.Any, /, *, separator: str = "=") -> str:
|
50
25
|
""""""
|
51
26
|
formatted_type = TypeAsRichStr(value, prefix=":")
|
52
|
-
if isinstance(value, Sequence) and (value.__len__() == 0):
|
27
|
+
if isinstance(value, h.Sequence) and (value.__len__() == 0):
|
53
28
|
value = "[cyan]<empty>[/]"
|
54
29
|
|
55
30
|
return f"[blue]{name}[/]{separator}{value}{formatted_type}"
|
31
|
+
|
32
|
+
|
33
|
+
"""
|
34
|
+
COPYRIGHT NOTICE
|
35
|
+
|
36
|
+
This software is governed by the CeCILL license under French law and
|
37
|
+
abiding by the rules of distribution of free software. You can use,
|
38
|
+
modify and/ or redistribute the software under the terms of the CeCILL
|
39
|
+
license as circulated by CEA, CNRS and INRIA at the following URL
|
40
|
+
"http://www.cecill.info".
|
41
|
+
|
42
|
+
As a counterpart to the access to the source code and rights to copy,
|
43
|
+
modify and redistribute granted by the license, users are provided only
|
44
|
+
with a limited warranty and the software's author, the holder of the
|
45
|
+
economic rights, and the successive licensors have only limited
|
46
|
+
liability.
|
47
|
+
|
48
|
+
In this respect, the user's attention is drawn to the risks associated
|
49
|
+
with loading, using, modifying and/or developing or reproducing the
|
50
|
+
software by the user in light of its specific status of free software,
|
51
|
+
that may mean that it is complicated to manipulate, and that also
|
52
|
+
therefore means that it is reserved for developers and experienced
|
53
|
+
professionals having in-depth computer knowledge. Users are therefore
|
54
|
+
encouraged to load and test the software's suitability as regards their
|
55
|
+
requirements in conditions enabling the security of their systems and/or
|
56
|
+
data to be ensured and, more generally, to use and operate it in the
|
57
|
+
same conditions as regards security.
|
58
|
+
|
59
|
+
The fact that you are presently reading this means that you have had
|
60
|
+
knowledge of the CeCILL license and that you accept its terms.
|
61
|
+
|
62
|
+
SEE LICENCE NOTICE: file README-LICENCE-utf8.txt at project source root.
|
63
|
+
|
64
|
+
This software is being developed by Eric Debreuve, a CNRS employee and
|
65
|
+
member of team Morpheme.
|
66
|
+
Team Morpheme is a joint team between Inria, CNRS, and UniCA.
|
67
|
+
It is hosted by the Centre Inria d'Université Côte d'Azur, Laboratory
|
68
|
+
I3S, and Laboratory iBV.
|
69
|
+
|
70
|
+
CNRS: https://www.cnrs.fr/index.php/en
|
71
|
+
Inria: https://www.inria.fr/en/
|
72
|
+
UniCA: https://univ-cotedazur.eu/
|
73
|
+
Centre Inria d'Université Côte d'Azur: https://www.inria.fr/en/centre/sophia/
|
74
|
+
I3S: https://www.i3s.unice.fr/en/
|
75
|
+
iBV: http://ibv.unice.fr/
|
76
|
+
Team Morpheme: https://team.inria.fr/morpheme/
|
77
|
+
"""
|
str_to_obj/main.py
CHANGED
@@ -1,59 +1,35 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
# This software is governed by the CeCILL license under French law and
|
7
|
-
# abiding by the rules of distribution of free software. You can use,
|
8
|
-
# modify and/ or redistribute the software under the terms of the CeCILL
|
9
|
-
# license as circulated by CEA, CNRS and INRIA at the following URL
|
10
|
-
# "http://www.cecill.info".
|
11
|
-
#
|
12
|
-
# As a counterpart to the access to the source code and rights to copy,
|
13
|
-
# modify and redistribute granted by the license, users are provided only
|
14
|
-
# with a limited warranty and the software's author, the holder of the
|
15
|
-
# economic rights, and the successive licensors have only limited
|
16
|
-
# liability.
|
17
|
-
#
|
18
|
-
# In this respect, the user's attention is drawn to the risks associated
|
19
|
-
# with loading, using, modifying and/or developing or reproducing the
|
20
|
-
# software by the user in light of its specific status of free software,
|
21
|
-
# that may mean that it is complicated to manipulate, and that also
|
22
|
-
# therefore means that it is reserved for developers and experienced
|
23
|
-
# professionals having in-depth computer knowledge. Users are therefore
|
24
|
-
# encouraged to load and test the software's suitability as regards their
|
25
|
-
# requirements in conditions enabling the security of their systems and/or
|
26
|
-
# data to be ensured and, more generally, to use and operate it in the
|
27
|
-
# same conditions as regards security.
|
28
|
-
#
|
29
|
-
# The fact that you are presently reading this means that you have had
|
30
|
-
# knowledge of the CeCILL license and that you accept its terms.
|
1
|
+
"""
|
2
|
+
Copyright CNRS/Inria/UniCA
|
3
|
+
Contributor(s): Eric Debreuve (eric.debreuve@cnrs.fr) since 2023
|
4
|
+
SEE COPYRIGHT NOTICE BELOW
|
5
|
+
"""
|
31
6
|
|
32
7
|
import ast as bstr
|
33
|
-
|
34
|
-
|
8
|
+
import types as t
|
9
|
+
import typing as h
|
35
10
|
|
36
11
|
from str_to_obj.task.casting import CastValue
|
37
|
-
from str_to_obj.type.hint_tree import any_hint_h,
|
12
|
+
from str_to_obj.type.hint_tree import any_hint_h, hint_t
|
38
13
|
|
39
14
|
|
40
15
|
def ObjectFromStr(
|
41
16
|
string: str,
|
42
17
|
/,
|
43
18
|
*,
|
44
|
-
expected_type: any_hint_h |
|
45
|
-
) -> tuple[Any, list[str]]:
|
19
|
+
expected_type: any_hint_h | hint_t | type[t.NoneType] = None,
|
20
|
+
) -> tuple[h.Any, list[str]]:
|
46
21
|
"""
|
47
22
|
expected_type: Must not be passed explicitly as None since None is interpreted as
|
48
23
|
"no specific expected type". When expecting None, pass NoneType.
|
49
24
|
"""
|
50
|
-
if expected_type is NoneType:
|
25
|
+
if expected_type is t.NoneType:
|
51
26
|
if string.lower() == "none":
|
52
27
|
issues = []
|
53
28
|
else:
|
54
29
|
issues = [f'{string}: Invalid value; Expected="NONE" or "None" or "none".']
|
55
30
|
return None, issues
|
56
31
|
|
32
|
+
# value = _ObjectFromStr(string)
|
57
33
|
try:
|
58
34
|
value = bstr.literal_eval(string)
|
59
35
|
except (SyntaxError, ValueError):
|
@@ -63,3 +39,67 @@ def ObjectFromStr(
|
|
63
39
|
return value, []
|
64
40
|
|
65
41
|
return CastValue(value, expected_type)
|
42
|
+
|
43
|
+
|
44
|
+
# def _ObjectFromStr(string: str | h.Any, /)-> h.Any:
|
45
|
+
# """"""
|
46
|
+
# # if not isinstance(string, str):
|
47
|
+
# # return string
|
48
|
+
#
|
49
|
+
# try:
|
50
|
+
# value = bstr.literal_eval(string)
|
51
|
+
# except (SyntaxError, ValueError):
|
52
|
+
# value = string
|
53
|
+
#
|
54
|
+
# # if isinstance(value, h.Sequence) and not isinstance(value, str):
|
55
|
+
# # stripe = type(value)
|
56
|
+
# # value = stripe(_ObjectFromStr(_elm) for _elm in value)
|
57
|
+
#
|
58
|
+
# return value
|
59
|
+
|
60
|
+
|
61
|
+
"""
|
62
|
+
COPYRIGHT NOTICE
|
63
|
+
|
64
|
+
This software is governed by the CeCILL license under French law and
|
65
|
+
abiding by the rules of distribution of free software. You can use,
|
66
|
+
modify and/ or redistribute the software under the terms of the CeCILL
|
67
|
+
license as circulated by CEA, CNRS and INRIA at the following URL
|
68
|
+
"http://www.cecill.info".
|
69
|
+
|
70
|
+
As a counterpart to the access to the source code and rights to copy,
|
71
|
+
modify and redistribute granted by the license, users are provided only
|
72
|
+
with a limited warranty and the software's author, the holder of the
|
73
|
+
economic rights, and the successive licensors have only limited
|
74
|
+
liability.
|
75
|
+
|
76
|
+
In this respect, the user's attention is drawn to the risks associated
|
77
|
+
with loading, using, modifying and/or developing or reproducing the
|
78
|
+
software by the user in light of its specific status of free software,
|
79
|
+
that may mean that it is complicated to manipulate, and that also
|
80
|
+
therefore means that it is reserved for developers and experienced
|
81
|
+
professionals having in-depth computer knowledge. Users are therefore
|
82
|
+
encouraged to load and test the software's suitability as regards their
|
83
|
+
requirements in conditions enabling the security of their systems and/or
|
84
|
+
data to be ensured and, more generally, to use and operate it in the
|
85
|
+
same conditions as regards security.
|
86
|
+
|
87
|
+
The fact that you are presently reading this means that you have had
|
88
|
+
knowledge of the CeCILL license and that you accept its terms.
|
89
|
+
|
90
|
+
SEE LICENCE NOTICE: file README-LICENCE-utf8.txt at project source root.
|
91
|
+
|
92
|
+
This software is being developed by Eric Debreuve, a CNRS employee and
|
93
|
+
member of team Morpheme.
|
94
|
+
Team Morpheme is a joint team between Inria, CNRS, and UniCA.
|
95
|
+
It is hosted by the Centre Inria d'Université Côte d'Azur, Laboratory
|
96
|
+
I3S, and Laboratory iBV.
|
97
|
+
|
98
|
+
CNRS: https://www.cnrs.fr/index.php/en
|
99
|
+
Inria: https://www.inria.fr/en/
|
100
|
+
UniCA: https://univ-cotedazur.eu/
|
101
|
+
Centre Inria d'Université Côte d'Azur: https://www.inria.fr/en/centre/sophia/
|
102
|
+
I3S: https://www.i3s.unice.fr/en/
|
103
|
+
iBV: http://ibv.unice.fr/
|
104
|
+
Team Morpheme: https://team.inria.fr/morpheme/
|
105
|
+
"""
|