diff options
Diffstat (limited to 'source/slang/slang-check-modifier.cpp')
| -rw-r--r-- | source/slang/slang-check-modifier.cpp | 29 |
1 files changed, 29 insertions, 0 deletions
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<RequirePreludeAttribute>(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<StringLiteralExpr>(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) |
