From 8da15440e08bc7223c2014972c9effe1c97c1def Mon Sep 17 00:00:00 2001 From: Marc Zinnschlag Date: Mon, 26 Sep 2011 11:11:30 +0200 Subject: [PATCH 1/6] Issue #31: added function for creating cell records --- apps/openmw/mwworld/world.cpp | 23 +++++++++++++++++++++++ apps/openmw/mwworld/world.hpp | 4 ++++ components/esm_store/reclists.hpp | 15 ++++++++++++--- 3 files changed, 39 insertions(+), 3 deletions(-) diff --git a/apps/openmw/mwworld/world.cpp b/apps/openmw/mwworld/world.cpp index ee1a0ad2d4..cbc940ec79 100644 --- a/apps/openmw/mwworld/world.cpp +++ b/apps/openmw/mwworld/world.cpp @@ -722,4 +722,27 @@ namespace MWWorld return std::make_pair (stream.str(), created); } + + const ESM::Cell *World::createRecord (const ESM::Cell& record) + { + if (record.data.flags & ESM::Cell::Interior) + { + if (mStore.cells.searchInt (record.name)) + throw std::runtime_error ("failed creating interior cell"); + + ESM::Cell *cell = new ESM::Cell (record); + mStore.cells.intCells.insert (std::make_pair (record.name, cell)); + return cell; + } + else + { + if (mStore.cells.searchExt (record.data.gridX, record.data.gridY)) + throw std::runtime_error ("failed creating exterior cell"); + + ESM::Cell *cell = new ESM::Cell (record); + mStore.cells.extCells.insert ( + std::make_pair (std::make_pair (record.data.gridX, record.data.gridY), cell)); + return cell; + } + } } diff --git a/apps/openmw/mwworld/world.hpp b/apps/openmw/mwworld/world.hpp index 90d6121634..89c6057fa8 100644 --- a/apps/openmw/mwworld/world.hpp +++ b/apps/openmw/mwworld/world.hpp @@ -207,6 +207,10 @@ namespace MWWorld std::pair createRecord (const ESM::Class& record); ///< Create a new recrod (of type class) in the ESM store. /// \return ID, pointer to created record + + const ESM::Cell *createRecord (const ESM::Cell& record); + ///< Create a new recrod (of type cell) in the ESM store. + /// \return ID, pointer to created record }; } diff --git a/components/esm_store/reclists.hpp b/components/esm_store/reclists.hpp index 7d3afbb96b..20a2e8ff95 100644 --- a/components/esm_store/reclists.hpp +++ b/components/esm_store/reclists.hpp @@ -305,15 +305,24 @@ namespace ESMS delete it->second; } + const ESM::Cell* searchInt(const std::string &id) const + { + IntCells::const_iterator iter = intCells.find(id); + + if (iter!=intCells.end()) + return iter->second; + + return 0; + } const ESM::Cell* findInt(const std::string &id) const { - IntCells::const_iterator it = intCells.find(id); + const ESM::Cell *cell = searchInt (id); - if(it == intCells.end()) + if (!cell) throw std::runtime_error ("Interior cell not found - " + id); - return it->second; + return cell; } const ESM::Cell *searchExt (int x, int y) const From b866323cf31f4714960d6e7284af7ba35d37df3e Mon Sep 17 00:00:00 2001 From: Marc Zinnschlag Date: Tue, 27 Sep 2011 10:08:07 +0200 Subject: [PATCH 2/6] Issue #31: create new exterior cells on the fly --- apps/openmw/mwworld/cells.cpp | 22 +++++++++++++++++++--- apps/openmw/mwworld/cells.hpp | 7 ++++++- apps/openmw/mwworld/world.cpp | 2 +- 3 files changed, 26 insertions(+), 5 deletions(-) diff --git a/apps/openmw/mwworld/cells.cpp b/apps/openmw/mwworld/cells.cpp index 7d04cfc687..143ce557b5 100644 --- a/apps/openmw/mwworld/cells.cpp +++ b/apps/openmw/mwworld/cells.cpp @@ -4,6 +4,8 @@ #include +#include "world.hpp" + MWWorld::Ptr::CellStore *MWWorld::Cells::getCellStore (const ESM::Cell *cell) { if (cell->data.flags & ESM::Cell::Interior) @@ -33,8 +35,8 @@ MWWorld::Ptr::CellStore *MWWorld::Cells::getCellStore (const ESM::Cell *cell) } } -MWWorld::Cells::Cells (const ESMS::ESMStore& store, ESM::ESMReader& reader) -: mStore (store), mReader (reader) {} +MWWorld::Cells::Cells (const ESMS::ESMStore& store, ESM::ESMReader& reader, MWWorld::World& world) +: mStore (store), mReader (reader), mWorld (world) {} MWWorld::Ptr::CellStore *MWWorld::Cells::getExterior (int x, int y) { @@ -43,7 +45,21 @@ MWWorld::Ptr::CellStore *MWWorld::Cells::getExterior (int x, int y) if (result==mExteriors.end()) { - const ESM::Cell *cell = mStore.cells.findExt (x, y); + const ESM::Cell *cell = mStore.cells.searchExt (x, y); + + if (!cell) + { + // Cell isn't predefined. Make one on the fly. + ESM::Cell record; + + record.data.flags = 0; + record.data.gridX = x; + record.data.gridY = y; + record.water = 0; + record.mapColor = 0; + + cell = mWorld.createRecord (record); + } result = mExteriors.insert (std::make_pair ( std::make_pair (x, y), Ptr::CellStore (cell))).first; diff --git a/apps/openmw/mwworld/cells.hpp b/apps/openmw/mwworld/cells.hpp index 661969881f..0ecbd02d37 100644 --- a/apps/openmw/mwworld/cells.hpp +++ b/apps/openmw/mwworld/cells.hpp @@ -18,6 +18,8 @@ namespace ESM namespace MWWorld { + class World; + /// \brief Cell container class Cells { @@ -25,6 +27,7 @@ namespace MWWorld ESM::ESMReader& mReader; std::map mInteriors; std::map, Ptr::CellStore> mExteriors; + MWWorld::World& mWorld; Cells (const Cells&); Cells& operator= (const Cells&); @@ -33,7 +36,9 @@ namespace MWWorld public: - Cells (const ESMS::ESMStore& store, ESM::ESMReader& reader); + Cells (const ESMS::ESMStore& store, ESM::ESMReader& reader, MWWorld::World& world); + ///< \todo pass the dynamic part of the ESMStore isntead (once it is written) of the whole + /// world Ptr::CellStore *getExterior (int x, int y); diff --git a/apps/openmw/mwworld/world.cpp b/apps/openmw/mwworld/world.cpp index cbc940ec79..906d92c9f1 100644 --- a/apps/openmw/mwworld/world.cpp +++ b/apps/openmw/mwworld/world.cpp @@ -214,7 +214,7 @@ namespace MWWorld const std::string& master, const boost::filesystem::path& resDir, bool newGame, Environment& environment, const std::string& encoding) : mScene (renderer,physEng), mPlayer (0), mGlobalVariables (0), - mSky (false), mEnvironment (environment), mNextDynamicRecord (0), mCells (mStore, mEsm) + mSky (false), mEnvironment (environment), mNextDynamicRecord (0), mCells (mStore, mEsm, *this) { mPhysEngine = physEng; From b448fc7d4cff41cc4df1c5e3754666db6dc95c91 Mon Sep 17 00:00:00 2001 From: Marc Zinnschlag Date: Tue, 27 Sep 2011 10:22:55 +0200 Subject: [PATCH 3/6] Issue #31: Do not try to load dynamical generated cells from ESM/P files --- components/esm_store/cell_store.hpp | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/components/esm_store/cell_store.hpp b/components/esm_store/cell_store.hpp index 1336cc2ab3..19cb34c014 100644 --- a/components/esm_store/cell_store.hpp +++ b/components/esm_store/cell_store.hpp @@ -189,6 +189,9 @@ namespace ESMS { assert (cell); + if (cell->context.filename.empty()) + return; // this is a dynamically generated cell -> skipping. + // Reopen the ESM reader and seek to the right position. cell->restore (esm); @@ -212,6 +215,9 @@ namespace ESMS { assert (cell); + if (cell->context.filename.empty()) + return; // this is a dynamically generated cell -> skipping. + // Reopen the ESM reader and seek to the right position. cell->restore(esm); From 695452e1a38ee9bcedbfac565fd638d761af4b79 Mon Sep 17 00:00:00 2001 From: Marc Zinnschlag Date: Thu, 29 Sep 2011 09:02:06 +0200 Subject: [PATCH 4/6] Issue #169: Don't continue to run local scripts after the reference the script is attached to has been deleted --- apps/openmw/mwworld/world.cpp | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/apps/openmw/mwworld/world.cpp b/apps/openmw/mwworld/world.cpp index 906d92c9f1..f2e846ef44 100644 --- a/apps/openmw/mwworld/world.cpp +++ b/apps/openmw/mwworld/world.cpp @@ -574,6 +574,14 @@ namespace MWWorld mEnvironment.mSoundManager->stopSound3D (ptr); mPhysics->removeObject (ptr.getRefData().getHandle()); + + for (ScriptList::iterator iter = mLocalScripts.begin(); iter!=mLocalScripts.end(); + ++iter) + if (ptr==iter->second) + { + mLocalScripts.erase (iter); + break; + } } render->deleteObject (ptr.getRefData().getHandle()); From a6ffa1a82a30b302263e7f9affb77cbfd1383fff Mon Sep 17 00:00:00 2001 From: gugus Date: Thu, 29 Sep 2011 14:59:20 +0200 Subject: [PATCH 5/6] Allow not to build the launcher --- CMakeLists.txt | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index f4be17e904..a1b054853a 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -514,7 +514,10 @@ if (BUILD_ESMTOOL) add_subdirectory( apps/esmtool ) endif() -add_subdirectory( apps/launcher ) +option(BUILD_LAUNCHER "build Launcher inspector" ON) +if (BUILD_LAUNCHER) + add_subdirectory( apps/launcher ) +endif() if (WIN32) if (MSVC) From 9872c895397e46e6c488a12ea5d80cbfe6d84b6c Mon Sep 17 00:00:00 2001 From: Marc Zinnschlag Date: Fri, 30 Sep 2011 09:36:06 +0200 Subject: [PATCH 6/6] packaging fixes for .deb packages --- CMakeLists.txt | 8 ++++++-- apps/launcher/CMakeLists.txt | 4 ++++ 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index f99b41496c..07c1c821b0 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -452,6 +452,10 @@ if(DPKG_PROGRAM) set(PACKAGE_MAINTAINER "unknown") endif() + #Install icon and desktop file + INSTALL(FILES "${OpenMW_SOURCE_DIR}/files/openmw.desktop" DESTINATION "share/applications/" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ COMPONENT "openmw") + INSTALL(FILES "${OpenMW_SOURCE_DIR}/apps/launcher/resources/images/openmw.png" DESTINATION "share/pixmaps/" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ COMPONENT "openmw") + #Install global configuration files INSTALL(FILES "${OpenMW_BINARY_DIR}/openmw.cfg.install" DESTINATION "../etc/openmw/" RENAME "openmw.cfg" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ COMPONENT "openmw") INSTALL(FILES "${OpenMW_BINARY_DIR}/plugins.cfg" DESTINATION "../etc/openmw/" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ COMPONENT "openmw") @@ -470,8 +474,8 @@ if(DPKG_PROGRAM) Data files from the original game is required to run it.") SET(CPACK_DEBIAN_PACKAGE_NAME "openmw") SET(CPACK_DEBIAN_PACKAGE_VERSION "${VERSION_STRING}") - SET(CPACK_PACKAGE_EXECUTABLES "openmw;OpenMW") - SET(CPACK_DEBIAN_PACKAGE_DEPENDS "libogremain-1.7.1 (>= 1.7.1-1), libbullet2.77 (>= 2.77), libboost-filesystem1.42.0 (>= 1.42.0), libboost-program-options1.42.0 (>= 1.42.0), libboost-system1.42.0 (>= 1.42.0), libboost-thread1.42.0 (>= 1.42.0), libc6 (>= 2.11.2), libfreetype6 (>= 2.2.1), libgcc1 (>= 1:4.1.1), libmpg123-0 (>= 1.12.1), libois-1.2.0 (>= 1.2.0), libopenal1 (>= 1:1.12.854), libsndfile1 (>= 1.0.23), libstdc++6 (>= 4.4.5), libuuid1 (>= 2.17.2)") + SET(CPACK_PACKAGE_EXECUTABLES "openmw;OpenMW esmtool;Esmtool omwlauncher;OMWLauncher") + SET(CPACK_DEBIAN_PACKAGE_DEPENDS "libogremain-1.7.3 (>= 1.7.3), libbullet0 (>= 2.77), libboost-filesystem1.42.0 (>= 1.42.0), libboost-program-options1.42.0 (>= 1.42.0), libboost-system1.42.0 (>= 1.42.0), libboost-thread1.42.0 (>= 1.42.0), libc6 (>= 2.11.2), libfreetype6 (>= 2.2.1), libgcc1 (>= 1:4.1.1), libmpg123-0 (>= 1.12.1), libois-1.2.0 (>= 1.2.0), libopenal1 (>= 1:1.12.854), libsndfile1 (>= 1.0.23), libstdc++6 (>= 4.4.5), libuuid1 (>= 2.17.2), libqtgui4 (>= 4.7.0)") SET(CPACK_DEBIAN_PACKAGE_SECTION "Games") diff --git a/apps/launcher/CMakeLists.txt b/apps/launcher/CMakeLists.txt index 5090c167d4..ae68b8deb0 100644 --- a/apps/launcher/CMakeLists.txt +++ b/apps/launcher/CMakeLists.txt @@ -65,6 +65,10 @@ target_link_libraries(omwlauncher ${PNG_LIBRARY} ) +if(DPKG_PROGRAM) + INSTALL(TARGETS omwlauncher RUNTIME DESTINATION games COMPONENT omwlauncher) +endif() + if (APPLE) configure_file(${CMAKE_SOURCE_DIR}/files/launcher.qss "${APP_BUNDLE_DIR}/../launcher.qss")