@@ -16,31 +16,25 @@ def all_fsm_fields_data(model):
16
16
return [(field , model ) for field in model ._meta .get_fields () if isinstance (field , FSMFieldMixin )]
17
17
18
18
19
- def node_name (field , state ) -> str :
19
+ def node_name (field , state ):
20
20
opts = field .model ._meta
21
21
return "{}.{}.{}.{}" .format (opts .app_label , opts .verbose_name .replace (" " , "_" ), field .name , state )
22
22
23
23
24
- def node_label (field , state ) -> str :
25
- if isinstance (state , int ):
26
- return str (state )
27
- if isinstance (state , bool ) and hasattr (field , "choices" ):
24
+ def node_label (field , state ):
25
+ if isinstance (state , int ) or (isinstance (state , bool ) and hasattr (field , "choices" )):
28
26
return force_str (dict (field .choices ).get (state ))
29
27
return state
30
28
31
29
32
- def generate_dot (fields_data , ignore_transitions : list [str ] | None = None ): # noqa: C901, PLR0912
33
- ignore_transitions = ignore_transitions or []
30
+ def generate_dot (fields_data ): # noqa: C901, PLR0912
34
31
result = graphviz .Digraph ()
35
32
36
33
for field , model in fields_data :
37
34
sources , targets , edges , any_targets , any_except_targets = set (), set (), set (), set (), set ()
38
35
39
36
# dump nodes and edges
40
37
for transition in field .get_all_transitions (model ):
41
- if transition .name in ignore_transitions :
42
- continue
43
-
44
38
_targets = list (
45
39
(state for state in transition .target .allowed_states )
46
40
if isinstance (transition .target , (GET_STATE , RETURN_VALUE ))
@@ -133,7 +127,7 @@ def add_arguments(self, parser):
133
127
"-o" ,
134
128
action = "store" ,
135
129
dest = "outputfile" ,
136
- help = "Render output file. Type of output dependent on file extensions. Use png or jpg to render graph to image." ,
130
+ help = ( "Render output file. Type of output dependent on file extensions. Use png or jpg to render graph to image." ) ,
137
131
)
138
132
parser .add_argument (
139
133
"--layout" ,
@@ -143,14 +137,6 @@ def add_arguments(self, parser):
143
137
default = "dot" ,
144
138
help = f"Layout to be used by GraphViz for visualization. Layouts: { get_graphviz_layouts ()} ." ,
145
139
)
146
- parser .add_argument (
147
- "--exclude" ,
148
- "-e" ,
149
- action = "store" ,
150
- dest = "exclude" ,
151
- default = "" ,
152
- help = "Ignore transitions with this name." ,
153
- )
154
140
parser .add_argument ("args" , nargs = "*" , help = ("[appname[.model[.field]]]" ))
155
141
156
142
def render_output (self , graph , ** options ):
@@ -167,8 +153,9 @@ def handle(self, *args, **options):
167
153
field_spec = arg .split ("." )
168
154
169
155
if len (field_spec ) == 1 :
170
- app = apps .get_app_config (field_spec [0 ])
171
- for model in apps .get_models (app ):
156
+ app = apps .get_app (field_spec [0 ])
157
+ models = apps .get_models (app )
158
+ for model in models :
172
159
fields_data += all_fsm_fields_data (model )
173
160
if len (field_spec ) == 2 : # noqa: PLR2004
174
161
model = apps .get_model (field_spec [0 ], field_spec [1 ])
@@ -179,8 +166,7 @@ def handle(self, *args, **options):
179
166
else :
180
167
for model in apps .get_models ():
181
168
fields_data += all_fsm_fields_data (model )
182
-
183
- dotdata = generate_dot (fields_data , ignore_transitions = options ["exclude" ].split ("," ))
169
+ dotdata = generate_dot (fields_data )
184
170
185
171
if options ["outputfile" ]:
186
172
self .render_output (dotdata , ** options )
0 commit comments