mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-09-03 03:10:47 +00:00
* [License] Simplify the Texture license to be pure Apache 2 (removing ASDK-Licenses) With permission of the Facebook Open Source team, we are simplifying the Texture license so that clients can rely on the Apache 2 terms that most of Texture is already covered by. This means that code originally forked from AsyncDisplayKit will be re-licensed from "BSD 3-clause + PATENTS v2" to Apache 2 without a PATENTS file. After getting confirmation that the updates to these core files look good, we'll propagate this new license header to all files (in this same PR) and get sign-off from all parties before landing. * [License] Update all Texture source files to be pure Apache 2. * Changelog entry for Apache 2 license update. * Revert "[License] Update all Texture source files to be pure Apache 2." This reverts commit ffa0fbbba9717d871dd16c4b07539f2f8208fc2b. * [License] Update all Texture source files to be pure Apache 2, maintaining copyrights. * [License] Update CONTRIBUTING, README, Podspec & Dangerfile.
53 lines
1.7 KiB
Objective-C
53 lines
1.7 KiB
Objective-C
//
|
|
// ASTextKitTruncating.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 <Foundation/Foundation.h>
|
|
#import <vector>
|
|
|
|
NS_ASSUME_NONNULL_BEGIN
|
|
|
|
@class ASTextKitContext;
|
|
|
|
@protocol ASTextKitTruncating <NSObject>
|
|
|
|
/**
|
|
The character range from the original attributedString that is displayed by the renderer given the parameters in the
|
|
initializer.
|
|
*/
|
|
@property (nonatomic, readonly) std::vector<NSRange> visibleRanges;
|
|
|
|
/**
|
|
Returns the first visible range or an NSRange with location of NSNotFound and size of 0 if no first visible
|
|
range exists
|
|
*/
|
|
@property (nonatomic, readonly) NSRange firstVisibleRange;
|
|
|
|
/**
|
|
A truncater object is initialized with the full state of the text. It is a Single Responsibility Object that is
|
|
mutative. It configures the state of the TextKit components (layout manager, text container, text storage) to achieve
|
|
the intended truncation, then it stores the resulting state for later fetching.
|
|
|
|
The truncater may mutate the state of the text storage such that only the drawn string is actually present in the
|
|
text storage itself.
|
|
|
|
The truncater should not store a strong reference to the context to prevent retain cycles.
|
|
*/
|
|
- (instancetype)initWithContext:(ASTextKitContext *)context
|
|
truncationAttributedString:(NSAttributedString * _Nullable)truncationAttributedString
|
|
avoidTailTruncationSet:(NSCharacterSet * _Nullable)avoidTailTruncationSet;
|
|
|
|
/**
|
|
Actually do the truncation.
|
|
*/
|
|
- (void)truncate;
|
|
|
|
@end
|
|
|
|
NS_ASSUME_NONNULL_END
|