defmodule Scopes.CSys.Environ do alias Scopes.CSys alias Scopes.Shape defmodule State do defstruct [neurons: [], init_seq: []] end def setup({state, proc}, seq \\ []) do scope = {%State{init_seq: seq}, &proc_env/2, [], self()} env = CSys.neuron(scope) CSys.create(Shape.create([:csys, :zero]), {state, proc, [], env}) env end def proc_env(msg, scope) do case Shape.head(msg) do [:csys, :created | _rest] -> process_creation(msg, scope) _ -> nil end send(CSys.env(scope), msg) end def process_creation(msg, {state, proc, syns, env}) do new = Shape.data(msg).new neurons = [new | state.neurons] {step, seq} = List.pop_at(state.init_seq, 0) if step, do: step.(neurons) CSys.update({%{state | neurons: neurons, init_seq: seq}, proc, syns, env}) end end