2016-11-17 15:16:25 +00:00
|
|
|
#include "../mwbase/environment.hpp"
|
|
|
|
#include "../mwworld/worldimp.hpp"
|
2016-11-15 17:13:36 +00:00
|
|
|
#include <components/esm/cellid.hpp>
|
2016-11-15 16:42:52 +00:00
|
|
|
#include <components/openmw-mp/Log.hpp>
|
2016-12-16 09:27:19 +00:00
|
|
|
#include "../mwworld/containerstore.hpp"
|
|
|
|
#include "../mwworld/class.hpp"
|
2016-11-15 16:42:52 +00:00
|
|
|
|
2017-04-05 09:00:21 +00:00
|
|
|
#include "CellController.hpp"
|
2016-11-15 16:42:52 +00:00
|
|
|
#include "Main.hpp"
|
2016-12-16 10:13:44 +00:00
|
|
|
#include "LocalPlayer.hpp"
|
2017-04-05 21:49:20 +00:00
|
|
|
using namespace mwmp;
|
|
|
|
|
2017-04-06 01:00:50 +00:00
|
|
|
std::deque<mwmp::Cell *> CellController::cellsActive;
|
2016-11-15 16:42:52 +00:00
|
|
|
|
2017-04-05 09:00:21 +00:00
|
|
|
mwmp::CellController::CellController()
|
2016-11-15 16:42:52 +00:00
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2017-04-05 09:00:21 +00:00
|
|
|
mwmp::CellController::~CellController()
|
2016-11-15 16:42:52 +00:00
|
|
|
{
|
|
|
|
|
|
|
|
}
|
2016-11-15 17:13:36 +00:00
|
|
|
|
2017-04-06 08:46:56 +00:00
|
|
|
void CellController::updateLocal()
|
2017-04-05 21:49:20 +00:00
|
|
|
{
|
2017-04-06 01:00:50 +00:00
|
|
|
for (std::deque<mwmp::Cell *>::iterator it = cellsActive.begin(); it != cellsActive.end();)
|
2017-04-05 21:49:20 +00:00
|
|
|
{
|
2017-04-06 01:00:50 +00:00
|
|
|
mwmp::Cell *mpCell = *it;
|
2017-04-05 21:49:20 +00:00
|
|
|
|
2017-04-06 01:00:50 +00:00
|
|
|
if (!MWBase::Environment::get().getWorld()->isCellActive(mpCell->getCellStore()))
|
2017-04-05 21:49:20 +00:00
|
|
|
{
|
2017-04-06 01:59:55 +00:00
|
|
|
mpCell->uninitializeLocalActors();
|
2017-04-06 01:00:50 +00:00
|
|
|
it = cellsActive.erase(it);
|
2017-04-05 21:49:20 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-04-06 01:00:50 +00:00
|
|
|
//LOG_MESSAGE_SIMPLE(Log::LOG_VERBOSE, "Updating mwmp::Cell %s", mpCell->getDescription().c_str());
|
2017-04-06 08:46:56 +00:00
|
|
|
mpCell->updateLocal();
|
2017-04-05 21:49:20 +00:00
|
|
|
++it;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-04-06 08:46:56 +00:00
|
|
|
void CellController::initializeCellLocal(const ESM::Cell& cell)
|
2017-04-05 21:49:20 +00:00
|
|
|
{
|
|
|
|
MWWorld::CellStore *cellStore = getCell(cell);
|
|
|
|
|
|
|
|
if (!cellStore) return;
|
|
|
|
|
2017-04-06 01:00:50 +00:00
|
|
|
mwmp::Cell *mpCell = new mwmp::Cell(cellStore);
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_INFO, "Initialized mwmp::Cell %s", mpCell->getDescription().c_str());
|
2017-04-05 21:49:20 +00:00
|
|
|
|
2017-04-06 01:00:50 +00:00
|
|
|
mpCell->initializeLocalActors();
|
|
|
|
cellsActive.push_back(mpCell);
|
2017-04-05 21:49:20 +00:00
|
|
|
}
|
|
|
|
|
2017-04-06 08:46:56 +00:00
|
|
|
void CellController::readCellFrame(mwmp::WorldEvent& worldEvent)
|
|
|
|
{
|
|
|
|
bool cellExisted = false;
|
|
|
|
|
|
|
|
// Check if this cell already exists
|
|
|
|
for (std::deque<mwmp::Cell *>::iterator it = cellsActive.begin(); it != cellsActive.end(); ++it)
|
|
|
|
{
|
|
|
|
mwmp::Cell *mpCell = *it;
|
|
|
|
|
|
|
|
if (worldEvent.cell.getDescription() == mpCell->getDescription())
|
|
|
|
{
|
|
|
|
mpCell->readCellFrame(worldEvent);
|
|
|
|
cellExisted = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!cellExisted)
|
|
|
|
{
|
|
|
|
MWWorld::CellStore *cellStore = getCell(worldEvent.cell);
|
|
|
|
|
|
|
|
if (!cellStore) return;
|
|
|
|
|
|
|
|
mwmp::Cell *mpCell = new mwmp::Cell(cellStore);
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_INFO, "Initialized mwmp::Cell %s", mpCell->getDescription().c_str());
|
|
|
|
|
|
|
|
cellsActive.push_back(mpCell);
|
|
|
|
mpCell->readCellFrame(worldEvent);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-04-05 09:00:21 +00:00
|
|
|
int mwmp::CellController::getCellSize() const
|
2017-02-26 23:02:59 +00:00
|
|
|
{
|
|
|
|
return 8192;
|
|
|
|
}
|
|
|
|
|
2017-04-05 09:00:21 +00:00
|
|
|
MWWorld::CellStore *mwmp::CellController::getCell(const ESM::Cell& cell)
|
2016-11-15 17:13:36 +00:00
|
|
|
{
|
|
|
|
MWWorld::CellStore *cellStore;
|
|
|
|
|
|
|
|
if (cell.isExterior())
|
|
|
|
cellStore = MWBase::Environment::get().getWorld()->getExterior(cell.mData.mX, cell.mData.mY);
|
|
|
|
else
|
2016-11-15 17:51:05 +00:00
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
cellStore = MWBase::Environment::get().getWorld()->getInterior(cell.mName);
|
|
|
|
}
|
|
|
|
catch (std::exception&)
|
|
|
|
{
|
|
|
|
cellStore = NULL;
|
|
|
|
}
|
|
|
|
}
|
2016-11-15 17:13:36 +00:00
|
|
|
|
|
|
|
return cellStore;
|
|
|
|
}
|
2016-12-16 09:27:19 +00:00
|
|
|
|
|
|
|
|
2017-04-05 09:00:21 +00:00
|
|
|
void mwmp::CellController::openContainer(const MWWorld::Ptr &container, bool loot)
|
2016-12-16 09:27:19 +00:00
|
|
|
{
|
2017-02-05 16:45:23 +00:00
|
|
|
// Record this as the player's current open container
|
|
|
|
mwmp::Main::get().getLocalPlayer()->storeCurrentContainer(container, loot);
|
|
|
|
|
2017-01-19 11:08:24 +00:00
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_VERBOSE, "Container \"%s\" (%d) is opened. Loot: %s",
|
2017-03-04 06:55:35 +00:00
|
|
|
container.getCellRef().getRefId().c_str(), container.getCellRef().getRefNum().mIndex,
|
2016-12-16 09:27:19 +00:00
|
|
|
loot ? "true" : "false");
|
|
|
|
|
|
|
|
MWWorld::ContainerStore &cont = container.getClass().getContainerStore(container);
|
2016-12-16 09:31:41 +00:00
|
|
|
for (MWWorld::ContainerStoreIterator iter = cont.begin(); iter != cont.end(); iter++)
|
2016-12-16 09:27:19 +00:00
|
|
|
{
|
|
|
|
int count = iter->getRefData().getCount();
|
|
|
|
const std::string &name = iter->getCellRef().getRefId();
|
|
|
|
|
|
|
|
LOG_APPEND(Log::LOG_VERBOSE, " - Item. Refid: \"%s\" Count: %d", name.c_str(), count);
|
|
|
|
|
|
|
|
/*if(::Misc::StringUtils::ciEqual(name, "gold_001"))
|
|
|
|
cont.remove("gold_001", count, container);*/
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2017-04-05 09:00:21 +00:00
|
|
|
void mwmp::CellController::closeContainer(const MWWorld::Ptr &container)
|
2016-12-16 09:27:19 +00:00
|
|
|
{
|
2017-02-05 16:45:23 +00:00
|
|
|
mwmp::Main::get().getLocalPlayer()->clearCurrentContainer();
|
|
|
|
|
2017-02-22 04:41:25 +00:00
|
|
|
// If the player died while in a container, the container's Ptr could be invalid now
|
|
|
|
if (!container.isEmpty())
|
2016-12-16 09:27:19 +00:00
|
|
|
{
|
2017-03-04 06:55:35 +00:00
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_VERBOSE, "Container \"%s\" (%d) is closed.", container.getCellRef().getRefId().c_str(),
|
|
|
|
container.getCellRef().getRefNum().mIndex);
|
2017-02-22 04:41:25 +00:00
|
|
|
|
|
|
|
MWWorld::ContainerStore &cont = container.getClass().getContainerStore(container);
|
|
|
|
for (MWWorld::ContainerStoreIterator iter = cont.begin(); iter != cont.end(); iter++)
|
|
|
|
{
|
2017-03-04 06:55:35 +00:00
|
|
|
LOG_APPEND(Log::LOG_VERBOSE, " - Item. Refid: \"%s\" Count: %d", iter->getCellRef().getRefId().c_str(),
|
|
|
|
iter->getRefData().getCount());
|
2017-02-22 04:41:25 +00:00
|
|
|
}
|
2016-12-16 09:27:19 +00:00
|
|
|
}
|
2017-02-22 04:41:25 +00:00
|
|
|
|
2017-01-19 11:08:24 +00:00
|
|
|
mwmp::Main::get().getLocalPlayer()->updateInventory();
|
2016-12-16 09:27:19 +00:00
|
|
|
}
|