Skip to content

Commit

Permalink
Add backward compatible Obj-C Generic support for Tasks.
Browse files Browse the repository at this point in the history
  • Loading branch information
nlutsenko committed Sep 3, 2015
1 parent 71b69e7 commit 0c9840f
Show file tree
Hide file tree
Showing 5 changed files with 41 additions and 13 deletions.
6 changes: 6 additions & 0 deletions Bolts.xcodeproj/project.pbxproj
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,8 @@
8103FA7819900A84000BAE3F /* BFAppLinkTarget.m in Sources */ = {isa = PBXBuildFile; fileRef = 8103FA6319900A84000BAE3F /* BFAppLinkTarget.m */; };
8103FA7A19900A84000BAE3F /* BFURL.m in Sources */ = {isa = PBXBuildFile; fileRef = 8103FA6519900A84000BAE3F /* BFURL.m */; };
8103FA7C19900A84000BAE3F /* BFWebViewAppLinkResolver.m in Sources */ = {isa = PBXBuildFile; fileRef = 8103FA6719900A84000BAE3F /* BFWebViewAppLinkResolver.m */; };
8105DA251B7A83BC0092AE4F /* BFDefines.h in Headers */ = {isa = PBXBuildFile; fileRef = 8105DA241B7A83BC0092AE4F /* BFDefines.h */; settings = {ATTRIBUTES = (Public, ); }; };
8105DA261B7A83BC0092AE4F /* BFDefines.h in Headers */ = {isa = PBXBuildFile; fileRef = 8105DA241B7A83BC0092AE4F /* BFDefines.h */; settings = {ATTRIBUTES = (Public, ); }; };
8122B2871AA0C6890025C5AF /* Bolts.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 8EDDA63517E17DDD00655F8A /* Bolts.framework */; };
81D0EE7D19AFA8260000AE75 /* UIKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 81D0EE7C19AFA8260000AE75 /* UIKit.framework */; };
81D0EE8019AFA9E20000AE75 /* BoltsVersion.h in Headers */ = {isa = PBXBuildFile; fileRef = 8103FA5619900A84000BAE3F /* BoltsVersion.h */; settings = {ATTRIBUTES = (Public, ); }; };
Expand Down Expand Up @@ -148,6 +150,7 @@
8103FA6519900A84000BAE3F /* BFURL.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = BFURL.m; sourceTree = "<group>"; };
8103FA6619900A84000BAE3F /* BFWebViewAppLinkResolver.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = BFWebViewAppLinkResolver.h; sourceTree = "<group>"; };
8103FA6719900A84000BAE3F /* BFWebViewAppLinkResolver.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = BFWebViewAppLinkResolver.m; sourceTree = "<group>"; };
8105DA241B7A83BC0092AE4F /* BFDefines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = BFDefines.h; sourceTree = "<group>"; };
8122B2881AA0E8220025C5AF /* iOS-Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; name = "iOS-Info.plist"; path = "Resources/iOS-Info.plist"; sourceTree = "<group>"; };
814916E11AD5D46600EE7C63 /* iOS.modulemap */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = "sourcecode.module-map"; name = iOS.modulemap; path = Resources/iOS.modulemap; sourceTree = "<group>"; };
81D0EE7C19AFA8260000AE75 /* UIKit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = UIKit.framework; path = Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS7.1.sdk/System/Library/Frameworks/UIKit.framework; sourceTree = DEVELOPER_DIR; };
Expand Down Expand Up @@ -250,6 +253,7 @@
8103FA5619900A84000BAE3F /* BoltsVersion.h */,
8103FA5419900A84000BAE3F /* Bolts.h */,
8103FA5519900A84000BAE3F /* Bolts.m */,
8105DA241B7A83BC0092AE4F /* BFDefines.h */,
8103FA5019900A84000BAE3F /* BFTask.h */,
8103FA5119900A84000BAE3F /* BFTask.m */,
8103FA5219900A84000BAE3F /* BFTaskCompletionSource.h */,
Expand Down Expand Up @@ -395,6 +399,7 @@
81D0EE8019AFA9E20000AE75 /* BoltsVersion.h in Headers */,
81D0EE8C19AFAA5F0000AE75 /* BFAppLink.h in Headers */,
81D0EE9219AFAA6F0000AE75 /* BFMeasurementEvent.h in Headers */,
8105DA251B7A83BC0092AE4F /* BFDefines.h in Headers */,
81D0EE9319AFAA6F0000AE75 /* BFURL.h in Headers */,
7CA39C921ADE715400DD78CC /* BFCancellationTokenRegistration.h in Headers */,
81D0EE8419AFAA100000AE75 /* Bolts.h in Headers */,
Expand All @@ -410,6 +415,7 @@
81D0EE8519AFAA190000AE75 /* BFTask.h in Headers */,
7C60AECA1ACF1A0B00747DD7 /* BFCancellationTokenSource.h in Headers */,
81D0EE8819AFAA240000AE75 /* BFExecutor.h in Headers */,
8105DA261B7A83BC0092AE4F /* BFDefines.h in Headers */,
81D0EE8A19AFAA2C0000AE75 /* BFTaskCompletionSource.h in Headers */,
81D0EE8219AFAA060000AE75 /* BoltsVersion.h in Headers */,
81D0EE8319AFAA0E0000AE75 /* Bolts.h in Headers */,
Expand Down
18 changes: 18 additions & 0 deletions Bolts/Common/BFDefines.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
/*
* Copyright (c) 2014, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
*/

