X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=bacula%2Fsrc%2Fqt-console%2Fmainwin.cpp;h=20335059c6f0a3cc3d1506c530b795fa8694dac5;hb=6855d818f215883a7f03ebe8a54f56e7c5e4d5b0;hp=1939461777de17324195401aa7b9d09e6536505e;hpb=22f94167a4a8669e79290a9b5981097d4c9cad0b;p=bacula%2Fbacula diff --git a/bacula/src/qt-console/mainwin.cpp b/bacula/src/qt-console/mainwin.cpp index 1939461777..20335059c6 100644 --- a/bacula/src/qt-console/mainwin.cpp +++ b/bacula/src/qt-console/mainwin.cpp @@ -1,14 +1,14 @@ /* Bacula® - The Network Backup Solution - Copyright (C) 2007-2007 Free Software Foundation Europe e.V. + Copyright (C) 2007-2008 Free Software Foundation Europe e.V. The main author of Bacula is Kern Sibbald, with contributions from many others, a complete list can be found in the file AUTHORS. This program is Free Software; you can redistribute it and/or modify it under the terms of version two of the GNU General Public - License as published by the Free Software Foundation plus additions - that are listed in the file LICENSE. + License as published by the Free Software Foundation and included + in the file LICENSE. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -37,12 +37,37 @@ #include "bat.h" #include "joblist/joblist.h" +#include "storage/storage.h" +#include "fileset/fileset.h" +#include "label/label.h" +#include "run/run.h" +#include "pages.h" +#include "restore/restore.h" +#include "medialist/medialist.h" +#include "joblist/joblist.h" +#include "clients/clients.h" +#include "restore/restoretree.h" +#include "help/help.h" +#include "jobs/jobs.h" +#include "jobgraphs/jobplot.h" +#include "status/dirstat.h" -MainWin::MainWin(QWidget *parent) : QMainWindow(parent) +/* + * Daemon message callback + */ +void message_callback(int /* type */, char *msg) { + QMessageBox::warning(mainWin, "Bat", msg, QMessageBox::Ok); +} +MainWin::MainWin(QWidget *parent) : QMainWindow(parent) +{ + m_isClosing = false; + m_dtformat = "yyyy-MM-dd HH:mm:ss"; mainWin = this; setupUi(this); /* Setup UI defined by main.ui (designer) */ + register_message_callback(message_callback); + readPreferences(); treeWidget->clear(); treeWidget->setColumnCount(1); treeWidget->setHeaderLabel("Select Page"); @@ -58,16 +83,16 @@ MainWin::MainWin(QWidget *parent) : QMainWindow(parent) readSettings(); - foreach(Console *console, m_consoleHash){ - console->connect(); + foreach(Console *console, m_consoleHash) { + console->connect_dir(); } m_currentConsole = (Console*)getFromHash(m_firstItem); - treeWidget->setCurrentItem(getFromHash(m_currentConsole)); - /* - * I'd like to turn this into a debug item - * DIRRES* dirres = m_currentConsole->getDirRes(); - * printf("Setting initial window to %s\n", dirres->name()); - */ + m_currentConsole->setCurrent(); + if (m_miscDebug) { + QString directoryResourceName; + m_currentConsole->getDirResName(directoryResourceName); + Pmsg1(000, "Setting initial window to %s\n", directoryResourceName.toUtf8().data()); + } } void MainWin::createPages() @@ -85,17 +110,20 @@ void MainWin::createPages() m_currentConsole->readSettings(); /* The top tree item representing the director */ - topItem = createTopPage(dir->name()); - topItem->setIcon(0, QIcon(QString::fromUtf8("images/server.png"))); - /* Set background to grey for ease of identification of inactive dirfector */ + topItem = new QTreeWidgetItem(treeWidget); + topItem->setText(0, dir->name()); + topItem->setIcon(0, QIcon(":images/server.png")); + /* Set background to grey for ease of identification of inactive Director */ QBrush greyBrush(Qt::lightGray); topItem->setBackground(0, greyBrush); m_currentConsole->setDirectorTreeItem(topItem); m_consoleHash.insert(topItem, m_currentConsole); /* Create Tree Widget Item */ - item = createPage("Console", topItem); + item = new QTreeWidgetItem(topItem); + item->setText(0, "Console"); if (!m_firstItem){ m_firstItem = item; } + item->setIcon(0,QIcon(QString::fromUtf8(":images/utilities-terminal.png"))); /* insert the cosole and tree widget item into the hashes */ hashInsert(item, m_currentConsole); @@ -107,13 +135,25 @@ void MainWin::createPages() item->setForeground(0, redBrush); m_currentConsole->dockPage(); - /* create instances of the rest of the classes that will by default exist - * under each director */ - createPagebRestore(); - createPageMediaList(); - QString emptymedia(""), emptyclient(""); - createPageJobList(emptymedia, emptyclient, NULL); - createPageClients(); + /* + * Create instances in alphabetic order of the rest + * of the classes that will by default exist under each Director. + */ +// new bRestore(); + new Clients(); + new FileSet(); + new Jobs(); + createPageJobList("", "", "", "", NULL); + JobPlotPass pass; + pass.use = false; + if (m_openPlot) + new JobPlot(NULL, pass); + new MediaList(); + new Storage(); + if (m_openBrowser) + new restoreTree(); + if (m_openDirStat) + new DirStat(); treeWidget->expandItem(topItem); stackedWidget->setCurrentWidget(m_currentConsole); @@ -121,40 +161,20 @@ void MainWin::createPages() UnlockRes(); } -/* - * create an instance of the the brestore class on the stack - */ -void MainWin::createPagebRestore() -{ - bRestore* brestore = new bRestore(); - brestore->dockPage(); -} - -/* - * create an instance of the the medialist class on the stack - */ -void MainWin::createPageMediaList() -{ - MediaList* medialist = new MediaList(); - medialist->dockPage(); -} - /* * create an instance of the the joblist class on the stack */ -void MainWin::createPageJobList(QString &media, QString &client, - QTreeWidgetItem *parentTreeWidgetItem) +void MainWin::createPageJobList(const QString &media, const QString &client, + const QString &job, const QString &fileset, QTreeWidgetItem *parentTreeWidgetItem) { - QTreeWidgetItem *item, *holdItem; + QTreeWidgetItem *holdItem; /* save current tree widget item in case query produces no results */ holdItem = treeWidget->currentItem(); - JobList* joblist = new JobList(media, client, parentTreeWidgetItem); - joblist->dockPage(); + JobList* joblist = new JobList(media, client, job, fileset, parentTreeWidgetItem); /* If this is a query of jobs on a specific media */ - if ((media != "") || (client != "")) { - item = getFromHash(joblist); - treeWidget->setCurrentItem(item); + if ((media != "") || (client != "") || (job != "") || (fileset != "")) { + joblist->setCurrent(); /* did query produce results, if not close window and set back to hold */ if (joblist->m_resultCount == 0) { joblist->closeStackPage(); @@ -163,32 +183,6 @@ void MainWin::createPageJobList(QString &media, QString &client, } } -/* - * create an instance of the the Clients class on the stack - */ -void MainWin::createPageClients() -{ - Clients* clients = new Clients(); - clients->dockPage(); -} - - -/* Create a root Tree Widget */ -QTreeWidgetItem *MainWin::createTopPage(char *name) -{ - QTreeWidgetItem *item = new QTreeWidgetItem(treeWidget); - item->setText(0, name); - return item; -} - -/* Create A Tree Widget Item which will be associated with a Page in the stacked widget */ -QTreeWidgetItem *MainWin::createPage(char *name, QTreeWidgetItem *parent) -{ - QTreeWidgetItem *item = new QTreeWidgetItem(parent); - item->setText(0, name); - return item; -} - /* * Handle up and down arrow keys for the command line * history. @@ -230,6 +224,7 @@ void MainWin::createConnections() /* Connect signals to slots */ connect(lineEdit, SIGNAL(returnPressed()), this, SLOT(input_line())); connect(actionAbout_bat, SIGNAL(triggered()), this, SLOT(about())); + connect(actionBat_Help, SIGNAL(triggered()), this, SLOT(help())); connect(treeWidget, SIGNAL(itemClicked(QTreeWidgetItem *, int)), this, SLOT(treeItemClicked(QTreeWidgetItem *, int))); connect(treeWidget, SIGNAL( @@ -238,12 +233,17 @@ void MainWin::createConnections() connect(stackedWidget, SIGNAL(currentChanged(int)), this, SLOT(stackItemChanged(int))); connect(actionQuit, SIGNAL(triggered()), app, SLOT(closeAllWindows())); - connect(actionLabel, SIGNAL(triggered()), this, SLOT(labelDialogClicked())); - connect(actionRun, SIGNAL(triggered()), this, SLOT(runDialogClicked())); - connect(actionRestore, SIGNAL(triggered()), this, SLOT(restoreDialogClicked())); + connect(actionLabel, SIGNAL(triggered()), this, SLOT(labelButtonClicked())); + connect(actionRun, SIGNAL(triggered()), this, SLOT(runButtonClicked())); + connect(actionEstimate, SIGNAL(triggered()), this, SLOT(estimateButtonClicked())); + connect(actionBrowse, SIGNAL(triggered()), this, SLOT(browseButtonClicked())); + connect(actionStatusDirPage, SIGNAL(triggered()), this, SLOT(statusPageButtonClicked())); + connect(actionJobPlot, SIGNAL(triggered()), this, SLOT(jobPlotButtonClicked())); + connect(actionRestore, SIGNAL(triggered()), this, SLOT(restoreButtonClicked())); connect(actionUndock, SIGNAL(triggered()), this, SLOT(undockWindowButton())); connect(actionToggleDock, SIGNAL(triggered()), this, SLOT(toggleDockContextWindow())); connect(actionClosePage, SIGNAL(triggered()), this, SLOT(closePage())); + connect(actionPreferences, SIGNAL(triggered()), this, SLOT(setPreferences())); } /* @@ -251,16 +251,27 @@ void MainWin::createConnections() */ void MainWin::closeEvent(QCloseEvent *event) { + m_isClosing = true; writeSettings(); + /* close all non console pages, this will call settings in destructors */ + while (m_consoleHash.count() < m_pagehash.count()) { + foreach(Pages *page, m_pagehash) { + if (page != page->console()) { + QTreeWidgetItem* pageSelectorTreeWidgetItem = mainWin->getFromHash(page); + if (pageSelectorTreeWidgetItem->childCount() == 0) { + page->console()->setCurrent(); + page->closeStackPage(); + } + } + } + } + /* close the console pages and terminate connection */ foreach(Console *console, m_consoleHash){ console->writeSettings(); console->terminate(); + console->closeStackPage(); } event->accept(); - foreach(Pages *page, m_pagehash) { - if (!page->isDocked()) - page->close(); - } } void MainWin::writeSettings() @@ -270,6 +281,7 @@ void MainWin::writeSettings() settings.beginGroup("MainWin"); settings.setValue("winSize", size()); settings.setValue("winPos", pos()); + settings.setValue("state", saveState()); settings.endGroup(); } @@ -280,6 +292,7 @@ void MainWin::readSettings() settings.beginGroup("MainWin"); resize(settings.value("winSize", QSize(1041, 801)).toSize()); move(settings.value("winPos", QPoint(200, 150)).toPoint()); + restoreState(settings.value("state").toByteArray()); settings.endGroup(); } @@ -307,8 +320,16 @@ void MainWin::treeItemClicked(QTreeWidgetItem *item, int /*column*/) */ void MainWin::treeItemChanged(QTreeWidgetItem *currentitem, QTreeWidgetItem *previousitem) { + if (m_isClosing) return; /* if closing the application, do nothing here */ + Pages *previousPage, *nextPage; - Console *previousConsole, *nextConsole; + Console *previousConsole = NULL; + Console *nextConsole; + + /* remove all actions before adding actions appropriate for new page */ + foreach(QAction* pageAction, treeWidget->actions()) { + treeWidget->removeAction(pageAction); + } /* first determine the next item */ @@ -323,7 +344,7 @@ void MainWin::treeItemChanged(QTreeWidgetItem *currentitem, QTreeWidgetItem *pre /* let the next page BE the console */ nextPage = nextConsole; } else { - printf("Should never get here\n"); + /* Should never get here */ nextPage = NULL; nextConsole = NULL; } @@ -343,34 +364,27 @@ void MainWin::treeItemChanged(QTreeWidgetItem *currentitem, QTreeWidgetItem *pre if ((previousPage) || (previousConsole)) { if (nextConsole != previousConsole) { /* remove connections to the current console */ - disconnect(actionConnect, SIGNAL(triggered()), previousConsole, SLOT(connect())); + disconnect(actionConnect, SIGNAL(triggered()), previousConsole, SLOT(connect_dir())); disconnect(actionStatusDir, SIGNAL(triggered()), previousConsole, SLOT(status_dir())); + disconnect(actionMessages, SIGNAL(triggered()), previousConsole, SLOT(messages())); disconnect(actionSelectFont, SIGNAL(triggered()), previousConsole, SLOT(set_font())); QTreeWidgetItem *dirItem = previousConsole->directorTreeItem(); QBrush greyBrush(Qt::lightGray); dirItem->setBackground(0, greyBrush); } - /* make sure the close window and toggle dock options are removed */ - treeWidget->removeAction(actionClosePage); - treeWidget->removeAction(actionToggleDock); - /* Is this a page that has been inserted into the hash */ - if (previousPage) { - foreach(QAction* pageaction, previousPage->m_contextActions) { - treeWidget->removeAction(pageaction); - } - } } } - /* now process the next item */ + /* process the current (next) item */ if ((nextPage) || (nextConsole)) { if (nextConsole != previousConsole) { /* make connections to the current console */ m_currentConsole = nextConsole; - connect(actionConnect, SIGNAL(triggered()), m_currentConsole, SLOT(connect())); + connect(actionConnect, SIGNAL(triggered()), m_currentConsole, SLOT(connect_dir())); connect(actionSelectFont, SIGNAL(triggered()), m_currentConsole, SLOT(set_font())); connect(actionStatusDir, SIGNAL(triggered()), m_currentConsole, SLOT(status_dir())); + connect(actionMessages, SIGNAL(triggered()), m_currentConsole, SLOT(messages())); /* Set director's tree widget background to magenta for ease of identification */ QTreeWidgetItem *dirItem = m_currentConsole->directorTreeItem(); QBrush magentaBrush(Qt::magenta); @@ -388,13 +402,12 @@ void MainWin::treeItemChanged(QTreeWidgetItem *currentitem, QTreeWidgetItem *pre nextPage->raise(); } /* for the page selectors menu action to dock or undock, set the text */ - setContextMenuDockText(nextPage, currentitem); + nextPage->setContextMenuDockText(); treeWidget->addAction(actionToggleDock); - /* if this page is closeable, then add that action */ - if (nextPage->isCloseable()) { + /* if this page is closeable, and it has no childern, then add that action */ + if ((nextPage->isCloseable()) && (currentitem->child(0) == NULL)) treeWidget->addAction(actionClosePage); - } /* Add the actions to the Page Selectors tree widget that are part of the * current items list of desired actions regardless of whether on top of stack*/ @@ -402,19 +415,52 @@ void MainWin::treeItemChanged(QTreeWidgetItem *currentitem, QTreeWidgetItem *pre } } -void MainWin::labelDialogClicked() +void MainWin::labelButtonClicked() { - new labelDialog(m_currentConsole); + new labelPage(); } -void MainWin::runDialogClicked() +void MainWin::runButtonClicked() { - new runDialog(m_currentConsole); + new runPage(""); } -void MainWin::restoreDialogClicked() +void MainWin::estimateButtonClicked() { - new prerestoreDialog(m_currentConsole); + new estimatePage(); +} + +void MainWin::browseButtonClicked() +{ + new restoreTree(); +} + +void MainWin::statusPageButtonClicked() +{ + /* if one exists, then just set it current */ + bool found = false; + foreach(Pages *page, m_pagehash) { + if (m_currentConsole == page->console()) { + if (page->name() == "Director Status") { + found = true; + page->setCurrent(); + } + } + } + if (!found) + new DirStat(); +} + +void MainWin::restoreButtonClicked() +{ + new prerestorePage(); +} + +void MainWin::jobPlotButtonClicked() +{ + JobPlotPass pass; + pass.use = false; + new JobPlot(NULL, pass); } /* @@ -425,23 +471,30 @@ void MainWin::input_line() QString cmdStr = lineEdit->text(); /* Get the text */ lineEdit->clear(); /* clear the lineEdit box */ if (m_currentConsole->is_connected()) { - m_currentConsole->display_text(cmdStr + "\n"); - m_currentConsole->write_dir(cmdStr.toUtf8().data()); /* send to dir */ + /* Use consoleInput to allow typing anything */ + m_currentConsole->consoleInput(cmdStr); } else { - set_status("Director not connected. Click on connect button."); + set_status(tr("Director not connected. Click on connect button.")); } m_cmd_history.append(cmdStr); m_cmd_last = -1; + if (treeWidget->currentItem() != getFromHash(m_currentConsole)) + m_currentConsole->setCurrent(); } void MainWin::about() { QMessageBox::about(this, tr("About bat"), - tr("

bat 0.2, by Kern Sibbald

" - "

Copyright © " BYEAR " Free Software Foundation Europe e.V." - "

The bat is an administrative console" - " interface to the Director.")); + tr("

bat 1.0, by Dirk H Bartley and Kern Sibbald

" + "

Copyright © 2007-" BYEAR " Free Software Foundation Europe e.V." + "

The bat is an administrative console" + " interface to the Director.")); +} + +void MainWin::help() +{ + Help::displayFile("index.html"); } void MainWin::set_statusf(const char *fmt, ...) @@ -457,7 +510,12 @@ void MainWin::set_statusf(const char *fmt, ...) void MainWin::set_status_ready() { - set_status(" Ready"); + set_status(tr(" Ready")); +} + +void MainWin::set_status(const QString &str) +{ + statusBar()->showMessage(str); } void MainWin::set_status(const char *buf) @@ -472,8 +530,6 @@ void MainWin::undockWindowButton() { Pages* page = (Pages*)stackedWidget->currentWidget(); page->togglePageDocking(); - /* The window has been undocked, lets change the context menu */ - setContextMenuDockText(); } /* @@ -489,78 +545,6 @@ void MainWin::toggleDockContextWindow() if (getFromHash(currentitem)) { Pages* page = getFromHash(currentitem); page->togglePageDocking(); - if (page->isDocked()) { - stackedWidget->setCurrentWidget(page); - } - /* Toggle the menu item. The window's dock status has been toggled */ - setContextMenuDockText(page, currentitem); - } -} - -/* - * Function to set the text of the toggle dock context menu when page and - * widget item are NOT known. This is an overoaded funciton. - * It is called from MainWin::undockWindowButton, it is not intended to change - * for the top pages tree widget, it is for the currently active tree widget - * item. Which is why the page is not passed. - */ -void MainWin::setContextMenuDockText() -{ - QTreeWidgetItem *currentitem = treeWidget->currentItem(); - - /* Is this a page that has been inserted into the hash */ - if (getFromHash(currentitem)) { - Pages* page = getFromHash(currentitem); - setContextMenuDockText(page, currentitem); - } -} - -/* - * Function to set the text of the toggle dock context menu when page and - * widget item are known. This is the more commonly used. - */ -void MainWin::setContextMenuDockText(Pages* page, QTreeWidgetItem* item) -{ - QString docktext(""); - if (page->isDocked()) { - docktext += "UnDock "; - } else { - docktext += "ReDock "; - } - docktext += item->text(0) += " Window"; - - actionToggleDock->setText(docktext); - setTreeWidgetItemDockColor(page, item); -} - -/* - * Function to set the color of the tree widget item based on whether it is - * docked or not. - */ -void MainWin::setTreeWidgetItemDockColor(Pages* page, QTreeWidgetItem* item) -{ - if (item->text(0) != "Console") { - if (page->isDocked()) { - /* Set the brush to blue if undocked */ - QBrush blackBrush(Qt::black); - item->setForeground(0, blackBrush); - } else { - /* Set the brush back to black if docked */ - QBrush blueBrush(Qt::blue); - item->setForeground(0, blueBrush); - } - } -} - -/* - * Overload of previous function, use treeindex to get item from page - * This is called when an undocked window is closed. - */ -void MainWin::setTreeWidgetItemDockColor(Pages* page) -{ - QTreeWidgetItem* item = getFromHash(page); - if (item) { - setTreeWidgetItemDockColor(page, item); } } @@ -571,6 +555,7 @@ void MainWin::setTreeWidgetItemDockColor(Pages* page) */ void MainWin::stackItemChanged(int) { + if (m_isClosing) return; /* if closing the application, do nothing here */ Pages* page = (Pages*)stackedWidget->currentWidget(); /* run the virtual function in case this class overrides it */ page->currentStackItem(); @@ -634,3 +619,263 @@ void MainWin::closePage() } } } + +/* Quick function to return the current console */ +Console *MainWin::currentConsole() +{ + return m_currentConsole; +} +/* Quick function to return the tree item for the director */ +QTreeWidgetItem *MainWin::currentTopItem() +{ + return m_currentConsole->directorTreeItem(); +} + +/* Preferences menu item clicked */ +void MainWin::setPreferences() +{ + prefsDialog prefs; + prefs.commDebug->setCheckState(m_commDebug ? Qt::Checked : Qt::Unchecked); + prefs.displayAll->setCheckState(m_displayAll ? Qt::Checked : Qt::Unchecked); + prefs.sqlDebug->setCheckState(m_sqlDebug ? Qt::Checked : Qt::Unchecked); + prefs.commandDebug->setCheckState(m_commandDebug ? Qt::Checked : Qt::Unchecked); + prefs.miscDebug->setCheckState(m_miscDebug ? Qt::Checked : Qt::Unchecked); + prefs.recordLimit->setCheckState(m_recordLimitCheck ? Qt::Checked : Qt::Unchecked); + prefs.recordSpinBox->setValue(m_recordLimitVal); + prefs.daysLimit->setCheckState(m_daysLimitCheck ? Qt::Checked : Qt::Unchecked); + prefs.daysSpinBox->setValue(m_daysLimitVal); + prefs.checkMessages->setCheckState(m_checkMessages ? Qt::Checked : Qt::Unchecked); + prefs.checkMessagesSpin->setValue(m_checkMessagesInterval); + prefs.executeLongCheckBox->setCheckState(m_longList ? Qt::Checked : Qt::Unchecked); + prefs.rtPopDirCheckBox->setCheckState(m_rtPopDirDebug ? Qt::Checked : Qt::Unchecked); + prefs.rtDirCurICCheckBox->setCheckState(m_rtDirCurICDebug ? Qt::Checked : Qt::Unchecked); + prefs.rtDirICCheckBox->setCheckState(m_rtDirICDebug ? Qt::Checked : Qt::Unchecked); + prefs.rtFileTabICCheckBox->setCheckState(m_rtFileTabICDebug ? Qt::Checked : Qt::Unchecked); + prefs.rtVerTabICCheckBox->setCheckState(m_rtVerTabICDebug ? Qt::Checked : Qt::Unchecked); + prefs.rtUpdateFTCheckBox->setCheckState(m_rtUpdateFTDebug ? Qt::Checked : Qt::Unchecked); + prefs.rtUpdateVTCheckBox->setCheckState(m_rtUpdateVTDebug ? Qt::Checked : Qt::Unchecked); + prefs.rtChecksCheckBox->setCheckState(m_rtChecksDebug ? Qt::Checked : Qt::Unchecked); + prefs.rtIconStateCheckBox->setCheckState(m_rtIconStateDebug ? Qt::Checked : Qt::Unchecked); + prefs.rtRestore1CheckBox->setCheckState(m_rtRestore1Debug ? Qt::Checked : Qt::Unchecked); + prefs.rtRestore2CheckBox->setCheckState(m_rtRestore2Debug ? Qt::Checked : Qt::Unchecked); + prefs.rtRestore3CheckBox->setCheckState(m_rtRestore3Debug ? Qt::Checked : Qt::Unchecked); + if (m_radioConvert == 0) { + prefs.radioConvertOff->setChecked(Qt::Checked); + } else if (m_radioConvert == 1){ + prefs.radioConvertIEC->setChecked(Qt::Checked); + } else { + m_radioConvert = 2; + prefs.radioConvertStandard->setChecked(Qt::Checked); + } + prefs.openPlotCheckBox->setCheckState(m_openPlot ? Qt::Checked : Qt::Unchecked); + prefs.openBrowserCheckBox->setCheckState(m_openBrowser ? Qt::Checked : Qt::Unchecked); + prefs.openDirStatCheckBox->setCheckState(m_openDirStat ? Qt::Checked : Qt::Unchecked); + prefs.exec(); +} + +/* Preferences dialog */ +prefsDialog::prefsDialog() +{ + setupUi(this); +} + +void prefsDialog::accept() +{ + this->hide(); + mainWin->m_commDebug = this->commDebug->checkState() == Qt::Checked; + mainWin->m_displayAll = this->displayAll->checkState() == Qt::Checked; + mainWin->m_sqlDebug = this->sqlDebug->checkState() == Qt::Checked; + mainWin->m_commandDebug = this->commandDebug->checkState() == Qt::Checked; + mainWin->m_miscDebug = this->miscDebug->checkState() == Qt::Checked; + mainWin->m_recordLimitCheck = this->recordLimit->checkState() == Qt::Checked; + mainWin->m_recordLimitVal = this->recordSpinBox->value(); + mainWin->m_daysLimitCheck = this->daysLimit->checkState() == Qt::Checked; + mainWin->m_daysLimitVal = this->daysSpinBox->value(); + mainWin->m_checkMessages = this->checkMessages->checkState() == Qt::Checked; + mainWin->m_checkMessagesInterval = this->checkMessagesSpin->value(); + mainWin->m_longList = this->executeLongCheckBox->checkState() == Qt::Checked; + + mainWin->m_rtPopDirDebug = this->rtPopDirCheckBox->checkState() == Qt::Checked; + mainWin->m_rtDirCurICDebug = this->rtDirCurICCheckBox->checkState() == Qt::Checked; + mainWin->m_rtDirICDebug = this->rtDirICCheckBox->checkState() == Qt::Checked; + mainWin->m_rtFileTabICDebug = this->rtFileTabICCheckBox->checkState() == Qt::Checked; + mainWin->m_rtVerTabICDebug = this->rtVerTabICCheckBox->checkState() == Qt::Checked; + mainWin->m_rtUpdateFTDebug = this->rtUpdateFTCheckBox->checkState() == Qt::Checked; + mainWin->m_rtUpdateVTDebug = this->rtUpdateVTCheckBox->checkState() == Qt::Checked; + mainWin->m_rtChecksDebug = this->rtChecksCheckBox->checkState() == Qt::Checked; + mainWin->m_rtIconStateDebug = this->rtIconStateCheckBox->checkState() == Qt::Checked; + mainWin->m_rtRestore1Debug = this->rtRestore1CheckBox->checkState() == Qt::Checked; + mainWin->m_rtRestore2Debug = this->rtRestore2CheckBox->checkState() == Qt::Checked; + mainWin->m_rtRestore3Debug = this->rtRestore3CheckBox->checkState() == Qt::Checked; + if (this->radioConvertOff->isChecked()) { + mainWin->m_radioConvert = 0; + } else if (this->radioConvertIEC->isChecked()){ + mainWin->m_radioConvert = 1; + } else { + mainWin->m_radioConvert = 2; + } + mainWin->m_openPlot = this->openPlotCheckBox->checkState() == Qt::Checked; + mainWin->m_openBrowser = this->openBrowserCheckBox->checkState() == Qt::Checked; + mainWin->m_openDirStat = this->openDirStatCheckBox->checkState() == Qt::Checked; + + QSettings settings("www.bacula.org", "bat"); + settings.beginGroup("Debug"); + settings.setValue("commDebug", mainWin->m_commDebug); + settings.setValue("displayAll", mainWin->m_displayAll); + settings.setValue("sqlDebug", mainWin->m_sqlDebug); + settings.setValue("commandDebug", mainWin->m_commandDebug); + settings.setValue("miscDebug", mainWin->m_miscDebug); + settings.endGroup(); + settings.beginGroup("JobList"); + settings.setValue("recordLimitCheck", mainWin->m_recordLimitCheck); + settings.setValue("recordLimitVal", mainWin->m_recordLimitVal); + settings.setValue("daysLimitCheck", mainWin->m_daysLimitCheck); + settings.setValue("daysLimitVal", mainWin->m_daysLimitVal); + settings.endGroup(); + settings.beginGroup("Messages"); + settings.setValue("checkMessages", mainWin->m_checkMessages); + settings.setValue("checkMessagesInterval", mainWin->m_checkMessagesInterval); + settings.endGroup(); + settings.beginGroup("Misc"); + settings.setValue("longList", mainWin->m_longList); + settings.setValue("byteConvert", mainWin->m_radioConvert); + settings.setValue("openplot", mainWin->m_openPlot); + settings.setValue("openbrowser", mainWin->m_openBrowser); + settings.setValue("opendirstat", mainWin->m_openDirStat); + settings.endGroup(); + settings.beginGroup("RestoreTree"); + settings.setValue("rtPopDirDebug", mainWin->m_rtPopDirDebug); + settings.setValue("rtDirCurICDebug", mainWin->m_rtDirCurICDebug); + settings.setValue("rtDirCurICRetDebug", mainWin->m_rtDirICDebug); + settings.setValue("rtFileTabICDebug", mainWin->m_rtFileTabICDebug); + settings.setValue("rtVerTabICDebug", mainWin->m_rtVerTabICDebug); + settings.setValue("rtUpdateFTDebug", mainWin->m_rtUpdateFTDebug); + settings.setValue("rtUpdateVTDebug", mainWin->m_rtUpdateVTDebug); + settings.setValue("rtChecksDebug", mainWin->m_rtChecksDebug); + settings.setValue("rtIconStateDebug", mainWin->m_rtIconStateDebug); + settings.setValue("rtRestore1Debug", mainWin->m_rtRestore1Debug); + settings.setValue("rtRestore2Debug", mainWin->m_rtRestore2Debug); + settings.setValue("rtRestore3Debug", mainWin->m_rtRestore3Debug); + settings.endGroup(); + foreach(Console *console, mainWin->m_consoleHash) { + console->startTimer(); + } +} + +void prefsDialog::reject() +{ + this->hide(); + mainWin->set_status(tr("Canceled")); +} + +/* read preferences for the prefences dialog box */ +void MainWin::readPreferences() +{ + QSettings settings("www.bacula.org", "bat"); + settings.beginGroup("Debug"); + m_commDebug = settings.value("commDebug", false).toBool(); + m_displayAll = settings.value("displayAll", false).toBool(); + m_sqlDebug = settings.value("sqlDebug", false).toBool(); + m_commandDebug = settings.value("commandDebug", false).toBool(); + m_miscDebug = settings.value("miscDebug", false).toBool(); + settings.endGroup(); + settings.beginGroup("JobList"); + m_recordLimitCheck = settings.value("recordLimitCheck", true).toBool(); + m_recordLimitVal = settings.value("recordLimitVal", 150).toInt(); + m_daysLimitCheck = settings.value("daysLimitCheck", false).toBool(); + m_daysLimitVal = settings.value("daysLimitVal", 28).toInt(); + settings.endGroup(); + settings.beginGroup("Messages"); + m_checkMessages = settings.value("checkMessages", false).toBool(); + m_checkMessagesInterval = settings.value("checkMessagesInterval", 28).toInt(); + settings.endGroup(); + settings.beginGroup("Misc"); + m_longList = settings.value("longList", false).toBool(); + m_radioConvert = settings.value("byteConvert", false).toInt(); + m_openPlot = settings.value("openplot", false).toBool(); + m_openBrowser = settings.value("openbrowser", false).toBool(); + m_openDirStat = settings.value("opendirstat", false).toBool(); + settings.endGroup(); + settings.beginGroup("RestoreTree"); + m_rtPopDirDebug = settings.value("rtPopDirDebug", false).toBool(); + m_rtDirCurICDebug = settings.value("rtDirCurICDebug", false).toBool(); + m_rtDirICDebug = settings.value("rtDirCurICRetDebug", false).toBool(); + m_rtFileTabICDebug = settings.value("rtFileTabICDebug", false).toBool(); + m_rtVerTabICDebug = settings.value("rtVerTabICDebug", false).toBool(); + m_rtUpdateFTDebug = settings.value("rtUpdateFTDebug", false).toBool(); + m_rtUpdateVTDebug = settings.value("rtUpdateVTDebug", false).toBool(); + m_rtChecksDebug = settings.value("rtChecksDebug", false).toBool(); + m_rtIconStateDebug = settings.value("rtIconStateDebug", false).toBool(); + m_rtRestore1Debug = settings.value("rtRestore1Debug", false).toBool(); + m_rtRestore2Debug = settings.value("rtRestore2Debug", false).toBool(); + m_rtRestore3Debug = settings.value("rtRestore3Debug", false).toBool(); + settings.endGroup(); +} + +void MainWin::hrConvert(QString &ret, qlonglong &inval) +{ + double net = 0; + qlonglong base; + QStringList suflist; + + if (m_radioConvert == 0) { + ret = QString("%1").arg(inval); + return; + } else if (m_radioConvert == 1){ + base = 1000; + suflist = (QStringList() << "B" << "KiB" << "MiB" << "GiB" << "TiB" << "PiB" << "EiB" << "ZiB"); + } else { + base = 1024; + suflist = (QStringList() << "B" << "KB" << "MB" << "GB" << "TB" << "PB" << "EB" << "ZB"); + } + qlonglong running = base; + bool done = false; + int count = 1; + while (done == false) { + QString test1 = QString("%1").arg(inval); + QString test2 = QString("%1").arg(running); + if (float(inval) < (float)(running)) { + done = true; + ret = suflist[count - 1]; + net = (float)inval / (float)(running/base); + } + count += 1; + if (count > suflist.count()) done = true; + running *= base; + } + char format = 'f'; + if (net != 0) + ret = QString("%1 %2") + .arg(net, 0, format, 2, QLatin1Char(' ')) + .arg(ret); + else ret = "0 B"; +} + +void MainWin::hrConvertSeconds(QString &ret, qlonglong &inval) +{ + double net = 0; + QList durations; + durations.append(1); + durations.append(60); + durations.append(3600); + durations.append(86400); + durations.append(2592000); + durations.append(31536000); + QStringList abbrlist = (QStringList() << "Sec" << "Min" << "Hrs" << "Days" << "Mnth" << "Yrs"); + bool done = false; + int count = 1; + while (done == false) { + QString test1 = QString("%1").arg(inval); + QString test2 = QString("%1").arg(durations[count]); + if ((inval < durations[count]) || (count >= abbrlist.count() - 1)) { + done = true; + net = (float)inval / (float)(durations[count - 1]); + if (net != 0) + ret = QString("%1 %2") + .arg(net, 0, 'f', 2, QLatin1Char(' ')) + .arg(abbrlist[count - 1]); + else ret = "0 S"; + } + count += 1; + } +}