mirror of
https://github.com/pgadmin-org/pgadmin4.git
synced 2025-01-24 15:26:46 -06:00
104 lines
2.4 KiB
C++
104 lines
2.4 KiB
C++
//////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// pgAdmin 4 - PostgreSQL Tools
|
|
//
|
|
// Copyright (C) 2013 - 2021, The pgAdmin Development Team
|
|
// This software is released under the PostgreSQL Licence
|
|
//
|
|
// LogWindow.cpp - Log viewer window
|
|
//
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
#include "pgAdmin4.h"
|
|
#include "LogWindow.h"
|
|
#include "ui_LogWindow.h"
|
|
|
|
#include <QStandardPaths>
|
|
#include <QTime>
|
|
|
|
#include <stdio.h>
|
|
|
|
LogWindow::LogWindow(QWidget *parent) :
|
|
QDialog(parent)
|
|
{
|
|
initLogWindow();
|
|
}
|
|
|
|
void LogWindow::initLogWindow()
|
|
{
|
|
ui = new Ui::LogWindow;
|
|
ui->setupUi(this);
|
|
}
|
|
|
|
void LogWindow::LoadLog()
|
|
{
|
|
int startupLines;
|
|
int serverLines;
|
|
|
|
ui->lblStatus->setText(tr("Loading logfiles..."));
|
|
|
|
ui->lblStartupLog->setText(tr("Startup Log (%1):").arg(g_startupLogFile));
|
|
ui->lblServerLog->setText(tr("Server Log (%1):").arg(g_serverLogFile));
|
|
|
|
startupLines = this->readLog(g_startupLogFile, ui->textStartupLog);
|
|
serverLines = this->readLog(g_serverLogFile, ui->textServerLog);
|
|
|
|
ui->lblStatus->setText(QString(tr("Loaded startup log (%1 lines) and server log (%2 lines).")).arg(startupLines).arg(serverLines));
|
|
}
|
|
|
|
|
|
void LogWindow::reload()
|
|
{
|
|
this->LoadLog();
|
|
}
|
|
|
|
|
|
// Read the logfile
|
|
int LogWindow::readLog(QString logFile, QPlainTextEdit *logWidget)
|
|
{
|
|
FILE *log;
|
|
char *buffer;
|
|
long len = 0;
|
|
int i;
|
|
int lines = 0;
|
|
|
|
// Look busy!
|
|
QApplication::setOverrideCursor(Qt::WaitCursor);
|
|
this->setDisabled(true);
|
|
QCoreApplication::processEvents( QEventLoop::AllEvents, 100 );
|
|
|
|
logWidget->clear();
|
|
|
|
// Attempt to open the file
|
|
log = fopen(logFile.toUtf8().data(), "r");
|
|
if (log == Q_NULLPTR)
|
|
{
|
|
logWidget->setPlainText(QString(tr("The log file (%1) could not be opened.")).arg(g_serverLogFile));
|
|
this->setDisabled(false);
|
|
QApplication::restoreOverrideCursor();
|
|
return 0;
|
|
}
|
|
|
|
// Get the file size, and read the data
|
|
fseek(log, 0, SEEK_END);
|
|
len = ftell(log);
|
|
rewind(log);
|
|
buffer = static_cast<char *>(malloc((len + 1) * sizeof(char)));
|
|
|
|
for (i = 0; i < len; i++) {
|
|
if (fread(buffer + i, 1, 1, log) > 0 && buffer[i] == '\n')
|
|
lines++;
|
|
}
|
|
|
|
buffer[i] = 0;
|
|
|
|
fclose(log);
|
|
logWidget->setPlainText(buffer);
|
|
|
|
// And... relax
|
|
this->setDisabled(false);
|
|
QApplication::restoreOverrideCursor();
|
|
|
|
return lines;
|
|
}
|