Swiftgram/Source/Debug/AsyncDisplayKit+Tips.mm
Adlai Holler d0ba092a77
Convert the codebase to Objective-C++ (#1206)
* Convert the codebase to Objective-C++ throughout. One language is better than two.

* Put it back

* Fix linker

* Point explicitly to updated Weaver to unblock build

* Revert "Point explicitly to updated Weaver to unblock build"

This reverts commit fdc25296e8794d4e6e56c35f5fe6da2be3f71dbc.

* Revert "Fix linker"

This reverts commit 7be25f91519b8497ef42de79f115bcfbdb965c39.

* Add in the frameworks

* no message

* Address spec lint warnings

* Fix tvos build

* Put that back

* Address Michael's review

* Add comment to kick CI
2018-11-02 12:04:14 -07:00

49 lines
1.2 KiB
Plaintext

//
// AsyncDisplayKit+Tips.mm
// Texture
//
// Copyright (c) Facebook, Inc. and its affiliates. All rights reserved.
// Changes after 4/13/2017 are: Copyright (c) Pinterest, Inc. All rights reserved.
// Licensed under Apache 2.0: http://www.apache.org/licenses/LICENSE-2.0
//
#import <AsyncDisplayKit/AsyncDisplayKit+Tips.h>
#import <AsyncDisplayKit/ASDisplayNode+Ancestry.h>
@implementation ASDisplayNode (Tips)
static char ASDisplayNodeEnableTipsKey;
static ASTipDisplayBlock _Nullable __tipDisplayBlock;
/**
* Use associated objects with NSNumbers. This is a debug property - simplicity is king.
*/
+ (void)setEnableTips:(BOOL)enableTips
{
objc_setAssociatedObject(self, &ASDisplayNodeEnableTipsKey, @(enableTips), OBJC_ASSOCIATION_COPY);
}
+ (BOOL)enableTips
{
NSNumber *result = objc_getAssociatedObject(self, &ASDisplayNodeEnableTipsKey);
if (result == nil) {
return YES;
}
return result.boolValue;
}
+ (void)setTipDisplayBlock:(ASTipDisplayBlock)tipDisplayBlock
{
__tipDisplayBlock = tipDisplayBlock;
}
+ (ASTipDisplayBlock)tipDisplayBlock
{
return __tipDisplayBlock ?: ^(ASDisplayNode *node, NSString *string) {
NSLog(@"%@. Node ancestry: %@", string, node.ancestryDescription);
};
}
@end