// // ASObjectDescriptionHelpers.h // AsyncDisplayKit // // Created by Adlai Holler on 9/7/16. // Copyright © 2016 Facebook. All rights reserved. // #import #import NS_ASSUME_NONNULL_BEGIN @protocol ASDebugNameProvider @required /** * @abstract Name that is printed by ascii art string and displayed in description. */ @property (nullable, nonatomic, copy) NSString *debugName; @end /** * Your base class should conform to this and override `-debugDescription` * to call `[self propertiesForDebugDescription]` and use `ASObjectDescriptionMake` * to return a string. Subclasses of this base class just need to override * `propertiesForDebugDescription`, call super, and modify the result as needed. */ @protocol ASDebugDescriptionProvider @required - (NSMutableArray *)propertiesForDebugDescription; @end /** * Your base class should conform to this and override `-description` * to call `[self propertiesForDescription]` and use `ASObjectDescriptionMake` * to return a string. Subclasses of this base class just need to override * `propertiesForDescription`, call super, and modify the result as needed. */ @protocol ASDescriptionProvider @required - (NSMutableArray *)propertiesForDescription; @end ASDISPLAYNODE_EXTERN_C_BEGIN NSString *ASGetDescriptionValueString(id object); /// Useful for structs etc. Returns e.g. { position = (0 0); frame = (0 0; 50 50) } NSString *ASObjectDescriptionMakeWithoutObject(NSArray * _Nullable propertyGroups); /// Returns e.g. NSString *ASObjectDescriptionMake(__autoreleasing id object, NSArray * _Nullable propertyGroups); /** * Returns e.g. * * Note: `object` param is autoreleasing so that this function is dealloc-safe. * No, unsafe_unretained isn't acceptable here – the optimizer may deallocate object early. */ NSString *ASObjectDescriptionMakeTiny(__autoreleasing id _Nullable object); NSString * _Nullable ASStringWithQuotesIfMultiword(NSString * _Nullable string); ASDISPLAYNODE_EXTERN_C_END NS_ASSUME_NONNULL_END