summaryrefslogtreecommitdiff
path: root/x11/gnome-applets
diff options
context:
space:
mode:
authorAlexander Nedotsukov <bland@FreeBSD.org>2003-11-17 15:21:39 +0000
committerAlexander Nedotsukov <bland@FreeBSD.org>2003-11-17 15:21:39 +0000
commit9655fe196ad9352b9aaf0434a6eda82b45761eb6 (patch)
tree1b420e64abdf4ddf176b82f8a98f738b9cf52637 /x11/gnome-applets
parentPut a comment warning about USE_AUTOHEADER and USE_AUTOCONF (diff)
Network load indicator from multiload applet now works on FreeBSD.
Notes
Notes: svn path=/head/; revision=94181
Diffstat (limited to 'x11/gnome-applets')
-rw-r--r--x11/gnome-applets/Makefile2
-rw-r--r--x11/gnome-applets/files/patch-multiload::linux-proc.c84
2 files changed, 85 insertions, 1 deletions
diff --git a/x11/gnome-applets/Makefile b/x11/gnome-applets/Makefile
index b436f54f4e75..88f9750d2929 100644
--- a/x11/gnome-applets/Makefile
+++ b/x11/gnome-applets/Makefile
@@ -7,7 +7,7 @@
PORTNAME= gnomeapplets2
PORTVERSION= 2.4.1
-PORTREVISION= 1
+PORTREVISION= 2
CATEGORIES= x11 gnome
MASTER_SITES= ${MASTER_SITE_GNOME}
MASTER_SITE_SUBDIR= sources/gnome-applets/2.4
diff --git a/x11/gnome-applets/files/patch-multiload::linux-proc.c b/x11/gnome-applets/files/patch-multiload::linux-proc.c
new file mode 100644
index 000000000000..9eb916f2b59f
--- /dev/null
+++ b/x11/gnome-applets/files/patch-multiload::linux-proc.c
@@ -0,0 +1,84 @@
+--- multiload/linux-proc.c.orig Thu Jul 10 04:26:58 2003
++++ multiload/linux-proc.c Mon Nov 17 23:54:38 2003
+@@ -5,12 +5,17 @@
+ #include <fcntl.h>
+ #include <unistd.h>
+ #include <assert.h>
++#ifdef __FreeBSD__
++#include <sys/socket.h>
++#include <net/if.h>
++#endif
+
+ #include <glibtop.h>
+ #include <glibtop/cpu.h>
+ #include <glibtop/mem.h>
+ #include <glibtop/swap.h>
+ #include <glibtop/loadavg.h>
++#include <glibtop/netload.h>
+
+ #include "linux-proc.h"
+
+@@ -33,6 +38,10 @@
+ static unsigned needed_loadavg_flags =
+ (1 << GLIBTOP_LOADAVG_LOADAVG);
+
++static unsigned needed_netload_flags =
++(1 << GLIBTOP_NETLOAD_IF_FLAGS) +
++(1 << GLIBTOP_NETLOAD_BYTES_TOTAL);
++
+ void
+ GetLoad (int Maximum, int data [4], LoadGraph *g)
+ {
+@@ -236,6 +245,44 @@
+ int delta[COUNT_TYPES], i;
+ static int ticks = 0;
+ static gulong past[COUNT_TYPES] = {0};
++#ifdef __FreeBSD__
++ struct if_nameindex *ifindex, *ifptr;
++ static int max = 500;
++
++ ifindex = if_nameindex();
++ if (!ifindex)
++ return;
++
++ memset(present, 0, sizeof (present));
++
++ for (ifptr = ifindex; ifptr->if_index && ifptr->if_name; ifptr++)
++ {
++ int index;
++ glibtop_netload netload;
++
++ glibtop_get_netload(&netload, ifptr->if_name);
++ if (!netload.flags)
++ continue;
++
++ assert ((netload.flags & needed_netload_flags) == needed_netload_flags);
++
++ if (!(netload.if_flags & (1L << GLIBTOP_IF_FLAGS_UP)))
++ continue;
++ if (netload.if_flags & (1L << GLIBTOP_IF_FLAGS_LOOPBACK))
++ continue;
++
++ if (netload.if_flags & (1L << GLIBTOP_IF_FLAGS_POINTOPOINT)) {
++ index = strncmp(ifptr->if_name, "sl", 2) ? PPP_COUNT : SLIP_COUNT;
++ } else {
++ index = ETH_COUNT;
++ }
++
++ present[index] += netload.bytes_total;
++ }
++
++ if_freenameindex(ifindex);
++
++#else
+ static char *netdevfmt = NULL;
+ char *cp, buffer[256];
+ FILE *fp;
+@@ -317,6 +364,7 @@
+ }
+
+ fclose(fp);
++#endif
+
+ for (i = 0; i < 5; i++)
+ data[i] = 0;