All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.hazelcast.sql.impl.exec.io.Inbox Maven / Gradle / Ivy

There is a newer version: 5.0-BETA-1
Show newest version
/*
 * Copyright (c) 2008-2021, Hazelcast, Inc. All Rights Reserved.
 *
 * Licensed 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 com.hazelcast.sql.impl.exec.io;

import com.hazelcast.sql.impl.QueryId;
import com.hazelcast.sql.impl.exec.io.flowcontrol.FlowControl;
import com.hazelcast.sql.impl.operation.QueryOperationHandler;

import java.util.ArrayDeque;
import java.util.UUID;

/**
 * Normal inbox which merges all incoming batches into a single stream.
 */
public class Inbox extends AbstractInbox {
    /** Queue of batches from all remote stripes. */
    private final ArrayDeque batches = new ArrayDeque<>();

    public Inbox(
        QueryOperationHandler operationHandler,
        QueryId queryId,
        int edgeId,
        boolean ordered,
        int rowWidth,
        UUID localMemberId,
        int remainingStreams,
        FlowControl flowControl
    ) {
        super(operationHandler, queryId, edgeId, ordered, rowWidth, localMemberId, remainingStreams, flowControl);
    }

    @Override
    protected void onBatch0(InboundBatch batch) {
        batches.addLast(batch);
    }

    public InboundBatch poll() {
        InboundBatch batch = batches.pollFirst();

        onBatchPolled(batch);

        return batch;
    }

    @Override
    public String toString() {
        return "Inbox {queryId=" + queryId + ", edgeId=" + edgeId + "}";
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy