Passing arrays as arguments to functions working

This commit is contained in:
Krzosa Karol
2022-06-07 21:34:02 +02:00
parent b65a5f78bf
commit 5744da8899
4 changed files with 57 additions and 54 deletions

View File

@@ -2,6 +2,7 @@
#define gen(...) pctx->gen.addf(__VA_ARGS__) #define gen(...) pctx->gen.addf(__VA_ARGS__)
#define genln(...) do{gen("\n"); gen_indent(); gen(__VA_ARGS__); }while(0) #define genln(...) do{gen("\n"); gen_indent(); gen(__VA_ARGS__); }while(0)
global S32 global_indent; global S32 global_indent;
global S32 is_inside_struct;
function void function void
gen_indent(){ gen_indent(){
@@ -253,6 +254,40 @@ gen_block(Ast_Block *block){
genln("}"); genln("}");
} }
enum {
ALWAYS_EMIT_VALUE = 0,
DONT_EMIT_VALUE = 1,
};
function void
gen_var(Intern_String name, Ast_Resolved_Type *type, Ast_Expr *expr, B32 emit_value){
if(is_array(type)){
gen("Slice %s", name.str);
} else{
gen_simple_decl(type, name);
}
if(emit_value == DONT_EMIT_VALUE){
return;
}
if(expr){
gen(" = ");
gen_expr(expr);
} else if(is_array(type)){
gen(" = (Slice){%d, (", type->arr.size);
gen_simple_decl(type, {});
gen("){}");
gen("}");
} else { // Default zero
if(is_numeric(type)){
gen(" = 0");
} else {
gen(" = {}");
}
}
}
function void function void
gen_ast(Ast *ast){ gen_ast(Ast *ast){
switch(ast->kind){ switch(ast->kind){
@@ -280,24 +315,7 @@ gen_ast(Ast *ast){
CASE(VAR, Var){ CASE(VAR, Var){
Sym *sym = resolved_get(node); Sym *sym = resolved_get(node);
gen_var(sym->name, sym->type, node->expr, is_inside_struct ? DONT_EMIT_VALUE : ALWAYS_EMIT_VALUE);
if(is_array(sym->type)){
gen("Slice %s", node->name.str);
} else{
gen_simple_decl(sym->type, node->name);
}
if(node->expr){
gen(" = ");
gen_expr(node->expr);
} else if(is_array(sym->type)){
gen(" = (Slice){%d, (", sym->type->arr.size);
gen_simple_decl(sym->type, {});
gen("){}");
gen("}");
} else { // Default zero
gen(" = {}");
}
gen(";"); gen(";");
BREAK(); BREAK();
} }
@@ -381,7 +399,7 @@ gen_ast(Ast *ast){
For(lambda->args){ For(lambda->args){
assert(it->kind == AST_LAMBDA_ARG); assert(it->kind == AST_LAMBDA_ARG);
Ast_Resolved_Type *type = resolved_type_get(it->typespec); Ast_Resolved_Type *type = resolved_type_get(it->typespec);
gen_simple_decl(type, it->name); gen_var(it->name, type, 0, DONT_EMIT_VALUE);
if(&it != (lambda->args.end() - 1)) gen(", "); if(&it != (lambda->args.end() - 1)) gen(", ");
} }
gen(")"); gen(")");
@@ -405,6 +423,7 @@ gen_ast(Ast *ast){
if(node->value->kind == AST_STRUCT){ if(node->value->kind == AST_STRUCT){
gen("typedef struct %s{", node->name.str); gen("typedef struct %s{", node->name.str);
global_indent++; global_indent++;
is_inside_struct++;
For(agg->members){ For(agg->members){
genln(""); genln("");
gen_ast(it); gen_ast(it);
@@ -414,6 +433,7 @@ gen_ast(Ast *ast){
genln(""); genln("");
gen_ast(it); gen_ast(it);
} }
is_inside_struct--;
global_indent--; global_indent--;
genln("}%s;", node->name.str); genln("}%s;", node->name.str);
} }

View File

@@ -35,10 +35,7 @@ int main(){
entry(); entry();
} }
#line 0 "program.kl"
#line 1
#line 3
typedef struct Token{ typedef struct Token{
U8 kind; U8 kind;
U8 *str; U8 *str;
@@ -47,61 +44,40 @@ typedef struct Token{
Number = 0, Number = 0,
};*/ };*/
}Token; }Token;
#line 12
String kind_name(U8 kind){ String kind_name(U8 kind){
#line 15
if((kind==0)){ if((kind==0)){
#line 14
return LIT("<Number>"); return LIT("<Number>");
} }
else{ else{
#line 16
return LIT("<Unknown>"); return LIT("<Unknown>");
} }
} }
#line 18
Bool is_numeric(U8 c){ Bool is_numeric(U8 c){
#line 19
Bool result = ((c>=48)&&(c<=57)); Bool result = ((c>=48)&&(c<=57));
#line 20
return result; return result;
} }
#line 22 void print_tokens(Slice tokens){
for(S64 i = 0;(i<tokens.len);(i++)){
Token *t = (&(((Token *)tokens.data)[i]));
printf("%d. %.*s", i, ((S32 )t->len), t->str);
}
}
void entry(){ void entry(){
#line 23
String string_to_lex = LIT("Identifier 2425525 Not_Number"); String string_to_lex = LIT("Identifier 2425525 Not_Number");
#line 24
Slice token_array = (Slice){32, (Token [32]){}}; Slice token_array = (Slice){32, (Token [32]){}};
#line 25
S64 token_count = 0; S64 token_count = 0;
#line 27 Token t = {};
Token t;
#line 28
for(S64 i = 0;(i<string_to_lex.len);i+=1){ for(S64 i = 0;(i<string_to_lex.len);i+=1){
#line 29
if(is_numeric((string_to_lex.str[i]))){ if(is_numeric((string_to_lex.str[i]))){
#line 30
t.kind=0; t.kind=0;
#line 31
t.str=(&(string_to_lex.str[i])); t.str=(&(string_to_lex.str[i]));
#line 32
t.len=i; t.len=i;
#line 33
for(;is_numeric((string_to_lex.str[i]));){ for(;is_numeric((string_to_lex.str[i]));){
#line 34
i+=1; i+=1;
} }
#line 35
t.len=(i-t.len); t.len=(i-t.len);
#line 36
(((Token *)token_array.data)[(token_count++)])=t; (((Token *)token_array.data)[(token_count++)])=t;
} }
} }
#line 38 print_tokens(token_array);
for(S64 i = 0;(i<token_count);(i++)){
#line 39
Token *tk = (&(((Token *)token_array.data)[i]));
#line 40
printf("%.*s", ((S32 )tk->len), tk->str);
}
} }

View File

@@ -19,6 +19,11 @@ is_numeric :: (c: U8): Bool
result := c >= '0 && c <= '9 result := c >= '0 && c <= '9
return result return result
print_tokens :: (tokens: []Token)
for i := 0, i < tokens.len, i++
t := &tokens[i]
printf("%d. %.*s", i, cast(t.len: S32), t.str)
entry :: () entry :: ()
string_to_lex := "Identifier 2425525 Not_Number" string_to_lex := "Identifier 2425525 Not_Number"
token_array: [32]Token token_array: [32]Token
@@ -34,7 +39,5 @@ entry :: ()
i+=1 i+=1
t.len = i - t.len t.len = i - t.len
token_array[token_count++] = t token_array[token_count++] = t
print_tokens(token_array)
for i := 0, i < token_count, i++
tk := &token_array[i]
printf("%.*s", cast(tk.len: S32), tk.str)

View File

@@ -313,6 +313,10 @@ make_sure_value_is_compatible_with_type(Token *pos, Operand *expr, Ast_Resolved_
else if(is_untyped(expr->type)){ else if(is_untyped(expr->type)){
expr->value = convert_untyped_to_typed(pos, expr->value, type); expr->value = convert_untyped_to_typed(pos, expr->value, type);
} }
else if(is_array(type) && type->arr.size == ARRAY_SIZE_INFERRED){
if(type->arr.inferred_size_hash == expr->type->arr.inferred_size_hash)
expr->type = type;
}
if(type && expr->type != type){ if(type && expr->type != type){
parsing_error(pos, "Assigning but incompatible types, expression: %s expected var type: %s", docname(expr->type), docname(type)); parsing_error(pos, "Assigning but incompatible types, expression: %s expected var type: %s", docname(expr->type), docname(type));