forked from facebookarchive/AsyncDisplayKit
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathASTraceEvent.m
More file actions
66 lines (56 loc) · 2.18 KB
/
Copy pathASTraceEvent.m
File metadata and controls
66 lines (56 loc) · 2.18 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
//
// ASTraceEvent.m
// AsyncDisplayKit
//
// Created by Adlai Holler on 9/13/16.
// Copyright © 2016 Facebook. All rights reserved.
//
#import "ASTraceEvent.h"
#import <QuartzCore/QuartzCore.h>
static NSString *const ASTraceEventThreadDescriptionKey = @"ASThreadTraceEventDescription";
@interface ASTraceEvent ()
@property (nonatomic, strong, readonly) NSString *objectDescription;
@property (nonatomic, strong, readonly) NSString *threadDescription;
@end
@implementation ASTraceEvent
- (instancetype)initWithBacktrace:(NSArray<NSString *> *)backtrace format:(NSString *)format arguments:(va_list)args
{
self = [super init];
if (self != nil) {
static NSTimeInterval refTime;
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
refTime = CACurrentMediaTime();
});
// Create the format string passed to us.
_message = [[NSString alloc] initWithFormat:format arguments:args];
NSThread *thread = [NSThread currentThread];
NSString *threadDescription = thread.name;
if (threadDescription.length == 0) {
if ([thread isMainThread]) {
threadDescription = @"Main";
} else {
// If the bg thread has no name, we cache a 4-character ptr string to identify it by
// inside the thread dictionary.
NSMutableDictionary *threadDict = thread.threadDictionary;
threadDescription = threadDict[ASTraceEventThreadDescriptionKey];
if (threadDescription == nil) {
// Want these to be 4-chars to line up with "Main". It's possible that a collision could happen
// here but it's so unbelievably likely to impact development, the risk is acceptable.
NSString *ptrString = [NSString stringWithFormat:@"%p", thread];
threadDescription = [ptrString substringFromIndex:MAX(0, ptrString.length - 4)];
threadDict[ASTraceEventThreadDescriptionKey] = threadDescription;
}
}
}
_threadDescription = threadDescription;
_backtrace = backtrace;
_timestamp = CACurrentMediaTime() - refTime;
}
return self;
}
- (NSString *)description
{
return [NSString stringWithFormat:@"<(%@) t=%7.3f: %@>", _threadDescription, _timestamp, _message];
}
@end