From 584e9098468f96bb5af7eb6896afd5cd5e161c35 Mon Sep 17 00:00:00 2001 From: hiker Date: Tue, 30 Sep 2014 10:47:10 +1000 Subject: [PATCH] Use a separaet asset class for library object to avoid hardcoding the name of library directory (and avoid searching for files in more than one directory). --- src/io/file_manager.cpp | 5 +++-- src/io/file_manager.hpp | 2 +- src/tracks/track.cpp | 3 ++- 3 files changed, 6 insertions(+), 4 deletions(-) diff --git a/src/io/file_manager.cpp b/src/io/file_manager.cpp index fecf0f3b2..c9dc8d98e 100644 --- a/src/io/file_manager.cpp +++ b/src/io/file_manager.cpp @@ -114,13 +114,14 @@ FileManager::FileManager() m_subdir_name[GFX ] = "gfx"; m_subdir_name[GRANDPRIX ] = "grandprix"; m_subdir_name[GUI ] = "gui"; + m_subdir_name[LIBRARY ] = "library"; m_subdir_name[MODEL ] = "models"; m_subdir_name[MUSIC ] = "music"; - m_subdir_name[TRANSLATION] = "po"; - m_subdir_name[TEXTURE ] = "textures"; m_subdir_name[SFX ] = "sfx"; m_subdir_name[SKIN ] = "skins"; m_subdir_name[SHADER ] = "shaders"; + m_subdir_name[TEXTURE ] = "textures"; + m_subdir_name[TRANSLATION] = "po"; #ifdef __APPLE__ // irrLicht's createDevice method has a nasty habit of messing the CWD. // since the code above may rely on it, save it to be able to restore diff --git a/src/io/file_manager.hpp b/src/io/file_manager.hpp index 986f0df69..2e804be0d 100644 --- a/src/io/file_manager.hpp +++ b/src/io/file_manager.hpp @@ -48,7 +48,7 @@ public: * The last entry ASSET_COUNT specifies the number of entries. */ enum AssetType {ASSET_MIN, CHALLENGE=ASSET_MIN, - FONT, GFX, GRANDPRIX, GUI, MODEL, MUSIC, + FONT, GFX, GRANDPRIX, GUI, LIBRARY, MODEL, MUSIC, SFX, SHADER, SKIN, TEXTURE, TRANSLATION, ASSET_MAX = TRANSLATION, ASSET_COUNT}; diff --git a/src/tracks/track.cpp b/src/tracks/track.cpp index 39a640d2c..076458a5b 100644 --- a/src/tracks/track.cpp +++ b/src/tracks/track.cpp @@ -1939,7 +1939,8 @@ void Track::loadObjects(const XMLNode* root, const std::string& path, ModelDefin node->get("scale", &scale); XMLNode* libroot; - std::string lib_path = file_manager->getAsset("library/" + name)+"/"; + std::string lib_path = + file_manager->getAsset(FileManager::LIBRARY, name)+"/"; bool create_lod_definitions = true; if (library_nodes.find(name) == library_nodes.end())