/* * Created by Brett on 23/12/22. * Licensed under GNU General Public License V3.0 * See LICENSE file for license detail */ #ifndef BLT_PROFILER_H #define BLT_PROFILER_H #include #include #include #include #include #ifdef PHMAP_ENABLED #include #else #include #endif namespace BLT { struct CapturePoint { long point; }; struct CaptureInterval { CapturePoint start; CapturePoint end; }; #ifdef PHMAP_ENABLED typedef phmap::parallel_flat_hash_map INTERVAL_MAP; typedef phmap::parallel_flat_hash_map> POINT_MAP; typedef phmap::parallel_flat_hash_map POINT_HISTORY_MAP; typedef phmap::parallel_flat_hash_map ORDER_MAP; #else typedef std::unordered_map INTERVAL_MAP; typedef std::unordered_map POINT_MAP; typedef std::unordered_map POINT_HISTORY_MAP; typedef std::unordered_map ORDER_MAP; #endif class Profiler { private: INTERVAL_MAP intervals{}; std::queue points{}; std::queue cyclicPoints{}; POINT_HISTORY_MAP cyclicPointsHistory{}; ORDER_MAP order{}; std::mutex timerLock{}; int lastOrder = 0; public: Profiler() = default; void finishCycle(); void startInterval(const std::string_view& name); void endInterval(const std::string_view& name); void profilerPoint(); /** * Uses a separate tracking device that will be reset when finishCycle(); is called. */ void profilerPointCyclic(); }; } #endif //BLT_PROFILER_H