gRPC  0.6.0
 All Classes Namespaces Functions Variables Enumerations Properties Pages
GRXWriteable.h
1 /*
2  *
3  * Copyright 2015, Google Inc.
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions are
8  * met:
9  *
10  * * Redistributions of source code must retain the above copyright
11  * notice, this list of conditions and the following disclaimer.
12  * * Redistributions in binary form must reproduce the above
13  * copyright notice, this list of conditions and the following disclaimer
14  * in the documentation and/or other materials provided with the
15  * distribution.
16  * * Neither the name of Google Inc. nor the names of its
17  * contributors may be used to endorse or promote products derived from
18  * this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  *
32  */
33 
34 #import <Foundation/Foundation.h>
35 
36 // A GRXWriteable is an object to which a sequence of values can be sent. The
37 // sequence finishes with an optional error.
38 @protocol GRXWriteable <NSObject>
39 
40 // Push the next value of the sequence to the receiving object.
41 // TODO(jcanizales): Name it enumerator:(id<GRXEnumerator>) didProduceValue:(id)?
42 - (void)didReceiveValue:(id)value;
43 
44 // Signal that the sequence is completed, or that an error ocurred. After this
45 // message is sent to the instance, neither it nor didReceiveValue: may be
46 // called again.
47 // TODO(jcanizales): enumerator:(id<GRXEnumerator>) didFinishWithError:(NSError*)?
48 - (void)didFinishWithError:(NSError *)errorOrNil;
49 @end
50 
51 typedef void (^GRXValueHandler)(id value);
52 typedef void (^GRXCompletionHandler)(NSError *errorOrNil);
53 typedef void (^GRXSingleValueHandler)(id value, NSError *errorOrNil);
54 typedef void (^GRXStreamHandler)(BOOL done, id value, NSError *error);
55 
56 // Utility to create objects that conform to the GRXWriteable protocol, from
57 // blocks that handle each of the two methods of the protocol.
58 @interface GRXWriteable : NSObject<GRXWriteable>
59 
60 + (instancetype)writeableWithSingleValueHandler:(GRXSingleValueHandler)handler;
61 + (instancetype)writeableWithStreamHandler:(GRXStreamHandler)handler;
62 
63 - (instancetype)initWithValueHandler:(GRXValueHandler)valueHandler
64  completionHandler:(GRXCompletionHandler)completionHandler
65  NS_DESIGNATED_INITIALIZER;
66 @end
Definition: GRXWriteable.h:38
Definition: GRXWriteable.h:58