-
Notifications
You must be signed in to change notification settings - Fork 26
/
Copy pathrfsm_marsh.lua
75 lines (66 loc) · 1.97 KB
/
rfsm_marsh.lua
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
-- rfsm marshalling functions
--
-- (C) 2010-2013 Markus Klotzbuecher <[email protected]>
-- (C) 2014-2020 Markus Klotzbuecher <[email protected]>
--
-- SPDX-License-Identifier: BSD-3-Clause
--
local rfsm = require("rfsm")
local utils = require("utils")
local pcall = pcall
local tostring = tostring
local print = print -- debugging only
local M = {}
-- shortcuts
local mapfsm = rfsm.mapfsm
local get_sta_mode = rfsm.get_sta_mode
local is_composite = rfsm.is_composite
local is_leaf = rfsm.is_leaf
local is_conn = rfsm.is_conn
local is_node = rfsm.is_node
local is_trans = rfsm.is_trans
--- Convert an initalized fsm to a table
function M.model2tab(fsm)
--- convert a transition to a table
-- @param t rfsm.transition
local function trans2tab(t)
--- safely convert an event to a string
-- @param e arbitrary event type that supports __tostring
local function ev2str(e)
local res, evstr = pcall(tostring, e)
if res then return evstr
else return "?" end
end
return { type='transition', src=t.src._fqn, tgt=t.tgt._fqn,
pn=t.pn, events=utils.imap(ev2str, t.events) }
end
--- convert (sub-) fsm s to a table
local function __rfsm2tab(s)
if is_leaf(s) then
return { id=s._id, type='state' }
elseif is_conn(s) then
return { id=s._id, type='connector' }
elseif is_composite(s) then
local tab = { id=s._id, type='state' }
tab.transitions = mapfsm(trans2tab, s, is_trans, 1)
tab.subnodes = mapfsm(__rfsm2tab, s, rfsm.is_nr_node, 1)
return tab
end
end
if not fsm._initialized then
error("rfsm2tab: initialized fsm required")
return false
end
return __rfsm2tab(fsm)
end
--- Return the active state of an rFSM.
-- @return active leaf state fqn
-- @return state of that fqn
-- @return transition path taken to last state
function M.actinfo2tab(fsm)
if fsm._act_leaf then
return fsm._act_leaf._fqn, get_sta_mode(fsm._act_leaf), false
end
return false, false, false
end
return M