added main window icon,
implemented template replacement for Auto-Type git-svn-id: https://svn.code.sf.net/p/keepassx/code/trunk@76 b624d157-de02-0410-bad0-e51aec6abb33
This commit is contained in:
parent
ab244b187a
commit
b08e5e8fad
Binary file not shown.
After Width: | Height: | Size: 806 B |
|
@ -47,14 +47,14 @@ switch(mods){
|
||||||
case 0: //no modifier
|
case 0: //no modifier
|
||||||
break;
|
break;
|
||||||
case 1: //Shift
|
case 1: //Shift
|
||||||
XTestFakeKeyEvent(d,XKeysymToKeycode(d,XK_Shift_L),press,5);
|
XTestFakeKeyEvent(d,XKeysymToKeycode(d,XK_Shift_L),press,2);
|
||||||
break;
|
break;
|
||||||
case 2: //AltGr
|
case 2: //AltGr
|
||||||
XTestFakeKeyEvent(d,XKeysymToKeycode(d,XK_ISO_Level3_Shift),press,5);
|
XTestFakeKeyEvent(d,XKeysymToKeycode(d,XK_ISO_Level3_Shift),press,2);
|
||||||
break;
|
break;
|
||||||
case 3: //Shift+AltGr
|
case 3: //Shift+AltGr
|
||||||
XTestFakeKeyEvent(d,XKeysymToKeycode(d,XK_Shift_L),press,5);
|
XTestFakeKeyEvent(d,XKeysymToKeycode(d,XK_Shift_L),press,2);
|
||||||
XTestFakeKeyEvent(d,XKeysymToKeycode(d,XK_ISO_Level3_Shift),press,5);
|
XTestFakeKeyEvent(d,XKeysymToKeycode(d,XK_ISO_Level3_Shift),press,2);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -79,31 +79,29 @@ if(c==1){
|
||||||
else
|
else
|
||||||
str="{USERNAME}{TAB}{PASSWORD}{ENTER}";
|
str="{USERNAME}{TAB}{PASSWORD}{ENTER}";
|
||||||
|
|
||||||
/*
|
|
||||||
KeePass/Win template compatibility:
|
|
||||||
only supported syntax is:{TEMPLATE-NAME}
|
|
||||||
%TEMPLATE-NAME% syntax is not supported!
|
|
||||||
*/
|
|
||||||
|
|
||||||
str.replace("{TITLE}",entry->Title,Qt::CaseInsensitive);
|
|
||||||
str.replace("{USERNAME}",entry->UserName,Qt::CaseInsensitive);
|
|
||||||
entry->Password.unlock();
|
|
||||||
str.replace("{PASSWORD}",entry->Password.string(),Qt::CaseInsensitive);
|
|
||||||
entry->Password.lock();
|
|
||||||
str.replace("{URL}",entry->URL,Qt::CaseInsensitive);
|
|
||||||
str.replace("{SPACE}",QString(" "),Qt::CaseInsensitive);
|
|
||||||
str.replace("{ADD}",QString("+"),Qt::CaseInsensitive);
|
|
||||||
str.replace("{SUBTRACT}",QString("-"),Qt::CaseInsensitive);
|
|
||||||
str.replace("{DIVIDE}",QString("/"),Qt::CaseInsensitive);
|
|
||||||
str.replace("{MULTIPLY}",QString("*"),Qt::CaseInsensitive);
|
|
||||||
str.replace("{PLUS}",QString("+"),Qt::CaseInsensitive);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
QList<Q_UINT16> Keys;
|
QList<Q_UINT16> Keys;
|
||||||
for(int i=0;i<str.length();i++){
|
for(int i=0;i<str.size();i++){
|
||||||
Keys << getKeysym(str.at(i));
|
if(str[i]=='{'){
|
||||||
|
int start=i;
|
||||||
|
QString tmpl;
|
||||||
|
i++;
|
||||||
|
while(str[i]!='}' && i<str.size()){
|
||||||
|
tmpl += str[i];
|
||||||
|
i++;
|
||||||
}
|
}
|
||||||
|
if(i>=str.size()){
|
||||||
|
err=tr("Syntax Error in Auto-Type sequence near character %1\n\
|
||||||
|
Found '{' without closing '}'").arg(i+10);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
templateToKeysyms(tmpl.lower(),Keys,entry);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Keys << getKeysym(str[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
MainWin->hide();
|
MainWin->hide();
|
||||||
Display* pDisplay = XOpenDisplay( NULL );
|
Display* pDisplay = XOpenDisplay( NULL );
|
||||||
|
@ -111,14 +109,72 @@ for(int i=0;i<Keys.size();i++){
|
||||||
int keycode=XKeysymToKeycode(pDisplay,Keys[i]);
|
int keycode=XKeysymToKeycode(pDisplay,Keys[i]);
|
||||||
int mods=getModifiers(pDisplay,Keys[i],keycode);
|
int mods=getModifiers(pDisplay,Keys[i],keycode);
|
||||||
pressModifiers(pDisplay,mods);
|
pressModifiers(pDisplay,mods);
|
||||||
XTestFakeKeyEvent(pDisplay,keycode,True,5);
|
XTestFakeKeyEvent(pDisplay,keycode,True,0);
|
||||||
XTestFakeKeyEvent(pDisplay,keycode,False,5);
|
XTestFakeKeyEvent(pDisplay,keycode,False,1);
|
||||||
releaseModifiers(pDisplay,mods);
|
releaseModifiers(pDisplay,mods);
|
||||||
}
|
}
|
||||||
XCloseDisplay(pDisplay);
|
XCloseDisplay(pDisplay);
|
||||||
MainWin->show();
|
MainWin->show();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AutoType::templateToKeysyms(const QString& tmpl, QList<quint16>& keys,CEntry* entry){
|
||||||
|
//tmpl must be lower case!!!
|
||||||
|
if(!tmpl.compare("title")){
|
||||||
|
stringToKeysyms(entry->Title,keys);
|
||||||
|
return;}
|
||||||
|
if(!tmpl.compare("username")){
|
||||||
|
stringToKeysyms(entry->UserName,keys);
|
||||||
|
return;}
|
||||||
|
if(!tmpl.compare("url")){
|
||||||
|
stringToKeysyms(entry->URL,keys);
|
||||||
|
return;}
|
||||||
|
if(!tmpl.compare("password")){
|
||||||
|
entry->Password.unlock();
|
||||||
|
stringToKeysyms(entry->Password.string(),keys);
|
||||||
|
entry->Password.lock();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!tmpl.compare("space")){
|
||||||
|
keys << getKeysym(' ');
|
||||||
|
return;}
|
||||||
|
|
||||||
|
if(!tmpl.compare("backspace") || !tmpl.compare("bs") || !tmpl.compare("bksp")){
|
||||||
|
keys << XK_BackSpace;
|
||||||
|
return;}
|
||||||
|
|
||||||
|
if(!tmpl.compare("break")){
|
||||||
|
keys << XK_Break;
|
||||||
|
return;}
|
||||||
|
|
||||||
|
if(!tmpl.compare("capslock")){
|
||||||
|
keys << XK_Caps_Lock;
|
||||||
|
return;}
|
||||||
|
|
||||||
|
if(!tmpl.compare("del") || !tmpl.compare("delete")){
|
||||||
|
keys << XK_Delete;
|
||||||
|
return;}
|
||||||
|
|
||||||
|
if(!tmpl.compare("end")){
|
||||||
|
keys << XK_End;
|
||||||
|
return;}
|
||||||
|
|
||||||
|
if(!tmpl.compare("enter")){
|
||||||
|
keys << XK_Return;
|
||||||
|
return;}
|
||||||
|
|
||||||
|
if(!tmpl.compare("esc")){
|
||||||
|
keys << XK_Escape;
|
||||||
|
return;}
|
||||||
|
|
||||||
|
if(!tmpl.compare("help")){
|
||||||
|
keys << XK_Help;
|
||||||
|
return;}
|
||||||
|
}
|
||||||
|
|
||||||
|
void AutoType::stringToKeysyms(const QString& string,QList<quint16>& KeySymList){
|
||||||
|
for(int i=0; i<string.length();i++)
|
||||||
|
KeySymList << getKeysym(string[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -48,6 +48,8 @@ private:
|
||||||
static int getModifiers(Display*,KeySym,int);
|
static int getModifiers(Display*,KeySym,int);
|
||||||
static void pressModifiers(Display*,int,bool Press=true);
|
static void pressModifiers(Display*,int,bool Press=true);
|
||||||
static void releaseModifiers(Display*,int);
|
static void releaseModifiers(Display*,int);
|
||||||
|
static void templateToKeysyms(const QString& Template, QList<quint16>& KeySymList,CEntry* entry);
|
||||||
|
static void stringToKeysyms(const QString& string,QList<quint16>& KeySymList);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -233,6 +233,8 @@ void loadImages(){
|
||||||
|
|
||||||
bool small=true;
|
bool small=true;
|
||||||
QString ThemeDir=AppDir+"/../share/keepass/icons/nuvola/32x32";
|
QString ThemeDir=AppDir+"/../share/keepass/icons/nuvola/32x32";
|
||||||
|
|
||||||
|
|
||||||
QPixmap tmpImg;
|
QPixmap tmpImg;
|
||||||
|
|
||||||
//-----------------------
|
//-----------------------
|
||||||
|
|
|
@ -174,6 +174,7 @@ void KeepassMainWindow::setupToolbar(){
|
||||||
}
|
}
|
||||||
|
|
||||||
void KeepassMainWindow::setupIcons(){
|
void KeepassMainWindow::setupIcons(){
|
||||||
|
setWindowIcon(QIcon(AppDir+"/../share/keepass/icons/keepassx.png"));
|
||||||
FileNewAction->setIcon(*Icon_FileNew);
|
FileNewAction->setIcon(*Icon_FileNew);
|
||||||
FileOpenAction->setIcon(*Icon_FileOpen);
|
FileOpenAction->setIcon(*Icon_FileOpen);
|
||||||
FileSaveAction->setIcon(*Icon_FileSave);
|
FileSaveAction->setIcon(*Icon_FileSave);
|
||||||
|
|
Loading…
Reference in New Issue