fix $item with names that are also specials

This commit is contained in:
Martin Michelsen
2023-06-19 15:32:27 -07:00
parent e8fcf2884a
commit 6468af6eb7
2 changed files with 38 additions and 27 deletions
+37 -26
View File
@@ -1409,7 +1409,7 @@ const unordered_map<uint32_t, ItemNameInfo> name_info_for_primary_identifier({
{0x031903, "Team Points 10000"},
});
ItemData::ItemData(const string& orig_description) {
ItemData::ItemData(const string& orig_description, bool skip_special) {
this->data1d.clear(0);
this->id = 0xFFFFFFFF;
this->data2d = 0;
@@ -1444,16 +1444,18 @@ ItemData::ItemData(const string& orig_description) {
}
uint8_t weapon_special = 0;
for (const auto& it : name_for_weapon_special) {
if (!it.second) {
continue;
}
string prefix = tolower(it.second);
prefix += ' ';
if (starts_with(desc, prefix)) {
weapon_special = it.first;
desc = desc.substr(prefix.size());
break;
if (!skip_special) {
for (const auto& it : name_for_weapon_special) {
if (!it.second) {
continue;
}
string prefix = tolower(it.second);
prefix += ' ';
if (starts_with(desc, prefix)) {
weapon_special = it.first;
desc = desc.substr(prefix.size());
break;
}
}
}
@@ -1865,20 +1867,29 @@ ItemData item_for_string(const string& desc) {
try {
return ItemData(desc);
} catch (const exception&) {
string data = parse_data_string(desc);
if (data.size() < 2) {
throw runtime_error("item code too short");
}
if (data.size() > 16) {
throw runtime_error("item code too long");
}
ItemData ret;
if (data.size() <= 12) {
memcpy(ret.data1.data(), data.data(), data.size());
} else {
memcpy(ret.data1.data(), data.data(), 12);
memcpy(ret.data2.data(), data.data() + 12, data.size() - 12);
}
return ret;
}
try {
return ItemData(desc, true);
} catch (const exception&) {
}
string data = parse_data_string(desc);
if (data.size() < 2) {
throw runtime_error("item code too short");
}
if (data[0] > 4) {
throw runtime_error("invalid item class");
}
if (data.size() > 16) {
throw runtime_error("item code too long");
}
ItemData ret;
if (data.size() <= 12) {
memcpy(ret.data1.data(), data.data(), data.size());
} else {
memcpy(ret.data1.data(), data.data(), 12);
memcpy(ret.data2.data(), data.data() + 12, data.size() - 12);
}
return ret;
}
+1 -1
View File
@@ -96,7 +96,7 @@ struct ItemData { // 0x14 bytes
} __attribute__((packed));
ItemData();
explicit ItemData(const std::string& orig_description);
explicit ItemData(const std::string& orig_description, bool skip_special = false);
ItemData(const ItemData& other);
ItemData& operator=(const ItemData& other);