1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
/*
* Copyright (C) by Klaas Freitag <freitag@owncloud.com>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program 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 General Public License
* for more details.
*/
#include "logbrowser.h"
#include <cstdio>
#include <iostream>
#include <QDialogButtonBox>
#include <QLayout>
#include <QPushButton>
#include <QLabel>
#include <QDir>
#include <QTextStream>
#include <QMessageBox>
#include <QCoreApplication>
#include <QSettings>
#include <QAction>
#include <QDesktopServices>
#include "configfile.h"
#include "logger.h"
namespace OCC {
// ==============================================================================
LogBrowser::LogBrowser(QWidget *parent)
: QDialog(parent)
{
setWindowFlags(windowFlags() & ~Qt::WindowContextHelpButtonHint);
setObjectName("LogBrowser"); // for save/restoreGeometry()
setWindowTitle(tr("Log Output"));
setMinimumWidth(600);
auto mainLayout = new QVBoxLayout;
auto label = new QLabel(
tr("The client can write debug logs to a temporary folder. "
"These logs are very helpful for diagnosing problems.\n"
"Since log files can get large, the client will start a new one for each sync "
"run and compress older ones. It will also delete log files after a couple "
"of hours to avoid consuming too much disk space.\n"
"If enabled, logs will be written to %1")
.arg(Logger::instance()->temporaryFolderLogDirPath()));
label->setWordWrap(true);
label->setTextInteractionFlags(Qt::TextSelectableByMouse);
label->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::MinimumExpanding);
mainLayout->addWidget(label);
// button to permanently save logs
auto enableLoggingButton = new QCheckBox;
enableLoggingButton->setText(tr("Enable logging to temporary folder"));
enableLoggingButton->setChecked(ConfigFile().automaticLogDir());
connect(enableLoggingButton, &QCheckBox::toggled, this, &LogBrowser::togglePermanentLogging);
mainLayout->addWidget(enableLoggingButton);
label = new QLabel(
tr("This setting persists across client restarts.\n"
"Note that using any logging command line options will override this setting."));
label->setWordWrap(true);
label->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::MinimumExpanding);
mainLayout->addWidget(label);
auto openFolderButton = new QPushButton;
openFolderButton->setText(tr("Open folder"));
connect(openFolderButton, &QPushButton::clicked, this, []() {
QString path = Logger::instance()->temporaryFolderLogDirPath();
QDir().mkpath(path);
QDesktopServices::openUrl(QUrl::fromLocalFile(path));
});
mainLayout->addWidget(openFolderButton);
auto *btnbox = new QDialogButtonBox;
QPushButton *closeBtn = btnbox->addButton(QDialogButtonBox::Close);
connect(closeBtn, &QAbstractButton::clicked, this, &QWidget::close);
mainLayout->addStretch();
mainLayout->addWidget(btnbox);
setLayout(mainLayout);
setModal(false);
auto showLogWindow = new QAction(this);
showLogWindow->setShortcut(QKeySequence("F12"));
connect(showLogWindow, &QAction::triggered, this, &QWidget::close);
addAction(showLogWindow);
ConfigFile cfg;
cfg.restoreGeometry(this);
}
LogBrowser::~LogBrowser() = default;
void LogBrowser::closeEvent(QCloseEvent *)
{
ConfigFile cfg;
cfg.saveGeometry(this);
}
void LogBrowser::togglePermanentLogging(bool enabled)
{
ConfigFile().setAutomaticLogDir(enabled);
auto logger = Logger::instance();
if (enabled) {
if (!logger->isLoggingToFile()) {
logger->setupTemporaryFolderLogDir();
logger->enterNextLogFile();
}
} else {
logger->disableTemporaryFolderLogDir();
}
}
} // namespace
|