summaryrefslogtreecommitdiffstats
path: root/kftpgrabber/src/widgets/logview.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'kftpgrabber/src/widgets/logview.cpp')
-rw-r--r--kftpgrabber/src/widgets/logview.cpp143
1 files changed, 143 insertions, 0 deletions
diff --git a/kftpgrabber/src/widgets/logview.cpp b/kftpgrabber/src/widgets/logview.cpp
new file mode 100644
index 0000000..bac9df8
--- /dev/null
+++ b/kftpgrabber/src/widgets/logview.cpp
@@ -0,0 +1,143 @@
+/*
+ * This file is part of the KFTPGrabber project
+ *
+ * Copyright (C) 2003-2004 by the KFTPGrabber developers
+ * Copyright (C) 2003-2004 Jernej Kos <kostko@jweb-network.net>
+ *
+ * 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
+ * is provided AS IS, WITHOUT ANY WARRANTY; without even the implied
+ * warranty of MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, and
+ * NON-INFRINGEMENT. See the GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Steet, Fifth Floor, Boston,
+ * MA 02110-1301, USA.
+ *
+ * In addition, as a special exception, the copyright holders give
+ * permission to link the code of portions of this program with the
+ * OpenSSL library under certain conditions as described in each
+ * individual source file, and distribute linked combinations
+ * including the two.
+ * You must obey the GNU General Public License in all respects
+ * for all of the code used other than OpenSSL. If you modify
+ * file(s) with this exception, you may extend this exception to your
+ * version of the file(s), but you are not obligated to do so. If you
+ * do not wish to do so, delete this exception statement from your
+ * version. If you delete this exception statement from all source
+ * files in the program, then also delete it here.
+ */
+
+#include "logview.h"
+#include "misc/config.h"
+#include "kftpapi.h"
+
+#include <klocale.h>
+#include <kstdaction.h>
+#include <kfiledialog.h>
+#include <kmessagebox.h>
+
+#include <qfile.h>
+#include <qtextstream.h>
+
+namespace KFTPWidgets {
+
+LogView::LogView(QWidget *parent, const char *name)
+ : KTextEdit(parent, name)
+{
+ setTextFormat(Qt::LogText);
+ setMaxLogLines(200);
+ setFont(KFTPCore::Config::logFont());
+
+ // Override disabled background of KTextEdit
+ unsetPalette();
+
+ // Init actions
+ m_saveToFileAction = KStdAction::saveAs(this, SLOT(slotSaveToFile()), KFTPAPI::getInstance()->mainWindow()->actionCollection(), "log_safeAs");
+ m_clearLogAction = KStdAction::clear(this, SLOT(slotClearLog()), KFTPAPI::getInstance()->mainWindow()->actionCollection(), "log_clear");
+
+ append(i18n("<b>KFTPGrabber</b> logger initialized.<br>"));
+}
+
+
+LogView::~LogView()
+{
+}
+
+QPopupMenu *LogView::createPopupMenu(const QPoint &pos)
+{
+ QPopupMenu *menu = KTextEdit::createPopupMenu(pos);
+
+ m_saveToFileAction->plug(menu);
+ menu->insertSeparator();
+ m_clearLogAction->plug(menu);
+
+ return menu;
+}
+
+void LogView::slotSaveToFile()
+{
+ QString savePath = KFileDialog::getSaveFileName();
+
+ if (!savePath.isEmpty()) {
+ QFile file(savePath);
+ if (file.open(IO_WriteOnly)) {
+ QTextStream stream(&file);
+ stream << text();
+ file.close();
+ } else {
+ KMessageBox::error(0L, i18n("Unable to open file for writing."));
+ }
+ }
+}
+
+void LogView::slotClearLog()
+{
+ clear();
+}
+
+void LogView::append(const QString &text)
+{
+ QDateTime dt = QDateTime::currentDateTime();
+ QTextEdit::append("[" + dt.toString("hh:mm:ss") + "] " + text);
+ scrollToBottom();
+}
+
+void LogView::ftpLog(int type, const QString &text)
+{
+ // Set the font if changed
+ if (KFTPCore::Config::logFont() != font())
+ setFont(KFTPCore::Config::logFont());
+
+ QString line;
+ line = text.stripWhiteSpace();
+ line.replace("<", "&lt;");
+ line.replace(">", "&gt;");
+ switch (type) {
+ case 0: {
+ QString code = line.section(" ", 0, 0);
+ QString text = line.mid(line.find(' ')+1);
+ append("<font color=" + KFTPCore::Config::logResponsesColor().name() + "><b>" + code + "</b> " + text + "</font><br>");
+ break;
+ }
+ case 1: {
+ if (line.left(4) == "PASS")
+ line = "PASS (hidden)";
+
+ append("<font color=" + KFTPCore::Config::logCommandsColor().name() + "><b>" + line + "</b></font><br>");
+ break;
+ }
+ case 2: append("<font color=" + KFTPCore::Config::logMultilineColor().name() + ">" + line + "</font><br>"); break;
+ case 3: append("<font color=" + KFTPCore::Config::logStatusColor().name() + "><b>*** " + line + "</b></font><br>"); break;
+ case 4: append("<font color=" + KFTPCore::Config::logErrorColor().name() + "><b>*** " + line + "</b></font><br>"); break;
+ }
+}
+
+}
+
+#include "logview.moc"