private void loadLatestModelsRelatedToGroups( JwMap<Integer, JwSet<Integer>> m, Integer bId, JwSet<Integer> groups) { enterMonitor("AcActionSnapshotLoader.loadGroups"); try { JwList<AcBatchItem> is; JwList<AcBatchNest> ns; JwList<AcBatchAlias> as; JwList<AcBatchFlight> fs; JwTimestamp utcTs = _batch.getStartUtcTs(); is = _access.getBatchItemDb().getLatestViewBeforeByBatchGroups(bId, groups, utcTs); ns = _access.getBatchNestDb().getLatestViewBeforeByBatchGroups(bId, groups, utcTs); as = _access.getBatchAliasDb().getLatestViewBeforeByBatchGroups(bId, groups, utcTs); fs = _access.getBatchFlightDb().getLatestViewBeforeByBatchGroups(bId, groups, utcTs); for (AcBatchItem e : is) { // if ( e.hasItemId(DEBUG_ITEM_ID) ) // { // debug("x","Item "+ e.getItemId()+ " batch "+ e.getBatchId()+ " group // "+ e.getGroupCode()); // Thread.dumpStack(); // } _items.putIfMissing(e.getItemId(), e); addBatchGroup(m, e.getBatchId(), e.getGroupCode()); } for (AcBatchNest e : ns) { _nests.putIfMissing(e.getNestId(), e); addBatchGroup(m, e.getBatchId(), e.getGroupCode()); } for (AcBatchAlias e : as) { _aliases.putIfMissing(e.getAliasId(), e); // if ( _aliases.putIfMissing(e.getAliasId(), e) ) // { // if ( e.hasAliasId(DEBUG_ALIAS_ID) ) // { // debug("x", "Alias " // + e.getAliasId() // + " batch " // + e.getBatchId() // + " group " // + e.getGroupCode()); // Thread.dumpStack(); // } // } addBatchGroup(m, e.getBatchId(), e.getGroupCode()); } for (AcBatchFlight e : fs) { _flights.putIfMissing(e.getFlightId(), e); addBatchGroup(m, e.getBatchId(), e.getGroupCode()); } } finally { exitMonitor(); } }
private void fillMissingItems(JwSet<Integer> itemIds) { for (Integer id : itemIds) { if (isItemLoaded(id)) continue; AcBatchItem e = new AcBatchItem(getAccountCode()); e.setItemId(id); // if ( e.hasItemId(DEBUG_ITEM_ID) ) // { // debug("x","Item "+ e.getItemId()+ " batch "+ e.getBatchId()+ " group "+ // e.getGroupCode()); // Thread.dumpStack(); // } _items.put(id, e); } }
private void fillDatabaseItems(JwSet<Integer> itemIds) { JwList<AcBatchItem> v = _access.getBatchItemDb().getBatchItemsBefore(_batch.getStartUtcTs(), itemIds); for (AcBatchItem e : v) { Integer id = e.getItemId(); if (isItemLoaded(id)) continue; _items.put(id, e); if (e.hasGroupCode()) { // debug("1","Item "+ e.getItemId()+ " batch "+ e.getBatchId()+ " group "+ // e.getGroupCode()); addBatchGroup(_batchGroups, e.getBatchId(), e.getGroupCode()); } } }
private void fillActions(JwList<AcAction> actions, boolean skipRevokedActions) { enterMonitor("AcActionSnapshotLoader.fillActions"); try { // debug("B", "fillNonRevokedActions"); JwSet<Integer> itemIds = new JwSet<Integer>(); JwSet<Integer> nestIds = new JwSet<Integer>(); JwSet<Integer> aliasIds = new JwSet<Integer>(); JwSet<Integer> flightIds = new JwSet<Integer>(); if (hasEntanglement()) { itemIds.addAll(_entanglement.getItemIds()); nestIds.addAll(_entanglement.getNestIds()); aliasIds.addAll(_entanglement.getAliasIds()); flightIds.addAll(_entanglement.getFlightIds()); } for (AcAction a : actions) { if (skipRevokedActions && a.hasStatusRevoked() && a.hasPendingChangeNone()) continue; a.collectItemIdsOn(itemIds); a.collectNestIdsOn(nestIds); a.collectAliasIdsOn(aliasIds); a.collectFlightIdsOn(flightIds); } fillItems(itemIds); AcBatchItem.collectNestIdsOn(_items.values(), nestIds); AcBatchItem.collectFlightIdsOn(_items.values(), flightIds); // load aliases before nests fillAliases(aliasIds); AcBatchAlias.collectNestIdsOn(_aliases.values(), nestIds); fillNests(nestIds); AcBatchNest.collectFlightIdsOn(_nests.values(), flightIds); fillFlights(flightIds); fillGroups(); testAllItemsAndNestsLoaded(); } finally { exitMonitor(); } }
private void loadMissing(boolean logMissing) { JwSet<Integer> nestIds = new JwSet<Integer>(); AcBatchItem.collectNestIdsOn(_items.values(), nestIds); removeLoadedIds(nestIds, _nests.keySet()); if (logMissing && nestIds.isNotEmpty()) logMissing("nests", nestIds); fillNests(nestIds); JwSet<Integer> aliasIds = new JwSet<Integer>(); AcBatchNest.collectAliasIdsOn(_nests.values(), aliasIds); removeLoadedIds(aliasIds, _aliases.keySet()); if (logMissing && aliasIds.isNotEmpty()) logMissing("aliases", aliasIds); fillAliases(aliasIds); JwSet<Integer> flightIds = new JwSet<Integer>(); AcBatchItem.collectFlightIdsOn(_items.values(), flightIds); AcBatchNest.collectFlightIdsOn(_nests.values(), flightIds); removeLoadedIds(flightIds, _flights.keySet()); if (logMissing && flightIds.isNotEmpty()) logMissing("flights", flightIds); fillFlights(flightIds); }
public void loadBatch(AcBatch b) { enterMonitor("AcActionSnapshotLoader.loadBatch"); try { _batch = b; Integer batchId = b.getId(); JwList<AcBatchItem> items = _access.getBatchItemDb().getAllByBatchId(batchId); JwList<AcBatchNest> nests = _access.getBatchNestDb().getAllByBatchId(batchId); JwList<AcBatchAlias> aliases = _access.getBatchAliasDb().getAllByBatchId(batchId); JwList<AcBatchFlight> flights = _access.getBatchFlightDb().getAllByBatchId(batchId); _items = AcBatchItem.toItemIdMap(items); // AcBatchItem e = _items.get(DEBUG_ITEM_ID); // if ( e != null ) // { // debug("x","Item "+ e.getItemId()+ " batch "+ e.getBatchId()+ " group "+ // e.getGroupCode()); // Thread.dumpStack(); // } _nests = AcBatchNest.toNestIdMap(nests); _aliases = AcBatchAlias.toAliasIdMap(aliases); // AcBatchAlias e = _aliases.get(DEBUG_ALIAS_ID); // if ( e != null ) // { // debug( // "x", // "Alias " // + e.getAliasId() // + " batch " // + e.getBatchId() // + " group " // + e.getGroupCode()); // Thread.dumpStack(); // } _flights = AcBatchFlight.toFlightIdMap(flights); } finally { exitMonitor(); } }