From 2ac20982e0772b94b21d95b53519bd2164632d98 Mon Sep 17 00:00:00 2001 From: Perttu Ahola Date: Tue, 24 Jul 2012 20:57:17 +0300 Subject: Detached inventories --- src/server.cpp | 137 +++++++++++++++++++++++++++++++++++---------------------- 1 file changed, 85 insertions(+), 52 deletions(-) (limited to 'src/server.cpp') diff --git a/src/server.cpp b/src/server.cpp index b3cbea6a4..c7698a106 100644 --- a/src/server.cpp +++ b/src/server.cpp @@ -1160,6 +1160,15 @@ Server::~Server() // Deinitialize scripting infostream<<"Server: Deinitializing scripting"<::iterator + i = m_detached_inventories.begin(); + i != m_detached_inventories.end(); i++){ + delete i->second; + } + } } void Server::start(unsigned short port) @@ -2250,10 +2259,13 @@ void Server::ProcessData(u8 *data, u32 datasize, u16 peer_id) // Send inventory UpdateCrafting(peer_id); SendInventory(peer_id); - + // Send HP SendPlayerHP(peer_id); + // Send detached inventories + sendDetachedInventories(peer_id); + // Show death screen if necessary if(player->hp == 0) SendDeathscreen(m_con, peer_id, false, v3f(0,0,0)); @@ -2532,30 +2544,6 @@ void Server::ProcessData(u8 *data, u32 datasize, u16 peer_id) delete a; return; } - - // If player is not an admin, check for ownership of src and dst - /*if(!checkPriv(player->getName(), "server")) - { - std::string owner_from = getInventoryOwner(ma->from_inv); - if(owner_from != "" && owner_from != player->getName()) - { - infostream<<"WARNING: "<getName() - <<" tried to access an inventory that" - <<" belongs to "<to_inv); - if(owner_to != "" && owner_to != player->getName()) - { - infostream<<"WARNING: "<getName() - <<" tried to access an inventory that" - <<" belongs to "<getName(), "server")) - { - std::string owner_from = getInventoryOwner(da->from_inv); - if(owner_from != "" && owner_from != player->getName()) - { - infostream<<"WARNING: "<getName() - <<" tried to access an inventory that" - <<" belongs to "<getName(), "server")) - { - std::string owner_craft = getInventoryOwner(ca->craft_inv); - if(owner_craft != "" && owner_craft != player->getName()) - { - infostream<<"WARNING: "<getName() - <<" tried to access an inventory that" - <<" belongs to "<getInventory(); } break; + case InventoryLocation::DETACHED: + { + if(m_detached_inventories.count(loc.name) == 0) + return NULL; + return m_detached_inventories[loc.name]; + } + break; default: assert(0); } @@ -3352,6 +3320,11 @@ void Server::setInventoryModified(const InventoryLocation &loc) setBlockNotSent(blockpos); } break; + case InventoryLocation::DETACHED: + { + sendDetachedInventoryToAll(loc.name); + } + break; default: assert(0); } @@ -4309,6 +4282,51 @@ void Server::sendRequestedMedia(u16 peer_id, } } +void Server::sendDetachedInventory(const std::string &name, u16 peer_id) +{ + if(m_detached_inventories.count(name) == 0){ + errorstream<<__FUNCTION_NAME<<": \""<serialize(os); + + // Make data buffer + std::string s = os.str(); + SharedBuffer data((u8*)s.c_str(), s.size()); + // Send as reliable + m_con.Send(peer_id, 0, data, true); +} + +void Server::sendDetachedInventoryToAll(const std::string &name) +{ + DSTACK(__FUNCTION_NAME); + + for(core::map::Iterator + i = m_clients.getIterator(); + i.atEnd() == false; i++){ + RemoteClient *client = i.getNode()->getValue(); + sendDetachedInventory(name, client->peer_id); + } +} + +void Server::sendDetachedInventories(u16 peer_id) +{ + DSTACK(__FUNCTION_NAME); + + for(std::map::iterator + i = m_detached_inventories.begin(); + i != m_detached_inventories.end(); i++){ + const std::string &name = i->first; + //Inventory *inv = i->second; + sendDetachedInventory(name, peer_id); + } +} + /* Something random */ @@ -4493,6 +4511,21 @@ void Server::queueBlockEmerge(v3s16 blockpos, bool allow_generate) m_emerge_queue.addBlock(PEER_ID_INEXISTENT, blockpos, flags); } +Inventory* Server::createDetachedInventory(const std::string &name) +{ + if(m_detached_inventories.count(name) > 0){ + infostream<<"Server clearing detached inventory \""<