summaryrefslogtreecommitdiffstats
path: root/src/screen.cpp
diff options
context:
space:
mode:
authorMichele Calgaro <michele.calgaro@yahoo.it>2016-03-13 16:50:36 +0100
committerMichele Calgaro <michele.calgaro@yahoo.it>2016-03-13 16:51:41 +0100
commitbcf8fa06f0c48612f14beb216521eea9c4957501 (patch)
treee89ee7463305e1e7a2367bb4e105da0f5a773e26 /src/screen.cpp
parent504511d4a5758ad54ee4650aa5a6ddc92e26bcb8 (diff)
downloadtdepowersave-bcf8fa06f0c48612f14beb216521eea9c4957501.tar.gz
tdepowersave-bcf8fa06f0c48612f14beb216521eea9c4957501.zip
Fixed up timer for autosuspend and autodimm when a screensaver is also in use. This resolves bug 2603.
Signed-off-by: Michele Calgaro <michele.calgaro@yahoo.it> (cherry picked from commit d67bc99f08c6ba9113a769c45538ab3711cc1cfa)
Diffstat (limited to 'src/screen.cpp')
-rw-r--r--src/screen.cpp42
1 files changed, 36 insertions, 6 deletions
diff --git a/src/screen.cpp b/src/screen.cpp
index 4adb0f4..ef68a26 100644
--- a/src/screen.cpp
+++ b/src/screen.cpp
@@ -17,12 +17,12 @@
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
***************************************************************************/
/*! \file screen.cpp
- * All here displayed file members of screen.cpp are related to operations with the
- * XSreensaver/XServer. This functions are basic/low level operations. They are
+ * All here displayed file members of screen.cpp are related to operations with the
+ * XSreensaver/XServer. This functions are basic/low level operations. They are
* inspired, partly copied and modified from <a href="http://www.mplayerhq.hu/">MPlayer</a>
* code (1.05pre). Thanks for the inspiration. \n \n
- * All 'higher level' class members of the class screen can be found here: \ref screen
- * \brief In this file can be found all screensaver related code.
+ * All 'higher level' class members of the class screen can be found here: \ref screen
+ * \brief In this file can be found all screensaver related code.
* \author Danny Kukawka, <dkukawka@suse.de>, <danny.kukawka@web.de>
* \date 2004 - 2006
*/
@@ -81,7 +81,7 @@ bool screen::setScreenSaver(bool enable){
kdDebugFuncIn(trace);
if(SCREENSAVER_STATUS == -1) SCREENSAVER_STATUS = checkScreenSaverStatus();
- if((SCREENSAVER_STATUS == 1) || (SCREENSAVER_STATUS == 0)){
+ if((SCREENSAVER_STATUS == 1) || (SCREENSAVER_STATUS == 0)){
screen_save_dcop_ref.send( "enable", enable);
kdDebugFuncOut(trace);
return true;
@@ -298,6 +298,36 @@ int screen::checkScreenSaverStatus() {
return -1;
}
+bool screen::checkScreenSaverActive()
+{
+ // Check whether the screensaver is enabled
+ bool flagOK = false;
+ bool get_reply = false;
+ DCOPReply reply = screen_save_dcop_ref.call("isEnabled()");
+ if (reply.isValid()) {
+ if (reply.get(get_reply)) {
+ if (get_reply) {
+ flagOK = true;
+ }
+ }
+ }
+ if (!flagOK) {
+ return false;
+ }
+ // Check whether the screensaver is displayed
+ flagOK = false;
+ get_reply = false;
+ reply = screen_save_dcop_ref.call("isBlanked()");
+ if (reply.isValid()) {
+ if (reply.get(get_reply)) {
+ if (get_reply) {
+ flagOK = true;
+ }
+ }
+ }
+ return flagOK;
+}
+
/*!
* \b TQT_SLOT which called if the call of gnomescreensaver-command exited
* \param gnomecheckcommand the KPocess which called this SLOT
@@ -435,7 +465,7 @@ bool screen::lockScreen(){
if(SCREENSAVER_STATUS == -1) SCREENSAVER_STATUS = checkScreenSaverStatus();
// set lock for TDEScreensaver
- if((SCREENSAVER_STATUS == 1) || (SCREENSAVER_STATUS == 0)){
+ if((SCREENSAVER_STATUS == 1) || (SCREENSAVER_STATUS == 0)){
DCOPReply reply = screen_save_dcop_ref.call("lock");
if ( reply.isValid() ) {
return true;