From d7ed829c3f85514fc08a12a5701d64390b31040c Mon Sep 17 00:00:00 2001 From: jsmall-nvidia Date: Tue, 21 Dec 2021 12:11:08 -0500 Subject: 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. --- .../current-bugs/generic/mutating-interface.slang | 51 ++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 tests/current-bugs/generic/mutating-interface.slang (limited to 'tests/current-bugs/generic/mutating-interface.slang') diff --git a/tests/current-bugs/generic/mutating-interface.slang b/tests/current-bugs/generic/mutating-interface.slang new file mode 100644 index 000000000..2198b56b2 --- /dev/null +++ b/tests/current-bugs/generic/mutating-interface.slang @@ -0,0 +1,51 @@ +//DISABLE_TEST(compute):COMPARE_COMPUTE_EX:-slang -compute -shaderobj + +/* A test using interfaces with mutation. + +Doesn't work because + +.slang(18): error 30050: mutating method 'lock' cannot be called on an immutable value + lockable.lock(); + +If that section is removed we get on `doThing(count)` + +.slang(31): error 30047: argument passed to parameter '0' must be l-value. + +Which perhaps means an inteface cannot be used as a lvalue? +*/ + +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name outputBuffer +RWStructuredBuffer outputBuffer; + +interface ILockable +{ + [mutating] void lock(); + [mutating] void unlock(); +}; + +struct IntCount : ILockable +{ + [mutating] void lock() { count ++; } + [mutating] void unlock() { --count; } + int count = 0; +}; + +int doThing(inout ILockable lockable) +{ + lockable.lock(); + // do something... + + lockable.unlock(); + return 0; +} + +[numthreads(4, 1, 1)] +void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID) +{ + int index = dispatchThreadID.x; + + IntCount count; + doThing(count); + + outputBuffer[dispatchThreadID.x] = count.count; +} \ No newline at end of file -- cgit v1.2.3