summaryrefslogtreecommitdiffstats
path: root/tests/current-bugs/generic/fixed-array-5.slang
diff options
context:
space:
mode:
authorjsmall-nvidia <jsmall@nvidia.com>2021-12-21 12:11:08 -0500
committerGitHub <noreply@github.com>2021-12-21 12:11:08 -0500
commitd7ed829c3f85514fc08a12a5701d64390b31040c (patch)
tree4df957344ad0d5285359a2df541d69f76196b731 /tests/current-bugs/generic/fixed-array-5.slang
parent48530f4c3505d1ab6269a5c21881492f059538d6 (diff)
Assorted disabled tests around generics (#2062)
* #include an absolute path didn't work - because paths were taken to always be relative. * Some generic experiments. * Add some more generic tests. * More generic experiments/issues. * Some more generic tests. * Remove erroneous test. * Small improvements. * Disable test that was accidentally enabled. * Add equality-2.slang. * Some more generic tests. * Issues around type inference. * Some more generic tests. * Tuple experiment. * Generic interfaces don't seem to be supported. * Add inheritance test. * Alternative array type issue.
Diffstat (limited to 'tests/current-bugs/generic/fixed-array-5.slang')
-rw-r--r--tests/current-bugs/generic/fixed-array-5.slang61
1 files changed, 61 insertions, 0 deletions
diff --git a/tests/current-bugs/generic/fixed-array-5.slang b/tests/current-bugs/generic/fixed-array-5.slang
new file mode 100644
index 000000000..6d0c6f8b9
--- /dev/null
+++ b/tests/current-bugs/generic/fixed-array-5.slang
@@ -0,0 +1,61 @@
+//DISABLE_TEST(compute):COMPARE_COMPUTE_EX:-slang -compute -shaderobj
+
+/* A test around use of an array like container.
+
+Here the attempt is to make the equality test separate from the type.
+This isn't a great answer because it relies on the right types set
+for T and E to work together.
+
+This doesn't work because...
+.slang(25): error 30019: expected an expression of type 'Type', got 'T'
+ if (E::isEqual(v, elements[i]))
+
+ */
+
+//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name outputBuffer
+RWStructuredBuffer<float> outputBuffer;
+
+interface IEquality
+{
+ associatedtype Type;
+ static bool isEqual(Type a, Type b);
+};
+
+struct IntEquality : IEquality
+{
+ typedef int Type;
+ static bool isEqual(Type a, Type b) { return a == b; }
+};
+
+struct FixedArray<T, E : IEquality>
+{
+ static const int SIZE = 4;
+
+ [mutating] void setAt(int i, T value) { elements[i] = value; }
+ T getAt(int i) { return elements[i]; }
+ int indexOf(T v)
+ {
+ for (int i = 0; i < SIZE; ++i)
+ {
+ if (E::isEqual(v, elements[i]))
+ {
+ return i;
+ }
+ return -1;
+ }
+ }
+ T elements[SIZE];
+};
+
+
+[numthreads(4, 1, 1)]
+void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID)
+{
+ int index = dispatchThreadID.x;
+
+ FixedArray<int, IntEquality> arr;
+ arr.setAt(0, index);
+
+ outputBuffer[index] = 1 + arr.getAt(0);
+}
+