From 447b7e0e2be031409b1421b49c81f020353bf7c5 Mon Sep 17 00:00:00 2001 From: jsmall-nvidia Date: Tue, 21 Dec 2021 16:35:34 -0500 Subject: 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. --- tests/experiments/generic/param-specialize.slang | 44 ++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 tests/experiments/generic/param-specialize.slang (limited to 'tests/experiments/generic/param-specialize.slang') diff --git a/tests/experiments/generic/param-specialize.slang b/tests/experiments/generic/param-specialize.slang new file mode 100644 index 000000000..cff623827 --- /dev/null +++ b/tests/experiments/generic/param-specialize.slang @@ -0,0 +1,44 @@ +//DISABLE_TEST(compute):COMPARE_COMPUTE_EX:-slang -compute -shaderobj + +/* This test trys to specialize an algorithm through generic parameters. + +Using parameters in this way ensures the algorithm in function form +will have those values known at compile time, and presumably lead to a specialized version. + +Does not work because + +.slang(24): error 30019: expected an expression of type 'int', got 'Enum' + let v = doThing(); + ^ + +Note that docs say doesn't support any other than int, but error is a bit confusing. No error at declaration. +*/ + +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name outputBuffer +RWStructuredBuffer outputBuffer; + +enum class Enum +{ + A, B +}; + +int doThing() +{ + if (a) + { + return 1; + } + return 0; + // A more complex scenario + //return a ? b + b + int(c) : b - int(c); +} + +[numthreads(4, 1, 1)] +void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID) +{ + int index = dispatchThreadID.x; + + let v = doThing(); + + outputBuffer[dispatchThreadID.x] = v; +} \ No newline at end of file -- cgit v1.2.3