From f3fe9dddb8c528b4f9955d9105908600b4a8d0c8 Mon Sep 17 00:00:00 2001 From: Tim Foley Date: Fri, 7 Jul 2017 13:34:23 -0700 Subject: Map HLSL `lerp` to GLSL `mix` - Also fix a bug in `emit.cpp` where I wasn't detecting `__intrinsic` remaps that don't include `$` (this is a byproduct of changing the string index type to be unsigned; other bugs like this may be lurking) --- source/slang/emit.cpp | 2 +- source/slang/slang-stdlib.cpp | 17 ++++++++++++++--- 2 files changed, 15 insertions(+), 4 deletions(-) diff --git a/source/slang/emit.cpp b/source/slang/emit.cpp index 5d85b4d57..df74d19e4 100644 --- a/source/slang/emit.cpp +++ b/source/slang/emit.cpp @@ -1466,7 +1466,7 @@ struct EmitVisitor { auto name = getStringOrIdentifierTokenValue(targetIntrinsicModifier->definitionToken); - if(name.IndexOf('$') < 0) + if(name.IndexOf('$') == -1) { // Simple case: it is just an ordinary name, so we call it like a builtin. // diff --git a/source/slang/slang-stdlib.cpp b/source/slang/slang-stdlib.cpp index 87c2c2e8a..e1bba8885 100644 --- a/source/slang/slang-stdlib.cpp +++ b/source/slang/slang-stdlib.cpp @@ -592,9 +592,20 @@ __generic __intrinsic __generic __intrinsic T length(vector x); // Linear interpolation -__generic __intrinsic T lerp(T x, T y, T s); -__generic __intrinsic vector lerp(vector x, vector y, vector s); -__generic __intrinsic matrix lerp(matrix x, matrix y, matrix s); +__generic +__intrinsic(glsl, mix) +__intrinsic +T lerp(T x, T y, T s); + +__generic +__intrinsic(glsl, mix) +__intrinsic +vector lerp(vector x, vector y, vector s); + +__generic +__intrinsic(glsl, mix) +__intrinsic +matrix lerp(matrix x, matrix y, matrix s); // Legacy lighting function (obsolete) __intrinsic float4 lit(float n_dot_l, float n_dot_h, float m); -- cgit v1.2.3