summaryrefslogtreecommitdiffstats
path: root/sysutils/gnomesystemmonitor/files/patch-src::proctable.c
diff options
context:
space:
mode:
authoradamw <adamw@df743ca5-7f9a-e211-a948-0013205c9059>2004-07-19 22:14:26 +0800
committeradamw <adamw@df743ca5-7f9a-e211-a948-0013205c9059>2004-07-19 22:14:26 +0800
commit00e1e9870673ffebd65059afccc0d4c044d56fd2 (patch)
treefaddbf764a3662b92b29353be681b396b62881dd /sysutils/gnomesystemmonitor/files/patch-src::proctable.c
parent3a112471f48382d3d609e29627a6e780a77ab461 (diff)
downloadmarcuscom-ports-00e1e9870673ffebd65059afccc0d4c044d56fd2.tar
marcuscom-ports-00e1e9870673ffebd65059afccc0d4c044d56fd2.tar.gz
marcuscom-ports-00e1e9870673ffebd65059afccc0d4c044d56fd2.tar.bz2
marcuscom-ports-00e1e9870673ffebd65059afccc0d4c044d56fd2.tar.lz
marcuscom-ports-00e1e9870673ffebd65059afccc0d4c044d56fd2.tar.xz
marcuscom-ports-00e1e9870673ffebd65059afccc0d4c044d56fd2.tar.zst
marcuscom-ports-00e1e9870673ffebd65059afccc0d4c044d56fd2.zip
Add gnomesystemmonitor at 2.7.0.
git-svn-id: svn://creme-brulee.marcuscom.com/ports/trunk@2483 df743ca5-7f9a-e211-a948-0013205c9059
Diffstat (limited to 'sysutils/gnomesystemmonitor/files/patch-src::proctable.c')
-rw-r--r--sysutils/gnomesystemmonitor/files/patch-src::proctable.c55
1 files changed, 55 insertions, 0 deletions
diff --git a/sysutils/gnomesystemmonitor/files/patch-src::proctable.c b/sysutils/gnomesystemmonitor/files/patch-src::proctable.c
new file mode 100644
index 000000000..05f4c5384
--- /dev/null
+++ b/sysutils/gnomesystemmonitor/files/patch-src::proctable.c
@@ -0,0 +1,55 @@
+--- src/proctable.c.orig Mon Jul 19 10:02:09 2004
++++ src/proctable.c Mon Jul 19 10:08:18 2004
+@@ -563,6 +563,9 @@
+ glibtop_get_proc_uid (&procuid, pid);
+ glibtop_get_proc_time (&proctime, pid);
+ newcputime = proctime.utime + proctime.stime;
++ if (proctime.frequency) {
++ newcputime /= (proctime.frequency/100);
++ }
+ model = gtk_tree_view_get_model (GTK_TREE_VIEW (procdata->tree));
+
+ wnck_pid_read_resource_usage (gdk_screen_get_display (gdk_screen_get_default ()),
+@@ -667,6 +670,10 @@
+ glibtop_get_proc_uid (&procuid, pid);
+ glibtop_get_proc_time (&proctime, pid);
+ newcputime = proctime.utime + proctime.stime;
++ if (proctime.frequency) {
++ newcputime /= (proctime.frequency/100);
++ }
++
+
+ wnck_pid_read_resource_usage (gdk_screen_get_display (gdk_screen_get_default ()),
+ pid,
+@@ -761,6 +768,12 @@
+ return FALSE;
+ }
+
++static int
++pid_compare(const void* first, const void* second)
++{
++ return *(unsigned*)first - *(unsigned*)second;
++}
++
+ static void
+ refresh_list (ProcData *data, unsigned *pid_list, gint n)
+ {
+@@ -769,6 +782,8 @@
+ GtkTreeModel *model = gtk_tree_view_get_model (GTK_TREE_VIEW (procdata->tree));
+ gint i = 0;
+
++ qsort(pid_list, n, sizeof (*pid_list), pid_compare);
++
+ /* Add or update processes */
+ while (i < n) {
+ ProcInfo *info;
+@@ -862,6 +877,9 @@
+ ** should probably have a total_time_last gint in the ProcInfo structure */
+ glibtop_get_cpu (&cpu);
+ total_time = cpu.total - total_time_last;
++ if (cpu.frequency) {
++ total_time /= (cpu.frequency/100);
++ }
+ total_time_last = cpu.total;
+
+ refresh_list (procdata, pid_list, n);