#import <Foundation/Foundation.h>

#if __has_extension(objc_generics)
#define BF_GENERIC(type) <type>
#else
#define BF_GENERIC(type)
typedef id BFGenericType;
#endif
17 changes: 9 additions & 8 deletions Bolts/Common/BFTask.h
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
#import <Foundation/Foundation.h>

#import <Bolts/BFCancellationToken.h>
#import <Bolts/BFDefines.h>

/*!
Error domain used if there was multiple errors on <BFTask taskForCompletionOfAllTasks:>.
Expand All @@ -25,23 +26,23 @@ extern NSString *const BFTaskMultipleExceptionsException;
@class BFExecutor;
@class BFTask;

/*!
A block that can act as a continuation for a task.
*/
typedef id(^BFContinuationBlock)(BFTask *task);

/*!
The consumer view of a Task. A BFTask has methods to
inspect the state of the task, and to add continuations to
be run once the task is complete.
*/
@interface BFTask : NSObject
@interface BFTask BF_GENERIC(__covariant BFGenericType) : NSObject

/*!
A block that can act as a continuation for a task.
*/
typedef id(^BFContinuationBlock)(BFTask BF_GENERIC(BFGenericType) *task);

/*!
Creates a task that is already completed with the given result.
@param result The result for the task.
*/
+ (instancetype)taskWithResult:(id)result;
+ (instancetype)taskWithResult:(BFGenericType)result;

/*!
Creates a task that is already completed with the given error.
Expand Down Expand Up @@ -109,7 +110,7 @@ typedef id(^BFContinuationBlock)(BFTask *task);
/*!
The result of a successful task.
*/
@property (nonatomic, strong, readonly) id result;
@property (nonatomic, strong, readonly) BFGenericType result;

/*!
The error of a failed task.
Expand Down
12 changes: 7 additions & 5 deletions Bolts/Common/BFTaskCompletionSource.h
Original file line number Diff line number Diff line change
Expand Up @@ -10,14 +10,16 @@

#import <Foundation/Foundation.h>

@class BFTask;
#import <Bolts/BFDefines.h>

@class BFTask BF_GENERIC(BFResultType);

/*!
A BFTaskCompletionSource represents the producer side of tasks.
It is a task that also has methods for changing the state of the
task by settings its completion values.
*/
@interface BFTaskCompletionSource : NSObject
@interface BFTaskCompletionSource BF_GENERIC(__covariant BFGenericType) : NSObject

/*!
Creates a new unfinished task.
Expand All @@ -27,14 +29,14 @@
/*!
The task associated with this TaskCompletionSource.
*/
@property (nonatomic, strong, readonly) BFTask *task;
@property (nonatomic, strong, readonly) BFTask BF_GENERIC(BFGenericType) *task;

/*!
Completes the task by setting the result.
Attempting to set this for a completed task will raise an exception.
@param result The result of the task.
*/
- (void)setResult:(id)result;
- (void)setResult:(BFGenericType)result;

/*!
Completes the task by setting the error.
Expand All @@ -60,7 +62,7 @@
Sets the result of the task if it wasn't already completed.
@returns whether the new value was set.
*/
- (BOOL)trySetResult:(id)result;
- (BOOL)trySetResult:(BFGenericType)result;

/*!
Sets the error of the task if it wasn't already completed.
Expand Down
1 change: 1 addition & 0 deletions Bolts/Common/Bolts.h
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
#import <Bolts/BFCancellationToken.h>
#import <Bolts/BFCancellationTokenRegistration.h>
#import <Bolts/BFCancellationTokenSource.h>
#import <Bolts/BFDefines.h>
#import <Bolts/BFExecutor.h>
#import <Bolts/BFTask.h>
#import <Bolts/BFTaskCompletionSource.h>
Expand Down

0 comments on commit 0c9840f

Please sign in to comment.