about summary refs log tree commit diff stats
path: root/apps
diff options
context:
space:
mode:
Diffstat (limited to 'apps')
-rw-r--r--apps/mu.subx264
1 files changed, 117 insertions, 147 deletions
diff --git a/apps/mu.subx b/apps/mu.subx
index 13623e91..4c0fbb18 100644
--- a/apps/mu.subx
+++ b/apps/mu.subx
@@ -11036,76 +11036,57 @@ test-emit-subx-stmt-primitive:
     # setup
     (clear-stream _test-output-stream)
     (clear-stream $_test-output-buffered-file->buffer)
+    # simulate allocated payloads starting with an initial fake alloc-id (0x11)
 $test-emit-subx-stmt-primitive:initialize-type:
-    # var type/ecx: (handle tree type-id) = new tree(int)
-    68/push 0/imm32
-    68/push 0/imm32
+    # var type/ecx: (handle tree type-id) = int
+    68/push 0/imm32/right:null
+    68/push 0/imm32/right:null
+    68/push 0/imm32/left:unused
+    68/push 1/imm32/value:int
+    68/push 0x11/imm32/alloc-id:fake
+    68/push 0x11/imm32/alloc-id:fake:payload
     89/<- %ecx 4/r32/esp
-    (allocate Heap *Tree-size %ecx)
-    (lookup *ecx *(ecx+4))  # => eax
-    c7 0/subop/copy *eax 1/imm32/true  # Tree-is-atom
-    c7 0/subop/copy *(eax+4) 1/imm32/int  # Tree-value
 $test-emit-subx-stmt-primitive:initialize-var:
-    # var v/edx: (handle var) = new var(type)
-    68/push 0/imm32
-    68/push 0/imm32
-    89/<- %edx 4/r32/esp
-    (new-var Heap  0 0  %edx)  # name = null
-    (lookup *edx *(edx+4))  # => eax
-    # v->name = "foo"
-    (copy-array Heap "foo" %eax)  # Var-name
-    # v->type = type
-    8b/-> *ecx 3/r32/ebx
-    89/<- *(eax+8) 3/r32/ebx  # Var-type
-    8b/-> *(ecx+4) 3/r32/ebx
-    89/<- *(eax+0xc) 3/r32/ebx  # Var-type
-    # v->block-depth = 1
-    c7 0/subop/copy *(eax+0x10) 1/imm32
-    # v->offset = -8
-    c7 0/subop/copy *(eax+0x14) -8/imm32
-$test-emit-subx-stmt-primitive:initialize-stmt-var:
-    # var operand/ecx: (handle stmt-var) = new stmt-var(v)
-    68/push 0/imm32
-    68/push 0/imm32
+    # var var-foo/ecx: (handle var) = var(type)
+    68/push 0/imm32/no-register
+    68/push 0/imm32/no-register
+    68/push -8/imm32/stack-offset
+    68/push 1/imm32/block-depth
+    51/push-ecx/type
+    68/push 0x11/imm32/alloc-id:fake
+    68/push 0/imm32/name
+    68/push 0/imm32/name
+    68/push 0x11/imm32/alloc-id:fake:payload
     89/<- %ecx 4/r32/esp
-    (allocate Heap *Stmt-var-size %ecx)
-    (lookup *ecx *(ecx+4))  # => eax
-    8b/-> *edx 3/r32/ebx
-    89/<- *eax 3/r32/ebx  # Stmt-var-value
-    8b/-> *(edx+4) 3/r32/ebx
-    89/<- *(eax+4) 3/r32/ebx  # Stmt-var-value
-$test-emit-subx-stmt-primitive:initialize-var-list:
-    # var list/ebx: (handle list var) = new list(v, null)
-    68/push 0/imm32
-    68/push 0/imm32
+$test-emit-subx-stmt-primitive:initialize-var-name:
+    # var-foo->name = "foo"
+    8d/copy-address *(ecx+4) 0/r32/eax  # Var-name + 4
+    (copy-array Heap "foo" %eax)
+$test-emit-subx-stmt-primitive:initialize-stmt-var:
+    # var operand/ebx: (handle stmt-var) = stmt-var(var-foo)
+    68/push 0/imm32/is-deref:false
+    68/push 0/imm32/next
+    68/push 0/imm32/next
+    51/push-ecx/var-foo
+    68/push 0x11/imm32/alloc-id:fake
+    68/push 0x11/imm32/alloc-id:fake:payload
     89/<- %ebx 4/r32/esp
