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

com.obs.services.model.select.SelectEventVisitor Maven / Gradle / Ivy

/**
 * Copyright 2019 Huawei Technologies Co.,Ltd.
 * 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.obs.services.model.select;

import java.nio.ByteBuffer;

/**
 * Interface for a visitor over the events of the input stream
 * 
 * Those events not overriden do nothing.
 */
public class SelectEventVisitor {
    /**
     * Informs of the next chunk to be processed
     * 
     * The content of the chunk is only known by the wire format input serialization format.
     * The purpose of this method is for monitoring of the chunk sizes or for backup of the
     * input data.
     * 
     * @param payload
     *      Buffer with the next chunk of the input stream
     */
    public void visitRecordsEvent(ByteBuffer payload) {
    }

    /**
     * Informs that the server is still processing the Select request.
     * 
     * Used internally to maintain the connection alive. Optionally, the the receiver can abort
     * after some user-defined timeout
     */
    public void visitContinuationEvent() {
    }

    /**
     * Periodic progress information
     * 
     * @param bytesScanned
     *      Current number of input bytes scanned by the server
     * 
     * @param bytesProcessed
     *      Current number of input bytes processed by the server, less than or equal than the
     *      scanned bytes.
     * 
     * @param bytesReturned
     *      Current number of bytes returned as chunks by the server
     */
    public void visitProgressEvent(long bytesScanned, long bytesProcessed, long bytesReturned) {
    }

    /**
     * Final statistics when the request has finished successfully
     * 
     * @param bytesScanned
     *      Total number of input bytes scanned by the server
     * 
     * @param bytesProcessed
     *      Total number of input bytes processed by the server, less than or equal than the
     *      scanned bytes.
     * 
     * @param bytesReturned
     *      Total number of bytes returned as chunks by the server
     */
    public void visitStatsEvent(long bytesScanned, long bytesProcessed, long bytesReturned) {
    }

    /**
     * Informs than the request has finished successfully.
     */
    public void visitEndEvent() {
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy