Skip to content

Commit

Permalink
Merge branch 'master' into merged-vocab
Browse files Browse the repository at this point in the history
  • Loading branch information
RobinTF committed Dec 3, 2024
2 parents 4e61b01 + 44e2ba8 commit ae493b4
Show file tree
Hide file tree
Showing 53 changed files with 4,884 additions and 2,301 deletions.
6 changes: 5 additions & 1 deletion src/engine/CheckUsePatternTrick.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,9 @@

#include <algorithm>
#include <ranges>
#include <type_traits>

#include "parser/GraphPatternOperation.h"

namespace checkUsePatternTrick {
// __________________________________________________________________________
Expand Down Expand Up @@ -70,7 +73,8 @@ bool isVariableContainedInGraphPatternOperation(
return ad_utility::contains(arg.visibleVariables_, variable);
} else {
static_assert(std::is_same_v<T, p::TransPath> ||
std::is_same_v<T, p::PathQuery>);
std::is_same_v<T, p::PathQuery> ||
std::is_same_v<T, p::SpatialQuery>);
// The `TransPath` is set up later in the query planning, when this
// function should not be called anymore.
AD_FAIL();
Expand Down
16 changes: 15 additions & 1 deletion src/engine/Filter.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,9 @@ Filter::Filter(QueryExecutionContext* qec,
sparqlExpression::SparqlExpressionPimpl expression)
: Operation(qec),
_subtree(std::move(subtree)),
_expression{std::move(expression)} {}
_expression{std::move(expression)} {
setPrefilterExpressionForChildren();
}

// _____________________________________________________________________________
string Filter::getCacheKeyImpl() const {
Expand All @@ -37,10 +39,22 @@ string Filter::getCacheKeyImpl() const {
return std::move(os).str();
}

//______________________________________________________________________________
string Filter::getDescriptor() const {
return absl::StrCat("Filter ", _expression.getDescriptor());
}

//______________________________________________________________________________
void Filter::setPrefilterExpressionForChildren() {
std::vector<PrefilterVariablePair> prefilterPairs =
_expression.getPrefilterExpressionForMetadata();
auto optNewSubTree = _subtree->setPrefilterGetUpdatedQueryExecutionTree(
std::move(prefilterPairs));
if (optNewSubTree.has_value()) {
_subtree = std::move(optNewSubTree.value());
}
}

// _____________________________________________________________________________
ProtoResult Filter::computeResult(bool requestLaziness) {
LOG(DEBUG) << "Getting sub-result for Filter result computation..." << endl;
Expand Down
11 changes: 10 additions & 1 deletion src/engine/Filter.h
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,11 @@

#include "engine/Operation.h"
#include "engine/QueryExecutionTree.h"
#include "engine/sparqlExpressions/SparqlExpressionPimpl.h"
#include "parser/ParsedQuery.h"

class Filter : public Operation {
using PrefilterVariablePair = sparqlExpression::PrefilterExprVariablePair;

private:
std::shared_ptr<QueryExecutionTree> _subtree;
sparqlExpression::SparqlExpressionPimpl _expression;
Expand Down Expand Up @@ -58,6 +59,14 @@ class Filter : public Operation {
return _subtree->getVariableColumns();
}

// The method is directly invoked with the construction of this `Filter`
// object. Its implementation retrieves <PrefilterExpression, Variable> pairs
// from the corresponding `SparqlExpression` and uses them to call
// `QueryExecutionTree::setPrefilterGetUpdatedQueryExecutionTree()` on the
// `subtree_`. If necessary the `QueryExecutionTree` for this
// entity will be updated.
void setPrefilterExpressionForChildren();

ProtoResult computeResult(bool requestLaziness) override;

// Perform the actual filter operation of the data provided.
Expand Down
Loading

0 comments on commit ae493b4

Please sign in to comment.