-    (allocate Heap *List-size %ebx)
-    (lookup *ebx *(ebx+4))  # => eax
-    89/<- %esi 0/r32/eax
-    8b/-> *edx 0/r32/eax
-    89/<- *esi 0/r32/eax  # List-value
-    8b/-> *(edx+4) 0/r32/eax
-    89/<- *(esi+4) 0/r32/eax  # List-value
 $test-emit-subx-stmt-primitive:initialize-stmt:
-    # var stmt/ecx: stmt(operand)
-    # . outputs
-    68/push 0/imm32
-    68/push 0/imm32
-    # . inouts
-    ff 6/subop/push *(ecx+4)
-    ff 6/subop/push *ecx
-    # . operation
-    68/push 0/imm32
-    68/push 0/imm32
-    # . tag
-    68/push 1/imm32/stmt1
-    89/<- %ecx 4/r32/esp
+    # var stmt/esi: (addr statement)
+    68/push 0/imm32/outputs
+    68/push 0/imm32/outputs
+    53/push-ebx/inouts
+    68/push 0x11/imm32/alloc-id:fake
+    68/push 0/imm32/operation
+    68/push 0/imm32/operation
+    68/push 1/imm32/tag
+    89/<- %esi 4/r32/esp
 $test-emit-subx-stmt-primitive:initialize-stmt-operation:
     # stmt->operation = "increment"
-    8d/copy-address *(ecx+4) 0/r32/eax  # Stmt1-operation
+    8d/copy-address *(esi+4) 0/r32/eax  # Stmt1-operation
     (copy-array Heap "increment" %eax)
 $test-emit-subx-stmt-primitive:initialize-primitive:
-    # var primitives/ebx: primitive
+    # var primitives/ebx: (addr primitive)
     68/push 0/imm32/next
     68/push 0/imm32/next
     68/push 0/imm32/output-is-write-only
@@ -11117,9 +11098,8 @@ $test-emit-subx-stmt-primitive:initialize-primitive:
     68/push 0/imm32/subx-name
     68/push 0/imm32/outputs
     68/push 0/imm32/outputs
-    # inouts (in practice we won't have the same var as in the function call above)
-    ff 6/subop/push *(ebx+4)
-    ff 6/subop/push *ebx
+    53/push-ebx/inouts  # hack: reuse stmt-var from call stmt as (list var) in function declaration
+    68/push 0x11/imm32/alloc-id:fake
     68/push 0/imm32/name
     68/push 0/imm32/name
     89/<- %ebx 4/r32/esp
@@ -11129,10 +11109,10 @@ $test-emit-subx-stmt-primitive:initialize-primitive-name:
 $test-emit-subx-stmt-primitive:initialize-primitive-subx-name:
     # primitives->subx-name = "ff 0/subop/increment"
     8d/copy-address *(ebx+0x18) 0/r32/eax  # Primitive-subx-name
-    (copy-array Heap "ff 0/subop/increment" %eax)  # Primitive-name
+    (copy-array Heap "ff 0/subop/increment" %eax)
     # convert
     c7 0/subop/copy *Curr-block-depth 0/imm32
-    (emit-subx-stmt _test-output-buffered-file %ecx %ebx)
+    (emit-subx-stmt _test-output-buffered-file %esi %ebx)
     (flush _test-output-buffered-file)
 #?     # dump _test-output-stream {{{
 #?     (write 2 "^")
