iOS: add DoricDevPerfVC
This commit is contained in:
@@ -19,8 +19,32 @@
|
||||
|
||||
#import "DoricDevPerformanceAnchorHook.h"
|
||||
|
||||
@implementation DoricDevAnchorNode
|
||||
@end
|
||||
|
||||
@interface DoricDevPerformanceAnchorHook ()
|
||||
@property(nonatomic, strong) NSMutableDictionary<NSString *, NSMutableArray <DoricDevAnchorNode *> *> *nodeMap;
|
||||
@property(nonatomic, copy) NSComparator comparator;
|
||||
@end
|
||||
|
||||
@implementation DoricDevPerformanceAnchorHook
|
||||
- (instancetype)init {
|
||||
if (self = [super init]) {
|
||||
_nodeMap = [NSMutableDictionary new];
|
||||
_comparator = ^NSComparisonResult(DoricDevAnchorNode *obj1, DoricDevAnchorNode *obj2) {
|
||||
long ret = obj1.prepare - obj2.prepare;
|
||||
if (ret > 0) {
|
||||
return NSOrderedDescending;
|
||||
} else if (ret < 0) {
|
||||
return NSOrderedAscending;
|
||||
} else {
|
||||
return NSOrderedSame;
|
||||
}
|
||||
};
|
||||
}
|
||||
return self;
|
||||
}
|
||||
|
||||
- (void)onAnchorName:(NSString *)name prepare:(NSNumber *)prepare start:(NSNumber *)start end:(NSNumber *)end in:(DoricPerformanceProfile *)profile {
|
||||
NSLog(@"[DoricPerformance] %@: %@ prepared %@ms, cost %@ms",
|
||||
profile.name,
|
||||
@@ -28,10 +52,28 @@ - (void)onAnchorName:(NSString *)name prepare:(NSNumber *)prepare start:(NSNumbe
|
||||
@(start.integerValue - prepare.integerValue),
|
||||
@(end.integerValue - start.integerValue)
|
||||
);
|
||||
NSMutableArray<DoricDevAnchorNode *> *array = self.nodeMap[profile.name];
|
||||
if (!array) {
|
||||
array = [NSMutableArray new];
|
||||
self.nodeMap[profile.name] = array;
|
||||
}
|
||||
[array addObject:[[DoricDevAnchorNode new] also:^(DoricDevAnchorNode *it) {
|
||||
it.name = name;
|
||||
it.prepare = prepare.longValue;
|
||||
it.start = start.longValue;
|
||||
it.end = end.longValue;
|
||||
}]];
|
||||
[array sortUsingComparator:self.comparator];
|
||||
if ([name isEqualToString:@"Destroy"]) {
|
||||
[self.nodeMap removeObjectForKey:profile.name];
|
||||
}
|
||||
}
|
||||
|
||||
- (void)onAnchorName:(NSString *)name prepare:(NSNumber *)prepare start:(NSNumber *)start end:(NSNumber *)end {
|
||||
//Do nothing
|
||||
}
|
||||
|
||||
- (NSArray <DoricDevAnchorNode *> *)getAnchorNodeList:(NSString *)name {
|
||||
return [self.nodeMap[name] copy];
|
||||
}
|
||||
@end
|
||||
Reference in New Issue
Block a user