summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/diagnostics/bad-operator-call.slang4
-rw-r--r--tests/language-feature/generics/generic-overload-disambiguation.slang42
-rw-r--r--tests/language-feature/generics/vector-generic.slang19
3 files changed, 63 insertions, 2 deletions
diff --git a/tests/diagnostics/bad-operator-call.slang b/tests/diagnostics/bad-operator-call.slang
index 2764d27ae..2e0a196a2 100644
--- a/tests/diagnostics/bad-operator-call.slang
+++ b/tests/diagnostics/bad-operator-call.slang
@@ -14,7 +14,7 @@ void test()
{
int a;
S b;
- // CHECK:{{.*}}.slang(18): error {{.*}}: no overload for '+=' applicable to arguments of type (int, S)
+ // CHECK:{{.*}}.slang(18): error {{.*}}:
a += b;
// CHECK:{{.*}}.slang(20): error {{.*}}: no overload for '+' applicable to arguments of type (int, S)
a = a + b;
@@ -31,4 +31,4 @@ void test()
d += c;
// CHECK:{{.*}}.slang(33): error {{.*}}: no overload for '+' applicable to arguments of type (vector<int,4>, vector<float,3>)
d = c + d;
-} \ No newline at end of file
+}
diff --git a/tests/language-feature/generics/generic-overload-disambiguation.slang b/tests/language-feature/generics/generic-overload-disambiguation.slang
new file mode 100644
index 000000000..57d7a6d7e
--- /dev/null
+++ b/tests/language-feature/generics/generic-overload-disambiguation.slang
@@ -0,0 +1,42 @@
+//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=CHECK): -shaderobj -output-using-type
+//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=CHECK): -vk -shaderobj -output-using-type
+
+// Test that calls to overloaded generic functions can be resolved to prefer the
+// generic candidate with more specialized constraints.
+interface IBase
+{
+ float get();
+}
+interface IDerived : IBase
+{
+
+}
+float process<T>(T v)
+{
+ return 0.0;
+}
+float process<T : IBase>(T v)
+{
+ return v.get();
+}
+
+float process<T : IDerived>(T v)
+{
+ return v.get() + 1.0;
+}
+
+struct D : IDerived
+{
+ float get() { return 1.0; }
+}
+
+//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer
+RWStructuredBuffer<float> outputBuffer;
+
+[numthreads(1,1,1)]
+void computeMain()
+{
+ D d;
+ outputBuffer[0] = process(d);
+ // CHECK: 2.0
+}
diff --git a/tests/language-feature/generics/vector-generic.slang b/tests/language-feature/generics/vector-generic.slang
new file mode 100644
index 000000000..6bcd88018
--- /dev/null
+++ b/tests/language-feature/generics/vector-generic.slang
@@ -0,0 +1,19 @@
+//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=CHECK): -shaderobj -output-using-type
+//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=CHECK): -vk -shaderobj -output-using-type
+
+// Test that generic argument inference works when passing a scalar to a generic vector parameter.
+T process<T, let N : int>(vector<T, N> v)
+{
+ return v[0];
+}
+
+//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer
+RWStructuredBuffer<float> outputBuffer;
+
+[numthreads(1,1,1)]
+void computeMain()
+{
+ float a = 1.0;
+ outputBuffer[0] = process(a);
+ // CHECK: 1.0
+}