about summary refs log tree commit diff stats
path: root/066stream.mu
Commit message (Collapse)AuthorAgeFilesLines
* 4262 - literal 'null'Kartik Agaram2018-06-171-1/+1
|
* 4261 - start using literals for 'true' and 'false'Kartik Agaram2018-06-171-4/+4
| | | | | | | | | They uncovered one bug: in edit/003-shortcuts.mu <scroll-down> was returning 0 for an address in one place where I thought it was returning 0 for a boolean. Now we've eliminated this bad interaction between tangling and punning literals.
* 4134 - 'input' = 'ingredient'Kartik K. Agaram2017-12-031-6/+6
|
* 3817 - better errors on streams from null textsKartik K. Agaram2017-04-131-0/+6
| | | | Thanks Ella Couch for reporting this issue.
* 3390Kartik K. Agaram2016-09-171-5/+5
|
* 3389Kartik K. Agaram2016-09-171-12/+12
|
* 3386Kartik K. Agaram2016-09-171-6/+6
|
* 3385Kartik K. Agaram2016-09-171-9/+9
|
* 3379Kartik K. Agaram2016-09-171-1/+1
| | | | Can't use type abbreviations inside 'memory-should-contain'.
* 3341Kartik K. Agaram2016-09-121-1/+1
| | | | | | | Process type abbreviations in function headers. Still a couple of places where doing this causes strange errors. We'll track those down next.
* 3337 - first use of type abbreviations: textKartik K. Agaram2016-09-121-2/+2
| | | | | In the process I've uncover a couple of situations we don't support type abbreviations yet. They're next.
* 3156Kartik K. Agaram2016-07-271-14/+24
| | | | Make 'stream' generic.
* 3155Kartik K. Agaram2016-07-271-2/+2
|
* 3154 - reorg before making 'random' more testableKartik K. Agaram2016-07-271-0/+64
|
* 2430 - make room for more transformsKartik K. Agaram2015-11-131-44/+0
|
* 2225Kartik K. Agaram2015-10-011-1/+1
|
* 1883 - type-deducing in more .mu filesKartik K. Agaram2015-07-291-19/+19
|
* 1869 - rename the /deref property to /lookupKartik K. Agaram2015-07-281-14/+14
| | | | Should be a little bit more mnemonic.
* 1868 - start using naked literals everywhereKartik K. Agaram2015-07-281-4/+4
| | | | First step to reducing typing burden. Next step: inferring types.
* 1780 - now we always reclaim local scopesKartik K. Agaram2015-07-131-4/+4
| | | | | | But still no difference in either memory footprint or in running time. This will teach me -- for the umpteenth time -- to optimize before measuring.
* 1773 - update all mu recipes to new-default-spaceKartik K. Agaram2015-07-131-4/+4
| | | | | Turns out to not affect memory utilization or run-time. At all. But still looks nicer and requires less fudging on our part.
* 1597 - port more helpers from arc versionKartik K. Agaram2015-06-191-0/+44
id='n50' href='#n50'>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
76
77
78



                                                                                          
                                 
                                         

                                                
                                                                                                               
                                                 

                       

                                                                                                 
                    
                                     
                             



                             





                               






















                                                                                 


         
                             
                                                                                                                               
                         




                                                                                                                                             
                                                                                                                   







                                                                                                                                                       
                                                                                                                                                                                     


                                                                                            



                                     
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<title>Mu - real-files.mu</title>
<meta name="Generator" content="Vim/8.0">
<meta name="plugin-version" content="vim7.4_v2">
<meta name="syntax" content="none">
<meta name="settings" content="number_lines,use_css,pre_wrap,no_foldcolumn,expand_tabs,line_ids,prevent_copy=">
<meta name="colorscheme" content="minimal-light">
<style type="text/css">
<!--
pre { white-space: pre-wrap; font-family: monospace; color: #000000; background-color: #c6c6c6; }
body { font-size:12pt; font-family: monospace; color: #000000; background-color: #c6c6c6; }
a { color:inherit; }
* { font-size:12pt; font-size: 1em; }
.muRecipe { color: #ff8700; }
.LineNr { }
.Constant { color: #008787; }
.Special { color: #ff6060; }
.Comment { color: #005faf; }
-->
</style>

<script type='text/javascript'>
<!--

/* function to open any folds containing a jumped-to line before jumping to it */
function JumpToLine()
{
  var lineNum;
  lineNum = 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();'>
<a href='https://github.com/akkartik/mu/blob/master/real-files.mu'>https://github.com/akkartik/mu/blob/master/real-files.mu</a>
<pre id='vimCodeElement'>
<span id="L1" class="LineNr"> 1 </span><span class="Comment"># example program: read a character from one file and write it to another</span>
<span id="L2" class="LineNr"> 2 </span><span class="Comment"># BEWARE: this will modify your file system</span>
<span id="L3" class="LineNr"> 3 </span><span class="Comment"># before running it, put a character into /tmp/mu-x</span>
<span id="L4" class="LineNr"> 4 </span><span class="Comment"># after running it, check /tmp/mu-y</span>
<span id="L5" class="LineNr"> 5 </span>
<span id="L6" class="LineNr"> 6 </span><span class="muRecipe">def</span> <a href='real-files.mu.html#L6'>main</a> [
<span id="L7" class="LineNr"> 7 </span>  <span class="Constant">local-scope</span>
<span id="L8" class="LineNr"> 8 </span>  f:num/file <span class="Special">&lt;-</span> $open-file-for-reading <span class="Constant">[/tmp/mu-x]</span>
<span id="L9" class="LineNr"> 9 </span>  $print <span class="Constant">[file to read from: ]</span>, f, <span class="Constant">10/newline</span>
<span id="L10" class="LineNr">10 </span>  c:char, eof?:bool <span class="Special">&lt;-</span> $read-from-file f
<span id="L11" class="LineNr">11 </span>  $print <span class="Constant">[copying ]</span>, c, <span class="Constant">10/newline</span>
<span id="L12" class="LineNr">12 </span>  f <span class="Special">&lt;-</span> $close-file f
<span id="L13" class="LineNr">13 </span>  $print <span class="Constant">[file after closing: ]</span>, f, <span class="Constant">10/newline</span>
<span id="L14" class="LineNr">14 </span>  f <span class="Special">&lt;-</span> $open-file-for-writing <span class="Constant">[/tmp/mu-y]</span>
<span id="L15" class="LineNr">15 </span>  $print <span class="Constant">[file to <a href='075channel.mu.html#L60'>write</a> to: ]</span>, f, <span class="Constant">10/newline</span>
<span id="L16" class="LineNr">16 </span>  $write-to-file f, c
<span id="L17" class="LineNr">17 </span>  f <span class="Special">&lt;-</span> $close-file f
<span id="L18" class="LineNr">18 </span>]
</pre>
</body>
</html>
<!-- vim: set foldmethod=manual : -->