summaryrefslogtreecommitdiffstats
path: root/src/inactivity.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/inactivity.h')
-rw-r--r--src/inactivity.h170
1 files changed, 170 insertions, 0 deletions
diff --git a/src/inactivity.h b/src/inactivity.h
new file mode 100644
index 0000000..d3fb979
--- /dev/null
+++ b/src/inactivity.h
@@ -0,0 +1,170 @@
+ /**************************************************************************
+ * Copyright (C) 2006 by Danny Kukawka *
+ * <dkukawka@suse.de>, <danny.kukawka@web.de> *
+ * *
+ * This program is free software; you can redistribute it and/or modify *
+ * it under the terms of version 2 of the GNU General Public License *
+ * as published by the Free Software Foundation. *
+ * *
+ * 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., *
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
+ ***************************************************************************/
+
+#ifndef _INACTIVITY_H_
+#define _INACTIVITY_H_
+
+/* this is needed to avoid typedef clash with X11
+ */
+#ifndef QT_CLEAN_NAMESPACE
+#define QT_CLEAN_NAMESPACE
+#endif
+
+// KDE Header
+#include <kprocess.h>
+
+// QT Header
+#include <qregexp.h>
+#include <qstring.h>
+#include <qwidget.h>
+#include <qtimer.h>
+#include <qevent.h>
+
+// X11 Header
+#include <X11/X.h>
+#include <X11/Xlib.h>
+#include <X11/Xatom.h>
+#include <X11/Xutil.h>
+
+// from project
+#include "kpowersave_debug.h"
+
+/*!
+* \file inactivity.h
+* \brief Headerfile for inactivity.cpp and the class \ref inactivity.
+*/
+/*!
+* \class inactivity
+* \brief class for detect inactivity related funtionality
+* \author Danny Kukawka, <dkukawka@suse.de>, <danny.kukawka@web.de>
+* \date 2006
+*/
+
+class inactivity : public QWidget
+{
+ Q_OBJECT
+
+public:
+ //! default constructor
+ inactivity();
+ //! default destructor
+ ~inactivity();
+
+ //! to start the monitoring of the X-Server
+ void start(int, QStringList);
+ //! to stop the monitoring of the X-Server
+ void stop();
+
+ //! to get the current user inactivity
+ unsigned long getXInactivity();
+
+signals:
+
+ //! signal emited if the with \ref start() set time of inactivity is expired
+ void inactivityTimeExpired();
+ //! signal to emit error msg
+ void displayErrorMsg( QString );
+
+private:
+
+ //! pointer to the process to call pidof
+ KProcess *proc;
+
+ //! about the call result of pidof
+ /*!
+ * This boolean tells if call of the command pidof failed.
+ * \li true: if failed
+ * \li false: if not
+ */
+ bool pidof_call_failed;
+ //! about the call of command pidof
+ /*!
+ * This boolean tells if the call of the command pidof was started or if
+ * the command is running
+ * \li true: if is started/running
+ * \li false: if not
+ */
+ bool pidof_call_started;
+ //! if pidof return value is recieved
+ /*!
+ * This boolean tells if the call of the command pidof returned and the
+ * returnvalue was parsed to set \ref blacklisted_running
+ * \li true: if returned and parsed
+ * \li false: if not
+ */
+ bool pidof_call_returned;
+ //! if a blacklisted program/process is running
+ /*!
+ * This boolean tells if a blacklisted program/process is currently running.
+ * \li true: if a blacklisted program/process is running
+ * \li false: if not
+ */
+ bool blacklisted_running;
+
+ //! QStringList with blacklisted programs for autosuspend
+ QStringList blacklist;
+
+ //! time which must expire befor emit signal for autosuspend
+ unsigned long timeToInactivity;
+ //! time of inactivity from the last check
+ unsigned long idleTime;
+ //! time of inactivity from the last check
+ unsigned long blacklisted_running_last;
+ //! if the XServer-has XScreenSaverExtension
+ int has_XSC_Extension;
+
+ //! QTimer intervall for the \ref checkInactivity Timer
+ /*!
+ * The time intervall to check for the current status and time of
+ * userinactivity. The timeslice is currently 30 sec.
+ */
+ static const int CHECK_for_INACTIVITY = 30000;
+
+ //! QTimer for check inactivity
+ /*!
+ * This timer is used to check the currently status and time of
+ * userinactivity on the X-Server. The timerinterval is defined trough
+ * \ref CHECK_for_INACTIVITY .
+ */
+ QTimer *checkInactivity;
+
+ // -------- FUNCTIONS ------------
+
+ //! to check the user-inactivity on the XServer
+ void checkXInactivity();
+ //! to check for running blacklisted programs
+ void checkBlacklisted();
+ //! to monitor the values
+ void check( bool recheck );
+ //! to workaround a strange behavior of the XScreenSaver extension
+ unsigned long workaroundCreepyXServer( unsigned long );
+
+private slots:
+
+ //! to monitor the values
+ void check();
+ //! to monitor the values
+ void recheck();
+ //! to get the PIDs of blacklisted programs/processes
+ void getPIDs(KProcess *, char *, int);
+ //! to get the signal if the command call is exited
+ void getPIDsExited(KProcess *);
+};
+
+#endif