org.apache.ignite.internal.processors.bulkload.pipeline.PipelineBlock Maven / Gradle / Ivy
Show all versions of ignite-core Show documentation
/*
* 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 {
/** The next block in pipeline or null if this block is a terminator. */
@Nullable PipelineBlock nextBlock;
/**
* Creates a pipeline block.
*
* (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 next block.
*
*
Below is an example of using this method to set up a pipeline:
* {@code block1.append(block2).append(block3); }.
*
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 PipelineBlock append(PipelineBlock 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;
}