mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-12-20 10:25:28 +00:00
tint: Add enable directive for extensions
In this CL the enable directive is implemented. 1. Add AST node for enable directive, assign a ExtensionKind (enum) for each supported extension. 2. Use an unorder_set in ast::Module to record all required extensions' kind. 3. Provide inspector methods for getting names of used extension, and getting all used enable directives' extension names and location. 4. For different writer, the extension nodes are handled in different ways. MSL and HLSL writers will just ignore the extension nodes, while SPIRV and GLSL writers will emit corresponding code. 5. Implement unittests and end2end test for enable directive and inspector, using a reserved extension name `InternalExtensionForTesting`. Bug: tint:1472 Change-Id: I40cb4061554deb477bc2005d7e38c9718385f825 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/86623 Kokoro: Kokoro <noreply+kokoro@google.com> Reviewed-by: Ben Clayton <bclayton@google.com> Commit-Queue: Zhaoming Jiang <zhaoming.jiang@intel.com>
This commit is contained in:
committed by
Dawn LUCI CQ
parent
f92040a3d9
commit
7098d3d692
@@ -93,6 +93,8 @@ void SingleEntryPoint::Run(CloneContext& ctx,
|
||||
if (sem.Get(func)->HasAncestorEntryPoint(entry_point->symbol)) {
|
||||
ctx.dst->AST().AddFunction(ctx.Clone(func));
|
||||
}
|
||||
} else if (auto* ext = decl->As<ast::Enable>()) {
|
||||
ctx.dst->AST().AddEnable(ctx.Clone(ext));
|
||||
} else {
|
||||
TINT_UNREACHABLE(Transform, ctx.dst->Diagnostics())
|
||||
<< "unhandled global declaration: " << decl->TypeInfo().name;
|
||||
|
||||
Reference in New Issue
Block a user