From abb7f1a7790544010d6eaac0f137e6b39349cf76 Mon Sep 17 00:00:00 2001 From: Yong He Date: Mon, 1 Apr 2024 18:44:44 -0700 Subject: Support `[RequirePrelude]` attribute on types. (#3867) --- source/slang/slang-check-modifier.cpp | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) (limited to 'source/slang/slang-check-modifier.cpp') diff --git a/source/slang/slang-check-modifier.cpp b/source/slang/slang-check-modifier.cpp index 942afd559..1587fa1b0 100644 --- a/source/slang/slang-check-modifier.cpp +++ b/source/slang/slang-check-modifier.cpp @@ -848,6 +848,35 @@ namespace Slang } requireCapAttr->capabilitySet = CapabilitySet(capabilityNames); } + else if (auto requirePreludeAttr = as(attr)) + { + if (attr->args.getCount() > 2) + { + getSink()->diagnose(attr, Diagnostics::tooManyArguments, attr->args.getCount(), 0); + return false; + } + else if (attr->args.getCount() < 2) + { + getSink()->diagnose(attr, Diagnostics::notEnoughArguments, attr->args.getCount(), 2); + return false; + } + CapabilityName capName; + if (!checkCapabilityName(attr->args[0], capName)) + { + return false; + } + requirePreludeAttr->capabilitySet = CapabilitySet(capName); + if (auto stringLitExpr = as(attr->args[1])) + { + requirePreludeAttr->prelude = getStringLiteralTokenValue(stringLitExpr->token); + } + else + { + getSink()->diagnose(attr->args[1], Diagnostics::expectedAStringLiteral); + return false; + } + return true; + } else { if(attr->args.getCount() == 0) -- cgit v1.2.3