diff options
| author | Bruce Hill <bruce@bruce-hill.com> | 2024-05-12 19:21:44 -0400 |
|---|---|---|
| committer | Bruce Hill <bruce@bruce-hill.com> | 2024-05-12 19:21:44 -0400 |
| commit | e171d4a98caed10a7356d7cb78590cdf74443124 (patch) | |
| tree | 6df3eb12c2c19ab9f88739919f2d995ccd4d327a /compile.c | |
| parent | ff9f4fe6cf59085b726c096ef28ac080d7cdd742 (diff) | |
Fix up some promotion logic for closures
Diffstat (limited to 'compile.c')
| -rw-r--r-- | compile.c | 7 |
1 files changed, 5 insertions, 2 deletions
@@ -47,15 +47,18 @@ static bool promote(env_t *env, CORD *code, type_t *actual, type_t *needed) return promote(env, code, Match(actual, PointerType)->pointed, needed); } - // Optional promotion: + // Optional and stack ref promotion: if (actual->tag == PointerType && needed->tag == PointerType) return true; - if (needed->tag == ClosureType && actual->tag == FunctionType && type_eq(actual, Match(needed, ClosureType)->fn)) { + if (needed->tag == ClosureType && actual->tag == FunctionType) { *code = CORD_all("(closure_t){", *code, ", NULL}"); return true; } + if (needed->tag == ClosureType && actual->tag == ClosureType) + return true; + if (needed->tag == FunctionType && actual->tag == FunctionType) { *code = CORD_all("(", compile_type(env, needed), ")", *code); return true; |
