diff options
author | Erik Schilling <ablu.erikschilling@googlemail.com> | 2013-09-30 21:07:23 +0200 |
---|---|---|
committer | Erik Schilling <ablu.erikschilling@googlemail.com> | 2013-09-30 21:07:23 +0200 |
commit | 0eac9c5e43034866fd6a65479789022467afd335 (patch) | |
tree | 047a98200fce70ab942ff6ea8c72d52687b9fc21 | |
parent | 2a3af0a501c2374119970c0511e1fc23b204b8d4 (diff) | |
download | manaserv-0eac9c5e43034866fd6a65479789022467afd335.tar.gz manaserv-0eac9c5e43034866fd6a65479789022467afd335.tar.bz2 manaserv-0eac9c5e43034866fd6a65479789022467afd335.tar.xz manaserv-0eac9c5e43034866fd6a65479789022467afd335.zip |
Actually send and store the equipment slot
I was wrong to assume that we do not need it. The accountserver needs to
send the info the the client in order to display the equipment on the
character selection page.
-rw-r--r-- | src/account-server/storage.cpp | 11 | ||||
-rw-r--r-- | src/game-server/charactercomponent.cpp | 10 |
2 files changed, 6 insertions, 15 deletions
diff --git a/src/account-server/storage.cpp b/src/account-server/storage.cpp index 2a3bcf0b..3adea078 100644 --- a/src/account-server/storage.cpp +++ b/src/account-server/storage.cpp @@ -510,19 +510,15 @@ CharacterData *Storage::getCharacterBySQL(Account *owner) unsigned short slot = toUint(itemInfo(k, 2)); item.itemId = toUint(itemInfo(k, 3)); item.amount = toUint(itemInfo(k, 4)); + item.equipmentSlot = toUint(itemInfo(k, 5)); inventoryData[slot] = item; - if (toUint(itemInfo(k, 5)) != 0) + if (item.equipmentSlot != 0) { // The game server will set the right slot anyway, // but this speeds up checking if the item is equipped - item.equipmentSlot = 1; equipmentData.insert(slot); } - else - { - item.equipmentSlot = 0; - } } } poss.setInventory(inventoryData); @@ -850,10 +846,9 @@ bool Storage::updateCharacter(CharacterData *character) unsigned short slot = itemIt->first; unsigned itemId = itemIt->second.itemId; unsigned amount = itemIt->second.amount; - bool equipped = itemIt->second.equipmentSlot != 0; assert(itemId); sql << base << slot << ", " << itemId << ", " << amount << ", " - << (equipped ? 1 : 0) << ");"; + << itemIt->second.equipmentSlot << ");"; mDb->execSql(sql.str()); } diff --git a/src/game-server/charactercomponent.cpp b/src/game-server/charactercomponent.cpp index 344a8959..1fe7cd46 100644 --- a/src/game-server/charactercomponent.cpp +++ b/src/game-server/charactercomponent.cpp @@ -278,19 +278,15 @@ void CharacterComponent::serialize(Entity &entity, MessageOut &msg) // inventory - must be last because size isn't transmitted const Possessions &poss = getPossessions(); - const EquipData &equipData = poss.getEquipment(); const InventoryData &inventoryData = poss.getInventory(); for (InventoryData::const_iterator itemIt = inventoryData.begin(), itemIt_end = inventoryData.end(); itemIt != itemIt_end; ++itemIt) { msg.writeInt16(itemIt->first); // slot id - msg.writeInt16(itemIt->second.itemId); // item id - msg.writeInt16(itemIt->second.amount); // amount - if (equipData.find(itemIt->first) != equipData.end()) - msg.writeInt8(1); // equipped - else - msg.writeInt8(0); // not equipped + msg.writeInt16(itemIt->second.itemId); + msg.writeInt16(itemIt->second.amount); + msg.writeInt8(itemIt->second.equipmentSlot); } } |