blob: 90efb0e6cbb38df061c0b21c895d2f69ee5bc9af [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.iotdb.db.queryengine.execution.exchange.sink;
import org.apache.iotdb.db.queryengine.execution.driver.Driver;
import org.apache.iotdb.mpp.rpc.thrift.TFragmentInstanceId;
import com.google.common.util.concurrent.ListenableFuture;
import org.apache.tsfile.read.common.block.TsBlock;
/**
* Base interface of {@link ISinkChannel} and {@link ISinkHandle}. This interface defines the
* functions we need to transfer data to ISourceHandle.
*/
public interface ISink {
/** Get the local fragment instance ID that this ISink belongs to. */
TFragmentInstanceId getLocalFragmentInstanceId();
/** Get the total amount of memory used by buffered TsBlocks. */
long getBufferRetainedSizeInBytes();
/** Get a future that will be completed when the output buffer is not full. */
@SuppressWarnings("squid:S1452")
ListenableFuture<?> isFull();
/**
* Send a {@link TsBlock} to an un-partitioned output buffer. If no-more-TsBlocks has been set,
* the invocation will be ignored. This can happen with limit queries. A {@link RuntimeException}
* will be thrown if any exception happened during the data transmission.
*/
void send(TsBlock tsBlock);
/**
* Notify the ISink that there are no more TsBlocks. Any future calls to send a TsBlock should be
* ignored.
*/
void setNoMoreTsBlocks();
/** If the ISink is aborted. */
boolean isAborted();
/**
* If there are no more TsBlocks to be sent and all the TsBlocks have been fetched by downstream
* fragment instances.
*/
boolean isFinished();
/**
* Abort the ISink. If this is an ISinkHandle, we should abort all its channels. If this is an
* ISinkChannel, we discard all TsBlocks which may still be in the memory buffer and cancel the
* future returned by {@link #isFull()}.
*
* <p>Should only be called in abnormal case
*/
void abort();
/**
* Close the ISink. If this is an ISinkHandle, we should close all its channels. If this is an
* ISinkChannel, we discard all TsBlocks which may still be in the memory buffer and complete the
* future returned by {@link #isFull()}.
*
* <p>Should only be called in normal case.
*/
void close();
/** Return true if this ISink has been closed. Used in {@link Driver#isFinishedInternal()}. */
boolean isClosed();
/** Set max bytes this ISink can reserve from memory pool. */
void setMaxBytesCanReserve(long maxBytesCanReserve);
}