@@ -11172,93 +11152,85 @@ test-emit-subx-stmt-primitive-register:
     (clear-stream _test-output-stream)
     (clear-stream $_test-output-buffered-file->buffer)
 $test-emit-subx-stmt-primitive-register:initialize-type:
-    # var type/ecx: (handle tree type-id) = new tree(int)
-    68/push 0/imm32
-    68/push 0/imm32
+    # var type/ecx: (handle tree type-id) = int
+    68/push 0/imm32/right:null
+    68/push 0/imm32/right:null
+    68/push 0/imm32/left:unused
+    68/push 1/imm32/value:int
+    68/push 0x11/imm32/alloc-id:fake
+    68/push 0x11/imm32/alloc-id:fake:payload
     89/<- %ecx 4/r32/esp
-    (allocate Heap *Tree-size %ecx)
-    (lookup *ecx *(ecx+4))  # => eax
-    c7 0/subop/copy *eax 1/imm32/true  # Tree-is-atom
-    c7 0/subop/copy *(eax+4) 1/imm32/int  # Tree-value
 $test-emit-subx-stmt-primitive-register:initialize-var:
-    # var v/edx: (handle var) = new var(type)
-    68/push 0/imm32
-    68/push 0/imm32
-    89/<- %edx 4/r32/esp
-    (new-var Heap  0 0  %edx)  # name = null
-    (lookup *edx *(edx+4))  # => eax
-    # v->name = "foo"
-    (copy-array Heap "foo" %eax)  # Var-name
-    # v->type = type
-    8b/-> *ecx 3/r32/ebx
-    89/<- *(eax+8) 3/r32/ebx  # Var-type
-    8b/-> *(ecx+4) 3/r32/ebx
-    89/<- *(eax+0xc) 3/r32/ebx  # Var-type
-    # v->block-depth = 1
-    c7 0/subop/copy *(eax+0x10) 1/imm32
-    # v->register = "eax"
-    8d/copy-address *(eax+0x18) 0/r32/eax  # Var-register
+    # var var-foo/ecx: (handle var)
+    68/push 0/imm32/register
+    68/push 0/imm32/register
+    68/push 0/imm32/no-stack-offset
+    68/push 1/imm32/block-depth
+    51/push-ecx
+    68/push 0x11/imm32/alloc-id:fake
+    68/push 0/imm32/name
+    68/push 0/imm32/name
+    68/push 0x11/imm32/alloc-id:fake:payload
+    89/<- %ecx 4/r32/esp
+$test-emit-subx-stmt-primitive-register:initialize-var-name:
+    # var-foo->name = "foo"
+    8d/copy-address *(ecx+4) 0/r32/eax  # Var-name + 4
+    (copy-array Heap "foo" %eax)
+$test-emit-subx-stmt-primitive-register:initialize-var-register:
+    # var-foo->register = "eax"
+    8d/copy-address *(ecx+0x1c) 0/r32/eax  # Var-register + 4
     (copy-array Heap "eax" %eax)
 $test-emit-subx-stmt-primitive-register:initialize-stmt-var:
-    # var operand/ecx: (handle stmt-var) = new stmt-var(v)
-    68/push 0/imm32
-    68/push 0/imm32
-    89/<- %ecx 4/r32/esp
-    (allocate Heap *Stmt-var-size %ecx)
-    (lookup *ecx *(ecx+4))  # => eax
-    8b/-> *edx 3/r32/ebx
-    89/<- *eax 3/r32/ebx  # Stmt-var-value
-    8b/-> *(edx+4) 3/r32/ebx
-    89/<- *(eax+4) 3/r32/ebx  # Stmt-var-value
+    # var operand/ebx: (handle stmt-var)
+    68/push 0/imm32/is-deref:false
+    68/push 0/imm32/next
+    68/push 0/imm32/next
+    51/push-ecx/var-foo
+    68/push 0x11/imm32/alloc-id:fake
+    68/push 0x11/imm32/alloc-id:fake:payload
+    89/<- %ebx 4/r32/esp
 $test-emit-subx-stmt-primitive-register:initialize-stmt:
