Mercurial > urweb
diff lib/js/urweb.js @ 976:68eda5b0636d
demo/react works with interpretation
author | Adam Chlipala <adamc@hcoop.net> |
---|---|
date | Tue, 22 Sep 2009 17:12:20 -0400 |
parents | 8fe576c0bee9 |
children | 2ecf308772ba |
line wrap: on
line diff
--- a/lib/js/urweb.js Tue Sep 22 15:12:09 2009 -0400 +++ b/lib/js/urweb.js Tue Sep 22 17:12:20 2009 -0400 @@ -82,7 +82,7 @@ alert(kind + ": " + arg); for (; ls; ls = ls.next) try { - ls.data(arg)(null); + exec({c:"a", f:{c:"a", f:ls.data, x:{c:"c", v:arg}}, x:{c:"c", v:null}}); } catch (v) { } } @@ -114,8 +114,12 @@ var disconnectHandlers = null; +function flift(f) { + return {c:"l", b:f}; +} + function onDisconnect(f) { - disconnectHandlers = cons(function (_){return f}, disconnectHandlers); + disconnectHandlers = cons(flift(f), disconnectHandlers); } function discon() { @@ -125,7 +129,7 @@ var connectHandlers = null; function onConnectFail(f) { - connectHandlers = cons(function (_){return f}, connectHandlers); + connectHandlers = cons(flift(f), connectHandlers); } function conn() { @@ -207,12 +211,14 @@ // Dynamic tree management +var trace = ""; + function populate(node) { var s = node.signal; var oldSources = node.sources; try { - var sr = s(); - var newSources = sr.sources; + var sr = exec0(s.env, s.body); + var newSources = sr._sources; for (var sp = oldSources; sp; sp = sp.next) if (!member(sp.data, newSources)) @@ -223,7 +229,7 @@ sp.data.dyns = cons(node, sp.data.dyns); node.sources = newSources; - node.recreate(sr.data); + node.recreate(sr._data); } catch (v) { doExn(v); } @@ -244,20 +250,28 @@ } function ss(s) { - return function() { return {sources : cons(s, null), data : s.data } }; + return {env:cons(s, null), body:{c:"r", l: + cons({n:"sources", v:{c:"c", v:cons(s, null)}}, + cons({n:"data", v:{c:"f", f:sg, a:cons({c:"v", n:1}, null)}}, null))}}; } function sr(v) { - return function() { return {sources : null, data : v } }; + return {env:null, body:{c:"c", v:{_sources : null, _data : v}}}; } function sb(x,y) { - return function() { - var xr = x(); - var yr = y(xr.data)(); - return {sources : union(xr.sources, yr.sources), data : yr.data}; - }; + return {env:cons(y,cons(x,null)), + body:{c:"=", + e1:{c:"a", f:{c:"v", n:1}, x:{c:"c", v:null}}, + e2:{c:"=", + e1:{c:"a", + f:{c:"a", f:{c:"v", n:1}, x:{c:".", r:{c:"v", n:0}, f:"data"}}, + x:{c:"c", v:null}}, + e2:{c:"r", l:cons( + {n:"sources", v:{c:"f", f:union, a:cons({c:".", r:{c:"v", n:1}, f:"sources"}, + cons({c:".", r:{c:"v", n:0}, f:"sources"}, null))}}, + cons({n:"data", v:{c:".", r:{c:"v", n:0}, f:"data"}}, null))}}}}; } function scur(s) { - return s().data; + return exec(s).data; } function lastParent() { @@ -840,6 +854,9 @@ var stack = null; while (true) { + if (!e.c) + throw ("Trace: " + trace); + trace += "|" + e.c; switch (e.c) { case "c": var v = e.v; @@ -863,7 +880,6 @@ stack = stack.next; } else { e = fr.a.data; - if (e == null) alert("Oh no!"); fr.a = fr.a.next; } break; @@ -907,9 +923,9 @@ stack = stack.next; break; case "=": + stack = cons({c: "a3", env: env}, stack.next); env = cons(v, env); e = fr.e2; - stack = cons({c: "a3", env: env}, stack.next); break; case "m": var ps; @@ -996,6 +1012,10 @@ } } +function execD(e) { + return exec0(null, e); +} + function exec(e) { var r = exec0(null, e);