// // ASTextKitContext.h // 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 #import #if AS_ENABLE_TEXTNODE #import /** A threadsafe container for the TextKit components that ASTextKit uses to lay out and truncate its text. This container is the sole owner and manager of the TextKit classes. This is an important model because of major thread safety issues inside vanilla TextKit. It provides a central locking location for accessing TextKit methods. */ AS_SUBCLASSING_RESTRICTED @interface ASTextKitContext : NSObject /** Initializes a context and its associated TextKit components. Initialization of TextKit components is a globally locking operation so be careful of bottlenecks with this class. */ - (instancetype)initWithAttributedString:(NSAttributedString *)attributedString lineBreakMode:(NSLineBreakMode)lineBreakMode maximumNumberOfLines:(NSUInteger)maximumNumberOfLines exclusionPaths:(NSArray *)exclusionPaths constrainedSize:(CGSize)constrainedSize; /** All operations on TextKit values MUST occur within this locked context. Simultaneous access (even non-mutative) to TextKit components may cause crashes. The block provided MUST not call out to client code from within its scope or it is possible for this to cause deadlocks in your application. Use with EXTREME care. Callers MUST NOT keep a ref to these internal objects and use them later. This WILL cause crashes in your application. */ - (void)performBlockWithLockedTextKitComponents:(AS_NOESCAPE void (^)(NSLayoutManager *layoutManager, NSTextStorage *textStorage, NSTextContainer *textContainer))block; @end #endif