#ifndef __TRACYVIEW_HPP__ #define __TRACYVIEW_HPP__ #include #include #include #include #include #include #include #include "../common/tracy_lz4.hpp" #include "../common/TracySocket.hpp" #include "../common/TracyQueue.hpp" #include "TracyCharUtil.hpp" #include "TracyEvent.hpp" #include "TracySlab.hpp" #include "TracyVector.hpp" struct ImVec2; namespace tracy { struct QueueItem; class FileRead; class FileWrite; class View { public: View() : View( "127.0.0.1" ) {} View( const char* addr ); View( FileRead& f ); ~View(); static bool ShouldExit(); static void Draw(); private: struct ThreadData { uint64_t id; Vector timeline; }; struct LockMap { uint64_t srcloc; Vector timeline; std::unordered_set threads; }; void Worker(); void DispatchProcess( const QueueItem& ev ); void DispatchProcess( const QueueItem& ev, const char*& ptr ); void ServerQuery( uint8_t type, uint64_t data ); void Process( const QueueItem& ev ); void ProcessZoneBegin( const QueueZoneBegin& ev ); void ProcessZoneEnd( const QueueZoneEnd& ev ); void ProcessFrameMark( const QueueFrameMark& ev ); void ProcessZoneText( const QueueZoneText& ev ); void ProcessZoneName( const QueueZoneName& ev ); void ProcessLockAnnounce( const QueueLockAnnounce& ev ); void ProcessLockWait( const QueueLockWait& ev ); void ProcessLockObtain( const QueueLockObtain& ev ); void ProcessLockRelease( const QueueLockRelease& ev ); void ProcessLockMark( const QueueLockMark& ev ); void CheckString( uint64_t ptr ); void CheckThreadString( uint64_t id ); void CheckCustomString( uint64_t ptr, Event* dst ); void CheckSourceLocation( uint64_t ptr ); void AddString( uint64_t ptr, std::string&& str ); void AddThreadString( uint64_t id, std::string&& str ); void AddCustomString( uint64_t ptr, std::string&& str ); void AddSourceLocation( const QueueSourceLocation& srcloc ); void NewZone( Event* zone, uint64_t thread ); void UpdateZone( Event* zone ); void InsertZone( Event* zone, Event* parent, Vector& vec ); void InsertLockEvent( LockMap& lockmap, LockEvent* lev ); void UpdateLockCount( Vector& timeline, size_t pos ); uint64_t GetFrameTime( size_t idx ) const; uint64_t GetFrameBegin( size_t idx ) const; uint64_t GetFrameEnd( size_t idx ) const; int64_t GetLastTime() const; int64_t GetZoneEnd( const Event& ev ) const; Vector& GetParentVector( const Event& ev ); const char* TimeToString( int64_t ns ) const; const char* GetString( uint64_t ptr ) const; const char* GetThreadString( uint64_t id ) const; const QueueSourceLocation& GetSourceLocation( uint64_t srcloc ) const; void DrawImpl(); void DrawConnection(); void DrawFrames(); void DrawZones(); int DrawZoneLevel( const Vector& vec, bool hover, double pxns, const ImVec2& wpos, int offset, int depth ); int DrawLocks( uint64_t tid, bool hover, double pxns, const ImVec2& wpos, int offset, const LockEvent*& highlight ); void DrawZoneInfoWindow(); uint32_t GetZoneColor( const Event& ev ); uint32_t GetZoneColor( const QueueSourceLocation& srcloc ); uint32_t GetZoneHighlight( const Event& ev, bool migration ); float GetZoneThickness( const Event& ev ); void ZoomToZone( const Event& ev ); void ZoneTooltip( const Event& ev ); void Write( FileWrite& f ); void WriteTimeline( FileWrite& f, const Vector& vec ); void ReadTimeline( FileRead& f, Vector& vec, Event* parent, const std::unordered_map& stringMap ); std::string m_addr; Socket m_sock; std::thread m_thread; std::atomic m_shutdown; std::atomic m_connected; std::atomic m_hasData; bool m_staticView; // this block must be locked std::mutex m_lock; Vector m_frames; Vector m_threads; std::unordered_map m_strings; std::unordered_map m_threadNames; std::unordered_set m_customStrings; std::unordered_map m_sourceLocation; std::unordered_map m_lockMap; uint64_t m_zonesCnt; std::mutex m_mbpslock; std::vector m_mbps; // not used for vis - no need to lock std::unordered_map> m_zoneStack; std::unordered_set m_pendingStrings; std::unordered_set m_pendingThreads; std::unordered_set m_pendingSourceLocation; std::unordered_map m_pendingCustomStrings; std::unordered_map m_threadMap; Slab m_slab; LZ4_streamDecode_t* m_stream; char* m_buffer; int m_bufferOffset; int m_frameScale; bool m_pause; int m_frameStart; int64_t m_zvStart; int64_t m_zvEnd; int64_t m_zvStartNext; int64_t m_zvEndNext; uint64_t m_delay; uint64_t m_resolution; double m_timerMul; std::string m_captureName; int8_t m_lastCpu; const Event* m_zoneInfoWindow; const Event* m_zoneHighlight; const LockEvent* m_lockHighlight; }; } #endif