start cell registry in Environ.setup(), start env via application

This commit is contained in:
Helmut Merz 2026-06-17 23:15:34 +02:00
parent c15897aa93
commit 8efa448999
5 changed files with 38 additions and 29 deletions

View file

@ -1,6 +1,8 @@
defmodule Scopes.CSys.Application do defmodule Scopes.CSys.Application do
use Application use Application
alias Scopes.Core.Environ
alias Scopes.Core.Program
alias Scopes.Util alias Scopes.Util
require Logger require Logger
@ -10,9 +12,9 @@ defmodule Scopes.CSys.Application do
@impl true @impl true
def start(type, args) do def start(type, args) do
IO.puts("Hello CSys") IO.puts("Hello CSys")
Logger.info(Util.show [type, args]) Logger.info(Util.show [type, args, self()])
children = [ children = [
{Scopes.Core.Environ, init: []}, {Environ, [Program.prepare_basic(), Program.init_recursive_1()]},
Scopes.CSys.Server.Endpoint Scopes.CSys.Server.Endpoint
] ]
opts = [strategy: :one_for_one, name: Scopes.CSys.Supervisor] opts = [strategy: :one_for_one, name: Scopes.CSys.Supervisor]

View file

@ -3,7 +3,7 @@
import Config import Config
config :logger, :default_handler, config :logger, :default_handler,
level: System.get_env("SCOPES_LOG_LEVEL", "info") |> String.to_atom, level: System.get_env("SCOPES_LOG_LEVEL", "notice") |> String.to_atom,
config: [ config: [
file: ~c"test/log/scopes_test.log" file: ~c"test/log/scopes_test.log"
] ]

View file

@ -27,6 +27,7 @@ defmodule Scopes.Core do
end end
def notify(msg, scope) do def notify(msg, scope) do
Logger.info(Util.show [msg])
Actor.send(env(scope), msg) Actor.send(env(scope), msg)
end end

View file

@ -5,34 +5,29 @@ defmodule Scopes.Core.Environ do
alias Scopes.Core.Actor alias Scopes.Core.Actor
alias Scopes.Core.Shape alias Scopes.Core.Shape
require Logger
defmodule State do defmodule State do
defstruct [cells: %{}, init_seq: []] defstruct [cells: %{}, init_seq: []]
end end
def child_spec(opts) do
%{id: __MODULE__,
start: {__MODULE__, :start_link, opts}}
end
def start_link(opts \\ []) do
#IO.inspect(opts)
Registry.start_link(keys: :unique, name: @cell_registry)
zero_spec = opts[:zero_spec]
if zero_spec do
setup(zero_spec, opts[:init_seq] || [])
end
end
def cells(), do: @cell_registry def cells(), do: @cell_registry
def child_spec(opts) do
%{id: __MODULE__,
start: {__MODULE__, :setup, opts}}
end
def setup({state, proc}, init_seq, proc_env \\ &proc_env/2) do def setup({state, proc}, init_seq, proc_env \\ &proc_env/2) do
Registry.start_link(keys: :unique, name: cells())
env_scope = {%State{init_seq: init_seq}, proc_env, [], self()} env_scope = {%State{init_seq: init_seq}, proc_env, [], self()}
env = Core.neuron(env_scope) env = Core.neuron(env_scope)
Actor.register(env, cells(), {:env, :c00}) Actor.register(env, cells(), {:env, :c00})
msg = Shape.create([:csys, :zero], data: %{addr: [:csys, :c00, "0-0"]}) msg = Shape.create([:csys, :zero], data: %{addr: [:csys, :c00, "0-0"]})
scope = {state, proc, [], env} scope = {state, proc, [], env}
Core.create(msg, scope) Core.create(msg, scope)
env #{:ok, env}
:ignore
end end
def proc_env(msg, scope = {state, _proc, _syns, env}) do def proc_env(msg, scope = {state, _proc, _syns, env}) do
@ -59,10 +54,24 @@ defmodule Scopes.Core.Environ do
state1 = %State{cells: cells, init_seq: seq} state1 = %State{cells: cells, init_seq: seq}
Core.update({state1, proc, syns, env}) Core.update({state1, proc, syns, env})
if step do if step do
Process.sleep(1)
step.(state1) step.(state1)
end end
end end
# accessing cell registry
def get_cell(addr) do
data = Registry.lookup(cells(), addr)
if data do
[{cell, _val}] = data
cell
else
Logger.warning "No cell found at address #{inspect(addr)}!"
nil
end
end
# accessing cell registry via state.cells # accessing cell registry via state.cells
def get_cell(state, [dom, cat, item]) do def get_cell(state, [dom, cat, item]) do

View file

@ -17,12 +17,9 @@ defmodule Scopes.CoreTest do
describe "core-basic:" do describe "core-basic:" do
test "minimal-b1" do test "minimal-b1" do
Environ.start_link( Environ.setup(Program.prepare_basic(), Program.init_seq_b1())
zero_spec: Program.prepare_basic(), Process.sleep(10)
init_seq: Program.init_seq_b1()) env = Environ.get_cell({:env, :c00})
#env = Environ.setup(Program.prepare_basic(), Program.init_seq_b1())
Process.sleep(50)
[{env, _val}] = Registry.lookup(Environ.cells(), {:env, :c00})
Environ.forward_value(env, [:csys, :c00, "0-0"], 0) Environ.forward_value(env, [:csys, :c00, "0-0"], 0)
assert 0 = receive_data().value assert 0 = receive_data().value
Environ.forward_value(env, [:csys, :s01, "1-0"], 1) Environ.forward_value(env, [:csys, :s01, "1-0"], 1)
@ -31,18 +28,18 @@ defmodule Scopes.CoreTest do
Environ.forward_value(env, [:csys, :s01, "1-1"], 3) Environ.forward_value(env, [:csys, :s01, "1-1"], 3)
assert receive_data().value in [2, 3] assert receive_data().value in [2, 3]
assert receive_data().value in [2, 3] assert receive_data().value in [2, 3]
refute_receive msg, 30, "unhandled message(s): #{inspect(msg)}" refute_receive msg, 10, "unhandled message(s): #{inspect(msg)}"
end end
test "recursive-1" do test "recursive-1" do
Environ.start_link() Environ.setup(Program.prepare_basic(), Program.init_recursive_1())
env = Environ.setup(Program.prepare_basic(), Program.init_recursive_1()) Process.sleep(10)
Process.sleep(50) env = Environ.get_cell({:env, :c00})
Environ.forward_value(env, [:csys, :s01, "1-1"], 42) Environ.forward_value(env, [:csys, :s01, "1-1"], 42)
assert receive_data().value == 42 assert receive_data().value == 42
Environ.forward_value(env, [:csys, :s01, "1-1"], 47) Environ.forward_value(env, [:csys, :s01, "1-1"], 47)
assert receive_data().value == 5 assert receive_data().value == 5
refute_receive msg, 30, "unhandled message(s): #{inspect(msg)}" refute_receive msg, 10, "unhandled message(s): #{inspect(msg)}"
end end
end end
end end