-    # var stmt/ecx: stmt(outputs=operand)
-    # . outputs
-    ff 6/subop/push *(ecx+4)
-    ff 6/subop/push *ecx
-    # . inouts
-    68/push 0/imm32
-    68/push 0/imm32
-    # . operation
-    68/push 0/imm32
-    68/push 0/imm32
-    # . tag
-    68/push 1/imm32/stmt1
-    89/<- %ecx 4/r32/esp
+    # var stmt/esi: (addr statement)
+    53/push-ebx/outputs
+    68/push 0x11/imm32/alloc-id:fake
+    68/push 0/imm32/inouts
+    68/push 0/imm32/inouts
+    68/push 0/imm32/operation
+    68/push 0/imm32/operation
+    68/push 1/imm32
+    89/<- %esi 4/r32/esp
 $test-emit-subx-stmt-primitive-register:initialize-stmt-operation:
     # stmt->operation = "increment"
-    8d/copy-address *(ecx+4) 0/r32/eax  # Stmt1-operation
+    8d/copy-address *(esi+4) 0/r32/eax  # Stmt1-operation
     (copy-array Heap "increment" %eax)
 $test-emit-subx-stmt-primitive-register:initialize-formal-var:
-    # var formal-var/edx: (handle var) = new var(type)
-    68/push 0/imm32
-    68/push 0/imm32
-    89/<- %edx 4/r32/esp
-    (new-var Heap  0 0  %edx)  # name = null
-    (lookup *edx *(edx+4))  # => eax
-    # v->name = "dummy"
-    (copy-array Heap "dummy" %eax)  # Var-name
-    # v->type = type
-    8b/-> *ecx 3/r32/ebx
-    89/<- *(eax+8) 3/r32/ebx  # Var-type
-    8b/-> *(ecx+4) 3/r32/ebx
-    89/<- *(eax+0xc) 3/r32/ebx  # Var-type
-    # v->block-depth = 1
-    c7 0/subop/copy *(eax+0x10) 1/imm32
-    # v->register = "*"
-    8d/copy-address *(eax+0x18) 0/r32/eax  # Var-register
-    (copy-array Heap "*" %eax)
+    # var formal-var/ebx: (handle var)
+    68/push 0/imm32/register
+    68/push 0/imm32/register
+    68/push 0/imm32/no-stack-offset
+    68/push 1/imm32/block-depth
+    ff 6/subop/push *(ecx+0xc)  # Var-type + 4
+    68/push 0x11/imm32/alloc-id:fake
+    68/push 0/imm32/name
+    68/push 0/imm32/name
+    68/push 0x11/imm32/alloc-id:fake:payload
+    89/<- %ebx 4/r32/esp
+$test-emit-subx-stmt-primitive-register:initialize-formal-var-name:
+    # formal-var->name = "dummy"
+    8d/copy-address *(ebx+4) 0/r32/eax  # Var-name + 4
+    (copy-array Heap "dummy" %eax)
+$test-emit-subx-stmt-primitive-register:initialize-formal-register:
+    # formal-var->register = "*"
+    8d/copy-address *(ebx+0x1c) 0/r32/eax  # Var-register + 4
+    (copy-array Heap "*" %eax)  # Any-register
 $test-emit-subx-stmt-primitive-register:initialize-var-list:
-    # var list/ebx: (handle list var) = new list(formal-var, null)
-    68/push 0/imm32
-    68/push 0/imm32
+    # var formal-operand/ebx: (handle list stmt-var)
+    68/push 0/imm32/next
+    68/push 0/imm32/next
+    53/push-ebx/formal-var
+    68/push 0x11/imm32/alloc-id:fake
+    68/push 0x11/imm32/alloc-id:fake:payload
     89/<- %ebx 4/r32/esp
