about summary refs log tree commit diff stats
Commit message (Expand)AuthorAgeFilesLines
* 1563Kartik K. Agaram2015-06-141-1/+1
* 1562Kartik K. Agaram2015-06-141-0/+5
* 1561Kartik K. Agaram2015-06-141-0/+7
* 1560Kartik K. Agaram2015-06-132-17/+20
* 1559Kartik K. Agaram2015-06-131-0/+2
* 1558Kartik K. Agaram2015-06-131-0/+10
* 1557Kartik K. Agaram2015-06-132-5/+13
* 1556Kartik K. Agaram2015-06-1265-642/+1203
* 1555 - mu.vim: distinguish control-flow from constantsKartik K. Agaram2015-06-122-7/+8
* 1554Kartik K. Agaram2015-06-111-1/+2
* 1553Kartik K. Agaram2015-06-113-0/+0
* 1552 - mouse supportKartik K. Agaram2015-06-112-0/+44
* 1551 - initial sketch of layoutKartik K. Agaram2015-06-111-1/+53
* 1550Kartik K. Agaram2015-06-101-0/+7
* 1549Kartik K. Agaram2015-06-0967-191/+794
* 1548Kartik K. Agaram2015-06-091-2/+2
* 1547Kartik K. Agaram2015-06-091-0/+1
* 1546 - show crucial code samples in colorKartik K. Agaram2015-06-081-23/+36
* 1545 - sketching out a simple editor widgetKartik K. Agaram2015-06-083-0/+131
* 1544 - arrow keys in trace browserKartik K. Agaram2015-06-071-4/+4
* 1543Kartik K. Agaram2015-06-072-3/+3
* 1542 - more hacky tweaks for the replKartik K. Agaram2015-06-061-1/+1
* 1540Kartik K. Agaram2015-06-061-3/+3
* 1539Kartik K. Agaram2015-06-061-0/+4
* 1538Kartik K. Agaram2015-06-061-7/+26
* 1537Kartik K. Agaram2015-06-061-1/+1
* 1536Kartik K. Agaram2015-06-061-2/+19
* 1535 - repl: less hacky printing of resultsKartik K. Agaram2015-06-062-5/+26
* 1534 - print results in a different colorKartik K. Agaram2015-06-062-3/+15
* 1533 - repl: long-standing bug with backspaceKartik K. Agaram2015-06-061-1/+18
* 1531 - enable termbox's mouse supportKartik K. Agaram2015-06-052-0/+12
* 1530 - switch to termbox's 256-color modeKartik K. Agaram2015-06-055-55/+24
* 1528 - assignment operator now colored redKartik K. Agaram2015-06-041-3/+51
* 1527Kartik K. Agaram2015-06-041-1/+120
* 1526Kartik K. Agaram2015-06-041-3/+3
* 1525Kartik K. Agaram2015-06-041-1/+1
* 1524Kartik K. Agaram2015-06-041-1/+0
* 1523Kartik K. Agaram2015-06-034-22/+17
* 1522Kartik K. Agaram2015-06-031-4/+12
* 1521Kartik K. Agaram2015-06-031-13/+0
* 1520 - repl kinda workingKartik K. Agaram2015-06-023-6/+33
* 1519 - repl now running commandsKartik K. Agaram2015-06-012-2/+11
* 1518 - still horribly brokenKartik K. Agaram2015-06-018-2/+115
* 1517Kartik K. Agaram2015-05-3066-360/+1330
* 1516Kartik K. Agaram2015-05-301-2/+2
* 1515 - complain on unbalanced bracketsKartik K. Agaram2015-05-301-0/+4
* 1514 - cleaner way to show backspaces in fake keyboardKartik K. Agaram2015-05-304-60/+76
* 1513 - final repl test was never failingKartik K. Agaram2015-05-301-4/+4
* 1512Kartik K. Agaram2015-05-291-1/+0
* 1511 - repl finally passing all its tests againKartik K. Agaram2015-05-281-2/+9
lass="w"> = window.location.hash; lineNum = lineNum.substr(1); /* strip off '#' */ if (lineNum.indexOf('L') == -1) { lineNum = 'L'+lineNum; } lineElem = document.getElementById(lineNum); /* Always jump to new location even if the line was hidden inside a fold, or * we corrected the raw number to a line ID. */ if (lineElem) { lineElem.scrollIntoView(true); } return true; } if ('onhashchange' in window) { window.onhashchange = JumpToLine; } --> </script> </head> <body onload='JumpToLine();'> <pre id='vimCodeElement'> <span id="L1" class="LineNr"> 1 </span><span class="Comment"># example program: a single-request HTTP server</span> <span id="L2" class="LineNr"> 2 </span><span class="Comment"># listen for connections from clients on a server socket</span> <span id="L3" class="LineNr"> 3 </span><span class="Comment"># when a connection occurs, transfer it to a session socket</span> <span id="L4" class="LineNr"> 4 </span><span class="Comment"># read from it using channels</span> <span id="L5" class="LineNr"> 5 </span><span class="Comment"># write to it directly</span> <span id="L6" class="LineNr"> 6 </span><span class="Comment">#</span> <span id="L7" class="LineNr"> 7 </span><span class="Comment"># After running it, navigate to localhost:8080. Your browser should display</span> <span id="L8" class="LineNr"> 8 </span><span class="Comment"># &quot;SUCCESS!&quot; and the server will terminate after one connection.</span> <span id="L9" class="LineNr"> 9 </span> <span id="L10" class="LineNr">10 </span><span class="muRecipe">def</span> <a href='http-server.mu.html#L10'>main</a> [ <span id="L11" class="LineNr">11 </span> <span class="Constant">local-scope</span> <span id="L12" class="LineNr">12 </span> socket:num <span class="Special">&lt;-</span> $open-server-socket <span class="Constant">8080/port</span> <span id="L13" class="LineNr">13 </span> $print <span class="Constant">[Mu socket creation returned ]</span>, socket, <span class="Constant">10/newline</span> <span id="L14" class="LineNr">14 </span> <span class="muControl">return-unless</span> socket <span id="L15" class="LineNr">15 </span> session:num <span class="Special">&lt;-</span> $accept socket <span id="L16" class="LineNr">16 </span> contents:&amp;:<a href='075channel.mu.html#L43'>source</a>:char, <a href='075channel.mu.html#L47'>sink</a>:&amp;:<a href='075channel.mu.html#L47'>sink</a>:char <span class="Special">&lt;-</span> <a href='075channel.mu.html#L51'>new-channel</a><span class="Constant"> 30</span> <span id="L17" class="LineNr">17 </span> <a href='075channel.mu.html#L47'>sink</a> <span class="Special">&lt;-</span> <span class="muControl">start-running</span> <a href='092socket.mu.html#L104'>receive-from-socket</a> session, <a href='075channel.mu.html#L47'>sink</a> <span id="L18" class="LineNr">18 </span> query:text <span class="Special">&lt;-</span> <a href='075channel.mu.html#L507'>drain</a> contents <span id="L19" class="LineNr">19 </span> $print <span class="Constant">[Done reading from socket.]</span>, <span class="Constant">10/newline</span> <span id="L20" class="LineNr">20 </span> <a href='092socket.mu.html#L132'>write-to-socket</a> session, <span class="Constant">[HTTP/1.0 200 OK</span> <span id="L21" class="LineNr">21 </span><span class="Constant">Content-type: text/plain</span> <span id="L22" class="LineNr">22 </span> <span id="L23" class="LineNr">23 </span><span class="Constant">SUCCESS!</span> <span id="L24" class="LineNr">24 </span><span class="Constant">]</span> <span id="L25" class="LineNr">25 </span> $print <span class="Constant">10/newline</span>, <span class="Constant">[Wrote to and closing socket...]</span>, <span class="Constant">10/newline</span> <span id="L26" class="LineNr">26 </span> session <span class="Special">&lt;-</span> $close-socket session <span id="L27" class="LineNr">27 </span> socket <span class="Special">&lt;-</span> $close-socket socket <span id="L28" class="LineNr">28 </span>] </pre> </body> </html> <!-- vim: set foldmethod=manual : -->