/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.jena.sparql.engine.iterator;
import org.apache.jena.atlas.io.IndentedWriter ;
import org.apache.jena.atlas.lib.Lib ;
import org.apache.jena.sparql.engine.ExecutionContext ;
import org.apache.jena.sparql.engine.Plan ;
import org.apache.jena.sparql.engine.QueryIterator ;
import org.apache.jena.sparql.serializer.SerializationContext ;
/**
* This class marks a QueryIter that takes two QueryIterators as input. */
public abstract class QueryIter2 extends QueryIter
{
private QueryIterator leftInput ;
private QueryIterator rightInput ;
public QueryIter2(QueryIterator left, QueryIterator right, ExecutionContext execCxt)
{
super(execCxt) ;
this.leftInput = left ;
this.rightInput = right ;
}
protected QueryIterator getLeft() { return leftInput ; }
protected QueryIterator getRight() { return rightInput ; }
@Override
protected final
void closeIterator()
{
closeSubIterator() ;
performClose(leftInput) ;
performClose(rightInput) ;
leftInput = null ;
rightInput = null ;
}
@Override
protected final
void requestCancel()
{
requestSubCancel() ;
performRequestCancel(leftInput) ;
performRequestCancel(rightInput) ;
}
/** Cancellation of the query execution is happening */
protected abstract void requestSubCancel() ;
/** Pass on the close method - no need to close the left or right QueryIterators passed to the QueryIter2 constructor */
protected abstract void closeSubIterator() ;
// Do better
@Override
public void output(IndentedWriter out, SerializationContext sCxt)
{
out.println(Lib.className(this)) ;
out.incIndent() ;
out.print(Plan.startMarker) ;
out.incIndent() ;
getLeft().output(out, sCxt) ;
out.decIndent() ;
//out.ensureStartOfLine() ;
out.println(Plan.finishMarker) ;
out.print(Plan.startMarker) ;
out.incIndent() ;
getRight().output(out, sCxt) ;
out.decIndent() ;
//out.ensureStartOfLine() ;
out.println(Plan.finishMarker) ;
out.decIndent() ;
}
}