-    (allocate Heap *List-size %ebx)
-    (lookup *ebx *(ebx+4))  # => eax
-    89/<- %esi 0/r32/eax
-    8b/-> *edx 0/r32/eax
-    89/<- *esi 0/r32/eax  # List-value
-    8b/-> *(edx+4) 0/r32/eax
-    89/<- *(esi+4) 0/r32/eax  # List-value
 $test-emit-subx-stmt-primitive-register:initialize-primitive:
     # var primitives/ebx: primitive
     68/push 0/imm32/next
@@ -11270,10 +11242,8 @@ $test-emit-subx-stmt-primitive-register:initialize-primitive:
     68/push 3/imm32/rm32-is-first-output
     68/push 0/imm32/subx-name
     68/push 0/imm32/subx-name
-    # outputs = list
-    ff 6/subop/push *(ebx+4)
-    ff 6/subop/push *ebx
-    #
+    53/push-ebx/outputs
+    68/push 0x11/imm32/alloc-id:fake
     68/push 0/imm32/inouts
     68/push 0/imm32/inouts
     68/push 0/imm32/name
@@ -11285,10 +11255,10 @@ $test-emit-subx-stmt-primitive-register:initialize-primitive-name:
 $test-emit-subx-stmt-primitive-register:initialize-primitive-subx-name:
     # primitives->subx-name = "ff 0/subop/increment"
     8d/copy-address *(ebx+0x18) 0/r32/eax  # Primitive-subx-name
-    (copy-array Heap "ff 0/subop/increment" %eax)  # Primitive-name
+    (copy-array Heap "ff 0/subop/increment" %eax)
     # convert
     c7 0/subop/copy *Curr-block-depth 0/imm32
-    (emit-subx-stmt _test-output-buffered-file %ecx %ebx)
+    (emit-subx-stmt _test-output-buffered-file %esi %ebx)
     (flush _test-output-buffered-file)
 #?     # dump _test-output-stream {{{
 #?     (write 2 "^")
mbers'>
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



                                                                                          
                                              
                                         
                                                
                                   
                                                                                                               
                                                 

                       

                                                                                                 
                    
                                     
                               



                             

        



                               






















                                                                                 

         
       
                             
                                                                                                                                                         
                         





                                                                                                                                                
                                                                                                                            
                                                                                                                                                                          

                                                                 

                                                                               







                                                                                                                                     
                                                                                                                                                                         
                                                                                                     
                                                                                                                                                                                                                                                                                             
                                               
                                                                                                                                                                                                                 

                                                                 


                                                                                 

                                           




                                                                                                                                     
                                                                                                                             


                                                                                                                                                                                                                  

                                                                 

                                                                               

                                           


       
                                     
