void DocumentSourceProject::manageDependencies( const intrusive_ptr<DependencyTracker> &pTracker) { /* Look at all the products (inclusions and computed fields) of this projection. For each one that is a dependency, remove it from the list of dependencies, because this product will satisfy that dependency. */ DependencyRemover dependencyRemover(pTracker); pEO->emitPaths(&dependencyRemover); /* Look at the exclusions of this projection. If any of them are dependencies, inform the user (error/usassert) that the dependency can't be satisfied. Note we need to do this after the product examination above because it is possible for there to be an exclusion field name that matches a new computed product field name. The latter would satisfy the dependency. */ DependencyChecker dependencyChecker(pTracker, this); pEO->emitPaths(&dependencyChecker); /* Look at the products of this projection. For inclusions, add the field names to the list of dependencies. For computed expressions, add their dependencies to the list of dependencies. */ pEO->addDependencies(pTracker, this); }
void DocumentSourceProject::manageDependencies( const intrusive_ptr<DependencyTracker> &pTracker) { /* If the $project is in "inclusionary mode," then it produces a closed result set */ if (!pEO->isExclusionMode()) pTracker->setClosedSet(); /* Look at all the products (inclusions and computed fields) of this projection. For each one that is currently a dependency, remove it from the list of dependencies, because this product will satisfy that dependency. First look at the included paths */ ExpressionObject::DependencyRemover dependencyRemover(pTracker); pEO->emitPaths(&dependencyRemover); /* the computed expressions are also products */ intrusive_ptr<Iterator<string> > pFieldIter(pEO->getFieldIterator()); while(pFieldIter->hasNext()) { string fieldName(pFieldIter->next()); FieldPath fieldPath(fieldName); pTracker->removeDependency(fieldPath); } /* Look at the exclusions of this projection. If any of them are dependencies, inform the user (error/usassert) that the dependency can't be satisfied. Note we need to do this after the product examination above because it is possible for there to be an exclusion field name that matches a new computed product field name. The latter would satisfy the dependency. */ DependencyChecker dependencyChecker(pTracker, this); pEO->emitPaths(&dependencyChecker); /* Look at the products of this projection. For inclusions, add the field names to the list of dependencies. For computed expressions, add their dependencies to the list of dependencies. */ pEO->addDependencies(pTracker, this); }