This pull requests improves the pagination in GCE so it no longer sucks :D The 
main changes are:

* Removed all `listFirstPage` and similar methods from all APIs.
* All *list* methods have two forms: one to list all records that returns a 
`PagedIterable` (no params), and one to get a concrete page that accepts a 
`ListOptions` object.
* The `ListPage` object representing a single page has been refactored and 
improved and now has a convenience method `toPagedIterable`, that allows 
converting it to iterate over the pages after a filter operation or similar.
* Refactored all parsers to accommodate the new pagination logic.

In summary, every API only has the minimum and meaningful methods to get a list 
of records, and the pagination domain objects have been reworked to make it 
trivial to iterate over the pages.

I've also removed most of the warnings int he project.

/cc @ccustine @danbroudy Could you give a try to the branch and run the live 
tests? Your feedback on how the new pagination methods look like from a user 
point of view is appreciated too :)
/cc @adriancole Your feedback is appreciated too.

You can merge this Pull Request by running:

  git pull https://github.com/nacx/jclouds-labs-google pagination

Or you can view, comment on it, or merge it online at:

  https://github.com/jclouds/jclouds-labs-google/pull/62

-- Commit Summary --

  * Improved pagination

-- File Changes --

    R 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/GoogleComputeEngineFallbacks.java
 (30)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/compute/GoogleComputeEngineServiceAdapter.java
 (3)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/compute/extensions/GoogleComputeEngineSecurityGroupExtension.java
 (12)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/compute/functions/BuildInstanceMetadata.java
 (2)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/compute/functions/FirewallToIpPermission.java
 (2)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/compute/functions/InstanceInZoneToNodeMetadata.java
 (10)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/compute/functions/NetworkToSecurityGroup.java
 (14)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/compute/options/GoogleComputeEngineTemplateOptions.java
 (1)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/domain/ListPage.java
 (115)
    A 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/domain/PageWithMarker.java
 (135)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/AddressApi.java
 (58)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/DiskApi.java
 (60)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/DiskTypeApi.java
 (61)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/FirewallApi.java
 (65)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/GlobalOperationApi.java
 (65)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/ImageApi.java
 (64)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/InstanceApi.java
 (67)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/MachineTypeApi.java
 (65)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/NetworkApi.java
 (65)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/RegionApi.java
 (59)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/RegionOperationApi.java
 (68)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/RouteApi.java
 (59)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/SnapshotApi.java
 (57)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/ZoneApi.java
 (59)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/features/ZoneOperationApi.java
 (68)
    A 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/BasePageParser.java
 (61)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/BaseToPagedIterable.java
 (8)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/BaseWithRegionToPagedIterable.java
 (8)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/BaseWithZoneToPagedIterable.java
 (8)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseAddresses.java
 (26)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseDiskTypes.java
 (22)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseDisks.java
 (26)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseFirewalls.java
 (24)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseGlobalOperations.java
 (24)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseImages.java
 (24)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseInstances.java
 (28)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseMachineTypes.java
 (25)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseNetworks.java
 (24)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseRegionOperations.java
 (26)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseRegions.java
 (24)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseRoutes.java
 (24)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseSnapshots.java
 (25)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseZoneOperations.java
 (26)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/functions/internal/ParseZones.java
 (24)
    M 
google-compute-engine/src/main/java/org/jclouds/googlecomputeengine/options/ListOptions.java
 (17)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/PageSystemExpectTest.java
 (14)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/compute/functions/InstanceInZoneToNodeMetadataTest.java
 (15)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/compute/functions/NetworkToSecurityGroupTest.java
 (21)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/AddressApiExpectTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/AddressApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/DiskApiExpectTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/DiskApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/DiskTypeApiExpectTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/DiskTypeApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/FirewallApiExpectTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/FirewallApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/GlobalOperationApiExpectTest.java
 (12)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/GlobalOperationApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/ImageApiExpectTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/ImageApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/InstanceApiExpectTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/InstanceApiLiveTest.java
 (3)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/MachineTypeApiExpectTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/MachineTypeApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/NetworkApiExpectTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/NetworkApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/RegionApiExpectTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/RegionApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/RegionOperationApiExpectTest.java
 (30)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/RegionOperationApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/RouteApiExpectTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/RouteApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/SnapshotApiExpectTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/SnapshotApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/ZoneApiExpectTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/ZoneApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/ZoneOperationApiExpectTest.java
 (24)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/features/ZoneOperationApiLiveTest.java
 (2)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/parse/ParseAddressListTest.java
 (8)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/parse/ParseDiskListTest.java
 (8)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/parse/ParseDiskTypeListTest.java
 (8)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/parse/ParseFirewallListTest.java
 (8)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/parse/ParseImageListTest.java
 (8)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/parse/ParseInstanceListTest.java
 (8)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/parse/ParseMachineTypeListTest.java
 (8)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/parse/ParseNetworkListTest.java
 (8)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/parse/ParseOperationListTest.java
 (8)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/parse/ParseRegionListTest.java
 (8)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/parse/ParseRouteListTest.java
 (8)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/parse/ParseSnapshotListTest.java
 (8)
    M 
google-compute-engine/src/test/java/org/jclouds/googlecomputeengine/parse/ParseZoneListTest.java
 (8)

-- Patch Links --

https://github.com/jclouds/jclouds-labs-google/pull/62.patch
https://github.com/jclouds/jclouds-labs-google/pull/62.diff

---
Reply to this email directly or view it on GitHub:
https://github.com/jclouds/jclouds-labs-google/pull/62

Reply via email to