aboutsummaryrefslogtreecommitdiffstats
path: root/community/gnome-system-monitor
diff options
context:
space:
mode:
authorBartłomiej Piotrowski <b@bpiotrowski.pl>2015-11-09 12:11:12 +0100
committerBartłomiej Piotrowski <b@bpiotrowski.pl>2015-11-09 12:11:12 +0100
commite54037f9267800e3d6f358648061ae4ff255b1b5 (patch)
treeaddde11a984abbcfde61fa8330bc3496d940cdd7 /community/gnome-system-monitor
parent499dd4be3c8864b8411c58192ac164bbfd2f1df7 (diff)
downloadaports-e54037f9267800e3d6f358648061ae4ff255b1b5.tar.bz2
aports-e54037f9267800e3d6f358648061ae4ff255b1b5.tar.xz
main/gnome-system-monitor: move to community
Diffstat (limited to 'community/gnome-system-monitor')
-rw-r--r--community/gnome-system-monitor/001-duplicate-label.patch31
-rw-r--r--community/gnome-system-monitor/002-replace-gtknotebookpage.patch35
-rw-r--r--community/gnome-system-monitor/003-replace-old-drawing.patch115
-rw-r--r--community/gnome-system-monitor/004-replace-dialog-set.patch67
-rw-r--r--community/gnome-system-monitor/005-replace-gdk_drawable.patch56
-rw-r--r--community/gnome-system-monitor/006-fix-includes.patch86
-rw-r--r--community/gnome-system-monitor/007-deprecated-gconf_init.patch23
-rw-r--r--community/gnome-system-monitor/008-rsvg-fix.patch54
-rw-r--r--community/gnome-system-monitor/009-add-close-button.patch79
-rw-r--r--community/gnome-system-monitor/010-cpu-model-arm.patch22
-rw-r--r--community/gnome-system-monitor/011-max-nice-linux.patch21
-rw-r--r--community/gnome-system-monitor/APKBUILD126
-rw-r--r--community/gnome-system-monitor/gnome-system-monitor.post-install7
-rw-r--r--community/gnome-system-monitor/gnome-system-monitor.post-upgrade7
-rw-r--r--community/gnome-system-monitor/gnome-system-monitor.pre-deinstall7
-rw-r--r--community/gnome-system-monitor/link-gmodule.patch13
-rw-r--r--community/gnome-system-monitor/musl-ni-idn.patch13
17 files changed, 762 insertions, 0 deletions
diff --git a/community/gnome-system-monitor/001-duplicate-label.patch b/community/gnome-system-monitor/001-duplicate-label.patch
new file mode 100644
index 0000000000..97355312fb
--- /dev/null
+++ b/community/gnome-system-monitor/001-duplicate-label.patch
@@ -0,0 +1,31 @@
+From dd7f7953d01a3e1b8bd78334aed05c016558df85 Mon Sep 17 00:00:00 2001
+From: Andreas Nilsson <nisses.mail@home.se>
+Date: Tue, 26 Oct 2010 15:09:15 +0000
+Subject: Remove duplicate label in File System tab
+
+https://bugzilla.gnome.org/show_bug.cgi?id=597250
+---
+diff --git a/src/disks.cpp b/src/disks.cpp
+index 172fc7a..c694c0a 100644
+--- a/src/disks.cpp
++++ b/src/disks.cpp
+@@ -288,7 +288,6 @@ GtkWidget *
+ create_disk_view(ProcData *procdata)
+ {
+ GtkWidget *disk_box;
+- GtkWidget *label;
+ GtkWidget *scrolled;
+ GtkWidget *disk_tree;
+ GtkListStore *model;
+@@ -310,9 +309,6 @@ create_disk_view(ProcData *procdata)
+
+ gtk_container_set_border_width(GTK_CONTAINER(disk_box), 12);
+
+- label = make_title_label(_("File Systems"));
+- gtk_box_pack_start(GTK_BOX(disk_box), label, FALSE, FALSE, 0);
+-
+ scrolled = gtk_scrolled_window_new(NULL, NULL);
+ gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled),
+ GTK_POLICY_AUTOMATIC,
+--
+cgit v0.9
diff --git a/community/gnome-system-monitor/002-replace-gtknotebookpage.patch b/community/gnome-system-monitor/002-replace-gtknotebookpage.patch
new file mode 100644
index 0000000000..b1b9a52f04
--- /dev/null
+++ b/community/gnome-system-monitor/002-replace-gtknotebookpage.patch
@@ -0,0 +1,35 @@
+From b72d92a3bebaaa6d7382f582aef149bb604f3e11 Mon Sep 17 00:00:00 2001
+From: Javier Jardón <jjardon@gnome.org>
+Date: Thu, 30 Sep 2010 16:42:44 +0000
+Subject: Replacing GtkNotebookPage with GtkWidget according to changes in GTK+
+
+Signed-off-by: Chris Kühl <chrisk@openismus.com>
+---
+diff --git a/src/callbacks.cpp b/src/callbacks.cpp
+index be2c16a..b0ac269 100644
+--- a/src/callbacks.cpp
++++ b/src/callbacks.cpp
+@@ -323,7 +323,7 @@ cb_tree_popup_menu (GtkWidget *widget, gpointer data)
+
+
+ void
+-cb_switch_page (GtkNotebook *nb, GtkNotebookPage *page,
++cb_switch_page (GtkNotebook *nb, GtkWidget *page,
+ gint num, gpointer data)
+ {
+ cb_change_current_page (nb, num, data);
+diff --git a/src/callbacks.h b/src/callbacks.h
+index 4c84793..6ce3e18 100644
+--- a/src/callbacks.h
++++ b/src/callbacks.h
+@@ -60,7 +60,7 @@ gboolean cb_tree_button_pressed (GtkWidget *widget, GdkEventButton *event,
+
+ void cb_change_current_page (GtkNotebook *nb,
+ gint num, gpointer data);
+-void cb_switch_page (GtkNotebook *nb, GtkNotebookPage *page,
++void cb_switch_page (GtkNotebook *nb, GtkWidget *page,
+ gint num, gpointer data);
+
+ gint cb_update_disks (gpointer data);
+--
+cgit v0.9
diff --git a/community/gnome-system-monitor/003-replace-old-drawing.patch b/community/gnome-system-monitor/003-replace-old-drawing.patch
new file mode 100644
index 0000000000..eb7b7615d7
--- /dev/null
+++ b/community/gnome-system-monitor/003-replace-old-drawing.patch
@@ -0,0 +1,115 @@
+From 90d0162efa3d5196a96b07cf8eff8351c322f7f4 Mon Sep 17 00:00:00 2001
+From: Chris Kühl <chrisk@openismus.com>
+Date: Wed, 26 Jan 2011 10:51:50 +0000
+Subject: Replace old GDK drawing API
+
+Patch from Sergey Nizovtsev.
+See https://bugzilla.gnome.org/show_bug.cgi?id=627568
+---
+diff --git a/src/load-graph.cpp b/src/load-graph.cpp
+index 79700d4..3cf8683 100644
+--- a/src/load-graph.cpp
++++ b/src/load-graph.cpp
+@@ -87,7 +87,7 @@ void draw_background(LoadGraph *g) {
+ allocation.height,
+ -1);
+ cr = gdk_cairo_create (g->background);
+-
++
+ // set the background colour
+ GtkStyle *style = gtk_widget_get_style (ProcData::get_instance()->notebook);
+ gdk_cairo_set_source_color (cr, &style->bg[GTK_STATE_NORMAL]);
+@@ -95,13 +95,13 @@ void draw_background(LoadGraph *g) {
+
+ /* draw frame */
+ cairo_translate (cr, FRAME_WIDTH, FRAME_WIDTH);
+-
++
+ /* Draw background rectangle */
+ cairo_set_source_rgb (cr, 1.0, 1.0, 1.0);
+ cairo_rectangle (cr, g->rmargin + g->indent, 0,
+ g->draw_width - g->rmargin - g->indent, g->real_draw_height);
+ cairo_fill(cr);
+-
++
+ cairo_set_line_width (cr, 1.0);
+ cairo_set_dash (cr, dash, 2, 0);
+ cairo_set_font_size (cr, g->fontsize);
+@@ -191,10 +191,6 @@ load_graph_configure (GtkWidget *widget,
+
+ g->clear_background();
+
+- if (g->gc == NULL) {
+- g->gc = gdk_gc_new (GDK_DRAWABLE (gtk_widget_get_window (widget)));
+- }
+-
+ load_graph_draw (g);
+
+ return TRUE;
+@@ -212,19 +208,14 @@ load_graph_expose (GtkWidget *widget,
+ guint i, j;
+ gdouble sample_width, x_offset;
+
++ window = gtk_widget_get_window (g->disp);
++ gtk_widget_get_allocation (g->disp, &allocation);
++
+ if (g->background == NULL) {
+ draw_background(g);
++ gdk_window_set_back_pixmap (window, g->background, FALSE);
+ }
+
+- window = gtk_widget_get_window (g->disp);
+- gtk_widget_get_allocation (g->disp, &allocation);
+- gdk_draw_drawable (window,
+- g->gc,
+- g->background,
+- 0, 0, 0, 0,
+- allocation.width,
+- allocation.height);
+-
+ /* Number of pixels wide for one graph point */
+ sample_width = (float)(g->draw_width - g->rmargin - g->indent) / (float)LoadGraph::NUM_POINTS;
+ /* General offset */
+@@ -252,7 +243,7 @@ load_graph_expose (GtkWidget *widget,
+ for (i = 1; i < LoadGraph::NUM_POINTS; ++i) {
+ if (g->data[i][j] == -1.0f)
+ continue;
+- cairo_curve_to (cr,
++ cairo_curve_to (cr,
+ x_offset - ((i - 0.5f) * g->graph_delx),
+ (1.0f - g->data[i-1][j]) * g->real_draw_height + 3.5f,
+ x_offset - ((i - 0.5f) * g->graph_delx),
+@@ -619,7 +610,6 @@ LoadGraph::LoadGraph(guint type)
+ graph_buffer_offset(0),
+ main_widget(NULL),
+ disp(NULL),
+- gc(NULL),
+ background(NULL),
+ timer_index(0),
+ draw(FALSE),
+@@ -676,9 +666,9 @@ LoadGraph::LoadGraph(guint type)
+ case LOAD_GRAPH_MEM:
+ g->colors[0] = ProcData::get_instance()->config.mem_color;
+ g->colors[1] = ProcData::get_instance()->config.swap_color;
+- g->mem_color_picker = gsm_color_button_new (&g->colors[0],
++ g->mem_color_picker = gsm_color_button_new (&g->colors[0],
+ GSMCP_TYPE_PIE);
+- g->swap_color_picker = gsm_color_button_new (&g->colors[1],
++ g->swap_color_picker = gsm_color_button_new (&g->colors[1],
+ GSMCP_TYPE_PIE);
+ break;
+ case LOAD_GRAPH_NET:
+diff --git a/src/load-graph.h b/src/load-graph.h
+index 6111c78..2dc2b10 100644
+--- a/src/load-graph.h
++++ b/src/load-graph.h
+@@ -66,7 +66,6 @@ struct LoadGraph {
+ GtkWidget *main_widget;
+ GtkWidget *disp;
+
+- GdkGC *gc;
+ GdkDrawable *background;
+
+ guint timer_index;
+--
+cgit v0.9
diff --git a/community/gnome-system-monitor/004-replace-dialog-set.patch b/community/gnome-system-monitor/004-replace-dialog-set.patch
new file mode 100644
index 0000000000..3a6e25aef3
--- /dev/null
+++ b/community/gnome-system-monitor/004-replace-dialog-set.patch
@@ -0,0 +1,67 @@
+From e302c23c43112fe336bf9d0481bdd94fc5af7b21 Mon Sep 17 00:00:00 2001
+From: Chris Kühl <chrisk@openismus.com>
+Date: Wed, 26 Jan 2011 13:12:09 +0000
+Subject: Replaced occurances of gtk_dialog_set_has_separator with g_object_set.
+
+---
+diff --git a/src/lsof.cpp b/src/lsof.cpp
+index 24f14a5..7773eff 100644
+--- a/src/lsof.cpp
++++ b/src/lsof.cpp
+@@ -312,7 +312,6 @@ void procman_lsof(ProcData *procdata)
+ // G_CALLBACK(close_dialog), NULL);
+ gtk_window_set_resizable(GTK_WINDOW(dialog), TRUE);
+ gtk_window_set_default_size(GTK_WINDOW(dialog), 575, 400);
+- // gtk_dialog_set_has_separator(GTK_DIALOG(dialog), FALSE);
+ gtk_container_set_border_width(GTK_CONTAINER(dialog), 12);
+ GtkWidget *mainbox = gtk_vbox_new(FALSE, 12);
+ gtk_container_add(GTK_CONTAINER(dialog), mainbox);
+diff --git a/src/memmaps.cpp b/src/memmaps.cpp
+index 9a6fcae..3205721 100644
+--- a/src/memmaps.cpp
++++ b/src/memmaps.cpp
+@@ -608,7 +608,6 @@ create_single_memmaps_dialog (GtkTreeModel *model, GtkTreePath *path,
+ gtk_window_set_title(GTK_WINDOW(memmapsdialog), _("Memory Maps"));
+ gtk_window_set_resizable(GTK_WINDOW(memmapsdialog), TRUE);
+ gtk_window_set_default_size(GTK_WINDOW(memmapsdialog), 575, 400);
+- // gtk_dialog_set_has_separator(GTK_DIALOG(dialog), FALSE);
+ gtk_container_set_border_width(GTK_CONTAINER(memmapsdialog), 12);
+
+ GtkWidget *mainbox = gtk_vbox_new(FALSE, 12);
+diff --git a/src/openfiles.cpp b/src/openfiles.cpp
+index f4a088a..c4ba2c8 100644
+--- a/src/openfiles.cpp
++++ b/src/openfiles.cpp
+@@ -335,7 +335,7 @@ create_single_openfiles_dialog (GtkTreeModel *model, GtkTreePath *path,
+ NULL);
+ gtk_window_set_resizable (GTK_WINDOW (openfilesdialog), TRUE);
+ gtk_window_set_default_size (GTK_WINDOW (openfilesdialog), 575, 400);
+- gtk_dialog_set_has_separator (GTK_DIALOG (openfilesdialog), FALSE);
++ g_object_set(G_OBJECT(openfilesdialog), "has-separator", FALSE, NULL);
+ gtk_container_set_border_width (GTK_CONTAINER (openfilesdialog), 5);
+
+ vbox = gtk_dialog_get_content_area (GTK_DIALOG (openfilesdialog));
+diff --git a/src/procdialogs.cpp b/src/procdialogs.cpp
+index 4c814a0..398e68f 100644
+--- a/src/procdialogs.cpp
++++ b/src/procdialogs.cpp
+@@ -178,7 +178,7 @@ procdialog_create_renice_dialog (ProcData *procdata)
+ NULL);
+ renice_dialog = dialog;
+ gtk_window_set_resizable (GTK_WINDOW (renice_dialog), FALSE);
+- gtk_dialog_set_has_separator (GTK_DIALOG (renice_dialog), FALSE);
++ g_object_set (G_OBJECT (renice_dialog), "has-separator", FALSE, NULL);
+ gtk_container_set_border_width (GTK_CONTAINER (renice_dialog), 5);
+
+ button = gtk_button_new ();
+@@ -510,7 +510,7 @@ procdialog_create_preferences_dialog (ProcData *procdata)
+ /* any function to set list height by contents/items inside it. */
+ gtk_window_set_default_size (GTK_WINDOW (dialog), 400, 420);
+ gtk_container_set_border_width (GTK_CONTAINER (dialog), 5);
+- gtk_dialog_set_has_separator (GTK_DIALOG (dialog), FALSE);
++ g_object_set (G_OBJECT (dialog), "has-separator", FALSE, NULL);
+ prefs_dialog = dialog;
+
+ main_vbox = gtk_dialog_get_content_area (GTK_DIALOG (dialog));
+--
+cgit v0.9
diff --git a/community/gnome-system-monitor/005-replace-gdk_drawable.patch b/community/gnome-system-monitor/005-replace-gdk_drawable.patch
new file mode 100644
index 0000000000..c70f2d2072
--- /dev/null
+++ b/community/gnome-system-monitor/005-replace-gdk_drawable.patch
@@ -0,0 +1,56 @@
+From ff00bed20c1740b619a487c76d2a7671dd435cc9 Mon Sep 17 00:00:00 2001
+From: Chris Kühl <chrisk@openismus.com>
+Date: Thu, 27 Jan 2011 01:08:37 +0000
+Subject: Replaced use of gdk_drawable_get_size with gdk_window_get_[width|height]
+
+---
+diff --git a/src/gsm_color_button.c b/src/gsm_color_button.c
+index 01f162e..ef7b3de 100644
+--- a/src/gsm_color_button.c
++++ b/src/gsm_color_button.c
+@@ -287,7 +287,8 @@ render (GtkWidget * widget)
+ color->green = color->green + highlight_factor;
+ }
+ gdk_cairo_set_source_color (cr, color);
+- gdk_drawable_get_size (gtk_widget_get_window (widget), &width, &height);
++ width = gdk_window_get_width (gtk_widget_get_window (widget));
++ height = gdk_window_get_height(gtk_widget_get_window (widget));
+
+ switch (color_button->priv->type)
+ {
+diff --git a/src/procman.cpp b/src/procman.cpp
+index b5c0d0a..c9a5ac5 100644
+--- a/src/procman.cpp
++++ b/src/procman.cpp
+@@ -548,25 +548,20 @@ void
+ procman_save_config (ProcData *data)
+ {
+ GConfClient *client = data->client;
+- gint width, height;
+
+ g_assert(data);
+
+ procman_save_tree_state (data->client, data->tree, "/apps/procman/proctree");
+ procman_save_tree_state (data->client, data->disk_list, "/apps/procman/disktreenew");
+-
+- gdk_drawable_get_size (gtk_widget_get_window (data->app), &width, &height);
+- data->config.width = width;
+- data->config.height = height;
+-
++
++ data->config.width = gdk_window_get_width (gtk_widget_get_window (data->app));
++ data->config.height = gdk_window_get_height(gtk_widget_get_window (data->app));
++
+ gconf_client_set_int (client, "/apps/procman/width", data->config.width, NULL);
+ gconf_client_set_int (client, "/apps/procman/height", data->config.height, NULL);
+ gconf_client_set_int (client, "/apps/procman/current_tab", data->config.current_tab, NULL);
+
+ gconf_client_suggest_sync (client, NULL);
+-
+-
+-
+ }
+
+ static guint32
+--
+cgit v0.9
diff --git a/community/gnome-system-monitor/006-fix-includes.patch b/community/gnome-system-monitor/006-fix-includes.patch
new file mode 100644
index 0000000000..0f5c957a45
--- /dev/null
+++ b/community/gnome-system-monitor/006-fix-includes.patch
@@ -0,0 +1,86 @@
+From c90b91acfc6880d16c5c991ea455ecbfbfe6fdab Mon Sep 17 00:00:00 2001
+From: Chris Kühl <chrisk@openismus.com>
+Date: Thu, 27 Jan 2011 10:42:19 +0000
+Subject: Fixed includes flagged with *_DISABLE_SINGLE_INCLUDES
+
+---
+diff --git a/src/interface.h b/src/interface.h
+index 4bda35a..b26b670 100644
+--- a/src/interface.h
++++ b/src/interface.h
+@@ -20,7 +20,7 @@
+ #ifndef _PROCMAN_INTERFACE_H_
+ #define _PROCMAN_INTERFACE_H_
+
+-#include <glib/gtypes.h>
++#include <glib.h>
+ #include <gtk/gtk.h>
+ #include "procman.h"
+
+diff --git a/src/load-graph.h b/src/load-graph.h
+index 2dc2b10..9dd28bb 100644
+--- a/src/load-graph.h
++++ b/src/load-graph.h
+@@ -1,7 +1,7 @@
+ #ifndef _PROCMAN_LOAD_GRAPH_H_
+ #define _PROCMAN_LOAD_GRAPH_H_
+
+-#include <glib/gtypes.h>
++#include <glib.h>
+ #include <glibtop/cpu.h>
+
+ enum
+diff --git a/src/lsof.h b/src/lsof.h
+index ad7f111..da420e2 100644
+--- a/src/lsof.h
++++ b/src/lsof.h
+@@ -1,7 +1,7 @@
+ #ifndef H_PROCMAN_LSOF_1161179202
+ #define H_PROCMAN_LSOF_1161179202
+
+-#include <glib/gmacros.h>
++#include <glib.h>
+ #include "procman.h"
+
+ void procman_lsof(ProcData *data);
+diff --git a/src/openfiles.h b/src/openfiles.h
+index 38b1cc8..a8b7b05 100644
+--- a/src/openfiles.h
++++ b/src/openfiles.h
+@@ -1,7 +1,7 @@
+ #ifndef _OPENFILES_H_
+ #define _OPENFILES_H_
+
+-#include <glib/gtypes.h>
++#include <glib.h>
+
+ #include "procman.h"
+
+diff --git a/src/procman_gnomesu.h b/src/procman_gnomesu.h
+index fec2650..474ca9a 100644
+--- a/src/procman_gnomesu.h
++++ b/src/procman_gnomesu.h
+@@ -1,7 +1,7 @@
+ #ifndef H_GNOME_SYSTEM_MONITOR_GNOMESU_H_1132171917
+ #define H_GNOME_SYSTEM_MONITOR_GNOMESU_H_1132171917
+
+-#include <glib/gtypes.h>
++#include <glib.h>
+
+ gboolean
+ procman_gnomesu_create_root_password_dialog(const char * message);
+diff --git a/src/util.cpp b/src/util.cpp
+index 9b1c9f5..90073fe 100644
+--- a/src/util.cpp
++++ b/src/util.cpp
+@@ -1,7 +1,7 @@
+ #include <config.h>
+
+ #include <glib/gi18n.h>
+-#include <glib/gstring.h>
++#include <glib.h>
+ #include <gtk/gtk.h>
+
+ #include <glibtop/proctime.h>
+--
+cgit v0.9
diff --git a/community/gnome-system-monitor/007-deprecated-gconf_init.patch b/community/gnome-system-monitor/007-deprecated-gconf_init.patch
new file mode 100644
index 0000000000..beb52e0016
--- /dev/null
+++ b/community/gnome-system-monitor/007-deprecated-gconf_init.patch
@@ -0,0 +1,23 @@
+From 94636329cba97708f245f678ca0b85fec7f3d819 Mon Sep 17 00:00:00 2001
+From: Chris Kühl <chrisk@openismus.com>
+Date: Thu, 27 Jan 2011 10:55:10 +0000
+Subject: Removed use of deprecated gconf_init.
+
+---
+diff --git a/src/procman.cpp b/src/procman.cpp
+index c9a5ac5..19c4cbc 100644
+--- a/src/procman.cpp
++++ b/src/procman.cpp
+@@ -717,9 +717,7 @@ main (int argc, char *argv[])
+
+ gtk_window_set_default_icon_name ("utilities-system-monitor");
+ g_set_application_name(_("System Monitor"));
+-
+- gconf_init (argc, argv, NULL);
+-
++
+ client = gconf_client_get_default ();
+ gconf_client_add_dir(client, "/apps/procman", GCONF_CLIENT_PRELOAD_NONE, NULL);
+
+--
+cgit v0.9
diff --git a/community/gnome-system-monitor/008-rsvg-fix.patch b/community/gnome-system-monitor/008-rsvg-fix.patch
new file mode 100644
index 0000000000..9bad7152ac
--- /dev/null
+++ b/community/gnome-system-monitor/008-rsvg-fix.patch
@@ -0,0 +1,54 @@
+From 7c700dd09c30e866fd3e358388d6a518f417b41c Mon Sep 17 00:00:00 2001
+From: Chris Kühl <chrisk@openismus.com>
+Date: Thu, 27 Jan 2011 14:20:45 +0000
+Subject: Moved rsvg_init and rsvg_term into main to fix Bug #613752.
+
+---
+diff --git a/src/gsm_color_button.c b/src/gsm_color_button.c
+index ef7b3de..e829694 100644
+--- a/src/gsm_color_button.c
++++ b/src/gsm_color_button.c
+@@ -595,8 +595,6 @@ gsm_color_button_init (GSMColorButton * color_button)
+ {
+ color_button->priv = GSM_COLOR_BUTTON_GET_PRIVATE (color_button);
+
+- rsvg_init ();
+-
+ color_button->priv->color.red = 0;
+ color_button->priv->color.green = 0;
+ color_button->priv->color.blue = 0;
+@@ -645,7 +643,6 @@ gsm_color_button_finalize (GObject * object)
+ cairo_surface_destroy (color_button->priv->image_buffer);
+ color_button->priv->image_buffer = NULL;
+
+- rsvg_term ();
+ G_OBJECT_CLASS (gsm_color_button_parent_class)->finalize (object);
+ }
+
+diff --git a/src/procman.cpp b/src/procman.cpp
+index 19c4cbc..f20de72 100644
+--- a/src/procman.cpp
++++ b/src/procman.cpp
+@@ -715,6 +715,9 @@ main (int argc, char *argv[])
+ exit (0);
+ }
+
++ /* initialize rsvg */
++ rsvg_init ();
++
+ gtk_window_set_default_icon_name ("utilities-system-monitor");
+ g_set_application_name(_("System Monitor"));
+
+@@ -753,6 +756,10 @@ main (int argc, char *argv[])
+
+ glibtop_close ();
+
++ // This function should only be called just before program exit.
++ // See GNOME bug #592100 for a discussion about this.
++ rsvg_term ();
++
+ return 0;
+ }
+
+--
+cgit v0.9
diff --git a/community/gnome-system-monitor/009-add-close-button.patch b/community/gnome-system-monitor/009-add-close-button.patch
new file mode 100644
index 0000000000..7aa47209e8
--- /dev/null
+++ b/community/gnome-system-monitor/009-add-close-button.patch
@@ -0,0 +1,79 @@
+From 00eb83fdbc5a6b6d5369b59b00a13293b1981b4f Mon Sep 17 00:00:00 2001
+From: Chris Kühl <chrisk@openismus.com>
+Date: Wed, 02 Mar 2011 23:00:58 +0000
+Subject: Added close button to memory map dialog.
+
+https://bugzilla.gnome.org/show_bug.cgi?id=592758
+---
+diff --git a/src/memmaps.cpp b/src/memmaps.cpp
+index 67255d1..ae8ef1c 100644
+--- a/src/memmaps.cpp
++++ b/src/memmaps.cpp
+@@ -316,14 +316,15 @@ update_memmaps_dialog (MemMapsData *mmdata)
+
+
+
+-static gboolean window_delete_event(GtkWidget *, GdkEvent *, gpointer data)
++static void
++dialog_response (GtkDialog * dialog, gint response_id, gpointer data)
+ {
+ MemMapsData * const mmdata = static_cast<MemMapsData*>(data);
+
+ g_source_remove (mmdata->timer);
+
+ delete mmdata;
+- return FALSE;
++ gtk_widget_destroy (GTK_WIDGET (dialog));
+ }
+
+
+@@ -463,26 +464,16 @@ create_single_memmaps_dialog (GtkTreeModel *model, GtkTreePath *path,
+ mmdata = create_memmapsdata (procdata);
+ mmdata->info = info;
+
+- memmapsdialog = gtk_window_new(GTK_WINDOW_TOPLEVEL);
+- gtk_window_set_transient_for(GTK_WINDOW(memmapsdialog), GTK_WINDOW(procdata->app));
+- gtk_window_set_destroy_with_parent(GTK_WINDOW(memmapsdialog), TRUE);
+- // gtk_window_set_modal(GTK_WINDOW(dialog), TRUE);
+- gtk_window_set_title(GTK_WINDOW(memmapsdialog), _("Memory Maps"));
++ memmapsdialog = gtk_dialog_new_with_buttons (_("Memory Maps"), GTK_WINDOW (procdata->app),
++ GTK_DIALOG_DESTROY_WITH_PARENT,
++ GTK_STOCK_CLOSE, GTK_RESPONSE_CLOSE,
++ NULL);
+ gtk_window_set_resizable(GTK_WINDOW(memmapsdialog), TRUE);
+ gtk_window_set_default_size(GTK_WINDOW(memmapsdialog), 575, 400);
+- gtk_container_set_border_width(GTK_CONTAINER(memmapsdialog), 12);
+-
+- GtkWidget *mainbox = gtk_vbox_new(FALSE, 12);
+- gtk_container_add(GTK_CONTAINER(memmapsdialog), mainbox);
+-
+- vbox = mainbox;
+- gtk_box_set_spacing (GTK_BOX (vbox), 2);
+- gtk_container_set_border_width (GTK_CONTAINER (vbox), 5);
++ gtk_container_set_border_width(GTK_CONTAINER(memmapsdialog), 5);
+
+- dialog_vbox = gtk_vbox_new (FALSE, 6);
++ dialog_vbox = gtk_dialog_get_content_area (GTK_DIALOG(memmapsdialog));
+ gtk_container_set_border_width (GTK_CONTAINER (dialog_vbox), 5);
+- gtk_box_pack_start (GTK_BOX (vbox), dialog_vbox, TRUE, TRUE, 0);
+-
+
+ label = procman_make_label_for_mmaps_or_ofiles (
+ _("_Memory maps for process \"%s\" (PID %u):"),
+@@ -504,11 +495,10 @@ create_single_memmaps_dialog (GtkTreeModel *model, GtkTreePath *path,
+
+ gtk_box_pack_start (GTK_BOX (dialog_vbox), scrolled, TRUE, TRUE, 0);
+
+- gtk_widget_show_all (memmapsdialog);
+-
+- g_signal_connect(G_OBJECT(memmapsdialog), "delete-event",
+- G_CALLBACK(window_delete_event), mmdata);
++ g_signal_connect(G_OBJECT(memmapsdialog), "response",
++ G_CALLBACK(dialog_response), mmdata);
+
++ gtk_widget_show_all (memmapsdialog);
+ mmdata->timer = g_timeout_add_seconds (5, memmaps_timer, mmdata);
+
+ update_memmaps_dialog (mmdata);
+--
+cgit v0.9
diff --git a/community/gnome-system-monitor/010-cpu-model-arm.patch b/community/gnome-system-monitor/010-cpu-model-arm.patch
new file mode 100644
index 0000000000..c5c4a65ab2
--- /dev/null
+++ b/community/gnome-system-monitor/010-cpu-model-arm.patch
@@ -0,0 +1,22 @@
+From a84ed33fb4c313d7cf67fac791aa063a997cb3af Mon Sep 17 00:00:00 2001
+From: Debbie Beliveau <debbie.beliveau@canonical.com>
+Date: Thu, 03 Mar 2011 19:55:44 +0000
+Subject: Fix to show cpu model on ARM.
+
+https://bugzilla.gnome.org/show_bug.cgi?id=606769
+---
+diff --git a/src/sysinfo.cpp b/src/sysinfo.cpp
+index 5f28e0c..20c94b0 100644
+--- a/src/sysinfo.cpp
++++ b/src/sysinfo.cpp
+@@ -105,7 +105,7 @@ namespace {
+ const glibtop_sysinfo *info = glibtop_get_sysinfo();
+
+ for (guint i = 0; i != info->ncpu; ++i) {
+- const char * const keys[] = { "model name", "cpu" };
++ const char * const keys[] = { "model name", "cpu", "Processor" };
+ gchar *model = 0;
+
+ for (guint j = 0; !model && j != G_N_ELEMENTS(keys); ++j)
+--
+cgit v0.9
diff --git a/community/gnome-system-monitor/011-max-nice-linux.patch b/community/gnome-system-monitor/011-max-nice-linux.patch
new file mode 100644
index 0000000000..55d4e4110d
--- /dev/null
+++ b/community/gnome-system-monitor/011-max-nice-linux.patch
@@ -0,0 +1,21 @@
+From 7c493352b24fb6d0d8b003f25043b070244eeb2e Mon Sep 17 00:00:00 2001
+From: Chris Kühl <chrisk@openismus.com>
+Date: Fri, 15 Apr 2011 09:18:10 +0000
+Subject: Make maximum nice value 19 instead of 20 on Linux.
+
+---
+diff --git a/src/procdialogs.h b/src/procdialogs.h
+index eba3212..61decf8 100644
+--- a/src/procdialogs.h
++++ b/src/procdialogs.h
+@@ -26,7 +26,7 @@
+ /* These are the actual range of settable values. Values outside this range
+ are scaled back to these limits. So show these limits in the slider
+ */
+-#ifdef linux
++#ifdef __linux__
+ #define RENICE_VAL_MIN -20
+ #define RENICE_VAL_MAX 19
+ #else /* ! linux */
+--
+cgit v0.9
diff --git a/community/gnome-system-monitor/APKBUILD b/community/gnome-system-monitor/APKBUILD
new file mode 100644
index 0000000000..d646eb8bd9
--- /dev/null
+++ b/community/gnome-system-monitor/APKBUILD
@@ -0,0 +1,126 @@
+# Contributor: William Pitcock <nenolod@dereferenced.org>
+# Maintainer: William Pitcock <nenolod@dereferenced.org>
+pkgname=gnome-system-monitor
+pkgver=2.28.2
+pkgrel=6
+pkgdesc="GNOME system monitor"
+url="http://www.gnome.org"
+arch="all"
+license="GPL"
+depends=
+depends_dev="gtk+-dev
+ gconf-dev
+ libx11-dev
+ gnome-doc-utils
+ libgnome-dev
+ gnome-desktop-dev
+ libwnck-dev
+ librsvg-dev
+ libunique-dev
+
+ libxcursor-dev
+ libxcomposite-dev
+ libxi-dev
+ libxau-dev
+ libxdmcp-dev
+ libxext-dev
+ libxcb-dev
+
+ libgtop-dev
+ libgnomekbd-dev
+ libxklavier-dev
+
+ gtkmm-dev
+ glibmm-dev"
+makedepends="$depends_dev intltool gobject-introspection-dev desktop-file-utils gnome-icon-theme"
+install="$pkgname.post-install $pkgname.pre-deinstall $pkgname.post-upgrade"
+subpackages="$pkgname-lang"
+source="ftp://ftp.gnome.org/pub/GNOME/sources/${pkgname}/${pkgver%.*}/${pkgname}-${pkgver}.tar.bz2
+001-duplicate-label.patch
+002-replace-gtknotebookpage.patch
+003-replace-old-drawing.patch
+004-replace-dialog-set.patch
+005-replace-gdk_drawable.patch
+006-fix-includes.patch
+007-deprecated-gconf_init.patch
+008-rsvg-fix.patch
+009-add-close-button.patch
+010-cpu-model-arm.patch
+011-max-nice-linux.patch
+link-gmodule.patch
+musl-ni-idn.patch
+"
+
+_builddir="${srcdir}/${pkgname}-${pkgver}"
+prepare() {
+ local i
+ cd "$_builddir"
+ update_config_sub || return 1
+ for i in $source; do
+ case $i in
+ *.patch) msg $i; patch -p1 -i "$srcdir"/$i || return 1;;
+ esac
+ done
+}
+
+build() {
+ cd "$_builddir"
+ ./configure \
+ --build=$CBUILD \
+ --host=$CHOST \
+ --prefix=/usr \
+ --sysconfdir=/etc \
+ --disable-scrollkeeper \
+ || return 1
+ make || return 1
+}
+
+package() {
+ cd "$_builddir"
+
+ export GCONF_DISABLE_MAKEFILE_SCHEMA_INSTALL=1
+ make DESTDIR="$pkgdir" install || return 1
+}
+
+md5sums="3f0bca9b0ebc7a365466851cd580d167 gnome-system-monitor-2.28.2.tar.bz2
+c13e170cc9f420cfe910bb4d9b262c73 001-duplicate-label.patch
+3d4a0f8703322ab7ae905480476ec0b8 002-replace-gtknotebookpage.patch
+da523fdfb5973530c65004d7efb6bb07 003-replace-old-drawing.patch
+08a6a43c1475f919bddb7c8ab80f2b8a 004-replace-dialog-set.patch
+cfbed825106e8ab50ec4ee2e7bc3ddab 005-replace-gdk_drawable.patch
+444412a8e6022a77917a4d6c3bef40c1 006-fix-includes.patch
+a30694c6790c06336b81ac86b8c3f494 007-deprecated-gconf_init.patch
+4e653f81b534753b995e6587e470bda8 008-rsvg-fix.patch
+cd900e83ba75892979ad32c2c7779724 009-add-close-button.patch
+674e96dd3967fda8a26acbcf719b8914 010-cpu-model-arm.patch
+6ffce80f40adeb53862762a55b638c18 011-max-nice-linux.patch
+5f3f590af871a78202c8ce54b83d10c4 link-gmodule.patch
+6b447b1b12bc436f3577b218d4a75257 musl-ni-idn.patch"
+sha256sums="b628edfd39e3a6b374ce133f367d3568475eb4e981a367f4f9d62a9784e5ae59 gnome-system-monitor-2.28.2.tar.bz2
+7c3b93e88524d60e4fae0e744e3930122a04155908fa7cb111b4907b58fbba5c 001-duplicate-label.patch
+90b5cd1ab392834b031ae2bdca55c0b996cab9dfdc2c18c0a9b93662dd9e68e0 002-replace-gtknotebookpage.patch
+6a30445a7f03e811170c5546ef59f2b22ea3b785a4df4c3a48a8ca84aee40fe9 003-replace-old-drawing.patch
+58fbdc8c94ef8805939d07c4045cb98cb956cde9035e592bd991c4810e5b05be 004-replace-dialog-set.patch
+027378f3f75555c151c9a78a29e536476c66403405989057cb1ea8b9e3a48435 005-replace-gdk_drawable.patch
+f331aa3e71bb9005f856816b9001c29accfad8348f42a65c6c4461b57c6a8ddd 006-fix-includes.patch
+a36c0ddeb77a17983916c8f6eb1b595c7b68d91456d1e9174d16ba541431815d 007-deprecated-gconf_init.patch
+9a37f71f7254885c05aec023734978e824b60c17924524e7daa12e8ffaf67671 008-rsvg-fix.patch
+6fd98ef29d5300a8fa1c952891c78008b838c69d7914043672b06c319045d21c 009-add-close-button.patch
+e1a11e94c25acd6620b878792813a610b6e875f91eac9903894b017d9428ffe6 010-cpu-model-arm.patch
+bb90241bc8e68b2a0d0317d449686642cbef30462a6e0e3d466bab31c41cfd5d 011-max-nice-linux.patch
+a0e21a7ae0d9350cd6036a69d3c3aa27733c68a591ab22ecfdc18d68356a9eea link-gmodule.patch
+be09b9d5356dddce7660686b7aa4833a334e324f5168e7963ba70c4197a700c4 musl-ni-idn.patch"
+sha512sums="41d77fa9055ecfa1b379d7fd35c8f6401773f07a640f0b11e787cc985387d264cdb718aa0eed68e8b54f74abd301a98dbe8360160bda1e8e33459f83b3426e27 gnome-system-monitor-2.28.2.tar.bz2
+b09ad0f544483538e06fa0111f03901360fb55248046a9af0a6792808b8522369c0833d08bb7054a888827989813ffa664fc506e683523a2424fa8c7ab81dccc 001-duplicate-label.patch
+16244aef266cb143d80ee7ae4f4f5bc711008b788ea55e131801ad1b98deddad590f8e046e94aeab3abf991ed1449391262d2c08914237f98ecfdf4b3c4f2ece 002-replace-gtknotebookpage.patch
+b821c8443bfa369435e72851799493f3df3a960abca1ad20ad55a5453bf20dc2b77d3be8c0778e70eadb4f6229a2ea4d73bd0bbec20de3215d46da93c5060603 003-replace-old-drawing.patch
+82faea5a61227ec6cf8ad488bdcb10b28a24e94441c247673a3497dc104eb3c31f8e905974b5cd8c869f96f5c82d5205d4e147ac1d39d42def161d1ce10f3933 004-replace-dialog-set.patch
+53d542fb8cd1823a8c0d3786a1a1650d13591350d8f277c7195c107e6905b8780abc4a12b2b20b04917709fc735e1597a7fda9621db916e078d5ac2f3fedafbd 005-replace-gdk_drawable.patch
+618dfe6ecb84463eda98db979f933fd87e7862ef155b5c856d01bcf3dc5d468022f9bb3461dfef1ac930c44104b5b29bcf3137d7130d603561569687e7406019 006-fix-includes.patch
+ba5686a66a2c1ec9338afd2c78ad21bdda9e5a1582d8c8fa0f885bf51ed84ce462e9db41a836ff8170d24ad8496831058d7fa11a963414c46c79e1ec6f1b65ec 007-deprecated-gconf_init.patch
+397a77507f8cb5ae085e5180962d637687921a16195e356cc88606c8809a3be6768a1c11a8cc273990729cb9d717039bac7113eb846620b1342b18f0fb45082f 008-rsvg-fix.patch
+3a6a7530ec26494514cd6a97172ccb8bbaa04aa1fd357ecb020689be25ed63fa2f6ef482efc459d4cf3254537429cd9302718ea005576e9d7fb66fafc064a97d 009-add-close-button.patch
+489aeb049344a940fd0b48729162ea0817533c788be1dd2875527c44fcdb9f69dfcfa11efd9da706ce9210a3fefd295b4fa91832e1b48754443304fbf51fa457 010-cpu-model-arm.patch
+24cc61c5f3c7b6253e50d4e64d5d5de30fc19ba7dfe0009dbaffec56a3db41a64379308be0b16d043de5ec17adcfb4b4c847c8fa589174a32e46142ed5633adb 011-max-nice-linux.patch
+83d1dea183a49f5c5d2efd6fbc06ba88b39c219ec0cfe0014d95ef0086565995701c40151a4480441ef30f2db7e4ce339d5d29a13f0a6889233e7203916896b1 link-gmodule.patch
+120c20afe40c62ce2e6f257f17feb1794486664ba5baefe1f3568eeb7d77f40648b27aa524620600d36139a74a94a2422b4a89b08332a1286f9319e30df7d467 musl-ni-idn.patch"
diff --git a/community/gnome-system-monitor/gnome-system-monitor.post-install b/community/gnome-system-monitor/gnome-system-monitor.post-install
new file mode 100644
index 0000000000..8c003fa132
--- /dev/null
+++ b/community/gnome-system-monitor/gnome-system-monitor.post-install
@@ -0,0 +1,7 @@
+#!/bin/sh
+
+for i in gnome-system-monitor.schemas; do
+ echo "Installing GConf2 schema $i."
+ GCONF_CONFIG_SOURCE=`/usr/bin/gconftool-2 --get-default-source` \
+ /usr/bin/gconftool-2 --makefile-install-rule /etc/gconf/schemas/$i >/dev/null
+done
diff --git a/community/gnome-system-monitor/gnome-system-monitor.post-upgrade b/community/gnome-system-monitor/gnome-system-monitor.post-upgrade
new file mode 100644
index 0000000000..8c003fa132
--- /dev/null
+++ b/community/gnome-system-monitor/gnome-system-monitor.post-upgrade
@@ -0,0 +1,7 @@
+#!/bin/sh
+
+for i in gnome-system-monitor.schemas; do
+ echo "Installing GConf2 schema $i."
+ GCONF_CONFIG_SOURCE=`/usr/bin/gconftool-2 --get-default-source` \
+ /usr/bin/gconftool-2 --makefile-install-rule /etc/gconf/schemas/$i >/dev/null
+done
diff --git a/community/gnome-system-monitor/gnome-system-monitor.pre-deinstall b/community/gnome-system-monitor/gnome-system-monitor.pre-deinstall
new file mode 100644
index 0000000000..92d7db79c6
--- /dev/null
+++ b/community/gnome-system-monitor/gnome-system-monitor.pre-deinstall
@@ -0,0 +1,7 @@
+#!/bin/sh
+
+for i in gnome-system-monitor.schemas; do
+ echo "Uninstalling GConf2 schema $i."
+ GCONF_CONFIG_SOURCE=`/usr/bin/gconftool-2 --get-default-source` \
+ /usr/bin/gconftool-2 --makefile-uninstall-rule /etc/gconf/schemas/$i >/dev/null
+done
diff --git a/community/gnome-system-monitor/link-gmodule.patch b/community/gnome-system-monitor/link-gmodule.patch
new file mode 100644
index 0000000000..b95c676bd9
--- /dev/null
+++ b/community/gnome-system-monitor/link-gmodule.patch
@@ -0,0 +1,13 @@
+diff --git a/src/Makefile.in b/src/Makefile.in
+index b2a81e8..48d171e 100644
+--- a/src/Makefile.in
++++ b/src/Makefile.in
+@@ -299,7 +299,7 @@ gnome_system_monitor_SOURCES = \
+ e_date.c e_date.h \
+ gsm_color_button.c gsm_color_button.h
+
+-gnome_system_monitor_LDADD = @PROCMAN_LIBS@ libbacon.la
++gnome_system_monitor_LDADD = @PROCMAN_LIBS@ libbacon.la -lgmodule-2.0
+ noinst_LTLIBRARIES = libbacon.la
+ libbacon_la_SOURCES = \
+ bacon-message-connection.c \
diff --git a/community/gnome-system-monitor/musl-ni-idn.patch b/community/gnome-system-monitor/musl-ni-idn.patch
new file mode 100644
index 0000000000..07cd489359
--- /dev/null
+++ b/community/gnome-system-monitor/musl-ni-idn.patch
@@ -0,0 +1,13 @@
+--- gnome-system-monitor-2.28.2/src/openfiles.cpp.orig
++++ gnome-system-monitor-2.28.2/src/openfiles.cpp
+@@ -15,6 +15,10 @@
+ #include "util.h"
+ #include "gconf-keys.h"
+
++#ifndef NI_IDN
++#define NI_IDN 0
++#endif
++
+ enum
+ {
+ COL_FD,