summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--05/main.c7
-rw-r--r--05/parse.b32
2 files changed, 31 insertions, 8 deletions
diff --git a/05/main.c b/05/main.c
index 68b5f6e..3386be0 100644
--- a/05/main.c
+++ b/05/main.c
@@ -15,7 +15,12 @@ int h(void) {
int y, r[3], s;
char d, e[5], f, g, *p;
int z = 3, R=12+459834-g;
- return g;
+ int x[] = {1,2,3,4,5};
+ struct {
+ char a,b;
+ } P[] = {1,2,3,4,5};
+ static int marker = 0x12345678;
+ return 5;
}
/* typedef int AA[sizeof x]; */
diff --git a/05/parse.b b/05/parse.b
index 738872a..38609e8 100644
--- a/05/parse.b
+++ b/05/parse.b
@@ -392,25 +392,31 @@ function parse_statement
write_statement_header(out, STATEMENT_LOCAL_DECLARATION, token)
out += 8
*8out = local_var_next_rbp_offset
- out += 8
- *8out = type_sizeof(l_type)
- out += 24
+ out += 32
p = local_variables
p += block_depth < 3
l_offset = local_var_next_rbp_offset
+ c = ident_list_lookup(*8p, l_name)
+ if c != 0 goto local_redeclaration
c = l_offset
c |= l_type < 32
ident_list_add(*8p, l_name, c)
+
+ token = l_suffix_end
+ :local_decl_continue
+ ; we need to calculate the size of the type here, because of stuff like
+ ; int x[] = {1,2,3};
+ n = type_sizeof(l_type)
+ out -= 24
+ *8out = n
+ out += 24
; advance
local_var_next_rbp_offset += type_sizeof(l_type)
; align
local_var_next_rbp_offset += 7
local_var_next_rbp_offset >= 3
local_var_next_rbp_offset <= 3
-
- token = l_suffix_end
- :local_decl_continue
if *1token == SYMBOL_SEMICOLON goto local_decl_loop_end
if *1token == SYMBOL_EQ goto local_decl_initializer
if *1token != SYMBOL_COMMA goto local_decl_badsuffix
@@ -429,12 +435,24 @@ function parse_statement
token = n
goto local_decl_continue
:local_init_lbrace
- byte 0xcc ; @TODO
+ rwdata_end_addr += 7
+ rwdata_end_addr >= 3
+ rwdata_end_addr <= 3
+ out -= 8
+ *8out = rwdata_end_addr
+ out += 8
+ parse_constant_initializer(&token, l_type)
+ goto local_decl_continue
:local_decl_badsuffix
token_error(token, .str_local_decl_badsuffix)
:str_local_decl_badsuffix
string Expected equals, comma, or semicolon after variable declaration.
byte 0
+ :local_redeclaration
+ token_error(token, .str_local_redeclaration)
+ :str_local_redeclaration
+ string Redeclaration of local variable.
+ byte 0
:local_decl_loop_end
token += 16 ; skip semicolon
goto parse_statement_ret