/*
* Copyright (c) 2012, the Last.fm Java Project and Committers All rights
* reserved. Redistribution and use of this software in source and binary forms,
* with or without modification, are permitted provided that the following
* conditions are met: - Redistributions of source code must retain the above
* copyright notice, this list of conditions and the following disclaimer. -
* Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution. THIS SOFTWARE IS
* PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
* EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package com.cyanogenmod.eleven.lastfm;
import java.util.Collection;
import java.util.Iterator;
/**
* A PaginatedResult
is returned by methods which result set might
* be so large that it needs to be paginated. Each PaginatedResult
* contains the total number of result pages, the current page and a
* Collection
of entries for the current page.
*
* @author Janni Kovacs
*/
public class PaginatedResult implements Iterable {
private final int page;
private final int totalPages;
public final Collection pageResults;
/**
* @param page
* @param totalPages
* @param pageResults
*/
PaginatedResult(final int page, final int totalPages, final Collection pageResults) {
this.page = page;
this.totalPages = totalPages;
this.pageResults = pageResults;
}
/**
* Returns the page number of this result.
*
* @return page number
*/
public int getPage() {
return page;
}
/**
* Returns the total number of pages available.
*
* @return total pages
*/
public int getTotalPages() {
return totalPages;
}
/**
* Returns true
if this Result contains no elements, which is
* the case for service calls that would have returned a
* PaginatedResult
but fail.
*
* @return true
if this result contains no elements
*/
public boolean isEmpty() {
return pageResults == null || pageResults.isEmpty();
}
@Override
public Iterator iterator() {
return pageResults.iterator();
}
}