mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-09-12 07:21:06 +00:00
* Measure performance for ASCellNode layout * Address Adlai and Levi's feedback: * Move to ASDisplayNode level * Lock around setting/getting measurement options and results * Record all measurement passes and report times as an array * Only add relevant entries to the performanceMetrics dictionary * Rebase * Store sum and count instead of array * Rename ScopeTimerDataPoint to ScopeTimerSum * Address Levi's feedback * Address Adlai's feedback
53 lines
1.2 KiB
C++
53 lines
1.2 KiB
C++
//
|
|
// _ASScopeTimer.h
|
|
// AsyncDisplayKit
|
|
//
|
|
// Copyright (c) 2014-present, Facebook, Inc. All rights reserved.
|
|
// This source code is licensed under the BSD-style license found in the
|
|
// LICENSE file in the root directory of this source tree. An additional grant
|
|
// of patent rights can be found in the PATENTS file in the same directory.
|
|
//
|
|
|
|
#pragma once
|
|
|
|
/**
|
|
Must compile as c++ for this to work.
|
|
|
|
Usage:
|
|
// Can be an ivar or local variable
|
|
NSTimeInterval placeToStoreTiming;
|
|
|
|
{
|
|
// some scope
|
|
ASDisplayNode::ScopeTimer t(placeToStoreTiming);
|
|
DoPotentiallySlowWork();
|
|
MorePotentiallySlowWork();
|
|
}
|
|
|
|
*/
|
|
|
|
namespace ASDN {
|
|
struct ScopeTimer {
|
|
NSTimeInterval begin;
|
|
NSTimeInterval &outT;
|
|
ScopeTimer(NSTimeInterval &outRef) : outT(outRef) {
|
|
begin = CACurrentMediaTime();
|
|
}
|
|
~ScopeTimer() {
|
|
outT = CACurrentMediaTime() - begin;
|
|
}
|
|
};
|
|
|
|
// variant where repeated calls are summed
|
|
struct SumScopeTimer {
|
|
NSTimeInterval begin;
|
|
NSTimeInterval &outT;
|
|
SumScopeTimer(NSTimeInterval &outRef) : outT(outRef) {
|
|
begin = CACurrentMediaTime();
|
|
}
|
|
~SumScopeTimer() {
|
|
outT += CACurrentMediaTime() - begin;
|
|
}
|
|
};
|
|
}
|