From 95b0b0f8bc47fa4ae59c1e2dab1dcd667fb729dd Mon Sep 17 00:00:00 2001 From: Petr Ohlidal Date: Fri, 5 Mar 2021 20:11:17 +0100 Subject: [PATCH] :bug: Fixed missing 'nocast' in ODEF format Accidentally dropped while creating standalone ODEF parser, see https://github.com/RigsOfRods/rigs-of-rods/commit/2046c336068ffd0e024c6b5710fe2113c14cf559 Credit goes to @tritonas00 for discovering. --- source/main/resources/odef_fileformat/ODefFileFormat.cpp | 5 +++++ source/main/resources/odef_fileformat/ODefFileFormat.h | 1 + source/main/terrain/TerrainObjectManager.cpp | 1 + 3 files changed, 7 insertions(+) diff --git a/source/main/resources/odef_fileformat/ODefFileFormat.cpp b/source/main/resources/odef_fileformat/ODefFileFormat.cpp index 87d045c0f9..779990d2b8 100644 --- a/source/main/resources/odef_fileformat/ODefFileFormat.cpp +++ b/source/main/resources/odef_fileformat/ODefFileFormat.cpp @@ -291,6 +291,11 @@ bool ODefParser::ProcessCurrentLine() m_def->collision_meshes.emplace_back( m_ctx.cbox_mesh_name, m_ctx.header_scale, m_ctx.cbox_groundmodel_name); } + else if (line_str == "nocast") + { + m_def->header.cast_shadows = false; + } + return true; } diff --git a/source/main/resources/odef_fileformat/ODefFileFormat.h b/source/main/resources/odef_fileformat/ODefFileFormat.h index c86c5d4bc3..5b06950179 100644 --- a/source/main/resources/odef_fileformat/ODefFileFormat.h +++ b/source/main/resources/odef_fileformat/ODefFileFormat.h @@ -121,6 +121,7 @@ struct ODefFile { std::string mesh_name; Ogre::Vector3 scale; + bool cast_shadows = true; } header; bool mode_standard = false; diff --git a/source/main/terrain/TerrainObjectManager.cpp b/source/main/terrain/TerrainObjectManager.cpp index ca6693bd6e..b97695e3b6 100644 --- a/source/main/terrain/TerrainObjectManager.cpp +++ b/source/main/terrain/TerrainObjectManager.cpp @@ -579,6 +579,7 @@ void TerrainObjectManager::LoadTerrainObject(const Ogre::String& name, const Ogr { Str<100> ebuf; ebuf << m_entity_counter++ << "-" << odef->header.mesh_name; mo = new MeshObject(odef->header.mesh_name, m_resource_group, ebuf.ToCStr(), tenode); + mo->getEntity()->setCastShadows(odef->header.cast_shadows); m_mesh_objects.push_back(mo); }