[Quest API] Export $item to EVENT_DISCOVER_ITEM in Perl (#2863)

# Notes
- Exports `$item` to `EVENT_DISCOVER_ITEM`.
This commit is contained in:
Alex King 2023-02-10 23:56:50 -05:00 committed by GitHub
parent a3bb7e7741
commit 5a0a1b1ffd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 20 additions and 11 deletions

View File

@ -4067,7 +4067,13 @@ void Client::DiscoverItem(uint32 itemid) {
itemid, GetName(), Admin()); itemid, GetName(), Admin());
auto results = database.QueryDatabase(query); auto results = database.QueryDatabase(query);
parse->EventPlayer(EVENT_DISCOVER_ITEM, this, "", itemid); auto* inst = database.CreateItem(itemid);
std::vector<std::any> args;
args.emplace_back(inst);
parse->EventPlayer(EVENT_DISCOVER_ITEM, this, "", itemid, &args);
} }
void Client::UpdateLFP() { void Client::UpdateLFP() {
@ -10467,8 +10473,8 @@ void Client::ResetItemCooldown(uint32 item_id)
return; return;
} }
int recast_type = item_d->RecastType; int recast_type = item_d->RecastType;
bool found_item = false; bool found_item = false;
static const int16 slots[][2] = { static const int16 slots[][2] = {
{ EQ::invslot::POSSESSIONS_BEGIN, EQ::invslot::POSSESSIONS_END }, { EQ::invslot::POSSESSIONS_BEGIN, EQ::invslot::POSSESSIONS_END },
{ EQ::invbag::GENERAL_BAGS_BEGIN, EQ::invbag::GENERAL_BAGS_END }, { EQ::invbag::GENERAL_BAGS_BEGIN, EQ::invbag::GENERAL_BAGS_END },
@ -10484,7 +10490,7 @@ void Client::ResetItemCooldown(uint32 item_id)
item = GetInv().GetItem(slot_id); item = GetInv().GetItem(slot_id);
if (item) { if (item) {
item_d = item->GetItem(); item_d = item->GetItem();
if (item_d && item->GetID() == item_id || (item_d->RecastType != RECAST_TYPE_UNLINKED_ITEM && item_d->RecastType == recast_type)) { if (item_d && item->GetID() == item_id || (item_d->RecastType != RECAST_TYPE_UNLINKED_ITEM && item_d->RecastType == recast_type)) {
item->SetRecastTimestamp(0); item->SetRecastTimestamp(0);
DeleteItemRecastTimer(item_d->ID); DeleteItemRecastTimer(item_d->ID);
SendItemPacket(slot_id, item, ItemPacketCharmUpdate); SendItemPacket(slot_id, item, ItemPacketCharmUpdate);
@ -10512,7 +10518,7 @@ void Client::SetItemCooldown(uint32 item_id, bool use_saved_timer, uint32 in_sec
uint32 final_time = 0; uint32 final_time = 0;
const auto timer_type = item_d->RecastType != RECAST_TYPE_UNLINKED_ITEM ? item_d->RecastType : item_id; const auto timer_type = item_d->RecastType != RECAST_TYPE_UNLINKED_ITEM ? item_d->RecastType : item_id;
const int timer_id = recast_type != RECAST_TYPE_UNLINKED_ITEM ? (pTimerItemStart + recast_type) : (pTimerNegativeItemReuse * item_id); const int timer_id = recast_type != RECAST_TYPE_UNLINKED_ITEM ? (pTimerItemStart + recast_type) : (pTimerNegativeItemReuse * item_id);
if (use_saved_timer) { if (use_saved_timer) {
if (item_d->RecastType != RECAST_TYPE_UNLINKED_ITEM) { if (item_d->RecastType != RECAST_TYPE_UNLINKED_ITEM) {
total_time = timestamps.count(item_d->RecastType) ? timestamps.at(item_d->RecastType) : 0; total_time = timestamps.count(item_d->RecastType) ? timestamps.at(item_d->RecastType) : 0;
@ -10522,11 +10528,11 @@ void Client::SetItemCooldown(uint32 item_id, bool use_saved_timer, uint32 in_sec
} else { } else {
total_time = current_time + in_seconds; total_time = current_time + in_seconds;
} }
if (total_time > current_time) { if (total_time > current_time) {
final_time = total_time - current_time; final_time = total_time - current_time;
} }
static const int16 slots[][2] = { static const int16 slots[][2] = {
{ EQ::invslot::POSSESSIONS_BEGIN, EQ::invslot::POSSESSIONS_END }, { EQ::invslot::POSSESSIONS_BEGIN, EQ::invslot::POSSESSIONS_END },
{ EQ::invbag::GENERAL_BAGS_BEGIN, EQ::invbag::GENERAL_BAGS_END }, { EQ::invbag::GENERAL_BAGS_BEGIN, EQ::invbag::GENERAL_BAGS_END },
@ -10549,7 +10555,7 @@ void Client::SetItemCooldown(uint32 item_id, bool use_saved_timer, uint32 in_sec
} }
} }
} }
//Start timers and update in database only when timer is changed //Start timers and update in database only when timer is changed
if (!use_saved_timer) { if (!use_saved_timer) {
GetPTimers().Clear(&database, timer_id); GetPTimers().Clear(&database, timer_id);
@ -10569,16 +10575,16 @@ uint32 Client::GetItemCooldown(uint32 item_id)
if (!item_d) { if (!item_d) {
return 0; return 0;
} }
int recast_type = item_d->RecastType; int recast_type = item_d->RecastType;
auto timestamps = database.GetItemRecastTimestamps(CharacterID()); auto timestamps = database.GetItemRecastTimestamps(CharacterID());
const auto timer_type = recast_type != RECAST_TYPE_UNLINKED_ITEM ? recast_type : item_id; const auto timer_type = recast_type != RECAST_TYPE_UNLINKED_ITEM ? recast_type : item_id;
uint32 total_time = 0; uint32 total_time = 0;
uint32 current_time = static_cast<uint32>(std::time(nullptr)); uint32 current_time = static_cast<uint32>(std::time(nullptr));
uint32 final_time = 0; uint32 final_time = 0;
total_time = timestamps.count(timer_type) ? timestamps.at(timer_type) : 0; total_time = timestamps.count(timer_type) ? timestamps.at(timer_type) : 0;
if (total_time > current_time) { if (total_time > current_time) {
final_time = total_time - current_time; final_time = total_time - current_time;
} }

View File

@ -1792,6 +1792,9 @@ void PerlembParser::ExportEventVariables(
case EVENT_DISCOVER_ITEM: { case EVENT_DISCOVER_ITEM: {
ExportVar(package_name.c_str(), "itemid", extradata); ExportVar(package_name.c_str(), "itemid", extradata);
if (extra_pointers && extra_pointers->size() == 1) {
ExportVar(package_name.c_str(), "item", "QuestItem", std::any_cast<EQ::ItemInstance*>(extra_pointers->at(0)));
}
break; break;
} }