summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorskrll <skrll@pkgsrc.org>2002-08-21 15:33:05 +0000
committerskrll <skrll@pkgsrc.org>2002-08-21 15:33:05 +0000
commit6a94614e6697ed2614f4501699c62edb4b52becc (patch)
tree235b9ca290ee4978cda987c8877a1855a27ea4a2
parent2207f7e23500691ce5f9d1996668496c2f24eab9 (diff)
downloadpkgsrc-6a94614e6697ed2614f4501699c62edb4b52becc.tar.gz
Apply the fixes provided in pkg/17912 and pkg/17981 so that ksysguardd
can show something useful. Both PRs are from Hume Smith <hclsmith at yahoo dot ca> PKGREVISION++
-rw-r--r--x11/kdebase3/Makefile4
-rw-r--r--x11/kdebase3/distinfo6
-rw-r--r--x11/kdebase3/patches/patch-dd109
-rw-r--r--x11/kdebase3/patches/patch-df570
4 files changed, 573 insertions, 116 deletions
diff --git a/x11/kdebase3/Makefile b/x11/kdebase3/Makefile
index d34fc0fda17..36dccf6331a 100644
--- a/x11/kdebase3/Makefile
+++ b/x11/kdebase3/Makefile
@@ -1,7 +1,7 @@
-# $NetBSD: Makefile,v 1.4 2002/08/20 11:48:23 skrll Exp $
+# $NetBSD: Makefile,v 1.5 2002/08/21 15:33:05 skrll Exp $
DISTNAME= kdebase-3.0.2
-PKGREVISION= 1
+PKGREVISION= 2
CATEGORIES= x11
COMMENT= Base modules for the KDE 3 integrated X11 desktop
diff --git a/x11/kdebase3/distinfo b/x11/kdebase3/distinfo
index c8043781c98..48c6d2be375 100644
--- a/x11/kdebase3/distinfo
+++ b/x11/kdebase3/distinfo
@@ -1,4 +1,4 @@
-$NetBSD: distinfo,v 1.4 2002/08/20 11:48:24 skrll Exp $
+$NetBSD: distinfo,v 1.5 2002/08/21 15:33:05 skrll Exp $
SHA1 (kdebase-3.0.2.tar.bz2) = 763af0ddce718789fae3dfe2b67036dbc2d01a02
Size (kdebase-3.0.2.tar.bz2) = 13115043 bytes
@@ -87,9 +87,9 @@ SHA1 (patch-cz) = 54f8fe86f485a05bc568d3219a3aa2f1db804792
SHA1 (patch-da) = ad54da1bc81cfd6cecebaa57f5a0c0a56d6d589f
SHA1 (patch-db) = 9af64d1118aa30d99202430efc2921c731ae4a81
SHA1 (patch-dc) = ae7d541d91bd466142984b3680cc1e40834f528d
-SHA1 (patch-dd) = 16248be0933c5d48c276d397e57eee959d2143b2
+SHA1 (patch-dd) = 2e9da1069c86ccafd19dbd0ed2b4594c5a4e2f71
SHA1 (patch-de) = 1fbea1abe5a8aefc0eacdc94d4ff60d26fb3c02a
-SHA1 (patch-df) = 8c2ac2dda76839be08c4ed8667cd50b7a3cd4c2b
+SHA1 (patch-df) = 21055681477de84f526af1a552f39bb433627089
SHA1 (patch-dg) = 2a0e3e14049665549a793cf0f785fc55cc1c7d5d
SHA1 (patch-dh) = b84568ed97b14b16bbfdbc73dcb91b920242ad1b
SHA1 (patch-di) = c6044dc47bde5eee686163ca2f3e90d016dacd59
diff --git a/x11/kdebase3/patches/patch-dd b/x11/kdebase3/patches/patch-dd
index 1771716e172..180a425df61 100644
--- a/x11/kdebase3/patches/patch-dd
+++ b/x11/kdebase3/patches/patch-dd
@@ -1,7 +1,7 @@
-$NetBSD: patch-dd,v 1.1.1.1 2002/05/31 13:19:18 skrll Exp $
+$NetBSD: patch-dd,v 1.2 2002/08/21 15:33:05 skrll Exp $
--- ksysguard/ksysguardd/FreeBSD/Memory.c.orig Fri Sep 14 22:11:20 2001
-+++ ksysguard/ksysguardd/FreeBSD/Memory.c
++++ ksysguard/ksysguardd/FreeBSD/Memory.c Tue Aug 20 14:20:49 2002
@@ -32,7 +32,12 @@
#include <sys/types.h>
#include <sys/vmmeter.h>
@@ -15,68 +15,57 @@ $NetBSD: patch-dd,v 1.1.1.1 2002/05/31 13:19:18 skrll Exp $
#include "Command.h"
#include "Memory.h"
-@@ -82,15 +87,25 @@
- struct vmtotal p;
- FILE *file;
- char buf[256];
-+ int rc;
-+#ifndef __NetBSD__
- struct kvm_swap kswap[16];
- int i, swap_count, hlen, pagesize = getpagesize();
- long blocksize;
-+#endif
-
- len = sizeof (Total);
-+#ifdef __NetBSD__
-+ mib[0] = CTL_HW;
-+ mib[1] = HW_PHYSMEM;
-+ sysctl(mib, sizeof(mib), &Total, &len, NULL, 0);
-+#else
- sysctlbyname("hw.physmem", &Total, &len, NULL, 0);
-+#endif
- Total /= 1024;
-
- /* Borrowed from pstat */
-+#ifndef __NetBSD__
- swap_count = kvm_getswapinfo(kd, kswap, 16, SWIF_DEV_PREFIX);
- getbsize(&hlen, &blocksize);
-
-@@ -101,24 +116,42 @@
- SUsed = CONVERT(kswap[0].ksw_used);
- SFree = CONVERT(kswap[0].ksw_total - kswap[0].ksw_used);
- }
-+#endif
-
-+#ifdef __NetBSD__
-+ /* NetBSD doesn't know about vfs.bufspace */
-+ Buffers = -1;
-+#else
- len = sizeof (Buffers);
- if ((sysctlbyname("vfs.bufspace", &Buffers, &len, NULL, 0) == -1) || !len)
- Buffers = 0; /* Doesn't work under FreeBSD v2.2.x */
-+#endif
- Buffers /= 1024;
-
-
+@@ -77,6 +82,49 @@ exitMemory(void)
+ int
+ updateMemory(void)
+ {
+#ifdef __NetBSD__
++#define ARRLEN(X) (sizeof(X)/sizeof(X[0]))
++ long pagesize; /* using a long promotes the arithmetic */
++ size_t len;
++
++ { static int mib[]={ CTL_HW, HW_PHYSMEM };
++
++ len = sizeof(Total);
++ sysctl(mib, ARRLEN(mib), &Total, &len, NULL, 0);
++ Total >>= 10;
++ }
++
++ { struct uvmexp x;
++ static int mib[] = { CTL_VM, VM_UVMEXP };
++
++ len = sizeof(x);
++ STotal = SUsed = SFree = -1;
++ pagesize = 1;
++ if (-1 < sysctl(mib, ARRLEN(mib), &x, &len, NULL, 0)) {
++ pagesize = x.pagesize;
++ STotal = (pagesize*x.swpages) >> 10;
++ SUsed = (pagesize*x.swpginuse) >> 10;
++ SFree = STotal - SUsed;
++ }
++ }
++
++ /* can't find NetBSD filesystem buffer info */
++ Buffers = -1;
++
+ /* NetBSD doesn't know about vm.stats */
+ Cached = -1;
++
++ { static int mib[]={ CTL_VM, VM_METER };
++ struct vmtotal x;
++
++ len = sizeof(x);
++ MFree = Used = -1;
++ if (sysctl(mib, ARRLEN(mib), &x, &len, NULL, 0) > -1) {
++ MFree = (x.t_free * pagesize) >> 10;
++ Used = (x.t_rm * pagesize) >> 10;
++ }
++ }
+#else
- len = sizeof (Cached);
- if ((sysctlbyname("vm.stats.vm.v_cache_count", &Cached, &len, NULL, 0) == -1) || !len)
- Cached = 0; /* Doesn't work under FreeBSD v2.2.x */
-+#endif
- Cached *= getpagesize() / 1024;
-
-
-+#ifdef __NetBSD__
-+ /* No idea where to get them right now.
-+ * I don't want to start kmem-digging... */
-+ MFree = -1;
-+ Used = -1;
-+#else
- /* initializes the pointer to the vmmeter struct */
- len = sizeof (p);
+ int mib[2];
+ size_t len;
+ struct vmtotal p;
+@@ -119,6 +167,7 @@ updateMemory(void)
sysctlbyname("vm.vmmeter", &p, &len, NULL, 0);
MFree = p.t_free * getpagesize() / 1024;
Used = p.t_arm * getpagesize() / 1024 + Buffers + Cached;
diff --git a/x11/kdebase3/patches/patch-df b/x11/kdebase3/patches/patch-df
index 4eaab5c7b82..b7086d8d4b8 100644
--- a/x11/kdebase3/patches/patch-df
+++ b/x11/kdebase3/patches/patch-df
@@ -1,69 +1,537 @@
-$NetBSD: patch-df,v 1.2 2002/08/20 11:48:25 skrll Exp $
+$NetBSD: patch-df,v 1.3 2002/08/21 15:33:06 skrll Exp $
--- ksysguard/ksysguardd/FreeBSD/netdev.c.orig Tue Sep 18 15:03:53 2001
-+++ ksysguard/ksysguardd/FreeBSD/netdev.c
-@@ -20,4 +20,11 @@
- */
-
-+#if defined(__NetBSD__)
-+#include <sys/types.h>
-+#include <sys/socket.h>
++++ ksysguard/ksysguardd/FreeBSD/netdev.c Tue Aug 20 13:51:32 2002
+@@ -1,319 +1,263 @@
+-/*
+- KSysGuard, the KDE System Guard
+-
+- Copyright (c) 2001 Tobias Koenig <tokoe82@yahoo.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., 675 Mass Ave, Cambridge, MA 02139, USA.
+-
+- $Id: patch-df,v 1.3 2002/08/21 15:33:06 skrll Exp $
+-*/
+-
+-#include <fcntl.h>
++#include <sys/types.h> /* for sys/socket.h, ifaddrs.h */
+#include <ifaddrs.h>
-+#include <net/if.h>
-+#include <string.h>
-+#else
- #include <fcntl.h>
#include <sys/socket.h>
-@@ -30,4 +37,5 @@
- #include <sys/types.h>
- #include <unistd.h>
-+#endif
++#include <sys/param.h> /* for sys/sysctl.h */
++#include <sys/sysctl.h>
++#include <net/route.h>
+ #include <net/if.h>
+-#include <net/if_mib.h>
+-#include <stdio.h>
++#include <net/if_dl.h>
++#include <stdlib.h>
+ #include <string.h>
+-#include <sys/sysctl.h>
+-#include <sys/time.h>
+-#include <sys/types.h>
+-#include <unistd.h>
+-
+
+ #include "Command.h"
+ #include "ksysguardd.h"
+ #include "netdev.h"
+-
++#define I_bytes 0
++#define I_packs 1
++#define I_errs 2
++#define I_mcasts 3
++#define I_lost 4
+ typedef struct {
+ char name[32];
+- u_long recBytes;
+- u_long recPacks;
+- u_long recErrs;
+- u_long recDrop;
+- u_long recMulticast;
+- u_long sentBytes;
+- u_long sentPacks;
+- u_long sentErrs;
+- u_long sentMulticast;
+- u_long sentColls;
++ u_long recv[5],Drecv[5],sent[5],Dsent[5];
+ } NetDevInfo;
+
++#define LEN(X) (sizeof(X)/sizeof(X[0]))
++
+ #define MAXNETDEVS 64
+-static NetDevInfo NetDevs[MAXNETDEVS];
++static NetDevInfo NetDevs[MAXNETDEVS], newval[MAXNETDEVS];
+ static int NetDevCnt = 0;
-@@ -84,4 +92,17 @@ int numActivIfaces(void)
- {
- int counter = 0;
+-char **parseCommand(const char *cmd)
+-{
+- char tmp_cmd[1024];
+- char *begin;
+- static char sensor[100];
+- static char interface[100];
+- static char* retval[2];
+-
+- strncpy(tmp_cmd, cmd, 1024);
+-
+- begin = rindex(tmp_cmd, '/');
+- *begin = '\0';
+- begin++;
+- strcpy(sensor, begin);
+- retval[1] = sensor;
+-
+- begin = rindex(tmp_cmd, '/');
+- *begin = '\0';
+- begin = rindex(tmp_cmd, '/');
+- begin++;
+- strcpy(interface, begin);
+- retval[0] = interface;
+
+- return retval;
+-}
+-
+-int numActivIfaces(void)
+-{
+- int counter = 0;
+- int name[6];
+- int num_iface, i;
++/* Read the system's traffic registers.
++ * Merely count the IFs if countp nonzero.
++ * Returns count of IFs read, or -1; the data are written into newval.
++ * Based on getifaddrs source; getifaddrs itself seems to
++ * compile incorrectly, omitting the traffic data. (It also
++ * does things this doesn't need, thus this is slightly more efficient.)
++ */
++static int readSys(int countp) {
+ size_t len;
+- struct ifmibdata ifmd;
+-
+- len = sizeof(num_iface);
+- sysctlbyname("net.link.generic.system.ifcount", &num_iface, &len, NULL, 0);
+-
+- for (i = 1; i < num_iface + 1; i++) {
+- name[0] = CTL_NET;
+- name[1] = PF_LINK;
+- name[2] = NETLINK_GENERIC;
+- name[3] = IFMIB_IFDATA;
+- name[4] = i;
+- name[5] = IFDATA_GENERAL;
+-
+- len = sizeof(ifmd);
+- sysctl(name, 6, &ifmd, &len, NULL, 0);
+- if (ifmd.ifmd_flags & IFF_UP)
+- counter++;
++ char *bfr, *ptr;
++ struct rt_msghdr *rtm;
++ NetDevInfo *nv;
++ static int mib[] = {
++ /* see sysctl(3): */
++ CTL_NET,
++ PF_ROUTE,
++ 0, /* `currently always 0' */
++ 0, /* `may be set to 0 to select all address families' */
++ NET_RT_IFLIST,
++ 0 /* ignored but six levels are needed */
++ };
++
++ if (-1==sysctl(mib, LEN(mib), NULL, &len, NULL, 0))
++ return -1;
++ if (!(bfr = malloc(len)))
++ return -1;
++ if (-1==sysctl(mib, LEN(mib), bfr, &len, NULL, 0)) {
++ free(bfr);
++ return -1;
+ }
++ nv = newval;
++ for (ptr=bfr; ptr<bfr+len; ptr+=rtm->rtm_msglen) {
++ struct if_msghdr *ifm;
+
-+#if defined(__NetBSD__)
-+ struct ifaddrs *ifap, *ifa;
++ rtm = (void*)ptr; /* chg ptr type to router msg */
++ if (rtm->rtm_version != RTM_VERSION) continue;
++ if (rtm->rtm_type != RTM_IFINFO) continue;
++ ifm = (void*)rtm; /* chg ptr type to interface msg */
++ if (!(ifm->ifm_flags & IFF_UP)) continue;
+
-+ if (getifaddrs(&ifap) != 0)
-+ return 0;
++ if (!countp) {
++ /* a sdl is concat'd to the if msg */
++ struct sockaddr_dl *sdl = (void*)(ifm+1);
+
-+ for (ifa = ifap; ifa; ifa=ifa->ifa_next) {
-+ if (ifa->ifa_flags & IFF_UP)
-+ counter++;
++ /* copy and terminate the name */
++ /*fixme: check for overruns */
++ memcpy(nv->name, sdl->sdl_data, sdl->sdl_nlen);
++ nv->name[sdl->sdl_nlen] = 0;
++
++ /* copy the data */
++ nv->recv[I_bytes] = ifm->ifm_data.ifi_ibytes;
++ nv->recv[I_packs] = ifm->ifm_data.ifi_ipackets;
++ nv->recv[I_errs] = ifm->ifm_data.ifi_ierrors;
++ nv->recv[I_mcasts] = ifm->ifm_data.ifi_imcasts;
++ nv->recv[I_lost] = ifm->ifm_data.ifi_iqdrops;
++ nv->sent[I_bytes] = ifm->ifm_data.ifi_obytes;
++ nv->sent[I_packs] = ifm->ifm_data.ifi_opackets;
++ nv->sent[I_errs] = ifm->ifm_data.ifi_oerrors;
++ nv->sent[I_mcasts] = ifm->ifm_data.ifi_omcasts;
++ nv->sent[I_lost] = ifm->ifm_data.ifi_collisions;
++ }
+
+- return counter;
++ /*fixme: guard against buffer overrun */
++ nv++;
+ }
-+ freeifaddrs(ifap);
-+#else
- int name[6];
- int num_iface, i;
-@@ -105,4 +126,5 @@ int numActivIfaces(void)
- counter++;
- }
-+#endif
++ free(bfr);
++ return nv-newval;
+ }
+
++
++
++
+ /* ------------------------------ public part --------------------------- */
- return counter;
-@@ -175,4 +197,16 @@ void exitNetDev(void)
- void updateNetDev(void)
- {
-+#if defined(__NetBSD__)
-+ struct ifaddrs *ifap, *ifa;
+-void initNetDev(void)
+-{
+- int i;
+- char monitor[1024];
++static void prVal(const char*, int);
++void printNetDevRecv(const char *cmd) { prVal(cmd,0); }
++void printNetDevSent(const char *cmd) { prVal(cmd,1); }
++
++static void prInfo(const char*, int);
++void printNetDevRecvInfo(const char *cmd) { prInfo(cmd,0); }
++void printNetDevSentInfo(const char *cmd) { prInfo(cmd,1); }
++
++static struct {
++ char *label;
++ cmdExecutor read, inform;
++ struct {
++ char *label, *info;
++ int index;
++ } op[5];
++} opTable[] = {
++ {"receiver",
++ printNetDevRecv, printNetDevRecvInfo,
++ {{"data", "Received Data\t0\t0\tB/s\n", I_bytes},
++ {"packets", "Received Packets\t0\t0\tHz\n", I_packs},
++ {"errors", "Receiver Errors\t0\t0\tHz\n", I_errs},
++ {"multicast", "Received Multicast Packets\t0\t0\tHz\n", I_mcasts},
++ {"drops", "Receiver Drops\t0\t0\tHz\n", I_lost}}},
++ {"transmitter",
++ printNetDevSent, printNetDevSentInfo,
++ {{"data", "Sent Data\t0\t0\tB/s\n", I_bytes},
++ {"packets", "Sent Packets\t0\t0\tHz\n", I_packs},
++ {"errors", "Transmitter Errors\t0\t0\tHz\n", I_errs},
++ {"multicast", "Sent Multicast Packets\t0\t0\tHz\n", I_mcasts},
++ {"collisions", "Transmitter Collisions\t0\t0\tHz\n", I_lost}}}
++};
+
-+ if (getifaddrs(&ifap) != 0)
++
++static void prVal(const char *cmd, int N) {
++ char *p, *q, *r;
++ int i, d;
+
+- updateNetDev();
+-
+- for (i = 0; i < NetDevCnt; i++) {
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/receiver/data", NetDevs[i].name);
+- registerMonitor(monitor, "integer", printNetDevRecBytes, printNetDevRecBytesInfo);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/receiver/packets", NetDevs[i].name);
+- registerMonitor(monitor, "integer", printNetDevRecBytes, printNetDevRecBytesInfo);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/receiver/errors", NetDevs[i].name);
+- registerMonitor(monitor, "integer", printNetDevRecBytes, printNetDevRecBytesInfo);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/receiver/drops", NetDevs[i].name);
+- registerMonitor(monitor, "integer", printNetDevRecBytes, printNetDevRecBytesInfo);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/receiver/multicast", NetDevs[i].name);
+- registerMonitor(monitor, "integer", printNetDevRecBytes, printNetDevRecBytesInfo);
+-
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/transmitter/data", NetDevs[i].name);
+- registerMonitor(monitor, "integer", printNetDevSentBytes, printNetDevSentBytesInfo);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/transmitter/packets", NetDevs[i].name);
+- registerMonitor(monitor, "integer", printNetDevSentBytes, printNetDevSentBytesInfo);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/transmitter/errors", NetDevs[i].name);
+- registerMonitor(monitor, "integer", printNetDevSentBytes, printNetDevSentBytesInfo);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/transmitter/multicast", NetDevs[i].name);
+- registerMonitor(monitor, "integer", printNetDevSentBytes, printNetDevSentBytesInfo);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/transmitter/collisions", NetDevs[i].name);
+- registerMonitor(monitor, "integer", printNetDevSentBytes, printNetDevSentBytesInfo);
+- }
++ if (!(p=rindex(cmd, '/')))
+ return;
++ *p=0;
++ q=rindex(cmd, '/');
++ *q=0;
++ r=rindex(cmd, '/');
++ r++;
++ for (d=NetDevCnt; d--; )
++ if (!strcmp(r, NetDevs[d].name))
++ break;
++ *q=*p='/';
+
-+ for (ifa = ifap; ifa; ifa=ifa->ifa_next) {
-+ if (ifa->ifa_flags & IFF_UP)
-+ ;
-+ }
-+ freeifaddrs(ifap);
-+#else
- int name[6];
- int num_iface, i;
-@@ -209,4 +243,5 @@ void updateNetDev(void)
++ if (-1 == d) return;
++
++ p++;
++ for (i=0; i<LEN(opTable[0].op); i++)
++ if (!strcmp(p, opTable[N].op[i].label))
++ fprintf(CurrentClient, "%lu",
++ /*fixme: ugly and presumptuous */
++ (N?NetDevs[d].Dsent:NetDevs[d].Drecv)[opTable[N].op[i].index]);
++ fprintf(CurrentClient, "\n");
+ }
+
+-void exitNetDev(void)
+-{
++
++static void prInfo(const char *cmd, int N) {
++ char *p, *q;
+ int i;
+- char monitor[1024];
+
+- for (i = 0; i < NetDevCnt; i++) {
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/receiver/data", NetDevs[i].name);
+- removeMonitor(monitor);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/receiver/packets", NetDevs[i].name);
+- removeMonitor(monitor);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/receiver/errors", NetDevs[i].name);
+- removeMonitor(monitor);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/receiver/drops", NetDevs[i].name);
+- removeMonitor(monitor);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/receiver/multicast", NetDevs[i].name);
+- removeMonitor(monitor);
+-
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/transmitter/data", NetDevs[i].name);
+- removeMonitor(monitor);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/transmitter/packets", NetDevs[i].name);
+- removeMonitor(monitor);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/transmitter/errors", NetDevs[i].name);
+- removeMonitor(monitor);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/transmitter/multicast", NetDevs[i].name);
+- removeMonitor(monitor);
+- snprintf(monitor, sizeof(monitor), "network/interfaces/%s/transmitter/collisions", NetDevs[i].name);
+- removeMonitor(monitor);
+- }
+-}
++ if (!(p=rindex(cmd, '/'))) return;
++ p++;
+
+-void updateNetDev(void)
+-{
+- int name[6];
+- int num_iface, i;
+- size_t len;
+- struct ifmibdata ifmd;
++ q = p+strlen(p)-1;
++ if ('?' != *q) return;
++ *q=0;
++
++ for (i=0; i<LEN(opTable[0].op); i++)
++ if (!strcmp(p, opTable[N].op[i].label))
++ fputs(opTable[N].op[i].info, CurrentClient);
+
+- len = sizeof(num_iface);
+- sysctlbyname("net.link.generic.system.ifcount", &num_iface, &len, NULL, 0);
+-
+- NetDevCnt = 0;
+- for (i = 1; i < num_iface + 1; i++) {
+- name[0] = CTL_NET;
+- name[1] = PF_LINK;
+- name[2] = NETLINK_GENERIC;
+- name[3] = IFMIB_IFDATA;
+- name[4] = i;
+- name[5] = IFDATA_GENERAL;
+-
+- len = sizeof(ifmd);
+- sysctl(name, 6, &ifmd, &len, NULL, 0);
+- if (ifmd.ifmd_flags & IFF_UP) {
+- strncpy(NetDevs[NetDevCnt].name, ifmd.ifmd_name, 32);
+- NetDevs[NetDevCnt].recBytes = ifmd.ifmd_data.ifi_ibytes - NetDevs[NetDevCnt].recBytes;
+- NetDevs[NetDevCnt].recPacks = ifmd.ifmd_data.ifi_ipackets - NetDevs[NetDevCnt].recPacks;
+- NetDevs[NetDevCnt].recErrs = ifmd.ifmd_data.ifi_ierrors - NetDevs[NetDevCnt].recErrs;
+- NetDevs[NetDevCnt].recDrop = ifmd.ifmd_data.ifi_iqdrops - NetDevs[NetDevCnt].recDrop;
+- NetDevs[NetDevCnt].recMulticast = ifmd.ifmd_data.ifi_imcasts - NetDevs[NetDevCnt].recMulticast;
+- NetDevs[NetDevCnt].sentBytes = ifmd.ifmd_data.ifi_obytes - NetDevs[NetDevCnt].sentBytes;
+- NetDevs[NetDevCnt].sentPacks = ifmd.ifmd_data.ifi_opackets - NetDevs[NetDevCnt].sentPacks;
+- NetDevs[NetDevCnt].sentErrs = ifmd.ifmd_data.ifi_oerrors - NetDevs[NetDevCnt].sentErrs;
+- NetDevs[NetDevCnt].sentMulticast = ifmd.ifmd_data.ifi_omcasts - NetDevs[NetDevCnt].sentMulticast;
+- NetDevs[NetDevCnt].sentColls = ifmd.ifmd_data.ifi_collisions - NetDevs[NetDevCnt].sentColls;
+- NetDevCnt++;
+- }
+- }
++ *q='?';
+ }
+
+-void checkNetDev(void)
+-{
+- if (numActivIfaces() != NetDevCnt) {
+- /* interface has been added or removed
+- so we do a reset */
+- exitNetDev();
+- initNetDev();
+- }
+-}
+
+-void printNetDevRecBytes(const char *cmd)
+-{
++static void NDreg(int setp) {
+ int i;
+- char **retval;
+-
+- retval = parseCommand(cmd);
+-
+- if (retval[0] == NULL || retval[1] == NULL)
+- return;
+
+- for (i = 0; i < NetDevCnt; i++) {
+- if (!strcmp(NetDevs[i].name, retval[0])) {
+- if (!strncmp(retval[1], "data", 4))
+- fprintf(CurrentClient, "%lu", NetDevs[i].recBytes);
+- if (!strncmp(retval[1], "packets", 7))
+- fprintf(CurrentClient, "%lu", NetDevs[i].recPacks);
+- if (!strncmp(retval[1], "errors", 6))
+- fprintf(CurrentClient, "%lu", NetDevs[i].recErrs);
+- if (!strncmp(retval[1], "drops", 5))
+- fprintf(CurrentClient, "%lu", NetDevs[i].recDrop);
+- if (!strncmp(retval[1], "multicast", 9))
+- fprintf(CurrentClient, "%lu", NetDevs[i].recMulticast);
++ for (i = 0; i<NetDevCnt; i++) {
++ int j;
++
++ for (j=0; j<LEN(opTable); j++) {
++ int k;
++
++ for (k=0; k<LEN(opTable[0].op); k++) {
++ char buffer[1024];
++
++ snprintf(buffer, sizeof(buffer),
++ "network/interfaces/%s/%s/%s",
++ NetDevs[i].name,
++ opTable[j].label,
++ opTable[j].op[k].label);
++
++ /* printf("%d %d %d %s\n",i,j,k,buffer); */
++
++ if (setp)
++ registerMonitor(buffer,
++ "integer",
++ opTable[j].read,
++ opTable[j].inform);
++ else
++ removeMonitor(buffer);
++ }
}
}
-+#endif
+-
+- fprintf(CurrentClient, "\n");
}
+-void printNetDevRecBytesInfo(const char *cmd)
+-{
+- char **retval;
+-
+- retval = parseCommand(cmd);
+-
+- if (retval[1] == NULL)
+- return;
++void initNetDev(void) {
++ int i;
++ updateNetDev();
++ for (i=LEN(NetDevs); i--;)
++ strcpy(NetDevs[i].name, newval[i].name);
++ NDreg(!0);
++}
+
+- if (!strncmp(retval[1], "data", 4))
+- fprintf(CurrentClient, "Received Data\t0\t0\tkBytes/s\n");
+- if (!strncmp(retval[1], "packets", 7))
+- fprintf(CurrentClient, "Received Packets\t0\t0\t1/s\n");
+- if (!strncmp(retval[1], "errors", 6))
+- fprintf(CurrentClient, "Receiver Errors\t0\t0\t1/s\n");
+- if (!strncmp(retval[1], "drops", 5))
+- fprintf(CurrentClient, "Receiver Drops\t0\t0\t1/s\n");
+- if (!strncmp(retval[1], "multicast", 9))
+- fprintf(CurrentClient, "Received Multicast Packets\t0\t0\t1/s\n");
++void exitNetDev(void) {
++ NDreg(0);
+ }
+
+-void printNetDevSentBytes(const char *cmd)
+-{
+- int i;
+- char **retval;
+-
+- retval = parseCommand(cmd);
+-
+- if (retval[0] == NULL || retval[1] == NULL)
++void updateNetDev(void) {
++ NetDevInfo *p, *q;
++ int n;
++
++ if (-1==(n = readSys(0)))
+ return;
+
+- for (i = 0; i < NetDevCnt; i++) {
+- if (!strcmp(NetDevs[i].name, retval[0])) {
+- if (!strncmp(retval[1], "data", 4))
+- fprintf(CurrentClient, "%lu", NetDevs[i].sentBytes);
+- if (!strncmp(retval[1], "packets", 7))
+- fprintf(CurrentClient, "%lu", NetDevs[i].sentPacks);
+- if (!strncmp(retval[1], "errors", 6))
+- fprintf(CurrentClient, "%lu", NetDevs[i].sentErrs);
+- if (!strncmp(retval[1], "multicast", 9))
+- fprintf(CurrentClient, "%lu", NetDevs[i].sentMulticast);
+- if (!strncmp(retval[1], "collisions", 10))
+- fprintf(CurrentClient, "%lu", NetDevs[i].sentColls);
++ NetDevCnt = n;
++ /*fixme: assumes the interfaces are in the same order each time */
++ for (p=NetDevs, q=newval; n--; p++, q++) {
++ int i;
++ /* calculate deltas */
++ for (i=0; i<5; i++) {
++ p->Drecv[i] = q->recv[i]-p->recv[i];
++ p->recv[i] = q->recv[i];
++ p->Dsent[i] = q->sent[i]-p->sent[i];
++ p->sent[i] = q->sent[i];
+ }
+ }
+-
+- fprintf(CurrentClient, "\n");
+ }
+
+-void printNetDevSentBytesInfo(const char *cmd)
+-{
+- char **retval;
+-
+- retval = parseCommand(cmd);
+-
+- if (retval[1] == NULL)
+- return;
+
+- if (!strncmp(retval[1], "data", 4))
+- fprintf(CurrentClient, "Sent Data\t0\t0\tkBytes/s\n");
+- if (!strncmp(retval[1], "packets", 7))
+- fprintf(CurrentClient, "Sent Packets\t0\t0\t1/s\n");
+- if (!strncmp(retval[1], "errors", 6))
+- fprintf(CurrentClient, "Transmitter Errors\t0\t0\t1/s\n");
+- if (!strncmp(retval[1], "multicast", 9))
+- fprintf(CurrentClient, "Sent Multicast Packets\t0\t0\t1/s\n");
+- if (!strncmp(retval[1], "collisions", 10))
+- fprintf(CurrentClient, "Transmitter Collisions\t0\t0\t1/s\n");
++void checkNetDev(void) {
++ if (readSys(!0) != NetDevCnt) {
++ /* interface has been added or removed
++ so we do a reset */
++ exitNetDev();
++ initNetDev();
++ }
+ }
++
++
++/* eof */