From d8ff5b02cca694b2348b8f434b69ed4a025724ae Mon Sep 17 00:00:00 2001 From: GoldenGnu Date: Sat, 23 Sep 2023 21:43:20 +0200 Subject: [PATCH] Code: Added failsafe for endless outbid update loop on error --- .../eve/jeveasset/gui/tabs/orders/MarketOrdersTab.java | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/src/main/java/net/nikr/eve/jeveasset/gui/tabs/orders/MarketOrdersTab.java b/src/main/java/net/nikr/eve/jeveasset/gui/tabs/orders/MarketOrdersTab.java index 73e012219..d0124b219 100644 --- a/src/main/java/net/nikr/eve/jeveasset/gui/tabs/orders/MarketOrdersTab.java +++ b/src/main/java/net/nikr/eve/jeveasset/gui/tabs/orders/MarketOrdersTab.java @@ -559,14 +559,21 @@ private void updateESI() { JOptionPane.showMessageDialog(program.getMainWindow().getFrame(), TabsOrders.get().updateNoActiveMsg(), TabsOrders.get().updateNoActiveTitle(), JOptionPane.PLAIN_MESSAGE); return; } + final Date currentUpdate = Settings.get().getPublicMarketOrdersNextUpdate(); OutbidProcesserOutput output = new OutbidProcesserOutput(); final PublicMarkerOrdersUpdateTask updateTask = new PublicMarkerOrdersUpdateTask(input, output); TaskDialog taskDialog = new TaskDialog(program, updateTask, false, jAutoUpdate.isSelected(), jAutoUpdate.isSelected(), StatusPanel.UpdateType.PUBLIC_MARKET_ORDERS, new TaskDialog.TasksCompletedAdvanced() { @Override public void tasksCompleted(TaskDialog taskDialog) { + //Set data Settings.lock("Outbid (ESI)"); Settings.get().setMarketOrdersOutbid(output.getOutbids()); Settings.unlock("Outbid (ESI)"); + //Ensure we don't update repeatedly on errors + if (Settings.get().getPublicMarketOrdersNextUpdate().equals(currentUpdate)) { + //if next update did not change, set the next update to be 5 minutes in the future + Settings.get().setPublicMarketOrdersNextUpdate(new Date(System.currentTimeMillis() + (1000 * 60 * 5))); + } //Update eventlists if (!output.getOutbids().isEmpty() || !output.getUpdates().isEmpty()) { LOG.info("Updating Orders EventList");