Class BaseForExecOpRequestWithTPFPaging<ReqType extends DataRetrievalRequest,MemberType extends FederationMember,PageReqType extends DataRetrievalRequest>
java.lang.Object
se.liu.ida.hefquin.engine.queryplan.executable.impl.ops.BaseForExecOps
se.liu.ida.hefquin.engine.queryplan.executable.impl.ops.NullaryExecutableOpBase
se.liu.ida.hefquin.engine.queryplan.executable.impl.ops.BaseForExecOpRequest<ReqType,MemberType>
se.liu.ida.hefquin.engine.queryplan.executable.impl.ops.BaseForExecOpRequestWithTPFPaging<ReqType,MemberType,PageReqType>
- All Implemented Interfaces:
StatsProvider
,ExecutableOperator
,NullaryExecutableOp
- Direct Known Subclasses:
BaseForExecOpTriplePatternRequestWithTPF
,ExecOpRequestBRTPF
public abstract class BaseForExecOpRequestWithTPFPaging<ReqType extends DataRetrievalRequest,MemberType extends FederationMember,PageReqType extends DataRetrievalRequest>
extends BaseForExecOpRequest<ReqType,MemberType>
Base class for implementations of paging-based request operators
where pages are
TPFResponse
objects.-
Field Summary
Fields inherited from class se.liu.ida.hefquin.engine.queryplan.executable.impl.ops.BaseForExecOpRequest
fm, req
Fields inherited from class se.liu.ida.hefquin.engine.queryplan.executable.impl.ops.NullaryExecutableOpBase
timeAtExecEnd, timeAtExecStart
Fields inherited from class se.liu.ida.hefquin.engine.queryplan.executable.impl.ops.BaseForExecOps
collectExceptions
-
Constructor Summary
ConstructorsConstructorDescriptionBaseForExecOpRequestWithTPFPaging
(ReqType req, MemberType fm, boolean collectExceptions) -
Method Summary
Modifier and TypeMethodDescriptionprotected final void
_execute
(IntermediateResultElementSink sink, ExecutionContext execCxt) Implementations of this function need to execute the algorithm of this operator and send the result elements (if any) to the given sink.protected void
consumeMatchingTriples
(Iterable<Triple> itTriples, IntermediateResultElementSink sink) protected abstract Iterator<SolutionMapping>
protected abstract PageReqType
createPageRequest
(String nextPageURL) protected PageReqType
createPageRequest
(TPFResponse previousPage) protected ExecutableOperatorStatsImpl
protected boolean
isLastPage
(TPFResponse response) protected abstract TPFResponse
performPageRequest
(PageReqType pageReq, FederationAccessManager fedAccessMgr) void
Methods inherited from class se.liu.ida.hefquin.engine.queryplan.executable.impl.ops.NullaryExecutableOpBase
execute, getStats
Methods inherited from class se.liu.ida.hefquin.engine.queryplan.executable.impl.ops.BaseForExecOps
getExceptionsCaughtDuringExecution, recordExceptionCaughtDuringExecution
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface se.liu.ida.hefquin.engine.queryplan.executable.ExecutableOperator
getExceptionsCaughtDuringExecution
-
Constructor Details
-
BaseForExecOpRequestWithTPFPaging
-
-
Method Details
-
_execute
protected final void _execute(IntermediateResultElementSink sink, ExecutionContext execCxt) throws ExecOpExecutionException Description copied from class:NullaryExecutableOpBase
Implementations of this function need to execute the algorithm of this operator and send the result elements (if any) to the given sink. If an exception occurs during this process, then this exception needs to either be collected or be thrown, depending on whetherBaseForExecOps.collectExceptions
is set totrue
.- Specified by:
_execute
in classNullaryExecutableOpBase
- Throws:
ExecOpExecutionException
-
createPageRequest
-
isLastPage
-
consumeMatchingTriples
protected void consumeMatchingTriples(Iterable<Triple> itTriples, IntermediateResultElementSink sink) -
createPageRequest
-
performPageRequest
protected abstract TPFResponse performPageRequest(PageReqType pageReq, FederationAccessManager fedAccessMgr) throws FederationAccessException - Throws:
FederationAccessException
-
convert
-
resetStats
public void resetStats()- Specified by:
resetStats
in interfaceStatsProvider
- Overrides:
resetStats
in classNullaryExecutableOpBase
-
createStats
- Overrides:
createStats
in classBaseForExecOpRequest<ReqType extends DataRetrievalRequest,
MemberType extends FederationMember>
-