# HG changeset patch # User Adam Chlipala # Date 1253653940 14400 # Node ID 68eda5b0636d90b5f788e12fb9f7dc4b32c3e904 # Parent 8fe576c0bee97e201d3807e43d0328a865b1b146 demo/react works with interpretation diff -r 8fe576c0bee9 -r 68eda5b0636d lib/js/urweb.js --- 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); diff -r 8fe576c0bee9 -r 68eda5b0636d src/jscomp.sml --- a/src/jscomp.sml Tue Sep 22 15:12:09 2009 -0400 +++ b/src/jscomp.sml Tue Sep 22 17:12:20 2009 -0400 @@ -882,11 +882,11 @@ val (e1, st) = jsE inner (e1, st) val (e2, st) = jsE inner (e2, st) in - (strcat [str "{c:\"b\",e1:", + (strcat [str "{c:\"f\",f:sb,a:cons(", e1, - str ",e2:", + str ",cons(", e2, - str "}"], + str ",null))}"], st) end | ESignalSource e => diff -r 8fe576c0bee9 -r 68eda5b0636d src/monoize.sml --- a/src/monoize.sml Tue Sep 22 15:12:09 2009 -0400 +++ b/src/monoize.sml Tue Sep 22 17:12:20 2009 -0400 @@ -2682,7 +2682,7 @@ [("Signal", e, _)] => ((L'.EStrcat ((L'.EPrim (Prim.String ("")), loc)), loc)), loc), fm)