Add documentation for getItemType()

This commit is contained in:
Gent
2020-09-19 16:22:28 -04:00
parent d1c5e272a8
commit c6ec1c46c2
2 changed files with 10 additions and 7 deletions

View File

@@ -112,7 +112,7 @@ void TableData::init() {
itemSet = xdtData[setNames[i]]["m_pItemData"];
for (nlohmann::json::iterator _item = itemSet.begin(); _item != itemSet.end(); _item++) {
auto item = _item.value();
int typeOverride = getItemType(i);
int typeOverride = getItemType(i); // used for special cases where iEquipLoc doesn't indicate item type
ItemManager::ItemData[std::pair<int32_t, int32_t>(item["m_iItemNumber"], typeOverride != -1 ? typeOverride : (int)item["m_iEquipLoc"])]
= { item["m_iTradeAble"] == 1, item["m_iSellAble"] == 1, item["m_iItemPrice"], item["m_iItemSellPrice"], item["m_iStackNumber"], i > 9 ? 0 : (int)item["m_iMinReqLev"],
i > 9 ? 1 : (int)item["m_iRarity"] };
@@ -192,17 +192,20 @@ void TableData::cleanup() {
delete pair.second;
}
/*
* Some item categories either don't possess iEquipLoc or use a different value for item type.
*/
int TableData::getItemType(int itemSet) {
int overriden;
switch (itemSet)
{
case 11:
case 11: // Chest items don't have iEquipLoc and are type 9.
overriden = 9;
break;
case 10:
case 10: // General items don't have iEquipLoc and are type 7.
overriden = 7;
break;
case 9:
case 9: // Vehicles have iEquipLoc 8, but type 10.
overriden = 10;
break;
default: