diff options
| -rw-r--r-- | src/compiler/compiler.lm | 25 | 
1 files changed, 18 insertions, 7 deletions
| diff --git a/src/compiler/compiler.lm b/src/compiler/compiler.lm index 33dd2c3..4ed772b 100644 --- a/src/compiler/compiler.lm +++ b/src/compiler/compiler.lm @@ -45,6 +45,7 @@ context fspec           def type              name:str              items:item+ +            select:expr::paren::type              [type:`enum WS+ name::type? `{ item+ `}] { if (name::type in r3) lhs.name = $(name::type in r3) lhs.items = r5 }        end @@ -62,6 +63,7 @@ context fspec           def type              name:str              items:item+ +            select:expr::paren::type              [type:`struct WS+ name::type? `{ item+ `}] { if (name::type in r3) lhs.name = $(name::type in r3) lhs.items = r5 }        end @@ -80,7 +82,8 @@ context fspec           def type              name:str              items:item+ # BUG: marking item+ with items: in the match below causes weird behaviour -            [type:`select `( expr::paren::type `) `{ item+ `}] { lhs.items = r6 } +            select:expr::paren::type +            [type:`select `( expr::paren::type `) `{ item+ `}] { lhs.select = r3 lhs.items = r6 }        end        def type @@ -238,9 +241,13 @@ print_declaration(d:fspec::declaration::type)     c:fspec::container::type     if (d.cref) c = lookup($d.cref, $d.parent) else c = d.container -   if (c) +   if (c) {        print('`', c.data.type, ' ', container_name_str(c.data.name), '` ') +      if (c.data.select) +         print('with expression `', $c.data.select, '` ') +   } +     if (d.primitive)        print(d.primitive.bits, ' bits and ', signed_str(d.primitive.signed)) @@ -272,25 +279,29 @@ walk(s:fspec::container::type)  {     insert($s.data.type, s.data.name, s)     if ($s.data.type == 'enum') { -      for i:fspec::container::enum::item in repeat(s.data.items) +      for i:fspec::container::enum::item in repeat(s.data.items) { +         print('constant `', $i.name, '` = ', $i.value, '\n')           insert('variable', $i.name, i) +      }     } else if ($s.data.type == 'struct') {        push_scope()        for d:fspec::container::strukt::item in repeat(s.data.items) { -         if (d.data.container) -            walk(d.data.container)           if (d.data.name)              print_declaration(d.data) +         if (d.data.container) +            walk(d.data.container)        }        pop_scope()     } else if ($s.data.type == 'select') {        push_scope()        for d:fspec::container::select::item in repeat(s.data.items) { -         if (d.data.container) -            walk(d.data.container) +         print('━━━━ ', $d.expr, ' ━━━━\n')           if (d.data.name)              print_declaration(d.data) +         if (d.data.container) +            walk(d.data.container)        } +      print('━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n')        pop_scope()     }  } | 
