diff options
| author | gingerBill <bill@gingerbill.org> | 2020-04-04 21:23:11 +0100 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2020-04-04 21:23:11 +0100 |
| commit | 5e706bab56eb28023d27623e0d33c4b5e06b5781 (patch) | |
| tree | 1d114559c0a9a50f61cca67d63724021b994fd58 /src/checker.cpp | |
| parent | b362ce9a22e7eb751c281daf6e78bd8f473a799e (diff) | |
Fix typeid comparison bug in `ir.cpp`
Diffstat (limited to 'src/checker.cpp')
| -rw-r--r-- | src/checker.cpp | 22 |
1 files changed, 16 insertions, 6 deletions
diff --git a/src/checker.cpp b/src/checker.cpp index c8b737df8..a6cb80b7d 100644 --- a/src/checker.cpp +++ b/src/checker.cpp @@ -1035,12 +1035,22 @@ void add_type_and_value(CheckerInfo *i, Ast *expr, AddressingMode mode, Type *ty return; } - expr->tav.mode = mode; - expr->tav.type = type; - if (mode == Addressing_Constant || mode == Addressing_Invalid) { - expr->tav.value = value; - } else if (mode == Addressing_Value && is_type_typeid(type)) { - expr->tav.value = value; + Ast *prev_expr = nullptr; + for (;;) { + if (prev_expr != expr) { + expr->tav.mode = mode; + expr->tav.type = type; + if (mode == Addressing_Constant || mode == Addressing_Invalid) { + expr->tav.value = value; + } else if (mode == Addressing_Value && is_type_typeid(type)) { + expr->tav.value = value; + } + + prev_expr = expr; + } else { + break; + } + expr = unparen_expr(expr); } } |