mirror of
https://github.com/status-im/react-native.git
synced 2025-01-19 14:02:10 +00:00
104 lines
2.9 KiB
C
104 lines
2.9 KiB
C
|
/**
|
||
|
* Copyright (c) 2015-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.
|
||
|
*/
|
||
|
|
||
|
#import <Foundation/Foundation.h>
|
||
|
|
||
|
/**
|
||
|
* RCTProfile
|
||
|
*
|
||
|
* This file provides a set of functions and macros for performance profiling
|
||
|
*
|
||
|
* NOTE: This API is a work in a work in progress, please consider it before
|
||
|
* before using.
|
||
|
*/
|
||
|
|
||
|
#if DEBUG
|
||
|
|
||
|
/**
|
||
|
* Returns YES if the profiling information is currently being collected
|
||
|
*/
|
||
|
BOOL RCTProfileIsProfiling(void);
|
||
|
|
||
|
/**
|
||
|
* Start collecting profiling information
|
||
|
*/
|
||
|
void RCTProfileInit(void);
|
||
|
|
||
|
/**
|
||
|
* Stop profiling and return a JSON string of the collected data - The data
|
||
|
* returned is compliant with google's trace event format - the format used
|
||
|
* as input to trace-viewer
|
||
|
*/
|
||
|
NSString *RCTProfileEnd(void);
|
||
|
|
||
|
/**
|
||
|
* Collects the initial event information for the event and returns a reference ID
|
||
|
*/
|
||
|
NSNumber *_RCTProfileBeginEvent(void);
|
||
|
|
||
|
/**
|
||
|
* The ID returned by BeginEvent should then be passed into EndEvent, with the
|
||
|
* rest of the event information. Just at this point the event will actually be
|
||
|
* registered
|
||
|
*/
|
||
|
void _RCTProfileEndEvent(NSNumber *, NSString *, NSString *, id);
|
||
|
|
||
|
/**
|
||
|
* This pair of macros implicitly handle the event ID when beginning and ending
|
||
|
* an event, for both simplicity and performance reasons, this method is preferred
|
||
|
*
|
||
|
* NOTE: The EndEvent call has to be either, in the same scope of BeginEvent,
|
||
|
* or in a sub-scope, otherwise the ID stored by BeginEvent won't be accessible
|
||
|
* for EndEvent, in this case you may want to use the actual C functions.
|
||
|
*/
|
||
|
#define RCTProfileBeginEvent() \
|
||
|
_Pragma("clang diagnostic push") \
|
||
|
_Pragma("clang diagnostic ignored \"-Wshadow\"") \
|
||
|
NSNumber *__rct_profile_id = _RCTProfileBeginEvent(); \
|
||
|
_Pragma("clang diagnostic pop")
|
||
|
|
||
|
#define RCTProfileEndEvent(name, category, args...) \
|
||
|
_RCTProfileEndEvent(__rct_profile_id, name, category, args)
|
||
|
|
||
|
/**
|
||
|
* An event that doesn't have a duration (i.e. Notification, VSync, etc)
|
||
|
*/
|
||
|
void RCTProfileImmediateEvent(NSString *, NSTimeInterval , NSString *);
|
||
|
|
||
|
/**
|
||
|
* Helper to profile the duration of the execution of a block. This method uses
|
||
|
* self and _cmd to name this event for simplicity sake.
|
||
|
*
|
||
|
* NOTE: The block can't expect any argument
|
||
|
*/
|
||
|
#define RCTProfileBlock(block, category, arguments) \
|
||
|
^{ \
|
||
|
RCTProfileBeginEvent(); \
|
||
|
block(); \
|
||
|
RCTProfileEndEvent([NSString stringWithFormat:@"[%@ %@]", NSStringFromClass([self class]), NSStringFromSelector(_cmd)], category, arguments); \
|
||
|
}
|
||
|
|
||
|
#else
|
||
|
|
||
|
#define RCTProfileIsProfiling(...) NO
|
||
|
#define RCTProfileInit(...)
|
||
|
#define RCTProfileEnd(...) @""
|
||
|
|
||
|
#define _RCTProfileBeginEvent(...) @0
|
||
|
#define RCTProfileBeginEvent(...)
|
||
|
|
||
|
#define _RCTProfileEndEvent(...)
|
||
|
#define RCTProfileEndEvent(...)
|
||
|
|
||
|
#define RCTProfileImmediateEvent(...)
|
||
|
|
||
|
#define RCTProfileBlock(block, ...) block
|
||
|
|
||
|
#endif
|