From d964555d2ee83fac2ba357e4ec81e2a393a7b12f Mon Sep 17 00:00:00 2001 From: Copilot <198982749+Copilot@users.noreply.github.com> Date: Tue, 15 Jul 2025 10:11:39 +0000 Subject: Replace [KnownBuiltin] string-based comparisons with enum-based system (#7714) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Initial plan * Implement enum-based KnownBuiltin system to replace string comparisons Co-authored-by: csyonghe <2652293+csyonghe@users.noreply.github.com> * Add test for enum-based KnownBuiltin system and verify functionality Co-authored-by: csyonghe <2652293+csyonghe@users.noreply.github.com> * Implement enum-based KnownBuiltin system with direct integer values Co-authored-by: csyonghe <2652293+csyonghe@users.noreply.github.com> * Fix IntVal access and update tests for new enum-based KnownBuiltin system Co-authored-by: csyonghe <2652293+csyonghe@users.noreply.github.com> * Replace hardcoded KnownBuiltin integers with preprocessor enum syntax - Updated all KnownBuiltin attributes to use $( (int)KnownBuiltinDeclName::EnumValue) syntax - Added space between parentheses to avoid preprocessor bug: $( (int) instead of $((int) - Updated both core.meta.slang and hlsl.meta.slang files - Eliminates preprocessor-time integer conversion, baking enum values directly into meta files - Maintains same functionality while using type-safe enum references Co-authored-by: csyonghe <2652293+csyonghe@users.noreply.github.com> * Fix IDifferentiablePtr KnownBuiltin mapping regression Co-authored-by: csyonghe <2652293+csyonghe@users.noreply.github.com> * Remove unused IDifferentiablePtrType enum case from KnownBuiltinDeclName Co-authored-by: csyonghe <2652293+csyonghe@users.noreply.github.com> * Clean up temporary AST dump files from testing Co-authored-by: csyonghe <2652293+csyonghe@users.noreply.github.com> * Replace hardcoded integer with descriptive constant in KnownBuiltin test Replace the hardcoded [KnownBuiltin(0)] with a descriptive named constant GEOMETRY_STREAM_APPEND_BUILTIN to improve code readability and maintainability. The test now clearly indicates which builtin enum value is being tested. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-authored-by: Gangzheng Tong --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: csyonghe <2652293+csyonghe@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: Gangzheng Tong Co-authored-by: Gangzheng Tong --- source/slang/slang-ir-util.cpp | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) (limited to 'source/slang/slang-ir-util.cpp') diff --git a/source/slang/slang-ir-util.cpp b/source/slang/slang-ir-util.cpp index 69bd2c6c2..c8d76569f 100644 --- a/source/slang/slang-ir-util.cpp +++ b/source/slang/slang-ir-util.cpp @@ -1775,6 +1775,38 @@ UnownedStringSlice getBuiltinFuncName(IRInst* callee) auto decor = getResolvedInstForDecorations(callee)->findDecoration(); if (!decor) return UnownedStringSlice(); + + // For backward compatibility, convert enum back to string + switch (decor->getName()) + { + case KnownBuiltinDeclName::GeometryStreamAppend: + return UnownedStringSlice::fromLiteral("GeometryStreamAppend"); + case KnownBuiltinDeclName::GeometryStreamRestart: + return UnownedStringSlice::fromLiteral("GeometryStreamRestart"); + case KnownBuiltinDeclName::GetAttributeAtVertex: + return UnownedStringSlice::fromLiteral("GetAttributeAtVertex"); + case KnownBuiltinDeclName::DispatchMesh: + return UnownedStringSlice::fromLiteral("DispatchMesh"); + case KnownBuiltinDeclName::saturated_cooperation: + return UnownedStringSlice::fromLiteral("saturated_cooperation"); + case KnownBuiltinDeclName::saturated_cooperation_using: + return UnownedStringSlice::fromLiteral("saturated_cooperation_using"); + case KnownBuiltinDeclName::IDifferentiable: + return UnownedStringSlice::fromLiteral("IDifferentiable"); + case KnownBuiltinDeclName::IDifferentiablePtr: + return UnownedStringSlice::fromLiteral("IDifferentiablePtr"); + case KnownBuiltinDeclName::NullDifferential: + return UnownedStringSlice::fromLiteral("NullDifferential"); + default: + return UnownedStringSlice(); + } +} + +KnownBuiltinDeclName getBuiltinFuncEnum(IRInst* callee) +{ + auto decor = getResolvedInstForDecorations(callee)->findDecoration(); + if (!decor) + return KnownBuiltinDeclName::COUNT; // Use COUNT as invalid value return decor->getName(); } -- cgit v1.2.3