about summary refs log tree commit diff stats
path: root/translate_mu_debug
Commit message (Expand)AuthorAgeFilesLines
* 6400Kartik Agaram2020-05-241-0/+8
/commit/066stream.mu?h=hlt&id=7a84094adbf7570e0b9716d8f469458b901efec8'>7a84094a ^
a0331a9b ^
8fb0e672 ^

a0331a9b ^
77d5b5d6 ^
4a48bedc ^
01ce563d ^
4f3510d0 ^
748b6865 ^

8fb0e672 ^

760f683f ^
77d5b5d6 ^
4a48bedc ^
85b2f61b ^
748b6865 ^
8fb0e672 ^

760f683f ^
9acf5c0f ^
4a48bedc ^
85b2f61b ^
dd660682 ^
7a84094a ^
a0331a9b ^
7a84094a ^
51b0936f ^
4f3510d0 ^

760f683f ^
dd660682 ^
4f3510d0 ^
9acf5c0f ^




760f683f ^
050a93ac ^
4a48bedc ^
85b2f61b ^
dd660682 ^
7a84094a ^
a0331a9b ^
7a84094a ^
51b0936f ^
4f3510d0 ^

760f683f ^
dd660682 ^
4f3510d0 ^
050a93ac ^


760f683f ^
77d5b5d6 ^
4a48bedc ^
85b2f61b ^
7a84094a ^
ea19d0dc ^
7a84094a ^
748b6865 ^



8fb0e672 ^

760f683f ^
77d5b5d6 ^
4a48bedc ^
85b2f61b ^
7a84094a ^
a0331a9b ^
7a84094a ^
104854ca ^
8fb0e672 ^
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
76
77
78
79
80

                                            
           
                

 
                                                     
             
             
                       
                                      

                                         

 
                                                   
             
             
                  
                                 

 
                                                                            
             
             
                                              
                      
                                  
                                     
                      
                                          

                        
                                          
                              
   




                                   
                                                         
             
             
                                              
                           
                                  
                                     
                      
                                          

                        
                                          
                              
   


                         
                                                                 
             
             
                                                   
                                  
                                
                                              



                                        

 
                                                     
             
             
                                                              
                                  
                                     
                      
                                     
 
# new type to help incrementally scan arrays
container stream:_elem [
  index:num
  data:&:@:_elem
]

def new-stream s:&:@:_elem -> result:&:stream:_elem [
  local-scope
  load-inputs
  return-unless s, null
  result <- new {(stream _elem): type}
  *result <- put *result, index:offset, 0
  *result <- put *result, data:offset, s
]

def rewind in:&:stream:_elem -> in:&:stream:_elem [
  local-scope
  load-inputs
  return-unless in
  *in <- put *in, index:offset, 0
]

def read in:&:stream:_elem -> result:_elem, empty?:bool, in:&:stream:_elem [
  local-scope
  load-inputs
  assert in, [cannot read; stream has no data]
  empty? <- copy false
  idx:num <- get *in, index:offset
  s:&:@:_elem <- get *in, data:offset
  len:num <- length *s
  at-end?:bool <- greater-or-equal idx len
  {
    break-unless at-end?
    empty-result:&:_elem <- new _elem:type
    return *empty-result, true
  }
  result <- index *s, idx
  idx <- add idx, 1
  *in <- put *in, index:offset, idx
]

def peek in:&:stream:_elem -> result:_elem, empty?:bool [
  local-scope
  load-inputs
  assert in, [cannot peek; stream has no data]
  empty?:bool <- copy false
  idx:num <- get *in, index:offset
  s:&:@:_elem <- get *in, data:offset
  len:num <- length *s
  at-end?:bool <- greater-or-equal idx len
  {
    break-unless at-end?
    empty-result:&:_elem <- new _elem:type
    return *empty-result, true
  }
  result <- index *s, idx
]

def read-line in:&:stream:char -> result:text, in:&:stream:char [
  local-scope
  load-inputs
  assert in, [cannot read-line; stream has no data]
  idx:num <- get *in, index:offset
  s:text <- get *in, data:offset
  next-idx:num <- find-next s, 10/newline, idx
  result <- copy-range s, idx, next-idx
  idx <- add next-idx, 1  # skip newline
  # write back
  *in <- put *in, index:offset, idx
]

def end-of-stream? in:&:stream:_elem -> result:bool [
  local-scope
  load-inputs
  assert in, [cannot check end-of-stream?; stream has no data]
  idx:num <- get *in, index:offset
  s:&:@:_elem <- get *in, data:offset
  len:num <- length *s
  result <- greater-or-equal idx, len
]