summaryrefslogtreecommitdiffstats
path: root/source/slang/slang-parser.cpp
diff options
context:
space:
mode:
authorYong He <yonghe@outlook.com>2025-02-20 14:48:51 -0800
committerGitHub <noreply@github.com>2025-02-20 14:48:51 -0800
commit19867ffca6dca7995c799354081219c9e76f13d1 (patch)
treeb9153428fc8b7b6f3069931cf816ad374a2e7c52 /source/slang/slang-parser.cpp
parent9580e311e0cefb0f8e11afc316783a67201654eb (diff)
Simplify implicit cast ctors for vector & matrix. (#6408)
* Simplify implicit cast ctors for vector & matrix. * Fix formatting. * Fix tests. * Fix Falcor test. * Mark __builtin_cast as internal.
Diffstat (limited to 'source/slang/slang-parser.cpp')
-rw-r--r--source/slang/slang-parser.cpp29
1 files changed, 27 insertions, 2 deletions
diff --git a/source/slang/slang-parser.cpp b/source/slang/slang-parser.cpp
index 82cb8caf3..aec3b4e90 100644
--- a/source/slang/slang-parser.cpp
+++ b/source/slang/slang-parser.cpp
@@ -1721,6 +1721,20 @@ static void maybeParseGenericConstraints(Parser* parser, ContainerDecl* genericP
constraint->sup = parser->ParseTypeExp();
AddMember(genericParent, constraint);
}
+ else if (AdvanceIf(parser, TokenType::LParent))
+ {
+ auto constraint = parser->astBuilder->create<TypeCoercionConstraintDecl>();
+ constraint->whereTokenLoc = whereToken.loc;
+ parser->FillPosition(constraint);
+ constraint->toType = subType;
+ constraint->fromType = parser->ParseTypeExp();
+ parser->ReadToken(TokenType::RParent);
+ if (AdvanceIf(parser, "implicit"))
+ {
+ addModifier(constraint, parser->astBuilder->create<ImplicitConversionModifier>());
+ }
+ AddMember(genericParent, constraint);
+ }
}
}
@@ -8910,8 +8924,19 @@ static NodeBase* parseImplicitConversionModifier(Parser* parser, void* /*userDat
ConversionCost cost = kConversionCost_Default;
if (AdvanceIf(parser, TokenType::LParent))
{
- cost =
- ConversionCost(stringToInt(parser->ReadToken(TokenType::IntegerLiteral).getContent()));
+ if (AdvanceIf(parser, "constraint"))
+ {
+ cost = kConversionCost_TypeCoercionConstraint;
+ if (AdvanceIf(parser, TokenType::OpAdd))
+ {
+ cost = kConversionCost_TypeCoercionConstraintPlusScalarToVector;
+ }
+ }
+ else
+ {
+ cost = ConversionCost(
+ stringToInt(parser->ReadToken(TokenType::IntegerLiteral).getContent()));
+ }
if (AdvanceIf(parser, TokenType::Comma))
{
builtinKind = BuiltinConversionKind(