summaryrefslogtreecommitdiff
path: root/tests/current-bugs/generic/enum-flags.slang
diff options
context:
space:
mode:
authorjsmall-nvidia <jsmall@nvidia.com>2021-12-21 16:35:34 -0500
committerGitHub <noreply@github.com>2021-12-21 16:35:34 -0500
commit447b7e0e2be031409b1421b49c81f020353bf7c5 (patch)
tree721a1e892b4dc0bcc8c62d7b7e3f9dbb843bf958 /tests/current-bugs/generic/enum-flags.slang
parentd7ed829c3f85514fc08a12a5701d64390b31040c (diff)
Language experiments (#2068)
* #include an absolute path didn't work - because paths were taken to always be relative. * Moved to experiments. Added some more tests. * More tests around associated types. * Return interface tests. * More tests.
Diffstat (limited to 'tests/current-bugs/generic/enum-flags.slang')
-rw-r--r--tests/current-bugs/generic/enum-flags.slang40
1 files changed, 0 insertions, 40 deletions
diff --git a/tests/current-bugs/generic/enum-flags.slang b/tests/current-bugs/generic/enum-flags.slang
deleted file mode 100644
index 2afee720f..000000000
--- a/tests/current-bugs/generic/enum-flags.slang
+++ /dev/null
@@ -1,40 +0,0 @@
-//DISABLE_TEST(compute):COMPARE_COMPUTE_EX:-slang -compute -shaderobj
-
-/* A test to use generics to treat an enum as a set.
-
-Doesn't work because the integer ops required for Flags impl, can't be seen */
-
-//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name outputBuffer
-RWStructuredBuffer<float> outputBuffer;
-
-enum Enum
-{
- A = 0x1,
- B = 0x2,
- C = 0x4,
-};
-
-__generic<E, B : __BuiltinIntegerType>
-struct Flags
-{
- [mutating] void set(E e) { value |= (B)e; }
- void isSet(E e) { return (((B)e) & value) != 0; }
- B value = 0;
-};
-
-[numthreads(4, 1, 1)]
-void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID)
-{
- int index = dispatchThreadID.x;
-
- Flags<Enum, uint8_t> flags;
-
- if (index & 1)
- {
- flags.set(Enum::A);
- }
- bool isASet = flags.isSet(Enum::A);
-
- outputBuffer[index] = isASet ? 2 : 1;
-}
-