<!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 - 083scenario_screen_test.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; }
.muScenario { color: #00af00; }
.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/083scenario_screen_test.mu'>https://github.com/akkartik/mu/blob/master/083scenario_screen_test.mu</a>
<pre id='vimCodeElement'>
<span id="L1" class="LineNr"> 1 </span><span class="Comment"># To check our support for screens in scenarios, rewrite tests from print.mu</span>
<span id="L2" class="LineNr"> 2 </span>
<span id="L3" class="LineNr"> 3 </span><span class="muScenario">scenario</span> print-character-at-top-left-2 [
<span id="L4" class="LineNr"> 4 </span>  <span class="Constant">local-scope</span>
<span id="L5" class="LineNr"> 5 </span>  assume-screen <span class="Constant">3/width</span>, <span class="Constant">2/height</span>
<span id="L6" class="LineNr"> 6 </span>  run [
<span id="L7" class="LineNr"> 7 </span>    a:char <span class="Special">&lt;-</span> copy <span class="Constant">97/a</span>
<span id="L8" class="LineNr"> 8 </span>    <a href='081print.mu.html#L16'>screen</a> <span class="Special">&lt;-</span> print <a href='081print.mu.html#L16'>screen</a>, a
<span id="L9" class="LineNr"> 9 </span>  ]
<span id="L10" class="LineNr">10 </span>  screen-should-contain [
<span id="L11" class="LineNr">11 </span>   <span class="Constant"> .a  .</span>
<span id="L12" class="LineNr">12 </span>   <span class="Constant"> .   .</span>
<span id="L13" class="LineNr">13 </span>  ]
<span id="L14" class="LineNr">14 </span>]
<span id="L15" class="LineNr">15 </span>
<span id="L16" class="LineNr">16 </span><span class="muScenario">scenario</span> clear-line-erases-printed-characters-2 [
<span id="L17" class="LineNr">17 </span>  <span class="Constant">local-scope</span>
<span id="L18" class="LineNr">18 </span>  assume-screen <span class="Constant">5/width</span>, <span class="Constant">3/height</span>
<span id="L19" class="LineNr">19 </span>  <span class="Comment"># print a character</span>
<span id="L20" class="LineNr">20 </span>  a:char <span class="Special">&lt;-</span> copy <span class="Constant">97/a</span>
<span id="L21" class="LineNr">21 </span>  <a href='081print.mu.html#L16'>screen</a> <span class="Special">&lt;-</span> print <a href='081print.mu.html#L16'>screen</a>, a
<span id="L22" class="LineNr">22 </span>  <span class="Comment"># move cursor to start of line</span>
<span id="L23" class="LineNr">23 </span>  <a href='081print.mu.html#L16'>screen</a> <span class="Special">&lt;-</span> <a href='081print.mu.html#L591'>move-cursor</a> <a href='081print.mu.html#L16'>screen</a>, <span class="Constant">0/row</span>, <span class="Constant">0/column</span>
<span id="L24" class="LineNr">24 </span>  run [
<span id="L25" class="LineNr">25 </span>    <a href='081print.mu.html#L16'>screen</a> <span class="Special">&lt;-</span> <a href='081print.mu.html#L524'>clear-line</a> <a href='081print.mu.html#L16'>screen</a>
<span id="L26" class="LineNr">26 </span>  ]
<span id="L27" class="LineNr">27 </span>  screen-should-contain [
<span id="L28" class="LineNr">28 </span>   <span class="Constant"> .     .</span>
<span id="L29" class="LineNr">29 </span>   <span class="Constant"> .     .</span>
<span id="L30" class="LineNr">30 </span>   <span class="Constant"> .     .</span>
<span id="L31" class="LineNr">31 </span>  ]
<span id="L32" class="LineNr">32 </span>]
<span id="L33" class="LineNr">33 </span>
<span id="L34" class="LineNr">34 </span><span class="muScenario">scenario</span> scroll-screen [
<span id="L35" class="LineNr">35 </span>  <span class="Constant">local-scope</span>
<span id="L36" class="LineNr">36 </span>  assume-screen <span class="Constant">3/width</span>, <span class="Constant">2/height</span>
<span id="L37" class="LineNr">37 </span>  run [
<span id="L38" class="LineNr">38 </span>    a:char <span class="Special">&lt;-</span> copy <span class="Constant">97/a</span>
<span id="L39" class="LineNr">39 </span>    <a href='081print.mu.html#L591'>move-cursor</a> <a href='081print.mu.html#L16'>screen</a>, <span class="Constant">1/row</span>, <span class="Constant">2/column</span>
<span id="L40" class="LineNr">40 </span>    <a href='081print.mu.html#L16'>screen</a> <span class="Special">&lt;-</span> print <a href='081print.mu.html#L16'>screen</a>, a
<span id="L41" class="LineNr">41 </span>    <a href='081print.mu.html#L16'>screen</a> <span class="Special">&lt;-</span> print <a href='081print.mu.html#L16'>screen</a>, a
<span id="L42" class="LineNr">42 </span>  ]
<span id="L43" class="LineNr">43 </span>  screen-should-contain [
<span id="L44" class="LineNr">44 </span>   <span class="Constant"> .  a.</span>
<span id="L45" class="LineNr">45 </span>   <span class="Constant"> .a  .</span>
<span id="L46" class="LineNr">46 </span>  ]
<span id="L47" class="LineNr">47 </span>]
</pre>
</body>
</html>
<!-- vim: set foldmethod=manual : -->