Peter 9bc996374f Add 'submodules/AsyncDisplayKit/' from commit '02bedc12816e251ad71777f9d2578329b6d2bef6'
git-subtree-dir: submodules/AsyncDisplayKit
git-subtree-mainline: d06f423e0ed3df1fed9bd10d79ee312a9179b632
git-subtree-split: 02bedc12816e251ad71777f9d2578329b6d2bef6
2019-06-11 18:42:43 +01:00

57 lines
1.2 KiB
C++

//
// _ASScopeTimer.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
//
#pragma once
/**
Must compile as c++ for this to work.
Usage:
// Can be an ivar or local variable
NSTimeInterval placeToStoreTiming;
{
// some scope
AS::ScopeTimer t(placeToStoreTiming);
DoPotentiallySlowWork();
MorePotentiallySlowWork();
}
*/
namespace AS {
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;
BOOL enable;
SumScopeTimer(NSTimeInterval &outRef, BOOL enable = YES) : outT(outRef), enable(enable) {
if (enable) {
begin = CACurrentMediaTime();
}
}
~SumScopeTimer() {
if (enable) {
outT += CACurrentMediaTime() - begin;
}
}
};
}