mirror of
https://github.com/Grasscutters/Grasscutter.git
synced 2025-01-25 13:13:06 +08:00
fix giveall doesn't give everything (#2210)
* fix giveall doesn't give everything * avoid unnecessary failure to add items by catching exception earlier * switch to use grasscutter logger * use debug()
This commit is contained in:
parent
47172c995f
commit
6b3f19e588
@ -133,13 +133,9 @@ public class Inventory extends BasePlayerManager implements Iterable<GameItem> {
|
|||||||
for (var item : items) {
|
for (var item : items) {
|
||||||
if (item.getItemId() == 0) continue;
|
if (item.getItemId() == 0) continue;
|
||||||
GameItem result = null;
|
GameItem result = null;
|
||||||
try {
|
|
||||||
// putItem might throw exception
|
result = putItem(item);
|
||||||
// ignore that exception and continue
|
|
||||||
result = putItem(item);
|
|
||||||
} catch (Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
if (result != null) {
|
if (result != null) {
|
||||||
this.triggerAddItemEvents(result);
|
this.triggerAddItemEvents(result);
|
||||||
changedItems.add(result);
|
changedItems.add(result);
|
||||||
@ -155,22 +151,30 @@ public class Inventory extends BasePlayerManager implements Iterable<GameItem> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void triggerAddItemEvents(GameItem result) {
|
private void triggerAddItemEvents(GameItem result) {
|
||||||
getPlayer()
|
try {
|
||||||
.getBattlePassManager()
|
getPlayer()
|
||||||
.triggerMission(
|
.getBattlePassManager()
|
||||||
WatcherTriggerType.TRIGGER_OBTAIN_MATERIAL_NUM, result.getItemId(), result.getCount());
|
.triggerMission(
|
||||||
getPlayer()
|
WatcherTriggerType.TRIGGER_OBTAIN_MATERIAL_NUM, result.getItemId(), result.getCount());
|
||||||
.getQuestManager()
|
getPlayer()
|
||||||
.queueEvent(QuestContent.QUEST_CONTENT_OBTAIN_ITEM, result.getItemId(), result.getCount());
|
.getQuestManager()
|
||||||
|
.queueEvent(QuestContent.QUEST_CONTENT_OBTAIN_ITEM, result.getItemId(), result.getCount());
|
||||||
|
} catch (Exception e) {
|
||||||
|
Grasscutter.getLogger().debug("triggerAddItemEvents failed", e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void triggerRemItemEvents(GameItem item, int removeCount) {
|
private void triggerRemItemEvents(GameItem item, int removeCount) {
|
||||||
getPlayer()
|
try {
|
||||||
.getBattlePassManager()
|
getPlayer()
|
||||||
.triggerMission(WatcherTriggerType.TRIGGER_COST_MATERIAL, item.getItemId(), removeCount);
|
.getBattlePassManager()
|
||||||
getPlayer()
|
.triggerMission(WatcherTriggerType.TRIGGER_COST_MATERIAL, item.getItemId(), removeCount);
|
||||||
.getQuestManager()
|
getPlayer()
|
||||||
.queueEvent(QuestContent.QUEST_CONTENT_ITEM_LESS_THAN, item.getItemId(), item.getCount());
|
.getQuestManager()
|
||||||
|
.queueEvent(QuestContent.QUEST_CONTENT_ITEM_LESS_THAN, item.getItemId(), item.getCount());
|
||||||
|
} catch (Exception e) {
|
||||||
|
Grasscutter.getLogger().debug("triggerRemItemEvents failed", e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addItemParams(Collection<ItemParam> items) {
|
public void addItemParams(Collection<ItemParam> items) {
|
||||||
@ -193,8 +197,11 @@ public class Inventory extends BasePlayerManager implements Iterable<GameItem> {
|
|||||||
// Dont add items that dont have a valid item definition.
|
// Dont add items that dont have a valid item definition.
|
||||||
var data = item.getItemData();
|
var data = item.getItemData();
|
||||||
if (data == null) return null;
|
if (data == null) return null;
|
||||||
|
try {
|
||||||
this.player.getProgressManager().addItemObtainedHistory(item.getItemId(), item.getCount());
|
this.player.getProgressManager().addItemObtainedHistory(item.getItemId(), item.getCount());
|
||||||
|
} catch (Exception e) {
|
||||||
|
Grasscutter.getLogger().debug("addItemObtainedHistory failed", e);
|
||||||
|
}
|
||||||
|
|
||||||
if (data.isUseOnGain()) {
|
if (data.isUseOnGain()) {
|
||||||
var params = new UseItemParams(this.player, data.getUseTarget());
|
var params = new UseItemParams(this.player, data.getUseTarget());
|
||||||
|
Loading…
Reference in New Issue
Block a user