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

com.microsoft.azure.ListOperationCallback Maven / Gradle / Ivy

Go to download

This package contains the basic runtime for AutoRest generated Azure Java clients.

The newest version!
/**
 * Copyright (c) Microsoft Corporation. All rights reserved.
 * Licensed under the MIT License. See License.txt in the project root for
 * license information.
 */

package com.microsoft.azure;

import com.microsoft.rest.ServiceCallback;

import java.util.List;

/**
 * The callback used for client side asynchronous list operations.
 *
 * @param  the item type
 */
public abstract class ListOperationCallback implements ServiceCallback> {
    /**
     * A list result that stores the accumulated resources loaded from server.
     */
    private List result;

    /**
     * Number of loaded pages.
     */
    private int pageCount;

    /**
     * Creates an instance of ListOperationCallback.
     */
    public ListOperationCallback() {
        this.pageCount = 0;
    }

    /**
     * Override this method to handle progressive results.
     * The user is responsible for returning a {@link PagingBehavior} Enum to indicate
     * whether the client should continue loading or stop.
     *
     * @param partial the list of resources from the current request.
     * @return CONTINUE if you want to go on loading, STOP otherwise.
     *
     */
    public abstract PagingBehavior progress(List partial);

    /**
     * Get the list result that stores the accumulated resources loaded from server.
     *
     * @return the list of resources.
     */
    public List get() {
        return result;
    }

    /**
     * This method is called by the client to load the most recent list of resources.
     * This method should only be called by the service client.
     *
     * @param result the most recent list of resources.
     */
    public void load(List result) {
        ++pageCount;
        if (this.result == null || this.result.isEmpty()) {
            this.result = result;
        } else {
            this.result.addAll(result);
        }
    }

    @Override
    public void success(List result) {
        success();
    }

    /**
     * Override this method to handle successful REST call results.
     */
    public abstract void success();

    /**
     * Get the number of loaded pages.
     *
     * @return the number of pages.
     */
    public int pageCount() {
        return pageCount;
    }

    /**
     * An enum to indicate whether the client should continue loading or stop.
     */
    public enum PagingBehavior {
        /**
         * Indicates that the client should continue loading.
         */
        CONTINUE,
        /**
         * Indicates that the client should stop loading.
         */
        STOP
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy