str-to-obj 2023.11__py3-none-any.whl → 2025.2__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- 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 +75 -39
- 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.2.dist-info}/METADATA +90 -48
- str_to_obj-2025.2.dist-info/RECORD +26 -0
- {str_to_obj-2023.11.dist-info → str_to_obj-2025.2.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.2.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,65 +1,101 @@
|
|
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)
|
33
|
+
|
34
|
+
if expected_type is None:
|
35
|
+
return value, []
|
36
|
+
|
37
|
+
return CastValue(value, expected_type)
|
38
|
+
|
39
|
+
|
40
|
+
def _ObjectFromStr(string: str | h.Any, /)-> h.Any:
|
41
|
+
""""""
|
42
|
+
if not isinstance(string, str):
|
43
|
+
return string
|
44
|
+
|
57
45
|
try:
|
58
46
|
value = bstr.literal_eval(string)
|
59
47
|
except (SyntaxError, ValueError):
|
60
48
|
value = string
|
61
49
|
|
62
|
-
if
|
63
|
-
|
50
|
+
if isinstance(value, h.Sequence) and not isinstance(value, str):
|
51
|
+
stripe = type(value)
|
52
|
+
value = stripe(_ObjectFromStr(_elm) for _elm in value)
|
64
53
|
|
65
|
-
return
|
54
|
+
return value
|
55
|
+
|
56
|
+
|
57
|
+
"""
|
58
|
+
COPYRIGHT NOTICE
|
59
|
+
|
60
|
+
This software is governed by the CeCILL license under French law and
|
61
|
+
abiding by the rules of distribution of free software. You can use,
|
62
|
+
modify and/ or redistribute the software under the terms of the CeCILL
|
63
|
+
license as circulated by CEA, CNRS and INRIA at the following URL
|
64
|
+
"http://www.cecill.info".
|
65
|
+
|
66
|
+
As a counterpart to the access to the source code and rights to copy,
|
67
|
+
modify and redistribute granted by the license, users are provided only
|
68
|
+
with a limited warranty and the software's author, the holder of the
|
69
|
+
economic rights, and the successive licensors have only limited
|
70
|
+
liability.
|
71
|
+
|
72
|
+
In this respect, the user's attention is drawn to the risks associated
|
73
|
+
with loading, using, modifying and/or developing or reproducing the
|
74
|
+
software by the user in light of its specific status of free software,
|
75
|
+
that may mean that it is complicated to manipulate, and that also
|
76
|
+
therefore means that it is reserved for developers and experienced
|
77
|
+
professionals having in-depth computer knowledge. Users are therefore
|
78
|
+
encouraged to load and test the software's suitability as regards their
|
79
|
+
requirements in conditions enabling the security of their systems and/or
|
80
|
+
data to be ensured and, more generally, to use and operate it in the
|
81
|
+
same conditions as regards security.
|
82
|
+
|
83
|
+
The fact that you are presently reading this means that you have had
|
84
|
+
knowledge of the CeCILL license and that you accept its terms.
|
85
|
+
|
86
|
+
SEE LICENCE NOTICE: file README-LICENCE-utf8.txt at project source root.
|
87
|
+
|
88
|
+
This software is being developed by Eric Debreuve, a CNRS employee and
|
89
|
+
member of team Morpheme.
|
90
|
+
Team Morpheme is a joint team between Inria, CNRS, and UniCA.
|
91
|
+
It is hosted by the Centre Inria d'Université Côte d'Azur, Laboratory
|
92
|
+
I3S, and Laboratory iBV.
|
93
|
+
|
94
|
+
CNRS: https://www.cnrs.fr/index.php/en
|
95
|
+
Inria: https://www.inria.fr/en/
|
96
|
+
UniCA: https://univ-cotedazur.eu/
|
97
|
+
Centre Inria d'Université Côte d'Azur: https://www.inria.fr/en/centre/sophia/
|
98
|
+
I3S: https://www.i3s.unice.fr/en/
|
99
|
+
iBV: http://ibv.unice.fr/
|
100
|
+
Team Morpheme: https://team.inria.fr/morpheme/
|
101
|
+
"""
|