ash_state_machine/lib/transformers/fill_in_event_defaults.ex

61 lines
1.4 KiB
Elixir
Raw Normal View History

2023-04-22 05:43:36 +12:00
defmodule AshFsm.Transformers.FillInEventDefaults do
use Spark.Dsl.Transformer
alias Spark.Dsl.Transformer
@moduledoc false
def transform(dsl_state) do
2023-04-22 07:25:39 +12:00
initial_states =
case AshFsm.Info.fsm_initial_states(dsl_state) do
{:ok, value} -> List.wrap(value)
_ -> []
end
initial_states =
case initial_states do
[] ->
case AshFsm.Info.fsm_default_initial_state(dsl_state) do
{:ok, value} when not is_nil(value) ->
[value]
_ ->
initial_states
end
_ ->
initial_states
end
2023-04-22 05:43:36 +12:00
events =
dsl_state
|> AshFsm.Info.fsm_events()
all_states =
events
|> Enum.flat_map(fn event ->
List.wrap(event.from) ++ List.wrap(event.to)
end)
|> Enum.concat(List.wrap(initial_states))
2023-04-22 07:25:39 +12:00
|> Enum.uniq()
2023-04-22 05:43:36 +12:00
dsl_state =
case AshFsm.Info.fsm_initial_states(dsl_state) do
{:ok, value} when not is_nil(value) and value != [] ->
dsl_state
_ ->
Transformer.set_option(dsl_state, [:fsm], :initial_states, all_states)
end
2023-04-22 07:25:39 +12:00
{:ok,
events
|> Enum.reduce(dsl_state, fn event, dsl_state ->
Transformer.replace_entity(dsl_state, [:fsm], %{
event
| from: event.from || all_states,
to: event.to || all_states
})
end)
|> Transformer.persist(:all_fsm_states, all_states)}
2023-04-22 05:43:36 +12:00
end
end