summaryrefslogtreecommitdiffstats
path: root/kdesktop/lock
diff options
context:
space:
mode:
authorTimothy Pearson <kb9vqf@pearsoncomputing.net>2012-04-23 14:59:01 -0500
committerSlávek Banko <slavek.banko@axis.cz>2012-06-03 03:27:09 +0200
commit1bd1c6586c658d3aa7195c34eaf009c61ffa7e73 (patch)
treeb8371a1aa9c5dc9c1b9d4888805216593fcc1208 /kdesktop/lock
parent4a67f231f00d75b9b91e13874d70d5e9fcf9c460 (diff)
downloadtdebase-1bd1c6586c658d3aa7195c34eaf009c61ffa7e73.tar.gz
tdebase-1bd1c6586c658d3aa7195c34eaf009c61ffa7e73.zip
Fix desktop lock failure due to race condition within signal handler between qt and xcb
(cherry picked from commit 67a3a8f34892a6491ba0073a3f583503b44e58e7)
Diffstat (limited to 'kdesktop/lock')
-rw-r--r--kdesktop/lock/lockprocess.cc2
-rw-r--r--kdesktop/lock/main.cc2
2 files changed, 3 insertions, 1 deletions
diff --git a/kdesktop/lock/lockprocess.cc b/kdesktop/lock/lockprocess.cc
index f3f1e6cfe..0981d2a50 100644
--- a/kdesktop/lock/lockprocess.cc
+++ b/kdesktop/lock/lockprocess.cc
@@ -664,6 +664,7 @@ void LockProcess::startSecureDialog()
}
trinity_desktop_lock_in_sec_dlg = false;
if (ret == 0) {
+ trinity_desktop_lock_closing_windows = 1;
kapp->quit();
}
if (ret == 1) {
@@ -687,6 +688,7 @@ void LockProcess::startSecureDialog()
mBusy = false;
}
if (ret == 2) {
+ trinity_desktop_lock_closing_windows = 1;
if (system("ksysguard &") == -1) {
// Error handler to shut up gcc warnings
}
diff --git a/kdesktop/lock/main.cc b/kdesktop/lock/main.cc
index 658472c22..89dc1917c 100644
--- a/kdesktop/lock/main.cc
+++ b/kdesktop/lock/main.cc
@@ -266,7 +266,7 @@ int main( int argc, char **argv )
bool rt;
bool sig = false;
- if( (!child && (args->isSet( "forcelock" )) || (signalled_forcelock == TRUE))) {
+ if( (((!child) && (args->isSet( "forcelock" ))) || (signalled_forcelock == TRUE))) {
rt = process.lock();
sig = true;
}