#include "mainwindow.h"
#include <QDebug>
#include <QString>
#include <QDir>
#include <QFileDialog>
#include <QMessageBox>
#include <QLabel>
#include <QProgressBar>
#include <QLayout>
#include <QVBoxLayout>
#include <QTimer>
#include <QCoreApplication>
#include <QPushButton>
#include <QSqlDatabase>
#include <QSqlQuery>
#include <QSqlError>
MainWindow
::MainWindow(QWidget *parent
){
layout->addWidget(progress);
connect(abortButton, SIGNAL(clicked()), this, SLOT(abortButtonClicked()));
layout->addWidget(abortButton);
w->setLayout(layout);
this->setCentralWidget(w);
abortButtonFlag = new bool;
abortButtonFlag = false;
QTimer::singleShot(100,
this,
SLOT(test
()));
}
MainWindow::~MainWindow()
{
}
void MainWindow::test(){
db.setDatabaseName("thomsonkeysDB");
if (db.open()) {
if (db.tables().indexOf("thomsonkeys") == -1) {
query.prepare("CREATE TABLE thomsonkeys (ssid VARCHAR(6), pass VARCHAR(10))");
if (!query.exec())
qCritical() << query.lastError();
}
} else {
qCritical() << db.lastError();
}
QString dir
= QFileDialog::getOpenFileName(this, tr
("Select Text File"),
"",tr
("Text (*.txt)"));
if(f.isOpen())
{
int fileSize=f.size();
int step=fileSize/100;
int bytesProcessed=0;
progress->setMaximum(fileSize);
progress->setValue(bytesProcessed);
while ((not f.atEnd()) & (not abortButtonFlag)){
line = f.readLine().data();
bytesProcessed+= line.size();
list = line.split(":");
query.exec("insert into thomsonkeys values('"+list.at(0)+"', '"+list.at(1)+"')");
if (bytesProcessed%step<=20){
progress->setValue(bytesProcessed);
}
}
f.close();
db.close();
progress->setValue(bytesProcessed);
progress->setEnabled(false);
}
else
{
QMessageBox::warning(this,
"Error",
"No file selected!");
}
}
void MainWindow::abortButtonClicked(){
abortButtonFlag=true;
}