summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGluzskiy Alexandr <sss@sss.chaoslab.ru>2011-10-26 12:52:42 +0300
committerGluzskiy Alexandr <sss@sss.chaoslab.ru>2011-10-26 12:52:42 +0300
commitab62cd41fab9a0c941d035041df98f4ae3346339 (patch)
tree846d753829bcfc2087683372c1634c6f64239e42
parent4d8b70aaee170fa46116f10ef3eed3eb30ceffea (diff)
fixed crash in password enter dialog again
-rwxr-xr-xmessages.cpp23
1 files changed, 10 insertions, 13 deletions
diff --git a/messages.cpp b/messages.cpp
index 1d7e555..dc249da 100755
--- a/messages.cpp
+++ b/messages.cpp
@@ -924,23 +924,20 @@ static BOOL CALLBACK DlgProcKeyPassword(HWND hwndDlg, UINT msg, WPARAM wParam, L
if(_tcslen(tmp) > 0)
{
extern TCHAR *password;
- if(password && password[0])
+ if(IsDlgButtonChecked(hwndDlg, IDC_SAVE_PASSWORD))
{
- if(IsDlgButtonChecked(hwndDlg, IDC_SAVE_PASSWORD))
+ if(inkeyid && inkeyid[0] && !IsDlgButtonChecked(hwndDlg, IDC_DEFAULT_PASSWORD))
{
- if((strlen(inkeyid) > 0) && !IsDlgButtonChecked(hwndDlg, IDC_DEFAULT_PASSWORD))
- {
- string dbsetting = "szKey_";
- dbsetting += inkeyid;
- dbsetting += "_Password";
- DBWriteContactSettingTString(NULL, szGPGModuleName, dbsetting.c_str(), tmp);
- }
- else
- DBWriteContactSettingTString(NULL, szGPGModuleName, "szKeyPassword", tmp);
+ string dbsetting = "szKey_";
+ dbsetting += inkeyid;
+ dbsetting += "_Password";
+ DBWriteContactSettingTString(NULL, szGPGModuleName, dbsetting.c_str(), tmp);
}
- if(password)
- delete [] password;
+ else
+ DBWriteContactSettingTString(NULL, szGPGModuleName, "szKeyPassword", tmp);
}
+ if(password)
+ delete [] password;
password = new TCHAR [_tcslen(tmp)+1];
_tcscpy(password, tmp);
}