summaryrefslogtreecommitdiffstats
path: root/servers
diff options
context:
space:
mode:
authorChaosus <chaosus89@gmail.com>2024-11-02 12:12:19 +0300
committerChaosus <chaosus89@gmail.com>2024-11-02 12:13:23 +0300
commit5efe8ccdead82e10fcfc68779d1872ca75bddfe3 (patch)
tree00dded80629beb361ecbcbbe28f0d4ab769ec475 /servers
parentc6c464cf9ae56e8b68620af65125dd980d0e8122 (diff)
downloadredot-engine-5efe8ccdead82e10fcfc68779d1872ca75bddfe3.tar.gz
Add prefix to struct member names in shader compiler
Diffstat (limited to 'servers')
-rw-r--r--servers/rendering/shader_compiler.cpp10
1 files changed, 8 insertions, 2 deletions
diff --git a/servers/rendering/shader_compiler.cpp b/servers/rendering/shader_compiler.cpp
index 119ac677eb..f52963f98f 100644
--- a/servers/rendering/shader_compiler.cpp
+++ b/servers/rendering/shader_compiler.cpp
@@ -489,7 +489,7 @@ String ShaderCompiler::_dump_node_code(const SL::Node *p_node, int p_level, Gene
struct_code += _typestr(m->datatype);
}
struct_code += " ";
- struct_code += m->name;
+ struct_code += _mkid(m->name);
if (m->array_size > 0) {
struct_code += "[";
struct_code += itos(m->array_size);
@@ -1448,7 +1448,13 @@ String ShaderCompiler::_dump_node_code(const SL::Node *p_node, int p_level, Gene
} break;
case SL::Node::NODE_TYPE_MEMBER: {
SL::MemberNode *mnode = (SL::MemberNode *)p_node;
- code = _dump_node_code(mnode->owner, p_level, r_gen_code, p_actions, p_default_actions, p_assigning) + "." + mnode->name;
+ String name;
+ if (mnode->basetype == SL::TYPE_STRUCT) {
+ name = _mkid(mnode->name);
+ } else {
+ name = mnode->name;
+ }
+ code = _dump_node_code(mnode->owner, p_level, r_gen_code, p_actions, p_default_actions, p_assigning) + "." + name;
if (mnode->index_expression != nullptr) {
code += "[";
code += _dump_node_code(mnode->index_expression, p_level, r_gen_code, p_actions, p_default_actions, p_assigning);