/**
  * @since 2.4
  *
  * @return array
  */
 public function getFilteredIdList()
 {
     $start = microtime(true);
     $combinedChangedEntityList = array_flip($this->compositePropertyTableDiffIterator->getCombinedIdListOfChangedEntities());
     $affiliateEntityList = array();
     $tableChangeOps = $this->compositePropertyTableDiffIterator->getTableChangeOps();
     foreach ($tableChangeOps as $tableChangeOp) {
         $this->applyFilterToTableChangeOp($tableChangeOp, $affiliateEntityList, $combinedChangedEntityList);
     }
     $filteredIdList = array_merge(array_keys($combinedChangedEntityList), array_keys($affiliateEntityList));
     wfDebugLog('smw', __METHOD__ . ' procTime (sec): ' . round(microtime(true) - $start, 6));
     return $filteredIdList;
 }
 public function testTryToGetTableChangeOpForSingleTable()
 {
     $diff = array();
     $instance = new CompositePropertyTableDiffIterator($diff);
     $this->assertEmpty($instance->getTableChangeOps('smw_di_number'));
 }
 /**
  * This method is called from the `SMW::SQLStore::AfterDataUpdateComplete` hook and
  * removes outdated query ID's from the table if the diff contains a `delete`
  * entry for the _ask table.
  *
  * @since 2.3
  *
  * @param CompositePropertyTableDiffIterator $compositePropertyTableDiffIterator
  */
 public function pruneOutdatedTargetLinks(DIWikiPage $subject, CompositePropertyTableDiffIterator $compositePropertyTableDiffIterator)
 {
     if (!$this->isEnabled()) {
         return null;
     }
     $start = microtime(true);
     $tableName = $this->store->getPropertyTableInfoFetcher()->findTableIdForProperty(new DIProperty('_ASK'));
     $tableChangeOps = $compositePropertyTableDiffIterator->getTableChangeOps($tableName);
     // Remove any dependency for queries that are no longer used
     foreach ($tableChangeOps as $tableChangeOp) {
         if (!$tableChangeOp->hasChangeOp('delete')) {
             continue;
         }
         $deleteIdList = array();
         foreach ($tableChangeOp->getFieldChangeOps('delete') as $fieldChangeOp) {
             $deleteIdList[] = $fieldChangeOp->get('o_id');
         }
         $this->dependencyLinksTableUpdater->deleteDependenciesFromList($deleteIdList);
     }
     wfDebugLog('smw', __METHOD__ . ' finished on ' . $subject->getHash() . ' with procTime (sec): ' . round(microtime(true) - $start, 7));
     return true;
 }
 /**
  * @since 2.5
  *
  * @param CompositePropertyTableDiffIterator $compositePropertyTableDiffIterator
  */
 public function pushUpdatesFromPropertyTableDiff(CompositePropertyTableDiffIterator $compositePropertyTableDiffIterator)
 {
     if (!$this->searchTableUpdater->isEnabled()) {
         return;
     }
     $start = microtime(true);
     foreach ($compositePropertyTableDiffIterator->getTableChangeOps() as $tableChangeOp) {
         $this->doUpdateFromTableChangeOp($tableChangeOp);
     }
     wfDebugLog('smw', __METHOD__ . ' procTime (sec): ' . round(microtime(true) - $start, 5));
 }