-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathnotes.txt
76 lines (50 loc) · 1.71 KB
/
notes.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
Two beautiful programs
For a long time one of my favorite Erlang program was this:
loop() ->
receive
F -> F(),
loop()
end.
It's nice because it does very little, but what is does is universal. It
enables mobile code.
Well now I can do this in Javascript.
The Javascript equivalent is:
function onMessage(evt) {
eval(evt.data);
}
Where the data comes from a websocket.
Websockets are controlled with a simple API:
websocket = new WebSocket(wsUri);
websocket.onopen = function(evt) { onOpen(evt) };
websocket.onclose = function(evt) { onClose(evt) };
websocket.onmessage = function(evt) { onMessage(evt) };
Linking a websocket and Erlang is pretty easy. So now I can write code like this in
erlang
-module(demo1).
-export([start/1]).
start(Pid) ->
Pid ! {eval, "document.body.innerHTML='';"},
Pid ! {eval, "document.body.style.backgroundColor='#eeffaa';"},
Pid ! {eval, "document.body.innerHTML+='<h1>Hello World</h1>'"},
event_loop(Pid).
event_loop(Pid) ->
receive
Any ->
io:format("??event loop:~p~n",[Any]),
event_loop(Pid)
end.
This code pushes asynchronous messages containing javascript to a generic
web page, and the web page evals the result.
This technique is amazingly powerful.
So now I only need one generic web page. Think of that.
Only one page is needed - forever.
All the genric pages does is:
loop:
wait for a message containing Javascript
eval the message
Beautiful
This is the easiest way to program a GUI I can conceive of.
You can download and run the examples from:
<a href="https://github.com/joearms/SEBG">https://github.com/joearms/SEBG</a>
You'll need something like Google chrome to run them.
Have fun