1 /* This file is part of the KDE project
3 Copyright (C) 2007 John Tapsell <tapsell@kde.org>
5 This library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Library General Public
7 License as published by the Free Software Foundation; either
8 version 2 of the License, or (at your option) any later version.
10 This library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Library General Public License for more details.
15 You should have received a copy of the GNU Library General Public License
16 along with this library; see the file COPYING.LIB. If not, write to
17 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
18 Boston, MA 02110-1301, USA.
22 #ifndef PROCESSES_BASE_P_H
23 #define PROCESSES_BASE_P_H
32 * This class contains the specific code to get the processes from the given host.
34 * To port this to other operating systems you need to make a processes_(osname).cpp file
35 * which implements all of the function below. If you need private functions/variables etc put them in
38 * @author John Tapsell <tapsell@kde.org>
40 class AbstractProcesses
: public QObject
46 AbstractProcesses() {}
47 virtual ~AbstractProcesses() {}
49 * To get information about processes, this will be the first function called.
51 virtual QSet
<long> getAllPids() = 0;
53 * For each of the pids that getAllPids() returns, getParentPid will be called. This is used to setup the tree structure.
54 * For a particular pid, this is guaranteed to be called before updateProcessInfo for that pid.
55 * However this may be called several times in a row before the updateProcessInfo is called, so be careful
56 * if you want to try to preserve state in Private.
58 virtual long getParentPid(long pid
) = 0;
60 * This will be called for every pid, after getParentPid() has been called for the same parameter.
62 * The process->pid process->ppid and process->parent are all guaranteed to be filled in correctly and process->parent
65 virtual bool updateProcessInfo(long pid
, Process
*process
) = 0;
67 * Send the specified named POSIX signal to the process given.
69 * For example, to indicate for process 324 to STOP do:
71 * #include <signals.h>
74 * KSysGuard::Processes::sendSignal(23, SIGSTOP);
78 virtual bool sendSignal(long pid
, int sig
) = 0;
81 * Set the priority for a process. For the normal scheduler, this is usually from 19
82 * (very nice, lowest priority) to -20 (highest priority). The default value for a process is 0.
84 * This has no effect if the scheduler is not the normal one (SCHED_OTHER)
86 * @return false if you do not have permission to set the priority
88 virtual bool setNiceness(long pid
, int priority
) = 0;
91 * Set the scheduler for a process. This is defined according to POSIX.1-2001
92 * See "man sched_setscheduler" for more information.
94 * @p priorityClass One of SCHED_FIFO, SCHED_RR, SCHED_OTHER, and SCHED_BATCH
95 * @p priority Set to 0 for SCHED_OTHER and SCHED_BATCH. Between 1 and 99 for SCHED_FIFO and SCHED_RR
96 * @return false if you do not have permission to set the priority
98 virtual bool setScheduler(long pid
, int priorityClass
, int priority
) = 0;
101 * Return the total amount of physical memory in KB. This is fast (just a system call)
104 virtual long long totalPhysicalMemory() = 0;
107 * Set the io priority for a process. This is from 7 (very nice, lowest io priority) to
108 * 0 (highest priority). The default value is determined as: io_nice = (cpu_nice + 20) / 5.
110 * @return false if you do not have permission to set the priority
112 virtual bool setIoNiceness(long pid
, int priorityClass
, int priority
) = 0;
115 * Returns true if ionice is supported on this system
117 virtual bool supportsIoNiceness() = 0;
120 * Return the number of processor cores enabled.
121 * (A system can disable procesors. Disabled processors are not counted here).
122 * This is fast (just a system call) */
123 virtual long numberProcessorCores() = 0;
126 * Get all the current process information from the machine. When done, emit updateAllProcesses().
128 virtual void updateAllProcesses() = 0;
132 * This is emitted when the processes have been updated, and the view should be refreshed
134 void processesUpdated();
139 #endif // PROCESSES_BASE_P_H