cleaned up main.cpp
git-svn-id: https://svn.code.sf.net/p/keepassx/code/trunk@170 b624d157-de02-0410-bad0-e51aec6abb33
This commit is contained in:
parent
3bcfa15fe1
commit
1be77c9e10
|
@ -26,6 +26,7 @@
|
||||||
#include <QSettings>
|
#include <QSettings>
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include <QLayout>
|
#include <QLayout>
|
||||||
|
#include <QWidget>
|
||||||
|
|
||||||
KpxConfig::KpxConfig(const QString& filePath) : settings(filePath,QSettings::IniFormat){
|
KpxConfig::KpxConfig(const QString& filePath) : settings(filePath,QSettings::IniFormat){
|
||||||
configFile=filePath;
|
configFile=filePath;
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
#ifndef _KPXCONFIG_H_
|
#ifndef _KPXCONFIG_H_
|
||||||
#define _KPXCONFIG_H_
|
#define _KPXCONFIG_H_
|
||||||
|
|
||||||
#include "main.h"
|
#include "lib/tools.h"
|
||||||
#include "AutoType.h"
|
#include "AutoType.h"
|
||||||
#include <QBitArray>
|
#include <QBitArray>
|
||||||
#include <QByteArray>
|
#include <QByteArray>
|
||||||
|
|
|
@ -19,7 +19,8 @@
|
||||||
|
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QPainter>
|
#include <QPainter>
|
||||||
|
#include <QFile>
|
||||||
|
#include "lib/tools.h"
|
||||||
#include "AboutDlg.h"
|
#include "AboutDlg.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
#include <QFileInfo>
|
#include <QFileInfo>
|
||||||
#include <QPainter>
|
#include <QPainter>
|
||||||
|
#include "lib/tools.h"
|
||||||
#include "lib/FileDialogs.h"
|
#include "lib/FileDialogs.h"
|
||||||
#include "lib/bookmarks.h"
|
#include "lib/bookmarks.h"
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
|
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
|
#include "main.h"
|
||||||
#include "AutoTypeDlg.h"
|
#include "AutoTypeDlg.h"
|
||||||
#include "KpxConfig.h"
|
#include "KpxConfig.h"
|
||||||
#include <QDesktopWidget>
|
#include <QDesktopWidget>
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
|
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
|
#include "lib/tools.h"
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "CalendarDlg.h"
|
#include "CalendarDlg.h"
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,9 @@
|
||||||
|
|
||||||
#include <QPainter>
|
#include <QPainter>
|
||||||
#include <QCursor>
|
#include <QCursor>
|
||||||
|
#include <QFile>
|
||||||
|
#include "lib/tools.h"
|
||||||
|
|
||||||
#include "crypto/yarrow.h"
|
#include "crypto/yarrow.h"
|
||||||
|
|
||||||
#include "CollectEntropyDlg.h"
|
#include "CollectEntropyDlg.h"
|
||||||
|
|
|
@ -23,6 +23,8 @@
|
||||||
#include <QLineEdit>
|
#include <QLineEdit>
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QShowEvent>
|
#include <QShowEvent>
|
||||||
|
#include <QFile>
|
||||||
|
#include "lib/tools.h"
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "DatabaseSettingsDlg.h"
|
#include "DatabaseSettingsDlg.h"
|
||||||
|
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#include <QPainter>
|
#include <QPainter>
|
||||||
#include <QPaintEvent>
|
#include <QPaintEvent>
|
||||||
#include <QResizeEvent>
|
#include <QResizeEvent>
|
||||||
|
#include "lib/tools.h"
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "ExpiredEntriesDlg.h"
|
#include "ExpiredEntriesDlg.h"
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
#include <QListWidget>
|
#include <QListWidget>
|
||||||
#include <QPainter>
|
#include <QPainter>
|
||||||
|
#include "lib/tools.h"
|
||||||
#include "ManageBookmarksDlg.h"
|
#include "ManageBookmarksDlg.h"
|
||||||
#include "lib/bookmarks.h"
|
#include "lib/bookmarks.h"
|
||||||
#include "dialogs/AddBookmarkDlg.h"
|
#include "dialogs/AddBookmarkDlg.h"
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#define PASSWORDDIALOG_H
|
#define PASSWORDDIALOG_H
|
||||||
#include "ui_PasswordDlg.h"
|
#include "ui_PasswordDlg.h"
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
|
#include "lib/tools.h"
|
||||||
#include "lib/UrlLabel.h"
|
#include "lib/UrlLabel.h"
|
||||||
#include "Database.h"
|
#include "Database.h"
|
||||||
#include <QPixmap>
|
#include <QPixmap>
|
||||||
|
|
|
@ -25,6 +25,8 @@
|
||||||
#include <QPushButton>
|
#include <QPushButton>
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QShowEvent>
|
#include <QShowEvent>
|
||||||
|
#include <QFile>
|
||||||
|
#include "lib/tools.h"
|
||||||
#include "SelectIconDlg.h"
|
#include "SelectIconDlg.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,8 @@
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
|
#include <QFile>
|
||||||
|
#include "lib/tools.h"
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "Export.h"
|
#include "Export.h"
|
||||||
#include "lib/FileDialogs.h"
|
#include "lib/FileDialogs.h"
|
||||||
|
|
|
@ -19,6 +19,8 @@
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
|
#include <QFile>
|
||||||
|
#include "lib/tools.h"
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "Import.h"
|
#include "Import.h"
|
||||||
#include "lib/FileDialogs.h"
|
#include "lib/FileDialogs.h"
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
|
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
|
#include <QtCore>
|
||||||
#include "KpxConfig.h"
|
#include "KpxConfig.h"
|
||||||
#include "AutoType.h"
|
#include "AutoType.h"
|
||||||
#include "mainwindow.h"
|
#include "mainwindow.h"
|
||||||
|
|
|
@ -35,6 +35,7 @@
|
||||||
#include "EntryView.h"
|
#include "EntryView.h"
|
||||||
#include "dialogs/EditEntryDlg.h"
|
#include "dialogs/EditEntryDlg.h"
|
||||||
#include "lib/AutoType.h"
|
#include "lib/AutoType.h"
|
||||||
|
#include "Database.h"
|
||||||
|
|
||||||
// just for the lessThan funtion
|
// just for the lessThan funtion
|
||||||
QList<EntryViewItem*>* pItems;
|
QList<EntryViewItem*>* pItems;
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
|
|
||||||
#include "UrlLabel.h"
|
#include "UrlLabel.h"
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
|
#include "lib/tools.h"
|
||||||
#include <QFont>
|
#include <QFont>
|
||||||
#include <QColor>
|
#include <QColor>
|
||||||
#include <QCursor>
|
#include <QCursor>
|
||||||
|
|
|
@ -0,0 +1,179 @@
|
||||||
|
/***************************************************************************
|
||||||
|
* Copyright (C) 2005-2008 by Tarek Saidi *
|
||||||
|
* tarek.saidi@arcor.de *
|
||||||
|
* *
|
||||||
|
* 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; version 2 of the License. *
|
||||||
|
* *
|
||||||
|
* This program is distributed in the hope that it will be useful, *
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 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., *
|
||||||
|
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
|
||||||
|
***************************************************************************/
|
||||||
|
#include <QtCore>
|
||||||
|
#include <QtGui>
|
||||||
|
#include "KpxConfig.h"
|
||||||
|
#include "main.h"
|
||||||
|
#include "lib/tools.h"
|
||||||
|
|
||||||
|
|
||||||
|
void createBanner(QPixmap* Pixmap,const QPixmap* IconAlpha,const QString& Text,int Width){
|
||||||
|
createBanner(Pixmap,IconAlpha,Text,Width,config->bannerColor1(),config->bannerColor2(),config->bannerTextColor());
|
||||||
|
}
|
||||||
|
|
||||||
|
void createBanner(QPixmap* Pixmap,const QPixmap* IconAlpha,const QString& Text,int Width, QColor Color1, QColor Color2, QColor TextColor){
|
||||||
|
*Pixmap=QPixmap(Width,50);
|
||||||
|
QPainter painter(Pixmap);
|
||||||
|
QLinearGradient grad(0,0,Width,0);
|
||||||
|
grad.setColorAt(0,Color1);
|
||||||
|
grad.setColorAt(1,Color2);
|
||||||
|
painter.setPen(Qt::NoPen);
|
||||||
|
painter.setBrush(grad);
|
||||||
|
painter.drawRect(0,0,Width,50);
|
||||||
|
|
||||||
|
QPixmap Icon(32,32);
|
||||||
|
if(IconAlpha){
|
||||||
|
Icon.fill(TextColor);
|
||||||
|
Icon.setAlphaChannel(*IconAlpha);
|
||||||
|
painter.drawPixmap(10,10,Icon);
|
||||||
|
}
|
||||||
|
|
||||||
|
painter.setPen(QPen(TextColor));
|
||||||
|
painter.setFont(QFont(QApplication::font().family(),16));
|
||||||
|
painter.drawText(50,35,Text);
|
||||||
|
}
|
||||||
|
|
||||||
|
QString decodeFileError(QFile::FileError Code){
|
||||||
|
switch(Code){
|
||||||
|
case QFile::NoError: return QApplication::translate("FileErrors","No error occurred.");
|
||||||
|
case QFile::ReadError: return QApplication::translate("FileErrors","An error occurred while reading from the file.");
|
||||||
|
case QFile::WriteError: return QApplication::translate("FileErrors","An error occurred while writing to the file.");
|
||||||
|
case QFile::FatalError: return QApplication::translate("FileErrors","A fatal error occurred.");
|
||||||
|
case QFile::ResourceError: return QApplication::translate("FileErrors","An resource error occurred.");
|
||||||
|
case QFile::OpenError: return QApplication::translate("FileErrors","The file could not be opened.");
|
||||||
|
case QFile::AbortError: return QApplication::translate("FileErrors","The operation was aborted.");
|
||||||
|
case QFile::TimeOutError: return QApplication::translate("FileErrors","A timeout occurred.");
|
||||||
|
case QFile::UnspecifiedError: return QApplication::translate("FileErrors","An unspecified error occurred.");
|
||||||
|
case QFile::RemoveError: return QApplication::translate("FileErrors","The file could not be removed.");
|
||||||
|
case QFile::RenameError: return QApplication::translate("FileErrors","The file could not be renamed.");
|
||||||
|
case QFile::PositionError: return QApplication::translate("FileErrors","The position in the file could not be changed.");
|
||||||
|
case QFile::ResizeError: return QApplication::translate("FileErrors","The file could not be resized.");
|
||||||
|
case QFile::PermissionsError: return QApplication::translate("FileErrors","The file could not be accessed.");
|
||||||
|
case QFile::CopyError: return QApplication::translate("FileErrors","The file could not be copied.");
|
||||||
|
}
|
||||||
|
return QString();
|
||||||
|
}
|
||||||
|
|
||||||
|
void openBrowser(IEntryHandle* entry){
|
||||||
|
QString url = entry->url();
|
||||||
|
url.replace("{TITLE}", entry->title(), Qt::CaseInsensitive);
|
||||||
|
url.replace("{USERNAME}", entry->username(), Qt::CaseInsensitive);
|
||||||
|
|
||||||
|
if (url.contains("{PASSWORD}",Qt::CaseInsensitive)){
|
||||||
|
SecString password=entry->password();
|
||||||
|
password.unlock();
|
||||||
|
url.replace("{PASSWORD}", password, Qt::CaseInsensitive);
|
||||||
|
}
|
||||||
|
|
||||||
|
openBrowser(url);
|
||||||
|
}
|
||||||
|
|
||||||
|
void openBrowser(const QString& UrlString){
|
||||||
|
if (UrlString.startsWith("cmd://") && UrlString.length()>6){
|
||||||
|
QProcess::startDetached(UrlString.right(UrlString.length()-6));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
QUrl url(UrlString);
|
||||||
|
if(url.scheme().isEmpty())
|
||||||
|
url=QUrl("http://"+UrlString);
|
||||||
|
if(config->urlCmdDef() || url.scheme()=="mailto"){
|
||||||
|
QDesktopServices::openUrl(url);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
QByteArray UrlEncoded = url.toEncoded();
|
||||||
|
QString browser = config->urlCmd();
|
||||||
|
if (browser.contains("%u", Qt::CaseInsensitive))
|
||||||
|
browser.replace("%u", UrlEncoded, Qt::CaseInsensitive);
|
||||||
|
else if (browser.contains("%1"))
|
||||||
|
browser.replace("%1", UrlEncoded);
|
||||||
|
else
|
||||||
|
browser.append(" ").append(UrlEncoded);
|
||||||
|
QProcess::startDetached(browser);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
QString makePathRelative(const QString& AbsDir,const QString& CurDir){
|
||||||
|
QStringList abs=AbsDir.split('/');
|
||||||
|
QStringList cur=CurDir.split('/');
|
||||||
|
QString rel="./";
|
||||||
|
int common;
|
||||||
|
for(common=0; common < abs.size() && common < cur.size(); common++){
|
||||||
|
if(abs[common]!=cur[common])break;
|
||||||
|
}
|
||||||
|
for(int i=0;i<cur.size()-common;i++)
|
||||||
|
rel.append("../");
|
||||||
|
for(int i=common;i<abs.size();i++)
|
||||||
|
rel.append(abs[i]+"/");
|
||||||
|
return rel;
|
||||||
|
}
|
||||||
|
|
||||||
|
void showErrMsg(const QString& msg,QWidget* parent){
|
||||||
|
QMessageBox::critical(parent,QApplication::translate("Main","Error"),msg,QApplication::translate("Main","OK"));
|
||||||
|
}
|
||||||
|
|
||||||
|
QString getImageFile(const QString& name){
|
||||||
|
if (QFile::exists(DataDir+"/icons/"+name))
|
||||||
|
return DataDir+"/icons/"+name;
|
||||||
|
else{
|
||||||
|
QMessageBox::critical(0,QApplication::translate("Main","Error"),
|
||||||
|
QApplication::translate("Main","File '%1' could not be found.")
|
||||||
|
.arg(name),QApplication::translate("Main","OK"),0,0,2,1);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const QIcon& getIcon(const QString& name){
|
||||||
|
static QHash<QString,QIcon*>IconCache;
|
||||||
|
QIcon* CachedIcon=IconCache.value(name);
|
||||||
|
if(CachedIcon)
|
||||||
|
return *CachedIcon;
|
||||||
|
QIcon* NewIcon=NULL;
|
||||||
|
//TODO plugins
|
||||||
|
/*if(IconLoader){
|
||||||
|
NewIcon=new QIcon(IconLoader->getIcon(name));
|
||||||
|
if(NewIcon->isNull()){
|
||||||
|
delete NewIcon;
|
||||||
|
NewIcon=NULL;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
IconCache.insert(name,NewIcon);
|
||||||
|
}*/
|
||||||
|
if(!NewIcon)
|
||||||
|
{
|
||||||
|
NewIcon=new QIcon(getImageFile(name+".png"));
|
||||||
|
IconCache.insert(name,NewIcon);
|
||||||
|
}
|
||||||
|
return *NewIcon;
|
||||||
|
}
|
||||||
|
|
||||||
|
const QPixmap* getPixmap(const QString& name){
|
||||||
|
static QHash<QString,QPixmap*>PixmapCache;
|
||||||
|
QPixmap* CachedPixmap=PixmapCache.value(name);
|
||||||
|
if(CachedPixmap)
|
||||||
|
return CachedPixmap;
|
||||||
|
QImage img(getImageFile(name+".png"));
|
||||||
|
QPixmap* NewPixmap=new QPixmap(QPixmap::fromImage(img));
|
||||||
|
PixmapCache.insert(name,NewPixmap);
|
||||||
|
return NewPixmap;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,41 @@
|
||||||
|
/***************************************************************************
|
||||||
|
* Copyright (C) 2005-2008 by Tarek Saidi *
|
||||||
|
* tarek.saidi@arcor.de *
|
||||||
|
* *
|
||||||
|
* 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; version 2 of the License. *
|
||||||
|
* *
|
||||||
|
* This program is distributed in the hope that it will be useful, *
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 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., *
|
||||||
|
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
|
||||||
|
***************************************************************************/
|
||||||
|
#ifndef TOOLS_H
|
||||||
|
#define TOOLS_H
|
||||||
|
|
||||||
|
#include <QFile>
|
||||||
|
#include <QString>
|
||||||
|
#include <QPixmap>
|
||||||
|
#include <QIcon>
|
||||||
|
|
||||||
|
#define CSTR(x)(x.toLocal8Bit().constData())
|
||||||
|
class IEntryHandle;
|
||||||
|
typedef enum tKeyType {PASSWORD=0,KEYFILE=1,BOTH=2};
|
||||||
|
const QIcon& getIcon(const QString& name);
|
||||||
|
const QPixmap* getPixmap(const QString& name);
|
||||||
|
void createBanner(QPixmap* Pixmap, const QPixmap* IconAlpha,const QString& Text,int Width);
|
||||||
|
void createBanner(QPixmap* Pixmap, const QPixmap* IconAlpha,const QString& Text,int Width, QColor Color1, QColor Color2, QColor TextColor);
|
||||||
|
void openBrowser(const QString& UrlString);
|
||||||
|
void openBrowser(IEntryHandle* entry);
|
||||||
|
void showErrMsg(const QString& msg,QWidget* parent=NULL);
|
||||||
|
QString decodeFileError(QFile::FileError Code);
|
||||||
|
QString makePathRelative(const QString& Abs,const QString& Cur);
|
||||||
|
QString getImageFile(const QString& name);
|
||||||
|
|
||||||
|
#endif //TOOLS_H
|
412
src/main.cpp
412
src/main.cpp
|
@ -19,25 +19,11 @@
|
||||||
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
|
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include <iostream>
|
#include <QtCore>
|
||||||
#include <QLibraryInfo>
|
|
||||||
#include <QLocale>
|
|
||||||
#include <QDir>
|
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QTranslator>
|
#include <iostream>
|
||||||
#include <QPainter>
|
|
||||||
#include <QImage>
|
|
||||||
#include <QStyleFactory>
|
|
||||||
#include <QProcess>
|
|
||||||
#include <QDesktopServices>
|
|
||||||
#include <QUrl>
|
|
||||||
#include <QCoreApplication>
|
|
||||||
#include <QVarLengthArray>
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
#include <QLibary>
|
|
||||||
#include <QPluginLoader>
|
|
||||||
#include "plugins/interfaces/IFileDialog.h"
|
#include "plugins/interfaces/IFileDialog.h"
|
||||||
#include "plugins/interfaces/IKdeInit.h"
|
#include "plugins/interfaces/IKdeInit.h"
|
||||||
#include "plugins/interfaces/IGnomeInit.h"
|
#include "plugins/interfaces/IGnomeInit.h"
|
||||||
|
@ -55,18 +41,9 @@
|
||||||
#if defined(Q_WS_X11) && defined(GLOBAL_AUTOTYPE)
|
#if defined(Q_WS_X11) && defined(GLOBAL_AUTOTYPE)
|
||||||
#include "Application_X11.h"
|
#include "Application_X11.h"
|
||||||
#endif
|
#endif
|
||||||
#ifdef Q_WS_WIN
|
|
||||||
#include <windows.h>
|
|
||||||
#endif
|
|
||||||
#ifdef Q_WS_MAC
|
|
||||||
#include <Carbon/Carbon.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
QHash<QString,QPixmap*>PixmapCache;
|
|
||||||
QHash<QString,QIcon*>IconCache;
|
|
||||||
|
|
||||||
KpxConfig *config;
|
KpxConfig *config;
|
||||||
QString AppDir;
|
QString AppDir;
|
||||||
QString HomeDir;
|
QString HomeDir;
|
||||||
|
@ -77,42 +54,25 @@ QString DetailViewTemplate;
|
||||||
|
|
||||||
QPixmap* EntryIcons;
|
QPixmap* EntryIcons;
|
||||||
//IIconTheme* IconLoader=NULL; //TODO plugins
|
//IIconTheme* IconLoader=NULL; //TODO plugins
|
||||||
char ** argv;
|
|
||||||
|
|
||||||
inline void loadImages();
|
inline void loadImages();
|
||||||
inline void parseCmdLineArgs(int argc, char** argv,QString &ArgFile,QString& ArgCfg,QString& ArgLang,bool& ArgMin,bool& ArgLock);
|
inline void parseCmdLineArgs(int argc, char** argv,QString &ArgFile,QString& ArgCfg,QString& ArgLang,bool& ArgMin,bool& ArgLock);
|
||||||
bool loadTranslation(QTranslator* tr,const QString& prefix,const QString& LocaleCode,const QStringList& SearchPaths);
|
bool loadTranslation(QTranslator* tr,const QString& prefix,const QString& LocaleCode,const QStringList& SearchPaths);
|
||||||
|
void initAppPaths(int argc, char **argv);
|
||||||
|
|
||||||
int main(int argc, char **_argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
argv=_argv;
|
QApplication* app=new QApplication(argc,argv);
|
||||||
QString ArgFile,ArgCfg,ArgLang,IniFilename;
|
initAppPaths(argc,argv);
|
||||||
QApplication* app=NULL;
|
CmdLineArgs args;
|
||||||
AppDir=applicationDirPath();
|
args.parse(app->arguments());
|
||||||
#if defined Q_WS_WIN
|
delete app;
|
||||||
HomeDir = QString::fromLocal8Bit(qgetenv("APPDATA").constData());
|
app=NULL;
|
||||||
if(!HomeDir.isEmpty() && QFile::exists(HomeDir))
|
qDebug(CSTR(AppDir));
|
||||||
HomeDir = QDir::fromNativeSeparators(HomeDir)+"/KeePassX";
|
qDebug(CSTR(DataDir));
|
||||||
else
|
|
||||||
HomeDir = QDir::homePath()+"/KeePassX";
|
|
||||||
#else
|
|
||||||
HomeDir = QDir::homePath()+"/.keepassx";
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined Q_WS_MACX
|
|
||||||
DataDir=AppDir+"/../Resources/keepassx";
|
|
||||||
#elif defined Q_WS_WIN
|
|
||||||
DataDir=AppDir+"/share";
|
|
||||||
#else
|
|
||||||
DataDir=AppDir+"/../share/keepassx";
|
|
||||||
#endif
|
|
||||||
bool ArgMin = false;
|
|
||||||
bool ArgLock = false;
|
|
||||||
parseCmdLineArgs(argc,argv,ArgFile,ArgCfg,ArgLang,ArgMin,ArgLock);
|
|
||||||
qDebug(CSTR(QDir::current().absolutePath()));
|
|
||||||
|
|
||||||
//Load Config
|
//Load Config
|
||||||
if(ArgCfg.isEmpty()){
|
QString IniFilename;
|
||||||
|
if(args.configLocation().isEmpty()){
|
||||||
if(!QDir(HomeDir).exists()){
|
if(!QDir(HomeDir).exists()){
|
||||||
QDir conf(QDir::homePath());
|
QDir conf(QDir::homePath());
|
||||||
if(!QDir().mkpath(HomeDir))
|
if(!QDir().mkpath(HomeDir))
|
||||||
|
@ -121,8 +81,7 @@ int main(int argc, char **_argv)
|
||||||
IniFilename=HomeDir+"/config";
|
IniFilename=HomeDir+"/config";
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
IniFilename=ArgCfg;
|
IniFilename=args.configLocation();
|
||||||
|
|
||||||
|
|
||||||
config = new KpxConfig(IniFilename);
|
config = new KpxConfig(IniFilename);
|
||||||
fileDlgHistory.load();
|
fileDlgHistory.load();
|
||||||
|
@ -180,10 +139,10 @@ int main(int argc, char **_argv)
|
||||||
|
|
||||||
//Internationalization
|
//Internationalization
|
||||||
QLocale loc;
|
QLocale loc;
|
||||||
if(!ArgLang.size())
|
if(!args.language().size())
|
||||||
loc=QLocale::system();
|
loc=QLocale::system();
|
||||||
else
|
else
|
||||||
loc=QLocale(ArgLang);
|
loc=QLocale(args.language());
|
||||||
|
|
||||||
QTranslator* translator = NULL;
|
QTranslator* translator = NULL;
|
||||||
QTranslator* qtTranslator=NULL;
|
QTranslator* qtTranslator=NULL;
|
||||||
|
@ -221,7 +180,6 @@ int main(int argc, char **_argv)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
DetailViewTemplate=config->detailViewTemplate();
|
DetailViewTemplate=config->detailViewTemplate();
|
||||||
|
|
||||||
loadImages();
|
loadImages();
|
||||||
|
@ -230,7 +188,7 @@ int main(int argc, char **_argv)
|
||||||
SecString::generateSessionKey();
|
SecString::generateSessionKey();
|
||||||
|
|
||||||
QApplication::setQuitOnLastWindowClosed(false);
|
QApplication::setQuitOnLastWindowClosed(false);
|
||||||
KeepassMainWindow *mainWin = new KeepassMainWindow(ArgFile,ArgMin,ArgLock);
|
KeepassMainWindow *mainWin = new KeepassMainWindow(args.file(), args.startMinimized(), args.startLocked());
|
||||||
int r=app->exec();
|
int r=app->exec();
|
||||||
delete mainWin;
|
delete mainWin;
|
||||||
|
|
||||||
|
@ -241,103 +199,6 @@ int main(int argc, char **_argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void createBanner(QPixmap* Pixmap,const QPixmap* IconAlpha,const QString& Text,int Width){
|
|
||||||
createBanner(Pixmap,IconAlpha,Text,Width,config->bannerColor1(),config->bannerColor2(),config->bannerTextColor());
|
|
||||||
}
|
|
||||||
|
|
||||||
void createBanner(QPixmap* Pixmap,const QPixmap* IconAlpha,const QString& Text,int Width, QColor Color1, QColor Color2, QColor TextColor){
|
|
||||||
*Pixmap=QPixmap(Width,50);
|
|
||||||
QPainter painter(Pixmap);
|
|
||||||
QLinearGradient grad(0,0,Width,0);
|
|
||||||
grad.setColorAt(0,Color1);
|
|
||||||
grad.setColorAt(1,Color2);
|
|
||||||
painter.setPen(Qt::NoPen);
|
|
||||||
painter.setBrush(grad);
|
|
||||||
painter.drawRect(0,0,Width,50);
|
|
||||||
|
|
||||||
QPixmap Icon(32,32);
|
|
||||||
if(IconAlpha){
|
|
||||||
Icon.fill(TextColor);
|
|
||||||
Icon.setAlphaChannel(*IconAlpha);
|
|
||||||
painter.drawPixmap(10,10,Icon);
|
|
||||||
}
|
|
||||||
|
|
||||||
painter.setPen(QPen(TextColor));
|
|
||||||
painter.setFont(QFont(QApplication::font().family(),16));
|
|
||||||
painter.drawText(50,35,Text);
|
|
||||||
}
|
|
||||||
|
|
||||||
QString decodeFileError(QFile::FileError Code){
|
|
||||||
switch(Code){
|
|
||||||
case QFile::NoError: return QApplication::translate("FileErrors","No error occurred.");
|
|
||||||
case QFile::ReadError: return QApplication::translate("FileErrors","An error occurred while reading from the file.");
|
|
||||||
case QFile::WriteError: return QApplication::translate("FileErrors","An error occurred while writing to the file.");
|
|
||||||
case QFile::FatalError: return QApplication::translate("FileErrors","A fatal error occurred.");
|
|
||||||
case QFile::ResourceError: return QApplication::translate("FileErrors","An resource error occurred.");
|
|
||||||
case QFile::OpenError: return QApplication::translate("FileErrors","The file could not be opened.");
|
|
||||||
case QFile::AbortError: return QApplication::translate("FileErrors","The operation was aborted.");
|
|
||||||
case QFile::TimeOutError: return QApplication::translate("FileErrors","A timeout occurred.");
|
|
||||||
case QFile::UnspecifiedError: return QApplication::translate("FileErrors","An unspecified error occurred.");
|
|
||||||
case QFile::RemoveError: return QApplication::translate("FileErrors","The file could not be removed.");
|
|
||||||
case QFile::RenameError: return QApplication::translate("FileErrors","The file could not be renamed.");
|
|
||||||
case QFile::PositionError: return QApplication::translate("FileErrors","The position in the file could not be changed.");
|
|
||||||
case QFile::ResizeError: return QApplication::translate("FileErrors","The file could not be resized.");
|
|
||||||
case QFile::PermissionsError: return QApplication::translate("FileErrors","The file could not be accessed.");
|
|
||||||
case QFile::CopyError: return QApplication::translate("FileErrors","The file could not be copied.");
|
|
||||||
}
|
|
||||||
return QString();
|
|
||||||
}
|
|
||||||
|
|
||||||
void openBrowser(IEntryHandle* entry){
|
|
||||||
QString url = entry->url();
|
|
||||||
url.replace("{TITLE}", entry->title(), Qt::CaseInsensitive);
|
|
||||||
url.replace("{USERNAME}", entry->username(), Qt::CaseInsensitive);
|
|
||||||
|
|
||||||
if (url.contains("{PASSWORD}",Qt::CaseInsensitive)){
|
|
||||||
SecString password=entry->password();
|
|
||||||
password.unlock();
|
|
||||||
url.replace("{PASSWORD}", password, Qt::CaseInsensitive);
|
|
||||||
}
|
|
||||||
|
|
||||||
openBrowser(url);
|
|
||||||
}
|
|
||||||
|
|
||||||
void openBrowser(const QString& UrlString){
|
|
||||||
if (UrlString.startsWith("cmd://") && UrlString.length()>6){
|
|
||||||
QProcess::startDetached(UrlString.right(UrlString.length()-6));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
QUrl url(UrlString);
|
|
||||||
if(url.scheme().isEmpty())
|
|
||||||
url=QUrl("http://"+UrlString);
|
|
||||||
if(config->urlCmdDef() || url.scheme()=="mailto"){
|
|
||||||
QDesktopServices::openUrl(url);
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
QByteArray UrlEncoded = url.toEncoded();
|
|
||||||
QString browser = config->urlCmd();
|
|
||||||
if (browser.contains("%u", Qt::CaseInsensitive))
|
|
||||||
browser.replace("%u", UrlEncoded, Qt::CaseInsensitive);
|
|
||||||
else if (browser.contains("%1"))
|
|
||||||
browser.replace("%1", UrlEncoded);
|
|
||||||
else
|
|
||||||
browser.append(" ").append(UrlEncoded);
|
|
||||||
QProcess::startDetached(browser);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
QString getImageFile(const QString& name){
|
|
||||||
if (QFile::exists(DataDir+"/icons/"+name))
|
|
||||||
return DataDir+"/icons/"+name;
|
|
||||||
else{
|
|
||||||
QMessageBox::critical(0,QApplication::translate("Main","Error"),
|
|
||||||
QApplication::translate("Main","File '%1' could not be found.")
|
|
||||||
.arg(name),QApplication::translate("Main","OK"),0,0,2,1);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
///TODO 0.2.3 remove
|
///TODO 0.2.3 remove
|
||||||
void loadImages(){
|
void loadImages(){
|
||||||
QPixmap tmpImg(getImageFile("clientic.png"));
|
QPixmap tmpImg(getImageFile("clientic.png"));
|
||||||
|
@ -347,39 +208,6 @@ void loadImages(){
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const QIcon& getIcon(const QString& name){
|
|
||||||
QIcon* CachedIcon=IconCache.value(name);
|
|
||||||
if(CachedIcon)
|
|
||||||
return *CachedIcon;
|
|
||||||
QIcon* NewIcon=NULL;
|
|
||||||
//TODO plugins
|
|
||||||
/*if(IconLoader){
|
|
||||||
NewIcon=new QIcon(IconLoader->getIcon(name));
|
|
||||||
if(NewIcon->isNull()){
|
|
||||||
delete NewIcon;
|
|
||||||
NewIcon=NULL;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
IconCache.insert(name,NewIcon);
|
|
||||||
}*/
|
|
||||||
if(!NewIcon)
|
|
||||||
{
|
|
||||||
NewIcon=new QIcon(getImageFile(name+".png"));
|
|
||||||
IconCache.insert(name,NewIcon);
|
|
||||||
}
|
|
||||||
return *NewIcon;
|
|
||||||
}
|
|
||||||
|
|
||||||
const QPixmap* getPixmap(const QString& name){
|
|
||||||
QPixmap* CachedPixmap=PixmapCache.value(name);
|
|
||||||
if(CachedPixmap)
|
|
||||||
return CachedPixmap;
|
|
||||||
QImage img(getImageFile(name+".png"));
|
|
||||||
QPixmap* NewPixmap=new QPixmap(QPixmap::fromImage(img));
|
|
||||||
PixmapCache.insert(name,NewPixmap);
|
|
||||||
return NewPixmap;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool loadTranslation(QTranslator* tr,const QString& prefix,const QString& loc,const QStringList& paths){
|
bool loadTranslation(QTranslator* tr,const QString& prefix,const QString& loc,const QStringList& paths){
|
||||||
for(int i=0;i<paths.size();i++)
|
for(int i=0;i<paths.size();i++)
|
||||||
|
@ -397,7 +225,60 @@ bool loadTranslation(QTranslator* tr,const QString& prefix,const QString& loc,co
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void printHelp(){
|
|
||||||
|
CmdLineArgs::CmdLineArgs(){
|
||||||
|
StartMinimized=false;
|
||||||
|
StartLocked=false;
|
||||||
|
Help=false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool CmdLineArgs::parse(const QStringList& argv){
|
||||||
|
for(int i=1;i<argv.size();i++){
|
||||||
|
if(argv[i]=="-help"){
|
||||||
|
Help=true;
|
||||||
|
break; // break, because other arguments will be ignored anyway
|
||||||
|
}
|
||||||
|
if(argv[i]=="-cfg"){
|
||||||
|
if(argv.size()==i+1){
|
||||||
|
Error="Missing argument for '-cfg'.";
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if(argv[i+1].left(1)=="-"){
|
||||||
|
Error=QString("Expected a path as argument for '-cfg' but got '%1.'").arg(argv[i+1]);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
ConfigLocation=argv[i+1];
|
||||||
|
i++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if(argv[i]=="-lang"){
|
||||||
|
if(argv.size()==i+1){
|
||||||
|
Error="Missing argument for '-lang'.";
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if(argv[i+1].size() != 2 && argv[i+1].size() != 5 ){
|
||||||
|
Error=QString("'%1' is not a valid language code.").arg(argv[i+1]);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
Language=argv[i+1];
|
||||||
|
i++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if(argv[i]=="-min"){
|
||||||
|
StartMinimized=true;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if(argv[i]=="-lock"){
|
||||||
|
StartLocked=true;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
Error=QString("** Unrecognized argument: '%1'").arg(argv[i]);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CmdLineArgs::printHelp(){
|
||||||
cout << "KeePassX" << APP_VERSION << endl;
|
cout << "KeePassX" << APP_VERSION << endl;
|
||||||
cout << "Usage: keepassx [Filename] [Options]" << endl;
|
cout << "Usage: keepassx [Filename] [Options]" << endl;
|
||||||
cout << " -help This Help" << endl;
|
cout << " -help This Help" << endl;
|
||||||
|
@ -411,55 +292,9 @@ void printHelp(){
|
||||||
cout << " pt_BR Portuguese(Brazil)"<<endl;
|
cout << " pt_BR Portuguese(Brazil)"<<endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
void parseCmdLineArgs(int argc, char** argv,QString &ArgFile,QString& ArgCfg,QString& ArgLang,bool& ArgMin, bool& ArgLock){
|
|
||||||
if(argc>1){
|
|
||||||
int i=1;
|
|
||||||
if(argv[i][0]!='-'){
|
|
||||||
ArgFile=QString::fromUtf8(argv[i]);
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
for(; i<argc; i++){
|
|
||||||
if(QString(argv[i])=="-help"){
|
|
||||||
printHelp();
|
|
||||||
exit(0);
|
|
||||||
}
|
|
||||||
else if(QString(argv[i])=="-cfg"){
|
|
||||||
if(i-1==argc){ cout << "Missing argument for -cfg" << endl; exit(1);}
|
|
||||||
else{ArgCfg=QString::fromUtf8(argv[i+1]); i++;}
|
|
||||||
}
|
|
||||||
else if(QString(argv[i])=="-lang"){
|
|
||||||
if(i-1==argc)
|
|
||||||
cout << "Missing argument for -lang" << endl;
|
|
||||||
else
|
|
||||||
ArgLang=QString::fromUtf8(argv[i+1]); i++;
|
|
||||||
}
|
|
||||||
else if(QString(argv[i])=="-min"){
|
|
||||||
ArgMin = true;
|
|
||||||
}
|
|
||||||
else if(QString(argv[i])=="-lock"){
|
|
||||||
ArgLock = true;
|
|
||||||
}
|
|
||||||
else if(QString(argv[i]).left(5)=="-psn_"){
|
|
||||||
// something like a pid or so, passed when starting an app bundle under MacOS X
|
|
||||||
// ignore
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
/*else if(QString(argv[i])=="-test"){
|
|
||||||
if (testDatabase()) exit(0);
|
|
||||||
else exit(1);
|
|
||||||
}*/
|
|
||||||
else{
|
|
||||||
cout << "** Unrecognized argument: " << argv[i] << endl << endl;
|
|
||||||
printHelp();
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void showErrMsg(const QString& msg,QWidget* parent){
|
|
||||||
QMessageBox::critical(parent,QApplication::translate("Main","Error"),msg,QApplication::translate("Main","OK"));
|
|
||||||
}
|
|
||||||
|
|
||||||
//TODO Plugins
|
//TODO Plugins
|
||||||
/*
|
/*
|
||||||
|
@ -474,106 +309,7 @@ QString findPlugin(const QString& filename){
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
QString makePathRelative(const QString& AbsDir,const QString& CurDir){
|
|
||||||
QStringList abs=AbsDir.split('/');
|
|
||||||
QStringList cur=CurDir.split('/');
|
|
||||||
QString rel="./";
|
|
||||||
int common;
|
|
||||||
for(common=0; common < abs.size() && common < cur.size(); common++){
|
|
||||||
if(abs[common]!=cur[common])break;
|
|
||||||
}
|
|
||||||
for(int i=0;i<cur.size()-common;i++)
|
|
||||||
rel.append("../");
|
|
||||||
for(int i=common;i<abs.size();i++)
|
|
||||||
rel.append(abs[i]+"/");
|
|
||||||
return rel;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
QString applicationDirPath(){
|
|
||||||
QString filepath=applicationFilePath();
|
|
||||||
filepath.truncate(filepath.lastIndexOf("/"));
|
|
||||||
return filepath;
|
|
||||||
}
|
|
||||||
|
|
||||||
QString applicationFilePath()
|
|
||||||
{
|
|
||||||
#if defined( Q_WS_WIN )
|
|
||||||
QFileInfo filePath;
|
|
||||||
QT_WA({
|
|
||||||
wchar_t module_name[256];
|
|
||||||
GetModuleFileNameW(0, module_name, sizeof(module_name) / sizeof(wchar_t));
|
|
||||||
filePath = QString::fromUtf16((ushort *)module_name);
|
|
||||||
}, {
|
|
||||||
char module_name[256];
|
|
||||||
GetModuleFileNameA(0, module_name, sizeof(module_name));
|
|
||||||
filePath = QString::fromLocal8Bit(module_name);
|
|
||||||
});
|
|
||||||
|
|
||||||
return filePath.filePath();
|
|
||||||
|
|
||||||
#elif defined(Q_WS_MAC)
|
|
||||||
|
|
||||||
CFURLRef bundleURL(CFBundleCopyExecutableURL(CFBundleGetMainBundle()));
|
|
||||||
//assert(bundleURL);
|
|
||||||
CFStringRef cfPath(CFURLCopyFileSystemPath(bundleURL, kCFURLPOSIXPathStyle));
|
|
||||||
//assert(cfPath);
|
|
||||||
CFIndex length = CFStringGetLength(cfPath);
|
|
||||||
const UniChar *chars = CFStringGetCharactersPtr(cfPath);
|
|
||||||
if (chars)
|
|
||||||
return QString(reinterpret_cast<const QChar *>(chars), length);
|
|
||||||
|
|
||||||
QVarLengthArray<UniChar> buffer(length);
|
|
||||||
CFStringGetCharacters(cfPath, CFRangeMake(0, length), buffer.data());
|
|
||||||
return QString(reinterpret_cast<const QChar *>(buffer.constData()), length);
|
|
||||||
|
|
||||||
#elif defined( Q_OS_UNIX )
|
|
||||||
#ifdef Q_OS_LINUX
|
|
||||||
// Try looking for a /proc/<pid>/exe symlink first which points to
|
|
||||||
// the absolute path of the executable
|
|
||||||
QFileInfo pfi(QString::fromLatin1("/proc/%1/exe").arg(getpid()));
|
|
||||||
if (pfi.exists() && pfi.isSymLink())
|
|
||||||
return pfi.canonicalFilePath();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
QString argv0 = QFile::decodeName(QByteArray(argv[0]));
|
|
||||||
QString absPath;
|
|
||||||
|
|
||||||
if (!argv0.isEmpty() && argv0.at(0) == QLatin1Char('/')) {
|
|
||||||
/*
|
|
||||||
If argv0 starts with a slash, it is already an absolute
|
|
||||||
file path.
|
|
||||||
*/
|
|
||||||
absPath = argv0;
|
|
||||||
} else if (argv0.contains(QLatin1Char('/'))) {
|
|
||||||
/*
|
|
||||||
If argv0 contains one or more slashes, it is a file path
|
|
||||||
relative to the current directory.
|
|
||||||
*/
|
|
||||||
absPath = QDir::current().absoluteFilePath(argv0);
|
|
||||||
} else {
|
|
||||||
/*
|
|
||||||
Otherwise, the file path has to be determined using the
|
|
||||||
PATH environment variable.
|
|
||||||
*/
|
|
||||||
QByteArray pEnv = qgetenv("PATH");
|
|
||||||
QDir currentDir = QDir::current();
|
|
||||||
QStringList paths = QString::fromLocal8Bit(pEnv.constData()).split(QLatin1String(":"));
|
|
||||||
for (QStringList::const_iterator p = paths.constBegin(); p != paths.constEnd(); ++p) {
|
|
||||||
if ((*p).isEmpty())
|
|
||||||
continue;
|
|
||||||
QString candidate = currentDir.absoluteFilePath(*p + QLatin1Char('/') + argv0);
|
|
||||||
QFileInfo candidate_fi(candidate);
|
|
||||||
if (candidate_fi.exists() && !candidate_fi.isDir()) {
|
|
||||||
absPath = candidate;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
absPath = QDir::cleanPath(absPath);
|
|
||||||
|
|
||||||
QFileInfo fi(absPath);
|
|
||||||
return fi.exists() ? fi.canonicalFilePath() : QString();
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
42
src/main.h
42
src/main.h
|
@ -37,27 +37,11 @@
|
||||||
|
|
||||||
#define BUILTIN_ICONS 65
|
#define BUILTIN_ICONS 65
|
||||||
|
|
||||||
#define CSTR(x)(x.toLocal8Bit().constData())
|
|
||||||
|
|
||||||
class IEntryHandle;
|
|
||||||
|
|
||||||
typedef enum tKeyType {PASSWORD=0,KEYFILE=1,BOTH=2};
|
|
||||||
class KpxConfig;
|
|
||||||
|
|
||||||
void createBanner(QPixmap* Pixmap, const QPixmap* IconAlpha,const QString& Text,int Width);
|
|
||||||
void createBanner(QPixmap* Pixmap, const QPixmap* IconAlpha,const QString& Text,int Width, QColor Color1, QColor Color2, QColor TextColor);
|
|
||||||
void openBrowser(IEntryHandle* entry);
|
|
||||||
void openBrowser(const QString& UrlString);
|
|
||||||
void showErrMsg(const QString& msg,QWidget* parent=NULL);
|
|
||||||
QString applicationFilePath();
|
|
||||||
QString applicationDirPath();
|
|
||||||
const QIcon& getIcon(const QString& name);
|
|
||||||
const QPixmap* getPixmap(const QString& name);
|
|
||||||
QString decodeFileError(QFile::FileError Code);
|
|
||||||
//QString findPlugin(const QString& filename); //TODO Plugins
|
//QString findPlugin(const QString& filename); //TODO Plugins
|
||||||
QString makePathRelative(const QString& Abs,const QString& Cur);
|
|
||||||
extern QString PluginLoadError;
|
|
||||||
|
|
||||||
|
class KpxConfig;
|
||||||
|
extern QString PluginLoadError;
|
||||||
extern KpxConfig *config;
|
extern KpxConfig *config;
|
||||||
extern QString AppDir;
|
extern QString AppDir;
|
||||||
extern QString HomeDir;
|
extern QString HomeDir;
|
||||||
|
@ -67,4 +51,26 @@ extern QString DetailViewTemplate;
|
||||||
extern QPixmap *EntryIcons;
|
extern QPixmap *EntryIcons;
|
||||||
|
|
||||||
|
|
||||||
|
class CmdLineArgs {
|
||||||
|
public:
|
||||||
|
CmdLineArgs();
|
||||||
|
bool parse(const QStringList& argv);
|
||||||
|
static void printHelp();
|
||||||
|
QString error() {return Error;}
|
||||||
|
QString file() {return File;}
|
||||||
|
QString configLocation() {return ConfigLocation;}
|
||||||
|
QString language() {return Language;}
|
||||||
|
bool startMinimized() {return StartMinimized;}
|
||||||
|
bool startLocked() {return StartLocked;}
|
||||||
|
bool help() {return Help;}
|
||||||
|
private:
|
||||||
|
QString Error;
|
||||||
|
QString File;
|
||||||
|
QString ConfigLocation;
|
||||||
|
QString Language;
|
||||||
|
bool StartMinimized;
|
||||||
|
bool StartLocked;
|
||||||
|
bool Help;
|
||||||
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -0,0 +1,43 @@
|
||||||
|
/***************************************************************************
|
||||||
|
* Copyright (C) 1992-2008 Trolltech ASA *
|
||||||
|
* *
|
||||||
|
* Copyright (C) 2005-2008 by Tarek Saidi *
|
||||||
|
* tarek.saidi@arcor.de *
|
||||||
|
* *
|
||||||
|
* 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; version 2 of the License. *
|
||||||
|
* *
|
||||||
|
* This program is distributed in the hope that it will be useful, *
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 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., *
|
||||||
|
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#include <Carbon/Carbon.h>
|
||||||
|
#include "main.h"
|
||||||
|
|
||||||
|
void initAppPaths() {
|
||||||
|
CFURLRef bundleURL(CFBundleCopyExecutableURL(CFBundleGetMainBundle()));
|
||||||
|
//assert(bundleURL);
|
||||||
|
CFStringRef cfPath(CFURLCopyFileSystemPath(bundleURL, kCFURLPOSIXPathStyle));
|
||||||
|
//assert(cfPath);
|
||||||
|
CFIndex length = CFStringGetLength(cfPath);
|
||||||
|
const UniChar *chars = CFStringGetCharactersPtr(cfPath);
|
||||||
|
if (chars) {
|
||||||
|
AppDir = QString(reinterpret_cast<const QChar *>(chars), length);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
QVarLengthArray<UniChar> buffer(length);
|
||||||
|
CFStringGetCharacters(cfPath, CFRangeMake(0, length), buffer.data());
|
||||||
|
AppDir = QString(reinterpret_cast<const QChar *>(buffer.constData()), length);
|
||||||
|
}
|
||||||
|
AppDir.truncate(AppDir.lastIndexOf("/"));
|
||||||
|
HomeDir = QDir::homePath()+"/.keepassx";
|
||||||
|
DataDir=AppDir+"/../Resources/keepassx";
|
||||||
|
}
|
|
@ -0,0 +1,74 @@
|
||||||
|
/***************************************************************************
|
||||||
|
* Copyright (C) 1992-2008 Trolltech ASA *
|
||||||
|
* *
|
||||||
|
* Copyright (C) 2005-2008 by Tarek Saidi *
|
||||||
|
* tarek.saidi@arcor.de *
|
||||||
|
* *
|
||||||
|
* 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; version 2 of the License. *
|
||||||
|
* *
|
||||||
|
* This program is distributed in the hope that it will be useful, *
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 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., *
|
||||||
|
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#include <QtCore>
|
||||||
|
#include "main.h"
|
||||||
|
|
||||||
|
void initAppPaths(int argc,char** argv) {
|
||||||
|
// Try looking for a /proc/<pid>/exe symlink first which points to
|
||||||
|
// the absolute path of the executable
|
||||||
|
QFileInfo pfi(QString::fromLatin1("/proc/%1/exe").arg(getpid()));
|
||||||
|
if (pfi.exists() && pfi.isSymLink()) {
|
||||||
|
AppDir = pfi.canonicalFilePath();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
QString argv0 = QFile::decodeName(QByteArray(argv[0]));
|
||||||
|
QString absPath;
|
||||||
|
|
||||||
|
if (!argv0.isEmpty() && argv0.at(0) == QLatin1Char('/')) {
|
||||||
|
/*
|
||||||
|
If argv0 starts with a slash, it is already an absolute
|
||||||
|
file path.
|
||||||
|
*/
|
||||||
|
absPath = argv0;
|
||||||
|
} else if (argv0.contains(QLatin1Char('/'))) {
|
||||||
|
/*
|
||||||
|
If argv0 contains one or more slashes, it is a file path
|
||||||
|
relative to the current directory.
|
||||||
|
*/
|
||||||
|
absPath = QDir::current().absoluteFilePath(argv0);
|
||||||
|
} else {
|
||||||
|
/*
|
||||||
|
Otherwise, the file path has to be determined using the
|
||||||
|
PATH environment variable.
|
||||||
|
*/
|
||||||
|
QByteArray pEnv = qgetenv("PATH");
|
||||||
|
QDir currentDir = QDir::current();
|
||||||
|
QStringList paths = QString::fromLocal8Bit(pEnv.constData()).split(QLatin1String(":"));
|
||||||
|
for (QStringList::const_iterator p = paths.constBegin(); p != paths.constEnd(); ++p) {
|
||||||
|
if ((*p).isEmpty())
|
||||||
|
continue;
|
||||||
|
QString candidate = currentDir.absoluteFilePath(*p + QLatin1Char('/') + argv0);
|
||||||
|
QFileInfo candidate_fi(candidate);
|
||||||
|
if (candidate_fi.exists() && !candidate_fi.isDir()) {
|
||||||
|
absPath = candidate;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
absPath = QDir::cleanPath(absPath);
|
||||||
|
QFileInfo fi(absPath);
|
||||||
|
AppDir = fi.exists() ? fi.canonicalFilePath() : QString();
|
||||||
|
}
|
||||||
|
AppDir.truncate(AppDir.lastIndexOf("/"));
|
||||||
|
DataDir=AppDir+"/../share/keepassx";
|
||||||
|
HomeDir = QDir::homePath()+"/.keepassx";
|
||||||
|
}
|
|
@ -0,0 +1,46 @@
|
||||||
|
/***************************************************************************
|
||||||
|
* Copyright (C) 1992-2007 Trolltech ASA *
|
||||||
|
* *
|
||||||
|
* Copyright (C) 2005-2007 by Tarek Saidi *
|
||||||
|
* tarek.saidi@arcor.de *
|
||||||
|
* *
|
||||||
|
* 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; version 2 of the License. *
|
||||||
|
* *
|
||||||
|
* This program is distributed in the hope that it will be useful, *
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 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., *
|
||||||
|
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#include <windows.h>
|
||||||
|
#include "main.h"
|
||||||
|
|
||||||
|
void initAppPaths(int argc,char** argv){
|
||||||
|
QFileInfo filePath;
|
||||||
|
QT_WA({
|
||||||
|
wchar_t module_name[256];
|
||||||
|
GetModuleFileNameW(0, module_name, sizeof(module_name) / sizeof(wchar_t));
|
||||||
|
filePath = QString::fromUtf16((ushort *)module_name);
|
||||||
|
}, {
|
||||||
|
char module_name[256];
|
||||||
|
GetModuleFileNameA(0, module_name, sizeof(module_name));
|
||||||
|
filePath = QString::fromLocal8Bit(module_name);
|
||||||
|
});
|
||||||
|
AppDir = filePath.filePath();
|
||||||
|
AppDir.truncate(AppDir.lastIndexOf("/"));
|
||||||
|
|
||||||
|
HomeDir = QString::fromLocal8Bit(qgetenv("APPDATA").constData());
|
||||||
|
if(!HomeDir.isEmpty() && QFile::exists(HomeDir))
|
||||||
|
HomeDir = QDir::fromNativeSeparators(HomeDir)+"/KeePassX";
|
||||||
|
else
|
||||||
|
HomeDir = QDir::homePath()+"/KeePassX";
|
||||||
|
|
||||||
|
DataDir=AppDir+"/share";
|
||||||
|
}
|
|
@ -48,6 +48,7 @@ unix : !macx : !isEqual(QMAKE_WIN32,1) {
|
||||||
SOURCES += Application_X11.cpp
|
SOURCES += Application_X11.cpp
|
||||||
HEADERS += Application_X11.h
|
HEADERS += Application_X11.h
|
||||||
}
|
}
|
||||||
|
SOURCES += main_unix.cpp
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -78,6 +79,7 @@ macx {
|
||||||
isEqual(ARCH,UNIVERSAL) : CONFIG += x86 ppc
|
isEqual(ARCH,UNIVERSAL) : CONFIG += x86 ppc
|
||||||
isEqual(ARCH,INTEL) : CONFIG += x86
|
isEqual(ARCH,INTEL) : CONFIG += x86
|
||||||
isEqual(ARCH,PPC) : CONFIG += ppc
|
isEqual(ARCH,PPC) : CONFIG += ppc
|
||||||
|
SOURCES += main_macx.cpp
|
||||||
}
|
}
|
||||||
|
|
||||||
#-------------------------------------------------------------------------------
|
#-------------------------------------------------------------------------------
|
||||||
|
@ -97,6 +99,7 @@ isEqual(QMAKE_WIN32,1) {
|
||||||
}
|
}
|
||||||
RC_FILE = ../share/win_ico/keepassx.rc
|
RC_FILE = ../share/win_ico/keepassx.rc
|
||||||
QMAKE_LINK_OBJECT_SCRIPT = $${OBJECTS_DIR}/$${QMAKE_LINK_OBJECT_SCRIPT}
|
QMAKE_LINK_OBJECT_SCRIPT = $${OBJECTS_DIR}/$${QMAKE_LINK_OBJECT_SCRIPT}
|
||||||
|
SOURCES += main_win32.cpp
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -173,6 +176,7 @@ HEADERS += lib/UrlLabel.h \
|
||||||
lib/ShortcutWidget.h \
|
lib/ShortcutWidget.h \
|
||||||
global.h \
|
global.h \
|
||||||
main.h \
|
main.h \
|
||||||
|
lib/tools.h \
|
||||||
lib/GroupView.h \
|
lib/GroupView.h \
|
||||||
lib/EntryView.h \
|
lib/EntryView.h \
|
||||||
crypto/arcfour.h \
|
crypto/arcfour.h \
|
||||||
|
@ -230,6 +234,7 @@ SOURCES += lib/UrlLabel.cpp \
|
||||||
# dialogs/TrashCanDlg.cpp \
|
# dialogs/TrashCanDlg.cpp \
|
||||||
lib/random.cpp \
|
lib/random.cpp \
|
||||||
Database.cpp \
|
Database.cpp \
|
||||||
|
lib/tools.cpp \
|
||||||
# lib/KdePlugin.cpp \
|
# lib/KdePlugin.cpp \
|
||||||
lib/GroupView.cpp \
|
lib/GroupView.cpp \
|
||||||
lib/EntryView.cpp \
|
lib/EntryView.cpp \
|
||||||
|
|
Loading…
Reference in New Issue