mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-12 09:09:12 +01:00
6bfa4fa643
Messages buffer is intended to be of a fixed capacity (MAX_LOG_LINES), which cannot be achieved by std::queue unless we manually pop() extra elements. std::queue uses std::deque internally which most likely results in allocations performed continuously. FixedSizeQueue keeps a single buffer during its entire lifetime, avoiding any allocations except the ones performed by stored objects.
58 lines
1.1 KiB
C++
58 lines
1.1 KiB
C++
// Copyright 2017 Dolphin Emulator Project
|
|
// Licensed under GPLv2+
|
|
// Refer to the license.txt file included.
|
|
|
|
#pragma once
|
|
|
|
#include <QDockWidget>
|
|
|
|
#include <mutex>
|
|
#include <string>
|
|
|
|
#include "Common/FixedSizeQueue.h"
|
|
#include "Common/Logging/LogManager.h"
|
|
|
|
class QCheckBox;
|
|
class QCloseEvent;
|
|
class QComboBox;
|
|
class QPlainTextEdit;
|
|
class QPushButton;
|
|
class QTimer;
|
|
|
|
class LogWidget final : public QDockWidget, LogListener
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
explicit LogWidget(QWidget* parent = nullptr);
|
|
~LogWidget();
|
|
|
|
protected:
|
|
void closeEvent(QCloseEvent*) override;
|
|
|
|
private:
|
|
void UpdateLog();
|
|
void UpdateFont();
|
|
void CreateWidgets();
|
|
void ConnectWidgets();
|
|
void LoadSettings();
|
|
void SaveSettings();
|
|
|
|
void Log(LogTypes::LOG_LEVELS level, const char* text) override;
|
|
|
|
// Log
|
|
QCheckBox* m_log_wrap;
|
|
QComboBox* m_log_font;
|
|
QPushButton* m_log_clear;
|
|
QPlainTextEdit* m_log_text;
|
|
|
|
QTimer* m_timer;
|
|
|
|
using LogEntry = std::pair<std::string, LogTypes::LOG_LEVELS>;
|
|
|
|
// Maximum number of lines to show in log viewer
|
|
static constexpr int MAX_LOG_LINES = 5000;
|
|
|
|
std::mutex m_log_mutex;
|
|
FixedSizeQueue<LogEntry, MAX_LOG_LINES> m_log_ring_buffer;
|
|
};
|