Skip to content

Commit

Permalink
add event support for mtkmodel components rebase
Browse files Browse the repository at this point in the history
  • Loading branch information
cgutsche committed Mar 10, 2024
1 parent 1b858f6 commit e40cd68
Showing 1 changed file with 32 additions and 2 deletions.
34 changes: 32 additions & 2 deletions src/systems/model_parsing.jl
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,8 @@ function _model_macro(mod, name, expr, isconnector)
eqs = Expr[]
icon = Ref{Union{String, URI}}()
ps, sps, vs, = [], [], []
c_evts = []
d_evts = []
kwargs = Set()
where_types = Expr[]

Expand All @@ -61,7 +63,7 @@ function _model_macro(mod, name, expr, isconnector)
for arg in expr.args
if arg.head == :macrocall
parse_model!(exprs.args, comps, ext, eqs, icon, vs, ps,
sps, dict, mod, arg, kwargs, where_types)
sps, c_evts, d_evts, dict, mod, arg, kwargs, where_types)
elseif arg.head == :block
push!(exprs.args, arg)
elseif arg.head == :if
Expand Down Expand Up @@ -116,6 +118,12 @@ function _model_macro(mod, name, expr, isconnector)
isconnector && push!(exprs.args,
:($Setfield.@set!(var"#___sys___".connector_type=$connector_type(var"#___sys___"))))

!(c_evts==[]) && push!(exprs.args,
:($Setfield.@set!(var"#___sys___".continuous_events=$SymbolicContinuousCallback.([$(c_evts...)]))))

!(d_evts==[]) && push!(exprs.args,
:($Setfield.@set!(var"#___sys___".discrete_events=$SymbolicDiscreteCallback.([$(d_evts...)]))))

f = if length(where_types) == 0
:($(Symbol(:__, name, :__))(; name, $(kwargs...)) = $exprs)
else
Expand All @@ -124,6 +132,7 @@ function _model_macro(mod, name, expr, isconnector)
:($(Symbol(:__, name, :__))(; name, $(kwargs...))), where_types...)
:($f_with_where = $exprs)
end

:($name = $Model($f, $dict, $isconnector))
end

Expand Down Expand Up @@ -341,7 +350,7 @@ function get_var(mod::Module, b)
end
end

function parse_model!(exprs, comps, ext, eqs, icon, vs, ps, sps,
function parse_model!(exprs, comps, ext, eqs, icon, vs, ps, sps, c_evts, d_evts,
dict, mod, arg, kwargs, where_types)
mname = arg.args[1]
body = arg.args[end]
Expand All @@ -359,6 +368,10 @@ function parse_model!(exprs, comps, ext, eqs, icon, vs, ps, sps,
parse_equations!(exprs, eqs, dict, body)
elseif mname == Symbol("@constants")
parse_constants!(exprs, dict, body, mod)
elseif mname == Symbol("@continuous_events")
parse_continuous_events!(c_evts, dict, body)
elseif mname == Symbol("@discrete_events")
parse_discrete_events!(d_evts, dict, body)
elseif mname == Symbol("@icon")
isassigned(icon) && error("This model has more than one icon.")
parse_icon!(body, dict, icon, mod)
Expand Down Expand Up @@ -753,6 +766,23 @@ function parse_equations!(exprs, eqs, dict, body)
end
end

function parse_continuous_events!(c_evts, dict, body)
dict[:continuous_events] = []
Base.remove_linenums!(body)
for arg in body.args
push!(c_evts, arg)
push!(dict[:continuous_events], readable_code.(c_evts)...)
end
end

function parse_discrete_events!(d_evts, dict, body)
dict[:discrete_events] = []
Base.remove_linenums!(body)
for arg in body.args
push!(dict[:discrete_events], readable_code.(d_evts)...)
end
end

function parse_icon!(body::String, dict, icon, mod)
icon_dir = get(ENV, "MTK_ICONS_DIR", joinpath(DEPOT_PATH[1], "mtk_icons"))
dict[:icon] = icon[] = if isfile(body)
Expand Down

0 comments on commit e40cd68

Please sign in to comment.