mirror of
https://github.com/wolfpld/tracy.git
synced 2024-11-27 00:04:35 +00:00
Use common functionality to get frame set name.
This commit is contained in:
parent
92871ba75a
commit
b19f9e1f4d
@ -845,7 +845,7 @@ bool View::DrawImpl()
|
|||||||
{
|
{
|
||||||
ImGui::PushStyleColor( ImGuiCol_Text, GImGui->Style.Colors[ImGuiCol_TextDisabled] );
|
ImGui::PushStyleColor( ImGuiCol_Text, GImGui->Style.Colors[ImGuiCol_TextDisabled] );
|
||||||
}
|
}
|
||||||
ImGui::Text( "%s: %s", m_frames->name == 0 ? "Frames" : m_worker.GetString( m_frames->name ), RealToString( m_worker.GetFrameCount( *m_frames ) ) );
|
ImGui::Text( "%s: %s", GetFrameSetName( *m_frames ), RealToString( m_worker.GetFrameCount( *m_frames ) ) );
|
||||||
if( !vis )
|
if( !vis )
|
||||||
{
|
{
|
||||||
ImGui::PopStyleColor();
|
ImGui::PopStyleColor();
|
||||||
@ -861,7 +861,7 @@ bool View::DrawImpl()
|
|||||||
for( auto& fd : frames )
|
for( auto& fd : frames )
|
||||||
{
|
{
|
||||||
bool isSelected = m_frames == fd;
|
bool isSelected = m_frames == fd;
|
||||||
if( ImGui::Selectable( fd->name == 0 ? "Frames" : m_worker.GetString( fd->name ), isSelected ) )
|
if( ImGui::Selectable( GetFrameSetName( *fd ), isSelected ) )
|
||||||
{
|
{
|
||||||
m_frames = fd;
|
m_frames = fd;
|
||||||
}
|
}
|
||||||
|
@ -303,6 +303,8 @@ private:
|
|||||||
const ZoneEvent* FindZoneAtTime( uint64_t thread, int64_t time ) const;
|
const ZoneEvent* FindZoneAtTime( uint64_t thread, int64_t time ) const;
|
||||||
uint64_t GetFrameNumber( const FrameData& fd, int i, uint64_t offset ) const;
|
uint64_t GetFrameNumber( const FrameData& fd, int i, uint64_t offset ) const;
|
||||||
const char* GetFrameText( const FrameData& fd, int i, uint64_t ftime, uint64_t offset ) const;
|
const char* GetFrameText( const FrameData& fd, int i, uint64_t ftime, uint64_t offset ) const;
|
||||||
|
const char* GetFrameSetName( const FrameData& fd ) const;
|
||||||
|
static const char* GetFrameSetName( const FrameData& fd, const Worker& worker );
|
||||||
|
|
||||||
#ifndef TRACY_NO_STATISTICS
|
#ifndef TRACY_NO_STATISTICS
|
||||||
void FindZones();
|
void FindZones();
|
||||||
|
@ -405,7 +405,7 @@ void View::DrawCompare()
|
|||||||
int idx = 0;
|
int idx = 0;
|
||||||
for( auto& v : f0 )
|
for( auto& v : f0 )
|
||||||
{
|
{
|
||||||
const auto name = m_worker.GetString( v->name );
|
const auto name = GetFrameSetName( *v );
|
||||||
ImGui::PushID( -1 - idx );
|
ImGui::PushID( -1 - idx );
|
||||||
ImGui::RadioButton( name, &m_compare.selMatch[0], idx++ );
|
ImGui::RadioButton( name, &m_compare.selMatch[0], idx++ );
|
||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
@ -418,7 +418,7 @@ void View::DrawCompare()
|
|||||||
idx = 0;
|
idx = 0;
|
||||||
for( auto& v : f1 )
|
for( auto& v : f1 )
|
||||||
{
|
{
|
||||||
const auto name = m_compare.second->GetString( v->name );
|
const auto name = GetFrameSetName( *v, *m_compare.second );
|
||||||
ImGui::PushID( idx );
|
ImGui::PushID( idx );
|
||||||
ImGui::RadioButton( name, &m_compare.selMatch[1], idx++ );
|
ImGui::RadioButton( name, &m_compare.selMatch[1], idx++ );
|
||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
@ -435,8 +435,8 @@ void View::DrawCompare()
|
|||||||
|
|
||||||
if( m_compare.link )
|
if( m_compare.link )
|
||||||
{
|
{
|
||||||
auto string0 = m_worker.GetString( f0[m_compare.selMatch[0]]->name );
|
auto string0 = GetFrameSetName( *f0[m_compare.selMatch[0]] );
|
||||||
auto string1 = m_compare.second->GetString( f1[m_compare.selMatch[1]]->name );
|
auto string1 = GetFrameSetName( *f1[m_compare.selMatch[1]], *m_compare.second );
|
||||||
|
|
||||||
if( strcmp( string0, string1 ) != 0 )
|
if( strcmp( string0, string1 ) != 0 )
|
||||||
{
|
{
|
||||||
@ -445,7 +445,7 @@ void View::DrawCompare()
|
|||||||
{
|
{
|
||||||
for( auto& v : f1 )
|
for( auto& v : f1 )
|
||||||
{
|
{
|
||||||
auto string = m_compare.second->GetString( v->name );
|
auto string = GetFrameSetName( *v, *m_compare.second );
|
||||||
if( strcmp( string0, string ) == 0 )
|
if( strcmp( string0, string ) == 0 )
|
||||||
{
|
{
|
||||||
m_compare.selMatch[1] = idx;
|
m_compare.selMatch[1] = idx;
|
||||||
@ -459,7 +459,7 @@ void View::DrawCompare()
|
|||||||
assert( prev1 != m_compare.selMatch[1] );
|
assert( prev1 != m_compare.selMatch[1] );
|
||||||
for( auto& v : f0 )
|
for( auto& v : f0 )
|
||||||
{
|
{
|
||||||
auto string = m_worker.GetString( v->name );
|
auto string = GetFrameSetName( *v );
|
||||||
if( strcmp( string1, string ) == 0 )
|
if( strcmp( string1, string ) == 0 )
|
||||||
{
|
{
|
||||||
m_compare.selMatch[0] = idx;
|
m_compare.selMatch[0] = idx;
|
||||||
|
@ -185,7 +185,7 @@ void View::DrawFrames()
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ImGui::TextDisabled( "%s:", m_worker.GetString( m_frames->name ) );
|
ImGui::TextDisabled( "%s:", GetFrameSetName( *m_frames ) );
|
||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
ImGui::TextUnformatted( RealToString( fnum ) );
|
ImGui::TextUnformatted( RealToString( fnum ) );
|
||||||
ImGui::Separator();
|
ImGui::Separator();
|
||||||
|
@ -320,7 +320,7 @@ void View::DrawTimelineFrames( const FrameData& frames )
|
|||||||
ImGui::BeginTooltip();
|
ImGui::BeginTooltip();
|
||||||
TextDisabledUnformatted( "Frame set:" );
|
TextDisabledUnformatted( "Frame set:" );
|
||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
ImGui::TextUnformatted( frames.name == 0 ? "Frames" : m_worker.GetString( frames.name ) );
|
ImGui::TextUnformatted( GetFrameSetName( frames ) );
|
||||||
ImGui::EndTooltip();
|
ImGui::EndTooltip();
|
||||||
}
|
}
|
||||||
if( IsMouseClicked( 0 ) )
|
if( IsMouseClicked( 0 ) )
|
||||||
|
@ -701,7 +701,7 @@ void View::DrawOptions()
|
|||||||
for( const auto& fd : m_worker.GetFrames() )
|
for( const auto& fd : m_worker.GetFrames() )
|
||||||
{
|
{
|
||||||
ImGui::PushID( idx++ );
|
ImGui::PushID( idx++ );
|
||||||
SmallCheckbox( fd->name == 0 ? "Frames" : m_worker.GetString( fd->name ), &Vis( fd ).visible );
|
SmallCheckbox( GetFrameSetName( *fd ), &Vis( fd ).visible );
|
||||||
ImGui::PopID();
|
ImGui::PopID();
|
||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
ImGui::TextDisabled( "%s %sframes", RealToString( fd->frames.size() ), fd->continuous ? "" : "discontinuous " );
|
ImGui::TextDisabled( "%s %sframes", RealToString( fd->frames.size() ), fd->continuous ? "" : "discontinuous " );
|
||||||
|
@ -188,7 +188,7 @@ void View::DrawInfo()
|
|||||||
auto fsz = m_worker.GetFullFrameCount( *m_frames );
|
auto fsz = m_worker.GetFullFrameCount( *m_frames );
|
||||||
if( fsz != 0 )
|
if( fsz != 0 )
|
||||||
{
|
{
|
||||||
TextFocused( "Frame set:", m_frames->name == 0 ? "Frames" : m_worker.GetString( m_frames->name ) );
|
TextFocused( "Frame set:", GetFrameSetName( *m_frames ) );
|
||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
ImGui::TextDisabled( "(%s)", m_frames->continuous ? "continuous" : "discontinuous" );
|
ImGui::TextDisabled( "(%s)", m_frames->continuous ? "continuous" : "discontinuous" );
|
||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
@ -199,7 +199,7 @@ void View::DrawInfo()
|
|||||||
for( auto& fd : frames )
|
for( auto& fd : frames )
|
||||||
{
|
{
|
||||||
bool isSelected = m_frames == fd;
|
bool isSelected = m_frames == fd;
|
||||||
if( ImGui::Selectable( fd->name == 0 ? "Frames" : m_worker.GetString( fd->name ), isSelected ) )
|
if( ImGui::Selectable( GetFrameSetName( *fd ), isSelected ) )
|
||||||
{
|
{
|
||||||
m_frames = fd;
|
m_frames = fd;
|
||||||
fsz = m_worker.GetFullFrameCount( *m_frames );
|
fsz = m_worker.GetFullFrameCount( *m_frames );
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
#include <inttypes.h>
|
||||||
|
|
||||||
#include "TracyColor.hpp"
|
#include "TracyColor.hpp"
|
||||||
#include "TracyPrint.hpp"
|
#include "TracyPrint.hpp"
|
||||||
#include "TracyView.hpp"
|
#include "TracyView.hpp"
|
||||||
@ -791,11 +793,32 @@ const char* View::GetFrameText( const FrameData& fd, int i, uint64_t ftime, uint
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
sprintf( buf, "%s %s (%s)", m_worker.GetString( fd.name ), RealToString( fnum ), TimeToString( ftime ) );
|
sprintf( buf, "%s %s (%s)", GetFrameSetName( fd ), RealToString( fnum ), TimeToString( ftime ) );
|
||||||
}
|
}
|
||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const char* View::GetFrameSetName( const FrameData& fd ) const
|
||||||
|
{
|
||||||
|
return GetFrameSetName( fd, m_worker );
|
||||||
|
}
|
||||||
|
|
||||||
|
const char* View::GetFrameSetName( const FrameData& fd, const Worker& worker )
|
||||||
|
{
|
||||||
|
enum { Pool = 4 };
|
||||||
|
static char bufpool[Pool][64];
|
||||||
|
static int bufsel = 0;
|
||||||
|
|
||||||
|
if( fd.name == 0 )
|
||||||
|
{
|
||||||
|
return "Frames";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return worker.GetString( fd.name );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const char* View::ShortenNamespace( const char* name ) const
|
const char* View::ShortenNamespace( const char* name ) const
|
||||||
{
|
{
|
||||||
if( m_namespace == Namespace::Full ) return name;
|
if( m_namespace == Namespace::Full ) return name;
|
||||||
|
Loading…
Reference in New Issue
Block a user