math-spec-mapping 0.2.3__tar.gz → 0.2.4__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/PKG-INFO +1 -1
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/pyproject.toml +1 -1
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/Block.py +90 -10
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/Policy.py +1 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/load.py +8 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/metrics.py +9 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/type.py +39 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/html.py +7 -2
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/markdown.py +29 -1
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/math_spec_mapping.egg-info/PKG-INFO +1 -1
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/LICENSE +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/README.md +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/setup.cfg +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/ActionTransmissionChannel.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/BoundaryAction.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/ControlAction.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/Entity.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/MathSpec.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/Mechanism.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/Metric.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/Parameter.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/Space.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/State.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/StateUpdateTransmissionChannel.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/StatefulMetric.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/Type.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/__init__.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Convenience/__init__.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Convenience/starter.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/__init__.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/action_transmission_channel.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/boundary_actions.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/control_actions.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/displays.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/entities.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/general.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/mechanism.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/parameters.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/policy.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/spaces.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/state_update_transmission_channels.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/stateful_metrics.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/states.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/wiring.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/__init__.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/boundary_actions.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/control_actions.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/general.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/mechanisms.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/node_map.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/parameters.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/policies.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/spaces.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/state.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/tables.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Reports/wiring.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/__init__.py +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/math_spec_mapping.egg-info/SOURCES.txt +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/math_spec_mapping.egg-info/dependency_links.txt +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/math_spec_mapping.egg-info/requires.txt +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/math_spec_mapping.egg-info/top_level.txt +0 -0
- {math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/schema.py +0 -0
@@ -21,6 +21,7 @@ class Block:
|
|
21
21
|
self.called_by = []
|
22
22
|
self.calls = []
|
23
23
|
self.block_type = "Block"
|
24
|
+
self.all_updates = []
|
24
25
|
# Will be overwritten in composite blocks to represent individual components
|
25
26
|
self.domain_blocks = tuple(
|
26
27
|
[
|
@@ -61,16 +62,85 @@ class Block:
|
|
61
62
|
for _ in range(len([x for x in self.codomain if x == TerminatingSpace]))
|
62
63
|
)
|
63
64
|
|
65
|
+
self.find_all_spaces_used(data)
|
66
|
+
|
64
67
|
def render_mermaid(self, i):
|
65
68
|
i += 1
|
66
|
-
|
69
|
+
out = 'X{}["{}"]'.format(i, self.name)
|
70
|
+
if self.block_type == "Mechanism":
|
71
|
+
for u in self.updates:
|
72
|
+
out += "\n"
|
73
|
+
out += "X{} --> {}".format(
|
74
|
+
i,
|
75
|
+
(u[0].name + "-" + u[1].name).replace(" ", "-"),
|
76
|
+
)
|
77
|
+
return out, i
|
78
|
+
|
79
|
+
def render_ending_entities(self):
|
80
|
+
if self.block_type == "Mechanism":
|
81
|
+
updates = self.updates
|
82
|
+
elif self.block_type in ["Parallel Block", "Stack Block", "Split Block"]:
|
83
|
+
updates = self.all_updates
|
84
|
+
else:
|
85
|
+
return "\n", {}
|
86
|
+
|
87
|
+
out = "\n"
|
88
|
+
out += 'subgraph SVS["State Variables"]\n'
|
89
|
+
|
90
|
+
# Render the entities
|
91
|
+
entity_mapping = {}
|
92
|
+
entities = set([x[0] for x in updates])
|
93
|
+
for i, x in enumerate(entities):
|
94
|
+
entity_mapping[x.name] = "EE{}".format(i)
|
95
|
+
out += '{}[("{}")]'.format(entity_mapping[x.name], x.name)
|
96
|
+
out += "\n"
|
97
|
+
|
98
|
+
entity_variable_mapping = {}
|
99
|
+
# Render the state variables
|
100
|
+
for i, x in enumerate(updates):
|
101
|
+
entity_variable_mapping[(x[0].name + "-" + x[1].name).replace(" ", "-")] = (
|
102
|
+
"EES{}".format(i)
|
103
|
+
)
|
104
|
+
out += '{}(["{}"])'.format("EES{}".format(i), x[1].name)
|
105
|
+
out += "\n"
|
106
|
+
|
107
|
+
out += "{} --- {}".format("EES{}".format(i), entity_mapping[x[0].name])
|
108
|
+
out += "\n"
|
109
|
+
out += "end\n"
|
110
|
+
out += "\n"
|
111
|
+
return out, entity_variable_mapping
|
67
112
|
|
68
113
|
def render_mermaid_root(self):
|
69
114
|
out = """```mermaid\ngraph TB\n"""
|
115
|
+
add, entity_variable_mapping = self.render_ending_entities()
|
116
|
+
out += add
|
70
117
|
out += self.render_mermaid(0)[0]
|
118
|
+
|
119
|
+
for key in entity_variable_mapping:
|
120
|
+
out = out.replace(key, entity_variable_mapping[key])
|
71
121
|
out += "\n```"
|
122
|
+
|
72
123
|
return out
|
73
124
|
|
125
|
+
def find_all_spaces_used(self, data):
|
126
|
+
self.all_spaces_used = []
|
127
|
+
self.all_spaces_used.extend(self.domain)
|
128
|
+
self.all_spaces_used.extend(self.codomain)
|
129
|
+
if "components" in data:
|
130
|
+
for x in data["components"]:
|
131
|
+
self.all_spaces_used.extend(x.all_spaces_used)
|
132
|
+
self.all_spaces_used = list(set(self.all_spaces_used))
|
133
|
+
|
134
|
+
def find_all_updates(self, data):
|
135
|
+
self.all_updates = []
|
136
|
+
if "components" in data:
|
137
|
+
for x in data["components"]:
|
138
|
+
if x.block_type == "Mechanism":
|
139
|
+
self.all_updates.extend(x.updates)
|
140
|
+
else:
|
141
|
+
self.all_updates.extend(x.all_updates)
|
142
|
+
self.all_updates = list(set(self.all_updates))
|
143
|
+
|
74
144
|
|
75
145
|
class ParallelBlock(Block):
|
76
146
|
def __init__(self, data: Dict):
|
@@ -123,8 +193,9 @@ class ParallelBlock(Block):
|
|
123
193
|
|
124
194
|
self.called_by = []
|
125
195
|
self.calls = []
|
126
|
-
self.block_type = "
|
196
|
+
self.block_type = "Parallel Block"
|
127
197
|
self.metadata = data["metadata"]
|
198
|
+
self.find_all_spaces_used(data)
|
128
199
|
|
129
200
|
def render_mermaid(self, i):
|
130
201
|
multi = None
|
@@ -139,6 +210,7 @@ class ParallelBlock(Block):
|
|
139
210
|
# Render components
|
140
211
|
domain_map = {}
|
141
212
|
codomain_map = {}
|
213
|
+
|
142
214
|
for component in self.components:
|
143
215
|
domain = component.domain
|
144
216
|
codomain = component.codomain
|
@@ -182,22 +254,27 @@ class ParallelBlock(Block):
|
|
182
254
|
for ix1 in nodes:
|
183
255
|
d = domain_map[ix1]
|
184
256
|
if len(d) > 0:
|
257
|
+
d_length = len(d)
|
185
258
|
d = "\n".join(d)
|
186
259
|
d = '"{}"'.format(d)
|
187
|
-
out += "X{} --{}
|
260
|
+
out += "X{} --{}{}-> X{}".format(domain_i, d, "-" * d_length, ix1)
|
188
261
|
else:
|
189
262
|
out += "X{} --> X{}".format(domain_i, ix1)
|
190
263
|
out += "\n"
|
191
264
|
|
265
|
+
codomain_connections = 0
|
192
266
|
for ix1 in nodes:
|
193
267
|
d = codomain_map[ix1]
|
194
268
|
if len(d) > 0:
|
195
269
|
d = "\n".join(d)
|
196
270
|
d = '"{}"'.format(d)
|
197
271
|
out += "X{} --{}--> X{}".format(ix1, d, codomain_i)
|
198
|
-
|
199
|
-
out += "
|
200
|
-
|
272
|
+
codomain_connections += 1
|
273
|
+
out += "\n"
|
274
|
+
# else:
|
275
|
+
# out += "X{} --> X{}".format(ix1, codomain_i)
|
276
|
+
if codomain_connections == 0:
|
277
|
+
out = out.replace("X{}[Codomain]".format(codomain_i), "")
|
201
278
|
|
202
279
|
# Subgraph it
|
203
280
|
if self.mermaid_show_name:
|
@@ -205,7 +282,7 @@ class ParallelBlock(Block):
|
|
205
282
|
else:
|
206
283
|
name = " "
|
207
284
|
i += 1
|
208
|
-
out =
|
285
|
+
out = 'subgraph X{}["{}"]\ndirection TB\n'.format(i, name) + out
|
209
286
|
|
210
287
|
out += "end"
|
211
288
|
|
@@ -241,6 +318,7 @@ class StackBlock(Block):
|
|
241
318
|
|
242
319
|
self.block_type = "Stack Block"
|
243
320
|
self.metadata = data["metadata"]
|
321
|
+
self.find_all_spaces_used(data)
|
244
322
|
|
245
323
|
def _check_domain_mapping(self):
|
246
324
|
x = self.components[:-1]
|
@@ -340,12 +418,13 @@ class StackBlock(Block):
|
|
340
418
|
d = domain_map[ix4]
|
341
419
|
optional = global_optional
|
342
420
|
if len(d) > 0:
|
421
|
+
d_length = len(d)
|
343
422
|
d = "\n".join(d)
|
344
423
|
d = '"{}"'.format(d)
|
345
424
|
if optional:
|
346
|
-
out += "X{}-.{}
|
425
|
+
out += "X{}-.{}.{}->X{}".format(ix3, d, "." * d_length, ix4)
|
347
426
|
else:
|
348
|
-
out += "X{}--{}
|
427
|
+
out += "X{}--{}-{}->X{}".format(ix3, d, "-" * d_length, ix4)
|
349
428
|
else:
|
350
429
|
if optional:
|
351
430
|
out += "X{}-.->X{}".format(ix3, ix4)
|
@@ -359,7 +438,7 @@ class StackBlock(Block):
|
|
359
438
|
else:
|
360
439
|
name = " "
|
361
440
|
i += 1
|
362
|
-
out =
|
441
|
+
out = 'subgraph X{}["{}"]\ndirection TB\n'.format(i, name) + out
|
363
442
|
out += "end"
|
364
443
|
|
365
444
|
return out, i
|
@@ -419,6 +498,7 @@ class SplitBlock(Block):
|
|
419
498
|
|
420
499
|
self.block_type = "Split Block"
|
421
500
|
self.metadata = data["metadata"]
|
501
|
+
self.find_all_spaces_used(data)
|
422
502
|
|
423
503
|
def render_mermaid(self, i):
|
424
504
|
multi = None
|
@@ -58,6 +58,14 @@ def load_from_json(json: Dict) -> MathSpec:
|
|
58
58
|
action_transmission_channels = load_wiring(ms, json)
|
59
59
|
load_action_transmission_channels(ms, action_transmission_channels)
|
60
60
|
load_state_update_transmission_channels(ms, state_update_transmission_channels)
|
61
|
+
|
62
|
+
temp = {}
|
63
|
+
for w in json["Wiring"]:
|
64
|
+
temp[w["name"]] = w
|
65
|
+
for w in ms["Wiring"]:
|
66
|
+
w = temp[w]
|
67
|
+
ms["Wiring"][w["name"]].find_all_updates(w)
|
68
|
+
|
61
69
|
load_metrics(ms, json, stateful_metrics_map)
|
62
70
|
if "Displays" in json:
|
63
71
|
load_displays(ms, json)
|
@@ -93,3 +93,12 @@ def load_metrics(ms: Dict, json: Dict, stateful_metrics_map) -> None:
|
|
93
93
|
z in ms["Metrics"] or z in names or z in stateful_metrics_map
|
94
94
|
), "{} is not defined in the spec".format(z)
|
95
95
|
assert len(metrics) == 0, "There are circular references"
|
96
|
+
|
97
|
+
# Load the metrics into the policies
|
98
|
+
for key in ms["Policies"]:
|
99
|
+
policy = ms["Policies"][key]
|
100
|
+
hold = policy.metrics_used[:]
|
101
|
+
policy.metrics_used = []
|
102
|
+
for x in hold:
|
103
|
+
assert x in ms["Metrics"], "{} not a valid metric".format(x)
|
104
|
+
policy.metrics_used.append(ms["Metrics"][x])
|
@@ -1,6 +1,7 @@
|
|
1
1
|
from .general import check_json_keys
|
2
2
|
from ..Classes import Type
|
3
3
|
import os
|
4
|
+
from typing import _UnionGenericAlias
|
4
5
|
|
5
6
|
|
6
7
|
def convert_type(data, ms):
|
@@ -32,8 +33,13 @@ def convert_type(data, ms):
|
|
32
33
|
val = val.__name__
|
33
34
|
out[key] = val
|
34
35
|
data["type_name"]["python"] = str(out)
|
36
|
+
elif type(data["type"]["python"]) == _UnionGenericAlias:
|
37
|
+
data["type_name"]["python"] = data["type"]["python"].__repr__()
|
35
38
|
else:
|
36
39
|
data["type_name"]["python"] = data["type"]["python"].__name__
|
40
|
+
if type_name in ms["Type Keys"]["typescript"]:
|
41
|
+
data["type"]["typescript"] = ms["Type Keys"]["typescript"][type_name]
|
42
|
+
data["type_name"]["typescript"] = ms["Type Keys"]["typescript"][type_name]
|
37
43
|
|
38
44
|
# Build the type object
|
39
45
|
return Type(data)
|
@@ -52,10 +58,43 @@ def load_python_type_key():
|
|
52
58
|
return mapping
|
53
59
|
|
54
60
|
|
61
|
+
def load_typescript_type_key(path):
|
62
|
+
with open(path, "r") as file:
|
63
|
+
type_definitions = file.read()
|
64
|
+
type_definitions = type_definitions.split("\n")
|
65
|
+
type_definitions = [x for x in type_definitions if len(x) > 0]
|
66
|
+
hold = type_definitions[:]
|
67
|
+
type_definitions = []
|
68
|
+
type_definitions.append(hold.pop(0))
|
69
|
+
while len(hold) > 0:
|
70
|
+
curr = hold.pop(0)
|
71
|
+
if "type" in curr or "interface" in curr:
|
72
|
+
type_definitions.append(curr)
|
73
|
+
else:
|
74
|
+
type_definitions[-1] += "\n" + curr
|
75
|
+
|
76
|
+
hold = type_definitions[:]
|
77
|
+
type_definitions = {}
|
78
|
+
for x in hold:
|
79
|
+
name = x
|
80
|
+
if x.startswith("type"):
|
81
|
+
name = name[5:]
|
82
|
+
elif x.startswith("interface"):
|
83
|
+
name = name[10:]
|
84
|
+
else:
|
85
|
+
assert False
|
86
|
+
name = name[: name.index("=")].strip()
|
87
|
+
type_definitions[name] = x
|
88
|
+
return type_definitions
|
89
|
+
|
90
|
+
|
55
91
|
def load_type_keys(ms) -> dict:
|
56
92
|
type_keys = {}
|
57
93
|
python_path = "src/TypeMappings/types.py"
|
94
|
+
typescript_path = "src/TypeMappings/types.ts"
|
58
95
|
if os.path.exists(python_path):
|
59
96
|
type_keys["python"] = load_python_type_key()
|
97
|
+
if os.path.exists(typescript_path):
|
98
|
+
type_keys["typescript"] = load_typescript_type_key(typescript_path)
|
60
99
|
|
61
100
|
ms["Type Keys"] = type_keys
|
@@ -111,7 +111,9 @@ def write_entity_reports(ms: MathSpec, directory: str, entities: List[str]) -> N
|
|
111
111
|
f.write(out)
|
112
112
|
|
113
113
|
|
114
|
-
def write_spec_tree(
|
114
|
+
def write_spec_tree(
|
115
|
+
ms: MathSpec, path=None, linking=False, add_tabbing=False, readme=False
|
116
|
+
) -> str:
|
115
117
|
"""Write the tree of the specification structure
|
116
118
|
|
117
119
|
Args:
|
@@ -198,6 +200,9 @@ def write_spec_tree(ms: MathSpec, path=None, linking=False, add_tabbing=False) -
|
|
198
200
|
out = out.split("\n")
|
199
201
|
out = ["\t" + x for x in out]
|
200
202
|
out = "\n".join(out)
|
203
|
+
if readme:
|
204
|
+
out = "\n\n```\n{}\n```".format(out)
|
205
|
+
out = out.replace("**", "")
|
201
206
|
|
202
207
|
if path:
|
203
208
|
with open("{}/Spec Tree.md".format(path), "w") as f:
|
@@ -211,6 +216,6 @@ def write_overview(ms: MathSpec, name: str, file_path: str, summary: str = None)
|
|
211
216
|
out += "<h2>Summary</h2>"
|
212
217
|
out += "<p>{}</p>".format(summary)
|
213
218
|
out += "<h2>Specification Tree</h2>"
|
214
|
-
out += write_spec_tree(ms)
|
219
|
+
out += write_spec_tree(ms, readme=True)
|
215
220
|
with open(file_path, "w") as f:
|
216
221
|
f.write(out)
|
@@ -95,6 +95,10 @@ def write_types_markdown_report(ms, path, t, add_metadata=True):
|
|
95
95
|
out += "### Python Type\n"
|
96
96
|
out += t.type_name["python"]
|
97
97
|
out += "\n"
|
98
|
+
if "typescript" in t.type:
|
99
|
+
out += "### Typescript Type\n"
|
100
|
+
out += t.type_name["typescript"]
|
101
|
+
out += "\n"
|
98
102
|
out += "\n"
|
99
103
|
out += "## Notes"
|
100
104
|
out += "\n\n"
|
@@ -208,6 +212,16 @@ def write_policy_markdown_report(ms, path, policy, add_metadata=True):
|
|
208
212
|
out += "{}. {}".format(i + 1, x)
|
209
213
|
out += "\n"
|
210
214
|
|
215
|
+
out += "## Parameters Used\n"
|
216
|
+
for i, x in enumerate(policy.parameters_used):
|
217
|
+
out += "{}. [[{}]]".format(i + 1, x)
|
218
|
+
out += "\n"
|
219
|
+
|
220
|
+
out += "## Metrics Used\n"
|
221
|
+
for i, x in enumerate(policy.metrics_used):
|
222
|
+
out += "{}. [[{}]]".format(i + 1, x.name)
|
223
|
+
out += "\n"
|
224
|
+
|
211
225
|
if policy.policy_options:
|
212
226
|
out += "## Policy Options\n"
|
213
227
|
for i, x in enumerate(policy.policy_options):
|
@@ -296,7 +310,9 @@ def write_space_markdown_report(ms, path, space, add_metadata=True):
|
|
296
310
|
out += "\n"
|
297
311
|
out += "\n"
|
298
312
|
d = space.schema
|
299
|
-
d = ",\n".join(
|
313
|
+
d = ",\n".join(
|
314
|
+
["{}: [[{}]]".format(a, b.name) for a, b in zip(d.keys(), d.values())]
|
315
|
+
)
|
300
316
|
d = "{" + d + "}"
|
301
317
|
out += d
|
302
318
|
out += "\n"
|
@@ -408,6 +424,12 @@ def write_wiring_markdown_report(ms, path, wiring, add_metadata=True):
|
|
408
424
|
out += "\n"
|
409
425
|
out += "\n"
|
410
426
|
|
427
|
+
out += "## All Spaces Used\n"
|
428
|
+
for i, x in enumerate(wiring.all_spaces_used):
|
429
|
+
out += "{}. [[{}]]".format(i + 1, x.name)
|
430
|
+
out += "\n"
|
431
|
+
out += "\n"
|
432
|
+
|
411
433
|
out += "## Parameters Used\n"
|
412
434
|
for i, x in enumerate(wiring.parameters_used):
|
413
435
|
out += "{}. [[{}]]".format(i + 1, x)
|
@@ -426,6 +448,12 @@ def write_wiring_markdown_report(ms, path, wiring, add_metadata=True):
|
|
426
448
|
out += "\n"
|
427
449
|
out += "\n"
|
428
450
|
|
451
|
+
out += "## All State Updates\n"
|
452
|
+
for i, x in enumerate(wiring.all_updates):
|
453
|
+
out += "{}. [[{}]].{}".format(i + 1, x[0].name, x[1].name)
|
454
|
+
out += "\n"
|
455
|
+
out += "\n"
|
456
|
+
|
429
457
|
with open("{}/Wiring/{}.md".format(path, wiring.name), "w") as f:
|
430
458
|
f.write(out)
|
431
459
|
|
File without changes
|
File without changes
|
File without changes
|
{math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/ActionTransmissionChannel.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Classes/StateUpdateTransmissionChannel.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/Load/state_update_transmission_channels.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/math_spec_mapping.egg-info/SOURCES.txt
RENAMED
File without changes
|
File without changes
|
{math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/math_spec_mapping.egg-info/requires.txt
RENAMED
File without changes
|
{math_spec_mapping-0.2.3 → math_spec_mapping-0.2.4}/src/math_spec_mapping.egg-info/top_level.txt
RENAMED
File without changes
|
File without changes
|