summaryrefslogtreecommitdiffstats
path: root/tests/language-feature
diff options
context:
space:
mode:
authorYong He <yonghe@outlook.com>2025-06-04 13:05:58 -0700
committerGitHub <noreply@github.com>2025-06-04 13:05:58 -0700
commit812e478989e27983b8dea7ab11964de751654ba2 (patch)
treee6db6def9c7896ee48c5fe42926856644e81c0e6 /tests/language-feature
parentb9dc21d362f65f22bc707bede733a9537b80460a (diff)
Make interface types non c-style in Slang2026. (#7260)
* Make interface types non c-style. * Make Optional<T> work with autodiff and existential types. * Fix. * patch behind slang 2026. * Fix warnings. * cleanup. * Fix tests. * Fix. * Fix com interface lowering. * Add comment to test. * regenerate command line reference * Add test for passing `none` to autodiff function. * Fix recording of `getDynamicObjectRTTIBytes`. * Fix nested Optional types. --------- Co-authored-by: slangbot <186143334+slangbot@users.noreply.github.com>
Diffstat (limited to 'tests/language-feature')
-rw-r--r--tests/language-feature/interfaces/optional-none.slang47
-rw-r--r--tests/language-feature/interfaces/zero-init-interface.slang33
-rw-r--r--tests/language-feature/nested-optional.slang35
3 files changed, 82 insertions, 33 deletions
diff --git a/tests/language-feature/interfaces/optional-none.slang b/tests/language-feature/interfaces/optional-none.slang
new file mode 100644
index 000000000..04bb8f83e
--- /dev/null
+++ b/tests/language-feature/interfaces/optional-none.slang
@@ -0,0 +1,47 @@
+// Test that the size of an optional interface type is the same as the existential box.
+
+//TEST:SIMPLE(filecheck=CHECK): -target hlsl -conformance "Impl1:IFoo=1" -entry computeMain -profile cs_6_0
+//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=BUFFER): -output-using-type
+//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=BUFFER): -vk -shaderobj -output-using-type
+
+//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer
+RWStructuredBuffer<int> outputBuffer;
+
+interface IFoo
+{
+ int method();
+}
+
+//TEST_INPUT: type_conformance Impl1:IFoo = 0
+struct Impl1 : IFoo
+{
+ int data;
+ int method() { return data + 1; }
+}
+
+struct MyType
+{
+ Optional<IFoo> foo;
+}
+
+Optional<T> process<T>(Optional<T> opt)
+{
+ return opt;
+}
+
+[numthreads(1, 1, 1)]
+void computeMain(uint3 dispatchThreadID: SV_DispatchThreadID)
+{
+ MyType t = {};
+ t.foo = process(t.foo);
+
+ // BUFFER: 100
+ if (let f = t.foo)
+ outputBuffer[0] = f.method();
+ else
+ outputBuffer[0] = 100;
+}
+
+// CHECK: struct MyType
+// CHECK-NEXT: {
+// CHECK-NEXT: Tuple{{.*}} foo{{.*}}; \ No newline at end of file
diff --git a/tests/language-feature/interfaces/zero-init-interface.slang b/tests/language-feature/interfaces/zero-init-interface.slang
deleted file mode 100644
index ed3b1eaa4..000000000
--- a/tests/language-feature/interfaces/zero-init-interface.slang
+++ /dev/null
@@ -1,33 +0,0 @@
-// Test that we can zero-init a struct with interface typed member.
-
-//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=BUFFER): -shaderobj
-//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=BUFFER): -vk -shaderobj
-
-//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer
-RWStructuredBuffer<int> outputBuffer;
-
-interface IFoo
-{
- int method();
-}
-
-//TEST_INPUT: type_conformance Impl1:IFoo = 0
-struct Impl1 : IFoo
-{
- int data;
- int method() { return data + 1; }
-}
-
-struct MyType
-{
- IFoo foo;
-}
-
-
-[numthreads(1, 1, 1)]
-void computeMain(uint3 dispatchThreadID: SV_DispatchThreadID)
-{
- MyType t = {};
- // BUFFER: 1
- outputBuffer[0] = t.foo.method();
-}
diff --git a/tests/language-feature/nested-optional.slang b/tests/language-feature/nested-optional.slang
new file mode 100644
index 000000000..8fdeac33b
--- /dev/null
+++ b/tests/language-feature/nested-optional.slang
@@ -0,0 +1,35 @@
+//TEST:INTERPRET(filecheck=CHECK):
+
+Optional<Optional<int>> getNone() { return none; }
+
+void main()
+{
+ Optional<Optional<Optional<int>>> val = Optional<Optional<int>>(5);
+ Optional<Optional<Optional<int>>> defaultVal1 = none;
+ Optional<Optional<Optional<int>>> defaultVal2 = getNone();
+
+ // CHECK: 8
+ printf("%d\n", sizeof(val));
+
+ // CHECK: success
+ if (defaultVal1.hasValue == defaultVal2.hasValue)
+ {
+ printf("success\n");
+ }
+ else
+ {
+ printf("failure\n");
+ }
+
+ // CHECK: value: 5
+ if (let x = val)
+ {
+ if (let y = x)
+ {
+ if (let z = y)
+ {
+ printf("value: %d\n", z);
+ }
+ }
+ }
+} \ No newline at end of file