added: - history in combobox\n - settings in application
This commit is contained in:
parent
789317ea12
commit
cb384e1c51
11
RsyncUI.pro
11
RsyncUI.pro
@ -1,7 +1,10 @@
|
||||
QT += core gui concurrent
|
||||
QT += KItemViews
|
||||
QT += KCompletion
|
||||
QT += widgets
|
||||
QT += core gui concurrent
|
||||
QT += KItemViews
|
||||
QT += KCompletion
|
||||
QT += widgets
|
||||
QT += KConfigCore KConfigGui
|
||||
QT += KCoreAddons
|
||||
QT += KDBusAddons
|
||||
|
||||
#LIBS += -lKF5WindowSystem
|
||||
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
|
||||
|
@ -1,19 +1,6 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!DOCTYPE TS>
|
||||
<TS version="2.1" language="fr_FR">
|
||||
<context>
|
||||
<name>Dialog</name>
|
||||
<message>
|
||||
<location filename="downloadProgress.ui" line="20"/>
|
||||
<source>Dialog</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="downloadProgress.ui" line="32"/>
|
||||
<source>TextLabel</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
</context>
|
||||
<context>
|
||||
<name>MainWindow</name>
|
||||
<message>
|
||||
@ -40,28 +27,75 @@
|
||||
</message>
|
||||
<message>
|
||||
<location filename="mainwindow.ui" line="295"/>
|
||||
<source>debug</source>
|
||||
<translation>debug</translation>
|
||||
<location filename="mainwindow.ui" line="312"/>
|
||||
<source>Menu</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="mainwindow.cpp" line="34"/>
|
||||
<location filename="mainwindow.ui" line="301"/>
|
||||
<source>help</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="mainwindow.ui" line="317"/>
|
||||
<location filename="mainwindow.ui" line="320"/>
|
||||
<source>Default save folder</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="mainwindow.ui" line="325"/>
|
||||
<source>Bandwidth limit</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="mainwindow.ui" line="330"/>
|
||||
<source>About</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="mainwindow.ui" line="335"/>
|
||||
<source>About Qt</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<source>debug</source>
|
||||
<translation type="vanished">debug</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="mainwindow.cpp" line="42"/>
|
||||
<source>Path</source>
|
||||
<translation>Chemin</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="mainwindow.cpp" line="34"/>
|
||||
<location filename="mainwindow.cpp" line="42"/>
|
||||
<source>Size</source>
|
||||
<translation>Taille</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="mainwindow.cpp" line="233"/>
|
||||
<location filename="mainwindow.cpp" line="60"/>
|
||||
<source>Exiting will stop downloading, and will clear the download queue.
|
||||
Do you want to exit ?</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="mainwindow.cpp" line="281"/>
|
||||
<source>server does not exists</source>
|
||||
<translation>Le serveur n'existe pas</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="mainwindow.cpp" line="326"/>
|
||||
<location filename="mainwindow.cpp" line="373"/>
|
||||
<source>Choose directory to save file</source>
|
||||
<translation>Choisissez le dossier où enregistrer</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="mainwindow.cpp" line="419"/>
|
||||
<source>Do you want to stop downloading and delete this file from download queue ?</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="mainwindow.cpp" line="431"/>
|
||||
<source>Do you want to delete this file from download queue ?</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
</context>
|
||||
</TS>
|
||||
|
@ -1,6 +1,6 @@
|
||||
#include "downloadfile.h"
|
||||
#include "mainwindow.h"
|
||||
#include "ui_mainwindow.h"
|
||||
#include "downloadfile.h"
|
||||
#include "tools.h"
|
||||
#include <pstreams/pstream.h>
|
||||
#include <sstream>
|
||||
@ -74,7 +74,7 @@ void downloadFile::download(MainWindow *mw)
|
||||
{
|
||||
line.erase(0, pos);
|
||||
value = stoi(line);
|
||||
cout << value << endl;
|
||||
//cout << value << endl;
|
||||
emit progressSignal(value);
|
||||
}
|
||||
}
|
||||
|
4
main.cpp
4
main.cpp
@ -1,6 +1,10 @@
|
||||
#include "mainwindow.h"
|
||||
#include <QApplication>
|
||||
#include <QSettings>
|
||||
#include <KAboutData>
|
||||
#include <KDBusService>
|
||||
#include <QTranslator>
|
||||
#include <QCommandLineParser>
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
|
108
mainwindow.cpp
108
mainwindow.cpp
@ -41,6 +41,7 @@ MainWindow::MainWindow(QWidget *parent)
|
||||
ui->ktreewidgetsearchline->setCaseSensitivity(Qt::CaseInsensitive);
|
||||
ui->treeWidget->setHeaderLabels({tr("Path"), tr("Size")} );
|
||||
ui->progressBar->hide();
|
||||
|
||||
loadSettings();
|
||||
|
||||
populateList();
|
||||
@ -51,7 +52,6 @@ MainWindow::~MainWindow()
|
||||
{
|
||||
QMessageBox::StandardButton reply;
|
||||
|
||||
|
||||
if (ui->listDownload->count() != 0)
|
||||
{
|
||||
reply = QMessageBox::question(
|
||||
@ -64,7 +64,8 @@ MainWindow::~MainWindow()
|
||||
{
|
||||
emit (stopDownloading(this->downloading.pid));
|
||||
}
|
||||
}
|
||||
}
|
||||
saveSettings();
|
||||
if (this->downloading.pid != 0)
|
||||
{
|
||||
waitpid(this->downloading.pid, NULL, WUNTRACED);
|
||||
@ -79,36 +80,59 @@ void MainWindow::populateTree()
|
||||
|
||||
if (!this->connexion.server.empty() and this->connexion.port > 0 and this->connexion.port < 65536)
|
||||
{
|
||||
QGuiApplication::setOverrideCursor(Qt::WaitCursor);
|
||||
if (validateServer(this->connexion.server))
|
||||
{
|
||||
QGuiApplication::setOverrideCursor(Qt::WaitCursor);
|
||||
path = explode(ui->listWidget->currentItem()->text().toStdString(), '\n', 2);
|
||||
scanDir(this->connexion.server, this->connexion.port, NULL, path[0].append("/") );
|
||||
this->unsetCursor();
|
||||
QGuiApplication::setOverrideCursor(Qt::ArrowCursor);
|
||||
}
|
||||
QGuiApplication::setOverrideCursor(Qt::ArrowCursor);
|
||||
}
|
||||
}
|
||||
|
||||
void MainWindow::populateList()
|
||||
{
|
||||
stringstream ss;
|
||||
QString str;
|
||||
QString server;
|
||||
QString port;
|
||||
|
||||
this->connexion.server.assign(ui->khistorycombobox->currentText().toStdString());
|
||||
server = ui->khistorycombobox->currentText();
|
||||
this->connexion.server.assign(server.toStdString());
|
||||
ss << ui->portEdit->text().toStdString();
|
||||
ss >> this->connexion.port;
|
||||
if (!this->connexion.server.empty() and this->connexion.port > 0 and this->connexion.port < 65536)
|
||||
QGuiApplication::setOverrideCursor(Qt::WaitCursor);
|
||||
|
||||
this->settings.beginGroup("connexion/server");
|
||||
if (this->settings.contains(server))
|
||||
{
|
||||
if (validateServer(this->connexion.server))
|
||||
port = this->settings.value(server).toString();
|
||||
ui->portEdit->setText(port);
|
||||
this->connexion.port = this->settings.value(server).toInt();
|
||||
}
|
||||
|
||||
if (!server.isEmpty() and this->connexion.port > 0 and this->connexion.port < 65536)
|
||||
{
|
||||
if (validateServer(server.toStdString()))
|
||||
{
|
||||
ui->khistorycombobox->addItem(this->connexion.server.c_str());
|
||||
ui->centralwidget->cursor().setShape(Qt::WaitCursor);
|
||||
//this->settings.beginGroup("connexion/server");
|
||||
if (!this->settings.contains(server))
|
||||
{
|
||||
cout << server.toStdString() << endl;
|
||||
// storing serverURL and port in settings
|
||||
this->settings.setValue(server, this->connexion.port);
|
||||
this->settings.sync();
|
||||
|
||||
// storing in history of combobox
|
||||
ui->khistorycombobox->addToHistory(server);
|
||||
}
|
||||
// "waiting" cursor
|
||||
// load and display rsync services of the rsync server
|
||||
listServices();
|
||||
ui->centralwidget->cursor().setShape(Qt::ArrowCursor);
|
||||
QStringList test = ui->khistorycombobox->historyItems();
|
||||
sleep(1);
|
||||
}
|
||||
}
|
||||
this->settings.endGroup();
|
||||
QGuiApplication::setOverrideCursor(Qt::ArrowCursor);
|
||||
}
|
||||
|
||||
void MainWindow::listServices()
|
||||
@ -119,11 +143,12 @@ void MainWindow::listServices()
|
||||
vector<string> v;
|
||||
char service[4096];
|
||||
|
||||
ui->listWidget->clear();
|
||||
sprintf(cmd, "rsync --contimeout=10 -P \"%s::\" --port %d ", this->connexion.server.c_str(), this->connexion.port );
|
||||
redi::ipstream in(cmd, redi::pstreams::pstdout | redi::pstreams::pstderr);
|
||||
while (getline(in.out(), line))
|
||||
{
|
||||
cout << "stdout: " << line << endl;
|
||||
//cout << "stdout: " << line << endl;
|
||||
boost::replace_all(line," ","");
|
||||
boost::replace_all(line, "\t", " - ");
|
||||
v = explode(line, ' ', 3 );
|
||||
@ -221,7 +246,7 @@ bool MainWindow::validateServer(string server)
|
||||
|
||||
while (getline(in.out(), line))
|
||||
{
|
||||
cout << "stdout: " << line << '\n';
|
||||
//cout << "stdout: " << line << '\n';
|
||||
if (line.find(";; ANSWER SECTION:") != string::npos)
|
||||
{
|
||||
flag = true;
|
||||
@ -268,7 +293,16 @@ void MainWindow::displayTree()
|
||||
|
||||
void MainWindow::on_khistorycombobox_returnPressed()
|
||||
{
|
||||
populateList();
|
||||
//populateList();
|
||||
}
|
||||
|
||||
void MainWindow::on_khistorycombobox_currentIndexChanged(int i)
|
||||
{
|
||||
/*QString server = ui->khistorycombobox->currentText();
|
||||
this->settings.beginGroup("connexion/server");
|
||||
ui->portEdit->setText(this->settings.value(server).toString());
|
||||
this->settings.endGroup();*/
|
||||
this->populateList();
|
||||
}
|
||||
|
||||
void MainWindow::on_portEdit_returnPressed()
|
||||
@ -276,16 +310,6 @@ void MainWindow::on_portEdit_returnPressed()
|
||||
populateList();
|
||||
}
|
||||
|
||||
void MainWindow::on_treeWidget_itemClicked(QTreeWidgetItem *item, int column)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
void MainWindow::on_treeWidget_customContextMenuRequested()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
void MainWindow::on_actionDownload_triggered()
|
||||
{
|
||||
|
||||
@ -387,7 +411,7 @@ void MainWindow::on_listDownload_itemClicked(QListWidgetItem *item)
|
||||
QFileDialog dialog;
|
||||
QMessageBox::StandardButton reply;
|
||||
|
||||
cout << item->text().toStdString() << endl;
|
||||
//cout << item->text().toStdString() << endl;
|
||||
if (item->listWidget()->row(item) == 0)
|
||||
{
|
||||
reply = QMessageBox::question(
|
||||
@ -418,10 +442,36 @@ void MainWindow::on_listDownload_itemClicked(QListWidgetItem *item)
|
||||
|
||||
void MainWindow::loadSettings()
|
||||
{
|
||||
this->settings.value("serverlist");
|
||||
this->restoreGeometry(settings.value("window/geometry").toByteArray());
|
||||
this->settings.beginGroup("connexion/server");
|
||||
|
||||
QStringList servers = this->settings.allKeys();
|
||||
this->settings.endGroup();
|
||||
|
||||
for( const QString &server : servers )
|
||||
{
|
||||
ui->khistorycombobox->addToHistory(server);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void MainWindow::saveSettings()
|
||||
{
|
||||
//ui->khistorycombobox->
|
||||
this->settings.setValue("window/geometry", saveGeometry());
|
||||
this->settings.sync();
|
||||
}
|
||||
|
||||
void MainWindow::on_actionAbout_triggered()
|
||||
{
|
||||
QString text = this->about.description + "\n\n" +
|
||||
"Licence: " + this->about.licence + "\n" +
|
||||
"Author: " + this->about.author + "\n" +
|
||||
"EMail : " + this->about.email + "\n" +
|
||||
"Source code: " + this->about.git;
|
||||
QMessageBox::about(this, this->about.title, text);
|
||||
}
|
||||
|
||||
void MainWindow::on_actionAbout_Qt_triggered()
|
||||
{
|
||||
QMessageBox::aboutQt(this);
|
||||
}
|
||||
|
25
mainwindow.h
25
mainwindow.h
@ -8,6 +8,7 @@
|
||||
#include "downloadfile.h"
|
||||
#include <QProgressDialog>
|
||||
#include <QSettings>
|
||||
#include <vector>
|
||||
|
||||
QT_BEGIN_NAMESPACE
|
||||
namespace Ui { class MainWindow; }
|
||||
@ -32,6 +33,17 @@ class Downloading
|
||||
int pid = 0;
|
||||
};
|
||||
|
||||
class About
|
||||
{
|
||||
public:
|
||||
QString title = "RsyncUI";
|
||||
QString author = "Daniel TARTAVEL-JEANNOT";
|
||||
QString licence = "GPL_V3";
|
||||
QString description = "Client for rsync server";
|
||||
QString email = "dtux@free.fr";
|
||||
QString git = "https://git.labolyon.fr/dtux/RsyncUI/issues";
|
||||
};
|
||||
|
||||
class MainWindow : public QMainWindow
|
||||
{
|
||||
Q_OBJECT
|
||||
@ -58,6 +70,9 @@ class MainWindow : public QMainWindow
|
||||
Downloading downloading;
|
||||
downloadFile downloadO;
|
||||
QSettings settings;
|
||||
About about;
|
||||
|
||||
std::vector <QString> serversList;
|
||||
|
||||
private slots:
|
||||
void on_khistorycombobox_returnPressed();
|
||||
@ -66,10 +81,6 @@ class MainWindow : public QMainWindow
|
||||
|
||||
void on_portEdit_returnPressed();
|
||||
|
||||
void on_treeWidget_itemClicked(QTreeWidgetItem *item, int column);
|
||||
|
||||
void on_treeWidget_customContextMenuRequested();
|
||||
|
||||
void on_actionDownload_triggered();
|
||||
|
||||
void on_listWidget_clicked(const QModelIndex &index);
|
||||
@ -82,6 +93,12 @@ class MainWindow : public QMainWindow
|
||||
|
||||
void on_listDownload_itemClicked(QListWidgetItem *item);
|
||||
|
||||
void on_actionAbout_triggered();
|
||||
|
||||
void on_actionAbout_Qt_triggered();
|
||||
|
||||
void on_khistorycombobox_currentIndexChanged(int i);
|
||||
|
||||
signals:
|
||||
void stopDownloading(int);
|
||||
|
||||
|
@ -296,7 +296,15 @@
|
||||
</property>
|
||||
<addaction name="DefaultSaveFolder"/>
|
||||
</widget>
|
||||
<widget class="QMenu" name="menuhelp">
|
||||
<property name="title">
|
||||
<string>help</string>
|
||||
</property>
|
||||
<addaction name="actionAbout"/>
|
||||
<addaction name="actionAbout_Qt"/>
|
||||
</widget>
|
||||
<addaction name="menu"/>
|
||||
<addaction name="menuhelp"/>
|
||||
</widget>
|
||||
<widget class="QStatusBar" name="statusbar"/>
|
||||
<action name="actionMenu">
|
||||
@ -317,6 +325,16 @@
|
||||
<string>Bandwidth limit</string>
|
||||
</property>
|
||||
</action>
|
||||
<action name="actionAbout">
|
||||
<property name="text">
|
||||
<string>About</string>
|
||||
</property>
|
||||
</action>
|
||||
<action name="actionAbout_Qt">
|
||||
<property name="text">
|
||||
<string>About Qt</string>
|
||||
</property>
|
||||
</action>
|
||||
</widget>
|
||||
<customwidgets>
|
||||
<customwidget>
|
||||
|
Loading…
Reference in New Issue
Block a user