blob: f0a7339d6425d690c8df7c79b2beee1275bfeb09 [file] [log] [blame]
/*
* 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.ignite.internal.processors.bulkload.pipeline;
import org.apache.ignite.IgniteCheckedException;
import org.jetbrains.annotations.Nullable;
/**
* A file parsing pipeline block. Accepts an portion of an input (isLastPortion flag is provided to signify the last
* block to process) and optionally calls the next block with transformed input or performs any other handling,
* such as storing input to internal structures.
*/
public abstract class PipelineBlock<I, O> {
/** The next block in pipeline or null if this block is a terminator. */
@Nullable PipelineBlock<O, ?> nextBlock;
/**
* Creates a pipeline block.
*
* <p>(There is no nextBlock argument in the constructor: setting the next block using
* {@link #append(PipelineBlock)} method is more convenient.
*/
PipelineBlock() {
nextBlock = null;
}
/**
* Sets the next block in this block and returns the <b>next</b> block.
*
* <p>Below is an example of using this method to set up a pipeline:<br>
* {@code block1.append(block2).append(block3); }.
* <p>Block2 here becomes the next for block1, and block3 is the next one for the block2.
*
* @param next The next block for the current block.
* @return The next block ({@code next} argument).
*/
public <N> PipelineBlock<O, N> append(PipelineBlock<O, N> next) {
nextBlock = next;
return next;
}
/**
* Accepts a portion of input. {@code isLastPortion} parameter should be set if this is a last portion
* of the input. The method must not be called after the end of input: the call with {@code isLastPortion == true}
* is the last one.
*
* @param inputPortion Portion of input.
* @param isLastPortion Is this the last portion.
* @throws IgniteCheckedException On error.
*/
public abstract void accept(I inputPortion, boolean isLastPortion) throws IgniteCheckedException;
}