diff options
| author | Kyle Gunger <kgunger12@gmail.com> | 2023-03-26 17:25:09 -0400 | 
|---|---|---|
| committer | Kyle Gunger <kgunger12@gmail.com> | 2023-03-26 17:25:09 -0400 | 
| commit | 4a71d4c02a4613454f3fdb782acd830de0f23641 (patch) | |
| tree | 004b30846966429d1c37ff5749170f3d8a9c40a2 /tnslc | |
| parent | 5a6004920a860160cdb4550f104b7bb20a54da7f (diff) | |
Fix multiple issues
+ Fix calling with multiple arguments
+ Fix issue with stack positioning
+ Fix issue with alt in _eval_value
Diffstat (limited to 'tnslc')
| -rw-r--r-- | tnslc/simple.tnsl | 6 | ||||
| -rw-r--r-- | tnslc/tnslc.tnsl | 42 | 
2 files changed, 34 insertions, 14 deletions
| diff --git a/tnslc/simple.tnsl b/tnslc/simple.tnsl index 20348c1..8af8a68 100644 --- a/tnslc/simple.tnsl +++ b/tnslc/simple.tnsl @@ -11,8 +11,8 @@ struct Test {      int i, j, k  } -/; call_me (int i, j) [int] -    return i + j +/; call_me (int i, ~int j) [int] +    return i + j`  ;/  /; main (int argc, ~~uint argv) [int] @@ -35,7 +35,7 @@ struct Test {          argc = 90      ;/ -    m.j = call_me(m.j, argc) +    m.j = call_me(m.j, ~argc)      # return 3      return m.j diff --git a/tnslc/tnslc.tnsl b/tnslc/tnslc.tnsl index 05cbe03..bb4d095 100644 --- a/tnslc/tnslc.tnsl +++ b/tnslc/tnslc.tnsl @@ -1239,7 +1239,7 @@          /; if (self.loc_type == LOCATION.LITERAL && v.loc_type == LOCATION.LITERAL)              ;self.location = v.location          ;; else if (self.is_prim()) -            /;if (self.is_ref() && v.is_ref()) +            /;if (self.is_ref() && (v.is_ref() || v.loc_type == LOCATION.STACK))                  ;data`.csec = string_join( {                      data`.csec,                      "\tmov ", get_reg(4, sz), ", ", v.norm_loc(sz), "\n", @@ -1465,6 +1465,8 @@          /; loop (int i = 0; i < len (self.vars) && out < 16) [i++]              /; if (self.vars{i}.loc_type == LOCATION.REGISTER) +                ;log_debug("Found register variable") +                ;log_debug(self.vars{i}.sprint())                  ;out++              ;/          ;/ @@ -1501,7 +1503,7 @@          ;/          /; if (!(self.is_cf()) && !(self.r)) -            ;return out + 80 +            ;return out + 72          ;/          ;return out @@ -1536,7 +1538,7 @@          ;int accum = 0          /; if (!(self.r)) -            ;accum = 80 +            ;accum = 72          ;/          ;{}uint8 moves = string_join( { @@ -1576,7 +1578,7 @@              ;/          ;/ -        /; if (accum > 80 && !(self.r)) +        /; if (accum > 72 && !(self.r))              ;out`.csec = string_add(out`.csec, moves)          ;/      ;/ @@ -1714,7 +1716,9 @@              "\tsub rsp, ", int_to_string(copy.norm_size()), "\n"          }, "")          ;copy.set(rv`, out) -        ;rv` = copy +        ;rv`.location = copy.location +        ;rv`.loc_type = LOCATION.STACK +        ;log_debug(self.sprint())          /; if (reg < last_var - 1)              ;rv = self.find_reg_variable(last_var - 1) @@ -1724,6 +1728,8 @@              }, ""))              ;rv`.move_register(reg, out)          ;/ +        ;log_debug(self.sprint()) +          ;return copy      ;/ @@ -2651,12 +2657,24 @@  # FIXME: should actually do call based on function given, and return a proper variable.  # assumes the call has been set up  /; _perform_call (Function f, ~CompData out) [Variable] -    ;int reg = 0 +    ;int reg = 0, i = 0      /; if (f.is_method())          ;reg = 1      ;/      ;Variable ctmp = {"#ctmp", NO_TYPE, 4, LOCATION.REGISTER} -    /; loop (int i = 0; i < len (f.inputs)) [i++] +    /; loop (i < len (f.inputs)) [i++] +        ;Type t = f.mod`.find_type(string_split(f.inputs{i}.name, '.'))` +        ;t.ptr_chain = f.inputs{i}.ptr_chain +        ;ctmp.data_type = t +        /; if (ctmp.is_prim() && reg < 6) +            ;reg++ +        ;; else if (reg == 6) +            ;break +        ;/ +    ;/ +    ;reg = reg - 1 +    ;i = i - 1 +    /; loop (i !< 0) [i = i - 1]          ;Type t = f.mod`.find_type(string_split(f.inputs{i}.name, '.'))`          ;t.ptr_chain = f.inputs{i}.ptr_chain          ;ctmp.data_type = t @@ -2666,7 +2684,7 @@                  "\tmov ", get_reg(reg, ctmp.norm_size()),", [rsp]\n",                  "\tadd rsp, ", int_to_string(ctmp.norm_size()), "\n"              }, "") -            ;reg++ +            ;reg = reg - 1          ;; else if (reg == 6)              ;break          ;/ @@ -2707,7 +2725,7 @@      ;; else if (tok`{start`}.cmp("`"))          ;log_debug("Pre loop deref")          ;wk = wk.deref(out) -        ;start` = start` + 1 +        ;start` = start` + 2      ;/      /; loop (start` < max) [start`++] @@ -2879,6 +2897,8 @@      ;/      /; if (pr < 2) +        ;log_debug("Dot _eval_value") +        ;tnsl.io.println(alt)          ;return _eval_dot(tok, ~start, max, out, mov, current, scope, t, alt)      ;/ @@ -2893,8 +2913,8 @@      ;; else if (first == max - 1)          ;s1 = _eval_value(tok, start, first, out, mov, current, scope, t, alt)      ;; else -        ;s2 = _eval_value(tok, first + 1, max, out, mov, current, scope, t, alt) -        ;s1 = _eval_value(tok, start, first, out, mov, current, scope, t, !alt) +        ;s2 = _eval_value(tok, first + 1, max, out, mov, current, scope, t, !alt) +        ;s1 = _eval_value(tok, start, first, out, mov, current, scope, t, alt)          /; if (tok`{first}.cmp("="))              ;t = s1.data_type          ;/ |