diff options
| author | Yong He <yonghe@outlook.com> | 2023-06-02 15:31:03 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-06-02 15:31:03 -0700 |
| commit | c3c1b56ae693ed23804544e929a3447bc921edf6 (patch) | |
| tree | f1d8f81a42f094729d7091cddd5622b1ff25071b /source | |
| parent | 16cd361dd67471bcc355d1b3b72b0b022518088f (diff) | |
Fix generic param inference through TypeCastIntVal. (#2916)
Diffstat (limited to 'source')
| -rw-r--r-- | source/slang/slang-check-constraint.cpp | 4 | ||||
| -rw-r--r-- | source/slang/slang-mangle.cpp | 18 |
2 files changed, 22 insertions, 0 deletions
diff --git a/source/slang/slang-check-constraint.cpp b/source/slang/slang-check-constraint.cpp index 42d01a996..f0df78c43 100644 --- a/source/slang/slang-check-constraint.cpp +++ b/source/slang/slang-check-constraint.cpp @@ -540,8 +540,12 @@ namespace Slang // Check if both are integer values in general if (auto fstInt = as<IntVal>(fst)) { + if (auto tc = as<TypeCastIntVal>(fstInt)) + fstInt = as<IntVal>(tc->base); if (auto sndInt = as<IntVal>(snd)) { + if (auto tc = as<TypeCastIntVal>(sndInt)) + sndInt = as<IntVal>(tc->base); auto fstParam = as<GenericParamIntVal>(fstInt); auto sndParam = as<GenericParamIntVal>(sndInt); diff --git a/source/slang/slang-mangle.cpp b/source/slang/slang-mangle.cpp index ef9bf4938..3b0d12da8 100644 --- a/source/slang/slang-mangle.cpp +++ b/source/slang/slang-mangle.cpp @@ -326,6 +326,24 @@ namespace Slang else if (const auto polynomialIntVal = dynamicCast<PolynomialIntVal>(val)) { emitRaw(context, "KX"); + emit(context, (UInt)polynomialIntVal->constantTerm); + emit(context, (UInt)polynomialIntVal->terms.getCount()); + for (auto term : polynomialIntVal->terms) + { + emit(context, (UInt)term->constFactor); + emit(context, (UInt)term->paramFactors.getCount()); + for (auto factor : term->paramFactors) + { + emitVal(context, factor->param); + emit(context, (UInt)factor->power); + } + } + } + else if (const auto typecastIntVal = dynamicCast<TypeCastIntVal>(val)) + { + emitRaw(context, "KK"); + emitVal(context, typecastIntVal->type); + emitVal(context, typecastIntVal->base); } else { |
