148 lines
4.0 KiB
C++
Executable File
148 lines
4.0 KiB
C++
Executable File
/**
|
|
* @file llfasttimerview.h
|
|
* @brief LLFastTimerView class definition
|
|
*
|
|
* $LicenseInfo:firstyear=2004&license=viewerlgpl$
|
|
* Second Life Viewer Source Code
|
|
* Copyright (C) 2010, Linden Research, Inc.
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation;
|
|
* version 2.1 of the License only.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*
|
|
* Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA
|
|
* $/LicenseInfo$
|
|
*/
|
|
|
|
#ifndef LL_LLFASTTIMERVIEW_H
|
|
#define LL_LLFASTTIMERVIEW_H
|
|
|
|
#include "llfloater.h"
|
|
#include "llfasttimer.h"
|
|
#include "llunits.h"
|
|
#include "lltracerecording.h"
|
|
#include <deque>
|
|
|
|
class LLFastTimerView : public LLFloater
|
|
{
|
|
public:
|
|
LLFastTimerView(const LLSD&);
|
|
~LLFastTimerView();
|
|
BOOL postBuild();
|
|
|
|
static BOOL sAnalyzePerformance;
|
|
|
|
static void outputAllMetrics();
|
|
static void doAnalysis(std::string baseline, std::string target, std::string output);
|
|
|
|
private:
|
|
static void doAnalysisDefault(std::string baseline, std::string target, std::string output) ;
|
|
static LLSD analyzePerformanceLogDefault(std::istream& is) ;
|
|
static void exportCharts(const std::string& base, const std::string& target);
|
|
void onPause();
|
|
|
|
public:
|
|
|
|
virtual BOOL handleMouseDown(S32 x, S32 y, MASK mask);
|
|
virtual BOOL handleDoubleClick(S32 x, S32 y, MASK mask);
|
|
virtual BOOL handleRightMouseDown(S32 x, S32 y, MASK mask);
|
|
virtual BOOL handleMouseUp(S32 x, S32 y, MASK mask);
|
|
virtual BOOL handleHover(S32 x, S32 y, MASK mask);
|
|
virtual BOOL handleToolTip(S32 x, S32 y, MASK mask);
|
|
virtual BOOL handleScrollWheel(S32 x, S32 y, S32 clicks);
|
|
virtual void draw();
|
|
virtual void onOpen(const LLSD& key);
|
|
LLTrace::TimeBlock* getLegendID(S32 y);
|
|
|
|
private:
|
|
virtual void onClickCloseBtn();
|
|
void drawTicks();
|
|
void drawLineGraph();
|
|
void drawLegend();
|
|
void drawHelp(S32 y);
|
|
void drawBorders( S32 y, const S32 x_start, S32 barh, S32 dy);
|
|
void drawBars();
|
|
|
|
void printLineStats();
|
|
void generateUniqueColors();
|
|
void updateTotalTime();
|
|
|
|
struct TimerBar
|
|
{
|
|
TimerBar()
|
|
: mTotalTime(0),
|
|
mSelfTime(0),
|
|
mStartFraction(0.f),
|
|
mEndFraction(1.f),
|
|
mFirstChild(false),
|
|
mLastChild(false)
|
|
{}
|
|
F32Seconds mTotalTime,
|
|
mSelfTime,
|
|
mChildrenStart,
|
|
mChildrenEnd,
|
|
mSelfStart,
|
|
mSelfEnd;
|
|
LLTrace::TimeBlock* mTimeBlock;
|
|
bool mVisible,
|
|
mFirstChild,
|
|
mLastChild;
|
|
F32 mStartFraction,
|
|
mEndFraction;
|
|
};
|
|
|
|
struct TimerBarRow
|
|
{
|
|
TimerBarRow()
|
|
: mBottom(0),
|
|
mTop(0),
|
|
mBars(NULL)
|
|
{}
|
|
S32 mBottom,
|
|
mTop;
|
|
TimerBar* mBars;
|
|
};
|
|
|
|
F32Seconds updateTimerBarWidths(LLTrace::TimeBlock* time_block, TimerBarRow& row, S32 history_index, U32& bar_index);
|
|
S32 updateTimerBarOffsets(LLTrace::TimeBlock* time_block, TimerBarRow& row, S32 timer_bar_index = 0);
|
|
S32 drawBar(LLRect bar_rect, TimerBarRow& row, S32 image_width, S32 image_height, bool hovered = false, bool visible = true, S32 bar_index = 0);
|
|
void setPauseState(bool pause_state);
|
|
|
|
std::deque<TimerBarRow> mTimerBarRows;
|
|
TimerBarRow mAverageTimerRow;
|
|
|
|
enum EDisplayType
|
|
{
|
|
DISPLAY_TIME,
|
|
DISPLAY_CALLS,
|
|
DISPLAY_HZ
|
|
} mDisplayType;
|
|
bool mPauseHistory;
|
|
F64Seconds mAllTimeMax,
|
|
mTotalTimeDisplay;
|
|
S32 mScrollIndex,
|
|
mHoverBarIndex,
|
|
mStatsIndex;
|
|
S32 mDisplayMode;
|
|
LLTrace::TimeBlock* mHoverID;
|
|
LLTrace::TimeBlock* mHoverTimer;
|
|
LLRect mToolTipRect,
|
|
mGraphRect,
|
|
mBarRect,
|
|
mLegendRect;
|
|
LLFrameTimer mHighlightTimer;
|
|
LLTrace::PeriodicRecording mRecording;
|
|
};
|
|
|
|
#endif
|