[aerogear-dev] Client Paging Strawman

Summers Pittman supittma at redhat.com
Tue Jan 15 14:40:05 EST 2013


> Basically, anything that involves creating a new object to maintain 
> paged pipes rather than just using any other pipe and overloading the 
> read method to do paging doesn't make sense to me. 
I'm confused.  Your strawman creates extra pipes to maintain paged 
states.  The other proposals all use an overridden read method and 
return a list which can be used to fetch different pages of data (which 
is what it sounds like you want).


On 01/15/2013 02:32 PM, Kris Borchers wrote:
> OK, so here is where I stand. I don't think there is any way to have 
> the API's match identically between JS and the others. It sounds like 
> Android and iOS are getting closer to agreement but as they get 
> closer, it seems they get further away from what makes sense for JS. 
> Basically, anything that involves creating a new object to maintain 
> paged pipes rather than just using any other pipe and overloading the 
> read method to do paging doesn't make sense to me. IMO, JS should move 
> forward with basically what was written up in the strawman as that 
> feels like the best solution for JS.
>
> On Jan 15, 2013, at 10:18 AM, Summers Pittman <supittma at redhat.com 
> <mailto:supittma at redhat.com>> wrote:
>
>> On 01/15/2013 08:45 AM, Sebastien Blanc wrote:
>>> Just to summarize what have until now :
>>>
>>> 1. Kris's proposition: https://gist.github.com/4531575
>>>
>>> 2. Summers's proposition: https://gist.github.com/4532661
>>>
>>> 3. qmx's propositon: https://gist.github.com/4538709
>>>
>>> 4. Sebi's propositionhttps://gist.github.com/4538725
>>>
>>>
>> I've just updated my proposition.  PageContext is no longer and thing 
>> and I've replaced it with a PagedList interface.
>>>
>>>
>>> On Tue, Jan 15, 2013 at 2:32 PM, Matthias Wessendorf 
>>> <matzew at apache.org <mailto:matzew at apache.org>> wrote:
>>>
>>>     On Tue, Jan 15, 2013 at 2:25 PM, Matthias Wessendorf
>>>     <matzew at apache.org <mailto:matzew at apache.org>> wrote:
>>>     > I was wondering, if the result should be received on every rquest,
>>>
>>>
>>>     ideally on the callback..., to not block (at least in iOS land, I
>>>     would pass that "result set" on to the "success" block)
>>>
>>>     -M
>>>
>>>     >
>>>     > thx
>>>     >
>>>     > On Tue, Jan 15, 2013 at 2:01 PM, Sebastien Blanc
>>>     <scm.blanc at gmail.com <mailto:scm.blanc at gmail.com>> wrote:
>>>     >> In the same spirit (inspired from
>>>     >>
>>>     http://stackoverflow.com/questions/5412059/how-to-implement-general-pagination)
>>>     >> :
>>>     >>
>>>     >>
>>>     >> public interface PagedResult<T> {
>>>     >>
>>>     >>     PagedResult<T> next();
>>>     >>
>>>     >>     PagedResult<T> prev();
>>>     >>
>>>     >>     PagedResult<T> withOffset(int offset);
>>>     >>
>>>     >>     PagedResult<T> withLimit(int limit);
>>>     >>
>>>     >>     List<T> result();
>>>     >>
>>>     >> }
>>>     >>
>>>     >>
>>>     >> On Tue, Jan 15, 2013 at 1:38 PM, Douglas Campos <qmx at qmx.me
>>>     <mailto:qmx at qmx.me>> wrote:
>>>     >>>
>>>     >>> I'm not a fan of those PageContext objects (remembers me of
>>>     some wild-ass
>>>     >>> ThreadLocals leaking all over)
>>>     >>>
>>>     >>> My proposal for the paging aware APIs would be something
>>>     like this:
>>>     >>>
>>>     >>> public interface PagedResult<T> {
>>>     >>>
>>>     >>>     List<T> next();
>>>     >>>
>>>     >>>     List<T> prev();
>>>     >>>
>>>     >>>     List<T> page(int offset, int limit);
>>>     >>>
>>>     >>> }
>>>     >>>
>>>     >>> and the Async counterpart
>>>     >>>
>>>     >>> public interface AsyncPagedResult<T> {
>>>     >>>
>>>     >>>     void next(Callback<List<T>> callback);
>>>     >>>
>>>     >>>     void prev(Callback<List<T>> callback);
>>>     >>>
>>>     >>>     void page(int offset, int limit, Callback<List<T>>
>>>     callback);
>>>     >>>
>>>     >>>     public static interface Callback<U> {
>>>     >>>         public void onResult(U result);
>>>     >>>     }
>>>     >>> }
>>>     >>>
>>>     >>> I don't like the idea of having a companion object for
>>>     holding the
>>>     >>> pagination state.
>>>     >>>
>>>     >>> Thoughts?
>>>     >>>
>>>     >>> -- qmx
>>>     >>>
>>>     >>> On 15/01/2013, at 08:37, Matthias Wessendorf
>>>     <matzew at apache.org <mailto:matzew at apache.org>> wrote:
>>>     >>>
>>>     >>> > Hi Summers,
>>>     >>> >
>>>     >>> >
>>>     >>> > https://gist.github.com/4532661
>>>     >>> >
>>>     >>> > That is a way to do paging which keeps Pipes immutable, uses
>>>     >>> > readWithFilter, and doesn't impose any (for convenient
>>>     definitions of any)
>>>     >>> > bookkeeping on the developer.
>>>     >>> >
>>>     >>> >
>>>     >>> > from your Andorid gist:
>>>     >>> >
>>>     >>> > A) Once the response has been received, the Pipe
>>>     implementation will
>>>     >>> > return a List of objects. If this List instance is passed to
>>>     >>> > Pipe.getPageContext the appropriate PageContext will be
>>>     returned
>>>     >>> >
>>>     >>> > Note: There is no 'return' - the readWithFilter is void,
>>>     instead a
>>>     >>> > Callback is invoked (onSuccess(list)), see Pipe.java
>>>     >>> >
>>>     >>> > B) The developer will receive from readWithFilter() a List
>>>     of object. If
>>>     >>> > she passes this list into Pipe.getPageContext(List result)
>>>     she will receive
>>>     >>> > the PageContext associated with this result.
>>>     >>> >
>>>     >>> > Do you mean like:
>>>     >>> >
>>>     >>> > ...
>>>     >>> > myPipe.readWithFilter(filter, new Callback<List<Data>>() {
>>>     >>> >
>>>     >>> >
>>>     >>> > @Override
>>>     >>> >
>>>     >>> >
>>>     >>> > public void onSuccess(List<Data> data) {
>>>     >>> >
>>>     >>> >
>>>     >>> >
>>>     >>> > // get the PageContext:
>>>     >>> >
>>>     >>> >
>>>     >>> > PageContext ctx = myPipe.getPageContext(data);
>>>     >>> >
>>>     >>> >
>>>     >>> > ...
>>>     >>> >
>>>     >>> >
>>>     >>> > }
>>>     >>> >
>>>     >>> >
>>>     >>> >
>>>     >>> > @Override
>>>     >>> >
>>>     >>> >
>>>     >>> > public void onFailure(Exception e) {
>>>     >>> >
>>>     >>> >
>>>     >>> > }
>>>     >>> > });
>>>     >>> > Not sure about that.....
>>>     >>> >
>>>     >>> > But for iOS I am thinking about passing in the PageContext
>>>     into the
>>>     >>> > closure/block of the readWithFilter, like:
>>>     >>> >
>>>     >>> > -(void) readWithFilter:(void (^)(id<AGFilterConfig>
>>>     config)) config
>>>     >>> >
>>>     >>> >
>>>     >>> > success:(void (^)(id listOfObjects, id pageContext))success
>>>     >>> >
>>>     >>> >
>>>     >>> > failure:(void (^)(NSError *error))failure;
>>>     >>> > A usage would look like:
>>>     >>> >
>>>     >>> >     [pipe readWithFilter:^(id<AGFilterConfig> config) {
>>>     >>> >
>>>     >>> >
>>>     >>> > // set the filter args and override the given defaults
>>>     >>> >
>>>     >>> >
>>>     >>> > } success:^(id listOfObjects, id pageContext) {
>>>     >>> >
>>>     >>> >
>>>     >>> > // work with the listOfObjects reponse.
>>>     >>> >
>>>     >>> >
>>>     >>> > // for paging/query info, access the given pagecontext,
>>>     >>> >
>>>     >>> >
>>>     >>> > // of the CURRENT request
>>>     >>> >
>>>     >>> >
>>>     >>> > ...
>>>     >>> >
>>>     >>> >
>>>     >>> > } failure:^(NSError *error) {
>>>     >>> >
>>>     >>> >
>>>     >>> > // handle errorz
>>>     >>> >
>>>     >>> >
>>>     >>> > }];
>>>     >>> > Any thoughts ?
>>>     >>> >
>>>     >>> > Not sure I like (or understand) the
>>>     Pipe.getPageContext(List result)
>>>     >>> > call. Current mindset is that thePageContext just (and
>>>     only) belongs to the
>>>     >>> > previous (executed) request... Not sure I want to support
>>>     something like
>>>     >>> >
>>>     >>> > // first call:
>>>     >>> > List<SomeType> first;
>>>     >>> > myPipe.readWithFilter(.....) // set first inside of callback
>>>     >>> > ...
>>>     >>> > // second call:
>>>     >>> > List<SomeType> second;
>>>     >>> > myPipe.readWithFilter(.....) // set second inside of callback
>>>     >>> > ...
>>>     >>> > // third call:
>>>     >>> > List<SomeType> third;
>>>     >>> > myPipe.readWithFilter(.....) // set third inside of callback
>>>     >>> > ...
>>>     >>> >
>>>     >>> >
>>>     >>> >
>>>     >>> >
>>>     >>> > /// A BIT LATER ....:
>>>     >>> > myPipe.getPageContext(first);
>>>     >>> >
>>>     >>> >
>>>     >>> > I am not sure if that (myPipe.getPageContext(first);) is
>>>     really desired
>>>     >>> > (or would even easily work, as it would need to store the
>>>     "metadata").....
>>>     >>> >
>>>     >>> >
>>>     >>> > Perhaps I am just wrong.
>>>     >>> >
>>>     >>> >
>>>     >>> > --
>>>     >>> > Matthias Wessendorf
>>>     >>> >
>>>     >>> > blog: http://matthiaswessendorf.wordpress.com/
>>>     >>> > sessions: http://www.slideshare.net/mwessendorf
>>>     >>> > twitter: http://twitter.com/mwessendorf
>>>     >>> > _______________________________________________
>>>     >>> > aerogear-dev mailing list
>>>     >>> > aerogear-dev at lists.jboss.org
>>>     <mailto:aerogear-dev at lists.jboss.org>
>>>     >>> > https://lists.jboss.org/mailman/listinfo/aerogear-dev
>>>     >>>
>>>     >>>
>>>     >>> _______________________________________________
>>>     >>> aerogear-dev mailing list
>>>     >>> aerogear-dev at lists.jboss.org
>>>     <mailto:aerogear-dev at lists.jboss.org>
>>>     >>> https://lists.jboss.org/mailman/listinfo/aerogear-dev
>>>     >>
>>>     >>
>>>     >>
>>>     >> _______________________________________________
>>>     >> aerogear-dev mailing list
>>>     >> aerogear-dev at lists.jboss.org
>>>     <mailto:aerogear-dev at lists.jboss.org>
>>>     >> https://lists.jboss.org/mailman/listinfo/aerogear-dev
>>>     >>
>>>     >
>>>     >
>>>     >
>>>     > --
>>>     > Matthias Wessendorf
>>>     >
>>>     > blog: http://matthiaswessendorf.wordpress.com/
>>>     > sessions: http://www.slideshare.net/mwessendorf
>>>     > twitter: http://twitter.com/mwessendorf
>>>
>>>
>>>
>>>     --
>>>     Matthias Wessendorf
>>>
>>>     blog: http://matthiaswessendorf.wordpress.com/
>>>     sessions: http://www.slideshare.net/mwessendorf
>>>     twitter: http://twitter.com/mwessendorf
>>>     _______________________________________________
>>>     aerogear-dev mailing list
>>>     aerogear-dev at lists.jboss.org <mailto:aerogear-dev at lists.jboss.org>
>>>     https://lists.jboss.org/mailman/listinfo/aerogear-dev
>>>
>>>
>>>
>>>
>>> _______________________________________________
>>> aerogear-dev mailing list
>>> aerogear-dev at lists.jboss.org
>>> https://lists.jboss.org/mailman/listinfo/aerogear-dev
>>
>> _______________________________________________
>> aerogear-dev mailing list
>> aerogear-dev at lists.jboss.org <mailto:aerogear-dev at lists.jboss.org>
>> https://lists.jboss.org/mailman/listinfo/aerogear-dev
>
>
>
> _______________________________________________
> aerogear-dev mailing list
> aerogear-dev at lists.jboss.org
> https://lists.jboss.org/mailman/listinfo/aerogear-dev

-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.jboss.org/pipermail/aerogear-dev/attachments/20130115/a6ac5815/attachment-0001.html 


More information about the aerogear-dev mailing list