|  | @@ -5,11 +5,11 @@
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  JPH_SUPPRESS_WARNINGS_STD_BEGIN
 |  |  JPH_SUPPRESS_WARNINGS_STD_BEGIN
 | 
											
												
													
														|  |  #include <mutex>
 |  |  #include <mutex>
 | 
											
												
													
														|  | -#include <unordered_map>
 |  | 
 | 
											
												
													
														|  |  JPH_SUPPRESS_WARNINGS_STD_END
 |  |  JPH_SUPPRESS_WARNINGS_STD_END
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  #include <Jolt/Core/NonCopyable.h>
 |  |  #include <Jolt/Core/NonCopyable.h>
 | 
											
												
													
														|  |  #include <Jolt/Core/TickCounter.h>
 |  |  #include <Jolt/Core/TickCounter.h>
 | 
											
												
													
														|  | 
 |  | +#include <Jolt/Core/UnorderedMap.h>
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  #if defined(JPH_EXTERNAL_PROFILE)
 |  |  #if defined(JPH_EXTERNAL_PROFILE)
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -76,6 +76,8 @@ class ProfileThread;
 | 
											
												
													
														|  |  class Profiler : public NonCopyable
 |  |  class Profiler : public NonCopyable
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  |  public:
 |  |  public:
 | 
											
												
													
														|  | 
 |  | +	JPH_OVERRIDE_NEW_DELETE
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  	/// Increments the frame counter to provide statistics per frame
 |  |  	/// Increments the frame counter to provide statistics per frame
 | 
											
												
													
														|  |  	void						NextFrame();
 |  |  	void						NextFrame();
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -90,13 +92,13 @@ public:
 | 
											
												
													
														|  |  	void						RemoveThread(ProfileThread *inThread);
 |  |  	void						RemoveThread(ProfileThread *inThread);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	/// Singleton instance
 |  |  	/// Singleton instance
 | 
											
												
													
														|  | -	static Profiler				sInstance;
 |  | 
 | 
											
												
													
														|  | 
 |  | +	static Profiler *			sInstance;
 | 
											
												
													
														|  |  								
 |  |  								
 | 
											
												
													
														|  |  private:
 |  |  private:
 | 
											
												
													
														|  |  	/// Helper class to freeze ProfileSamples per thread while processing them
 |  |  	/// Helper class to freeze ProfileSamples per thread while processing them
 | 
											
												
													
														|  |  	struct ThreadSamples
 |  |  	struct ThreadSamples
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  | -		string					mThreadName;
 |  | 
 | 
											
												
													
														|  | 
 |  | +		String					mThreadName;
 | 
											
												
													
														|  |  		ProfileSample *			mSamplesBegin;
 |  |  		ProfileSample *			mSamplesBegin;
 | 
											
												
													
														|  |  		ProfileSample *			mSamplesEnd;
 |  |  		ProfileSample *			mSamplesEnd;
 | 
											
												
													
														|  |  	};
 |  |  	};
 | 
											
										
											
												
													
														|  | @@ -135,9 +137,9 @@ private:
 | 
											
												
													
														|  |  		uint64					mMaxCyclesInCallWithChildren = 0;									///< Maximum amount of cycles spent per call
 |  |  		uint64					mMaxCyclesInCallWithChildren = 0;									///< Maximum amount of cycles spent per call
 | 
											
												
													
														|  |  	};							
 |  |  	};							
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -	using Threads = vector<ThreadSamples>;
 |  | 
 | 
											
												
													
														|  | -	using Aggregators = vector<Aggregator>;
 |  | 
 | 
											
												
													
														|  | -	using KeyToAggregator = unordered_map<const char *, size_t>;
 |  | 
 | 
											
												
													
														|  | 
 |  | +	using Threads = Array<ThreadSamples>;
 | 
											
												
													
														|  | 
 |  | +	using Aggregators = Array<Aggregator>;
 | 
											
												
													
														|  | 
 |  | +	using KeyToAggregator = UnorderedMap<const char *, size_t>;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	/// Helper function to aggregate profile sample data
 |  |  	/// Helper function to aggregate profile sample data
 | 
											
												
													
														|  |  	static void					sAggregate(int inDepth, uint32 inColor, ProfileSample *&ioSample, const ProfileSample *inEnd, Aggregators &ioAggregators, KeyToAggregator &ioKeyToAggregator);
 |  |  	static void					sAggregate(int inDepth, uint32 inColor, ProfileSample *&ioSample, const ProfileSample *inEnd, Aggregators &ioAggregators, KeyToAggregator &ioKeyToAggregator);
 | 
											
										
											
												
													
														|  | @@ -148,15 +150,17 @@ private:
 | 
											
												
													
														|  |  	void						DumpChart(const char *inTag, const Threads &inThreads, const KeyToAggregator &inKeyToAggregators, const Aggregators &inAggregators);
 |  |  	void						DumpChart(const char *inTag, const Threads &inThreads, const KeyToAggregator &inKeyToAggregators, const Aggregators &inAggregators);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	mutex						mLock;																///< Lock that protects mThreads
 |  |  	mutex						mLock;																///< Lock that protects mThreads
 | 
											
												
													
														|  | -	vector<ProfileThread *>		mThreads;															///< List of all active threads
 |  | 
 | 
											
												
													
														|  | 
 |  | +	Array<ProfileThread *>		mThreads;															///< List of all active threads
 | 
											
												
													
														|  |  	bool						mDump = false;														///< When true, the samples are dumped next frame
 |  |  	bool						mDump = false;														///< When true, the samples are dumped next frame
 | 
											
												
													
														|  | -	string						mDumpTag;															///< When not empty, this overrides the auto incrementing number of the dump filename
 |  | 
 | 
											
												
													
														|  | 
 |  | +	String						mDumpTag;															///< When not empty, this overrides the auto incrementing number of the dump filename
 | 
											
												
													
														|  |  };							
 |  |  };							
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // Class that contains the information of a single scoped measurement
 |  |  // Class that contains the information of a single scoped measurement
 | 
											
												
													
														|  |  class alignas(16) ProfileSample : public NonCopyable
 |  |  class alignas(16) ProfileSample : public NonCopyable
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  |  public:
 |  |  public:
 | 
											
												
													
														|  | 
 |  | +	JPH_OVERRIDE_NEW_DELETE
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  	const char *				mName;																///< User defined name of this item
 |  |  	const char *				mName;																///< User defined name of this item
 | 
											
												
													
														|  |  	uint32						mColor;																///< Color to use for this sample
 |  |  	uint32						mColor;																///< Color to use for this sample
 | 
											
												
													
														|  |  	uint8						mDepth;																///< Calculated depth
 |  |  	uint8						mDepth;																///< Calculated depth
 | 
											
										
											
												
													
														|  | @@ -169,13 +173,15 @@ public:
 | 
											
												
													
														|  |  class ProfileThread : public NonCopyable
 |  |  class ProfileThread : public NonCopyable
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  |  public:
 |  |  public:
 | 
											
												
													
														|  | 
 |  | +	JPH_OVERRIDE_NEW_DELETE
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  	/// Constructor
 |  |  	/// Constructor
 | 
											
												
													
														|  |  	inline						ProfileThread(const string_view &inThreadName);
 |  |  	inline						ProfileThread(const string_view &inThreadName);
 | 
											
												
													
														|  |  	inline						~ProfileThread();
 |  |  	inline						~ProfileThread();
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	static const uint cMaxSamples = 65536;
 |  |  	static const uint cMaxSamples = 65536;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -	string						mThreadName;														///< Name of the thread that we're collecting information for
 |  | 
 | 
											
												
													
														|  | 
 |  | +	String						mThreadName;														///< Name of the thread that we're collecting information for
 | 
											
												
													
														|  |  	ProfileSample				mSamples[cMaxSamples];												///< Buffer of samples
 |  |  	ProfileSample				mSamples[cMaxSamples];												///< Buffer of samples
 | 
											
												
													
														|  |  	uint						mCurrentSample = 0;													///< Next position to write a sample to
 |  |  	uint						mCurrentSample = 0;													///< Next position to write a sample to
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -208,8 +214,14 @@ JPH_NAMESPACE_END
 | 
											
												
													
														|  |  JPH_SUPPRESS_WARNING_PUSH
 |  |  JPH_SUPPRESS_WARNING_PUSH
 | 
											
												
													
														|  |  JPH_CLANG_SUPPRESS_WARNING("-Wc++98-compat-pedantic")
 |  |  JPH_CLANG_SUPPRESS_WARNING("-Wc++98-compat-pedantic")
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +/// Start instrumenting program
 | 
											
												
													
														|  | 
 |  | +#define JPH_PROFILE_START(name)			do { Profiler::sInstance = new Profiler; JPH_PROFILE_THREAD_START(name); } while (false)
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +/// End instrumenting program
 | 
											
												
													
														|  | 
 |  | +#define JPH_PROFILE_END()				do { JPH_PROFILE_THREAD_END(); delete Profiler::sInstance; Profiler::sInstance = nullptr; } while (false)
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  /// Start instrumenting a thread
 |  |  /// Start instrumenting a thread
 | 
											
												
													
														|  | -#define JPH_PROFILE_THREAD_START(name)	ProfileThread::sInstance = new ProfileThread(name)
 |  | 
 | 
											
												
													
														|  | 
 |  | +#define JPH_PROFILE_THREAD_START(name)	do { if (Profiler::sInstance) ProfileThread::sInstance = new ProfileThread(name); } while (false)
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  /// End instrumenting a thread
 |  |  /// End instrumenting a thread
 | 
											
												
													
														|  |  #define JPH_PROFILE_THREAD_END()		do { delete ProfileThread::sInstance; ProfileThread::sInstance = nullptr; } while (false)
 |  |  #define JPH_PROFILE_THREAD_END()		do { delete ProfileThread::sInstance; ProfileThread::sInstance = nullptr; } while (false)
 | 
											
										
											
												
													
														|  | @@ -223,10 +235,10 @@ JPH_CLANG_SUPPRESS_WARNING("-Wc++98-compat-pedantic")
 | 
											
												
													
														|  |  #define JPH_PROFILE_FUNCTION()			JPH_PROFILE(JPH_FUNCTION_NAME)
 |  |  #define JPH_PROFILE_FUNCTION()			JPH_PROFILE(JPH_FUNCTION_NAME)
 | 
											
												
													
														|  |  								
 |  |  								
 | 
											
												
													
														|  |  /// Update frame counter								
 |  |  /// Update frame counter								
 | 
											
												
													
														|  | -#define JPH_PROFILE_NEXTFRAME()			Profiler::sInstance.NextFrame()
 |  | 
 | 
											
												
													
														|  | 
 |  | +#define JPH_PROFILE_NEXTFRAME()			Profiler::sInstance->NextFrame()
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  /// Dump profiling info
 |  |  /// Dump profiling info
 | 
											
												
													
														|  | -#define JPH_PROFILE_DUMP(...)			Profiler::sInstance.Dump(__VA_ARGS__)
 |  | 
 | 
											
												
													
														|  | 
 |  | +#define JPH_PROFILE_DUMP(...)			Profiler::sInstance->Dump(__VA_ARGS__)
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  JPH_SUPPRESS_WARNING_POP
 |  |  JPH_SUPPRESS_WARNING_POP
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -239,6 +251,8 @@ JPH_SUPPRESS_WARNING_POP
 | 
											
												
													
														|  |  JPH_SUPPRESS_WARNING_PUSH
 |  |  JPH_SUPPRESS_WARNING_PUSH
 | 
											
												
													
														|  |  JPH_CLANG_SUPPRESS_WARNING("-Wc++98-compat-pedantic")
 |  |  JPH_CLANG_SUPPRESS_WARNING("-Wc++98-compat-pedantic")
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +#define JPH_PROFILE_START(name)
 | 
											
												
													
														|  | 
 |  | +#define JPH_PROFILE_END()
 | 
											
												
													
														|  |  #define JPH_PROFILE_THREAD_START(name)
 |  |  #define JPH_PROFILE_THREAD_START(name)
 | 
											
												
													
														|  |  #define JPH_PROFILE_THREAD_END()
 |  |  #define JPH_PROFILE_THREAD_END()
 | 
											
												
													
														|  |  #define JPH_PROFILE(...)
 |  |  #define JPH_PROFILE(...)
 |