about summary refs log tree commit diff stats
path: root/arc
diff options
context:
space:
mode:
Diffstat (limited to 'arc')
0 files changed, 0 insertions, 0 deletions
lt'>
08f4628e ^
7a84094a ^
9f484946 ^
6fef33fd ^
45c08fea ^


9f484946 ^
7a84094a ^


45c08fea ^

6fef33fd ^
7a84094a ^

6fef33fd ^

45c08fea ^
7a84094a ^
a0331a9b ^
e3092e7b ^

a0331a9b ^
77d5b5d6 ^
104854ca ^
760f683f ^
0d2686c7 ^
e3092e7b ^

760f683f ^
77d5b5d6 ^
104854ca ^
e3092e7b ^
104854ca ^
7a84094a ^
a0331a9b ^
e3092e7b ^
7a84094a ^
80df524b ^
502d2ea5 ^
760f683f ^
1ead3562 ^
e3092e7b ^
0d2686c7 ^


1ead3562 ^
e3092e7b ^
6aa42628 ^
80df524b ^
1ead3562 ^
e3092e7b ^

c6c19a27 ^


760f683f ^
77d5b5d6 ^
104854ca ^
80df524b ^
1ead3562 ^

80df524b ^
7bf9212f ^

e3092e7b ^
f8c0ef3e ^
760f683f ^
77d5b5d6 ^
104854ca ^
f8c0ef3e ^
80df524b ^
502d2ea5 ^


136412d2 ^
502d2ea5 ^
f8c0ef3e ^

5b1219ca ^
f8c0ef3e ^
6a0f71b9 ^
760f683f ^
77d5b5d6 ^
104854ca ^
6a0f71b9 ^
80df524b ^
502d2ea5 ^
6a0f71b9 ^

5e9eff8c ^

760f683f ^
77d5b5d6 ^
104854ca ^
5e9eff8c ^
502d2ea5 ^
5e9eff8c ^
1ead3562 ^
5e9eff8c ^
104854ca ^
5e9eff8c ^
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107

                                                                            
 
                           
           
                                                                  
                                              
                     


                                                              
                       


            

 
                        

            

 
                   
                         
                  

 
                                                           
             
                  
                                      
                                               

 
                                                                                              
             
                  
   
                        
                                                                       
                                                
     
                            
                                                             
                        
                                     
                                                                  
     


                                                                             
                                                                
   
                                                                      
                                                    
                                                             

 


                                                                            
                                                                                           
             
                  
                                                                 

                                                                      
                                                          

                                                                            
 
 
                                                                                                                                       
             
                  
   
                                                                


                                            
                             
                         

        
                    
 
 
                                                           
             
                  
   
                                                 
                      

   

                                                                             
                                                       
             
                  
   
                        
                                                     
                  
   
                              
 
# Wrappers around interaction primitives that take a potentially fake object
# and are thus easier to test.

exclusive-container event [
  text:char
  keycode:num  # keys on keyboard without a unicode representation
  touch:touch-event  # mouse, track ball, etc.
  resize:resize-event
  # update the assume-console handler if you add more variants
]

container touch-event [
  type:num
  row:num
  column:num
]

container resize-event [
  width:num
  height:num
]

container console [
  current-event-index:num
  events:&:@:event
]

def new-fake-console events:&:@:event -> result:&:console [
  local-scope
  load-ingredients
  result:&:console <- new console:type
  *result <- put *result, events:offset, events
]

def read-event console:&:console -> result:event, console:&:console, found?:bool, quit?:bool [
  local-scope
  load-ingredients
  {
    break-unless console
    current-event-index:num <- get *console, current-event-index:offset
    buf:&:@:event <- get *console, events:offset
    {
      max:num <- length *buf
      done?:bool <- greater-or-equal current-event-index, max
      break-unless done?
      dummy:&:event <- new event:type
      return *dummy, console/same-as-ingredient:0, 1/found, 1/quit
    }
    result <- index *buf, current-event-index
    current-event-index <- add current-event-index, 1
    *console <- put *console, current-event-index:offset, current-event-index
    return result, console/same-as-ingredient:0, 1/found, 0/quit
  }
  switch  # real event source is infrequent; avoid polling it too much
  result:event, found?:bool <- check-for-interaction
  return result, console/same-as-ingredient:0, found?, 0/quit
]

# variant of read-event for just keyboard events. Discards everything that
# isn't unicode, so no arrow keys, page-up/page-down, etc. But you still get
# newlines, tabs, ctrl-d..
def read-key console:&:console -> result:char, console:&:console, found?:bool, quit?:bool [
  local-scope
  load-ingredients
  x:event, console, found?:bool, quit?:bool <- read-event console
  return-if quit?, 0, console/same-as-ingredient:0, found?, quit?
  return-unless found?, 0, console/same-as-ingredient:0, found?, quit?
  c:char, converted?:bool <- maybe-convert x, text:variant
  return-unless converted?, 0, console/same-as-ingredient:0, 0/found, 0/quit
  return c, console/same-as-ingredient:0, 1/found, 0/quit
]

def send-keys-to-channel console:&:console, chan:&:sink:char, screen:&:screen -> console:&:console, chan:&:sink:char, screen:&:screen [
  local-scope
  load-ingredients
  {
    c:char, console, found?:bool, quit?:bool <- read-key console
    loop-unless found?
    break-if quit?
    assert c, [invalid event, expected text]
    screen <- print screen, c
    chan <- write chan, c
    loop
  }
  chan <- close chan
]

def wait-for-event console:&:console -> console:&:console [
  local-scope
  load-ingredients
  {
    _, console, found?:bool <- read-event console
    loop-unless found?
  }
]

# use this helper to skip rendering if there's lots of other events queued up
def has-more-events? console:&:console -> result:bool [
  local-scope
  load-ingredients
  {
    break-unless console
    # fake consoles should be plenty fast; never skip
    return 0/false
  }
  result <- interactions-left?
]