summaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorAlexandre Bléron <alex.bleron@gmail.com>2025-02-26 22:43:57 +0100
committerGitHub <noreply@github.com>2025-02-26 13:43:57 -0800
commit86669cbb781840f8de180b1f793275f4511d3b65 (patch)
treec28f261a15e3ea69f8a0ab533d484140fa780ec2 /include
parent519e866ff44ec728f95c191fff8a200b66a5377e (diff)
expose value of constant integers in module reflection (#6367)
* Expose value of constant integers in module reflection This commit adds `VariableReflection::getDefaultValueInt` to get the value of a variable if it is a compile-time constant integer. TODO: currently it works only if the initializer expression is an integer literal, references to other constant values are not handled. * Update VarDecl folded constant value during DeclBodyVisitor Constant folding for integer values is already done internally by _validateCircularVarDefinition, this just reuses the result. * Address review comments & formatting * Formatting --------- Co-authored-by: Yong He <yonghe@outlook.com>
Diffstat (limited to 'include')
-rw-r--r--include/slang-deprecated.h2
-rw-r--r--include/slang.h5
2 files changed, 7 insertions, 0 deletions
diff --git a/include/slang-deprecated.h b/include/slang-deprecated.h
index 82d81af75..df6e41488 100644
--- a/include/slang-deprecated.h
+++ b/include/slang-deprecated.h
@@ -659,6 +659,8 @@ extern "C"
SlangSession* globalSession,
char const* name);
SLANG_API bool spReflectionVariable_HasDefaultValue(SlangReflectionVariable* inVar);
+ SLANG_API SlangResult
+ spReflectionVariable_GetDefaultValueInt(SlangReflectionVariable* inVar, int64_t* rs);
SLANG_API SlangReflectionGeneric* spReflectionVariable_GetGenericContainer(
SlangReflectionVariable* var);
SLANG_API SlangReflectionVariable* spReflectionVariable_applySpecializations(
diff --git a/include/slang.h b/include/slang.h
index af635e3c4..54647b830 100644
--- a/include/slang.h
+++ b/include/slang.h
@@ -2832,6 +2832,11 @@ struct VariableReflection
return spReflectionVariable_HasDefaultValue((SlangReflectionVariable*)this);
}
+ SlangResult getDefaultValueInt(int64_t* value)
+ {
+ return spReflectionVariable_GetDefaultValueInt((SlangReflectionVariable*)this, value);
+ }
+
GenericReflection* getGenericContainer()
{
return (GenericReflection*)spReflectionVariable_GetGenericContainer(