Compare commits
55 Commits
table_0_01
...
fileutils_
Author | SHA1 | Date | |
---|---|---|---|
|
1d7491be0d | ||
|
15cc0113a9 | ||
|
9532dadc2e | ||
|
94715ef718 | ||
|
44bb75cf6e | ||
|
4d2072ce65 | ||
|
eb36f97c50 | ||
|
a76522a990 | ||
|
71187a5e51 | ||
|
b54a5d2dfd | ||
|
134ec106b3 | ||
|
1b90ed4fcc | ||
|
3fcc477b25 | ||
|
81c75477f4 | ||
|
8b025ff2c2 | ||
|
2de9ea5c7d | ||
|
d9e6288b7a | ||
|
8d78559597 | ||
|
2a281d0a53 | ||
|
28dfff5752 | ||
|
7d0d3db11c | ||
|
63c475d400 | ||
|
d334a77447 | ||
|
1b7d7976b1 | ||
|
d7770a12c6 | ||
|
5fef6560bf | ||
|
75605116d0 | ||
|
35943ea8fc | ||
|
e166f54328 | ||
|
c1cc35ac17 | ||
|
0acb497216 | ||
|
58707dac42 | ||
|
8f14d30d11 | ||
|
bde0d74282 | ||
|
026e93121e | ||
|
f87722233a | ||
|
03c5a235ef | ||
|
215ab9f17b | ||
|
794a8efaed | ||
|
b56c327ccc | ||
|
8f43551d68 | ||
|
23cccaf87f | ||
|
c75b77affc | ||
|
7ffc53f45e | ||
|
6ea7e47194 | ||
|
6130f0a4f9 | ||
|
44dcb69c41 | ||
|
13148c632f | ||
|
6fd3c113ec | ||
|
9661c4becc | ||
|
c60d1d5449 | ||
|
eedc64096c | ||
|
cf8068049f | ||
|
5e3d6bdf18 | ||
|
aff6786e71 |
135
ChangeLog
135
ChangeLog
@@ -1,3 +1,138 @@
|
|||||||
|
1998-07-03 Martin baulig <martin@home-of-linux.org>
|
||||||
|
|
||||||
|
* macros/gnome-libgtop-sysdeps.m4: No longer use
|
||||||
|
`glibtop_machine.h' for Linux.
|
||||||
|
|
||||||
|
* sysdeps/linux/glibtop_machine.h: Removed.
|
||||||
|
|
||||||
|
* sysdeps/guile/guile.awk: Using `scm_append'
|
||||||
|
instead of `gh_append'.
|
||||||
|
|
||||||
|
* sysdeps/guile/names/guile-names.awk: dito.
|
||||||
|
|
||||||
|
* sysdeps/linux/*.c: Using code from stable branch again.
|
||||||
|
|
||||||
|
* include/glibtop/parameter.h: New file.
|
||||||
|
|
||||||
|
* lib/parameter.c: New file.
|
||||||
|
|
||||||
|
* lib/{open, init}.c: Done some more work on server
|
||||||
|
initialization
|
||||||
|
|
||||||
|
1998-06-21 Martin Baulig <martin@home-of-linux.org>
|
||||||
|
|
||||||
|
* perl/*: Added perl interface.
|
||||||
|
|
||||||
|
* sysdeps/linux/cpu.c: Bug fix.
|
||||||
|
|
||||||
|
* include/glibtop/global.h: Only including guile header files
|
||||||
|
within libgtop.
|
||||||
|
|
||||||
|
* configure.in (LIGBTOP_LIBS): Added `-lgtop'.
|
||||||
|
|
||||||
|
* Makefile.am: Creating `perl/Makefile.PL' from `perl/Makefile.PL.in'
|
||||||
|
and `perl/Libgtop.xs' using `perl/perl.awk'.
|
||||||
|
|
||||||
|
1998-06-18 Martin Baulig <baulig@taurus.uni-trier.de>
|
||||||
|
|
||||||
|
* sysdeps/linux/*.c: Reverted some stuff from 06-07-1998
|
||||||
|
since it was too buggy.
|
||||||
|
|
||||||
|
* glibtop.h (_glibtop): New field `server_port'.
|
||||||
|
|
||||||
|
* lib/xmalloc.c (glibtop_strdup_r): New function.
|
||||||
|
|
||||||
|
* lib/gnuclient.c: Removed.
|
||||||
|
|
||||||
|
* lib/{command, write, read}.c: Changed client <-> server
|
||||||
|
interface to make less system calls.
|
||||||
|
|
||||||
|
* src/daemon/main.c: Changed server side of interface.
|
||||||
|
|
||||||
|
* include/glibtop/command.h (struct _glibtop_response): New
|
||||||
|
structure to return data from the server to the client.
|
||||||
|
|
||||||
|
1998-06-14 Martin Baulig <martin@home-of-linux.org>
|
||||||
|
|
||||||
|
* glibtop.h (struct _glibtop): Added `socket' field.
|
||||||
|
|
||||||
|
* include/glibtop/gnuserv.h: New file. Imported from xemacs 20.3.
|
||||||
|
|
||||||
|
* sysdeps/common/gnuslib.c: New file. Imported from xemacs 20.3
|
||||||
|
|
||||||
|
* lib/gnuclient.c: New file. Imported from xemacs 20.3
|
||||||
|
|
||||||
|
* sysdeps/daemon/gnuserv.c: New file. Imported from xemacs 20.3
|
||||||
|
|
||||||
|
* sysdeps/daemon: New directory.
|
||||||
|
|
||||||
|
* configure.in (LIBGTOP_LIBS, LIBGTOP_GUILE_LIBS): Added
|
||||||
|
`$X_LIBS -lXau' when we have xauth.
|
||||||
|
|
||||||
|
* acconfig.h (HAVE_XAUTH): New tag.
|
||||||
|
|
||||||
|
* configure.in: Added check for `HAVE_XAUTH'.
|
||||||
|
|
||||||
|
* sysdeps/common/error.c (glibtop_warn_r): New function -
|
||||||
|
same as `glibtop_error_r', but doesn't call `exit'.
|
||||||
|
(glibtop_error_io_r, glibtop_warn_io_r): New functions,
|
||||||
|
display `strerror (errno)' together with message.
|
||||||
|
|
||||||
|
* include/glibtop/global.h (TIME_WITH_SYS_TIME): including
|
||||||
|
correct headers; (HAVE_UNISTD_H): Added conditional.
|
||||||
|
Added `#include <sys/param.h>' and `#include <sys/stat.h>'.
|
||||||
|
|
||||||
|
* acconfig.h (HAVE_LINUX_TABLE): New tag.
|
||||||
|
|
||||||
|
* lib/lib.awk: New file.
|
||||||
|
Creates `lib.c' depending upon `features.def'.
|
||||||
|
|
||||||
|
* lib/<feature>.c: Removed.
|
||||||
|
|
||||||
|
* sysdeps/guile/guile.awk: New file.
|
||||||
|
Creates `guile.c' depending upon `features.def'.
|
||||||
|
|
||||||
|
* sysdeps/guile/*.c: Removed.
|
||||||
|
|
||||||
|
1998-06-13 Martin Baulig <martin@home-of-linux.org>
|
||||||
|
|
||||||
|
* features.def: List of features for `guile-names.awk'.
|
||||||
|
|
||||||
|
* sysdeps/guile/names/guile-names.awk: New file.
|
||||||
|
Creates `guile-names.c' depending upon `features.def'.
|
||||||
|
|
||||||
|
* sysdeps/guile/names/*.c: Removed.
|
||||||
|
|
||||||
|
* kernel: New directory. Contains some kernel code to
|
||||||
|
implement a new system call table () to fetch information
|
||||||
|
directly from the Linux kernel.
|
||||||
|
|
||||||
|
* sysdeps/kernel: New directory. Uses the table () function
|
||||||
|
from the `kernel' directory to fetch things directly from
|
||||||
|
the Linux kernel.
|
||||||
|
|
||||||
|
* sysdeps/Makefile.am (DIST_SUBDIRS): Added `kernel'.
|
||||||
|
|
||||||
|
* configure.in: Removed `build_CC' again.
|
||||||
|
|
||||||
|
1998-06-12 Martin Baulig <baulig@taurus.uni-trier.de>
|
||||||
|
|
||||||
|
* include/glibtop/sysdeps.h (glibtop_types_sysdeps):
|
||||||
|
Forgot to change declaration on Jun 6.
|
||||||
|
|
||||||
|
* sysdeps/names/sysdeps.c (glibtop_types_sysdeps):
|
||||||
|
Using numeric constants from `types.h' instead of string
|
||||||
|
constants; forgot to change this on Jun 6. Added information
|
||||||
|
about new `features' field of `_glibtop_sysdeps'.
|
||||||
|
|
||||||
|
* sysdeps/guile/names/*.c (glibtop_guile_types_*):
|
||||||
|
Using `gh_ulong2scm' instead of `gh_str02scm'.
|
||||||
|
|
||||||
|
* sysdeps/guile/proclist.c: Replaced call to
|
||||||
|
`gh_append2 ()' with `gh_append ()'.
|
||||||
|
|
||||||
|
* sysdeps/guile/names/*.c: dito.
|
||||||
|
|
||||||
1998-06-08 Martin Baulig <martin@home-of-linux.org>
|
1998-06-08 Martin Baulig <martin@home-of-linux.org>
|
||||||
|
|
||||||
* support: Added again.
|
* support: Added again.
|
||||||
|
27
Makefile.am
27
Makefile.am
@@ -22,6 +22,9 @@ release:
|
|||||||
confexecdir=$(libdir)
|
confexecdir=$(libdir)
|
||||||
confexec_DATA = $(top_builddir)/libgtopConf.sh
|
confexec_DATA = $(top_builddir)/libgtopConf.sh
|
||||||
|
|
||||||
|
noinst_DATA = $(top_builddir)/perl/Makefile.PL \
|
||||||
|
$(top_builddir)/perl/Libgtop.xs
|
||||||
|
|
||||||
## to automatically rebuild aclocal.m4 if any of the macros in
|
## to automatically rebuild aclocal.m4 if any of the macros in
|
||||||
## `macros/' change
|
## `macros/' change
|
||||||
@MAINT@include macros/macros.dep
|
@MAINT@include macros/macros.dep
|
||||||
@@ -51,3 +54,27 @@ libgtopConf.sh: libgtopConf.sh.in Makefile
|
|||||||
-e 's,\@libgtop_want_examples\@,$(libgtop_want_examples),g' \
|
-e 's,\@libgtop_want_examples\@,$(libgtop_want_examples),g' \
|
||||||
< $(srcdir)/libgtopConf.sh.in > libgtopConf.tmp \
|
< $(srcdir)/libgtopConf.sh.in > libgtopConf.tmp \
|
||||||
&& mv libgtopConf.tmp libgtopConf.sh
|
&& mv libgtopConf.tmp libgtopConf.sh
|
||||||
|
|
||||||
|
perl/Makefile.PL: perl/Makefile.PL.in Makefile
|
||||||
|
## Use sed and then mv to avoid problems if the user interrupts.
|
||||||
|
sed -e 's,\@LIBGTOP_LIBDIR\@,$(libdir),g' \
|
||||||
|
-e 's,\@LIBGTOP_INCLUDEDIR\@,$(includedir),g' \
|
||||||
|
-e 's,\@LIBGTOP_LIBS\@,$(LIBGTOP_LIBS),g' \
|
||||||
|
-e 's,\@LIBGTOP_INCS\@,$(LIBGTOP_INCS),g' \
|
||||||
|
-e 's,\@LIBGTOP_GUILE_LIBS\@,$(LIBGTOP_GUILE_LIBS),g' \
|
||||||
|
-e 's,\@LIBGTOP_GUILE_INCS\@,$(LIBGTOP_GUILE_INCS),g' \
|
||||||
|
-e 's,\@LIBGTOP_BINDIR\@,$(LIBGTOP_BINDIR),g' \
|
||||||
|
-e 's,\@LIBGTOP_SERVER\@,$(LIBGTOP_SERVER),g' \
|
||||||
|
-e 's,\@libgtop_sysdeps_dir\@,$(libgtop_sysdeps_dir),g' \
|
||||||
|
-e 's,\@libgtop_need_server\@,$(libgtop_need_server),g' \
|
||||||
|
-e 's,\@libgtop_use_machine_h\@,$(libgtop_use_machine_h),g' \
|
||||||
|
-e 's,\@libgtop_guile_found\@,$(libgtop_guile_found),g' \
|
||||||
|
-e 's,\@libgtop_want_names\@,$(libgtop_want_names),g' \
|
||||||
|
-e 's,\@libgtop_want_guile_names\@,$(libgtop_want_guile_names),g' \
|
||||||
|
-e 's,\@libgtop_want_examples\@,$(libgtop_want_examples),g' \
|
||||||
|
< $(srcdir)/perl/Makefile.PL.in > perl/Makefile.tmp \
|
||||||
|
&& mv perl/Makefile.tmp perl/Makefile.PL
|
||||||
|
|
||||||
|
perl/Libgtop.xs: perl/perl.awk $(top_builddir)/config.h $(top_srcdir)/features.def
|
||||||
|
$(AWK) -f $(top_srcdir)/perl/perl.awk < $(top_srcdir)/features.def > perl/lgt-t
|
||||||
|
mv perl/lgt-t perl/Libgtop.xs
|
||||||
|
@@ -33,3 +33,7 @@
|
|||||||
#undef GLIBTOP_EXAMPLES
|
#undef GLIBTOP_EXAMPLES
|
||||||
|
|
||||||
#undef NEED_LIBGTOP
|
#undef NEED_LIBGTOP
|
||||||
|
|
||||||
|
#undef HAVE_LINUX_TABLE
|
||||||
|
|
||||||
|
#undef HAVE_XAUTH
|
||||||
|
51
configure.in
51
configure.in
@@ -6,25 +6,18 @@ AC_INIT(copyright.txt)
|
|||||||
AM_CONFIG_HEADER(config.h)
|
AM_CONFIG_HEADER(config.h)
|
||||||
AC_CANONICAL_SYSTEM
|
AC_CANONICAL_SYSTEM
|
||||||
|
|
||||||
|
AM_INIT_AUTOMAKE(libgtop, 0.01)
|
||||||
|
|
||||||
AM_ACLOCAL_INCLUDE(macros)
|
AM_ACLOCAL_INCLUDE(macros)
|
||||||
|
|
||||||
dnl This is necessary for cross-compiling for programs
|
|
||||||
dnl that need to run on the build host.
|
|
||||||
|
|
||||||
AC_CHECK_PROG(build_CC, gcc, gcc)
|
|
||||||
if test -z "$build_CC" ; then
|
|
||||||
AC_CHECK_PROG(build_CC, cc, cc, , , /usr/ucb/cc)
|
|
||||||
test -z "$build_CC" && \
|
|
||||||
AC_MSG_ERROR([no acceptable cc found in \$PATH])
|
|
||||||
fi
|
|
||||||
|
|
||||||
AC_CHECK_TOOL(CC,gcc)
|
|
||||||
|
|
||||||
AC_ISC_POSIX
|
AC_ISC_POSIX
|
||||||
AC_PROG_CC
|
AC_PROG_CC
|
||||||
AC_STDC_HEADERS
|
AC_STDC_HEADERS
|
||||||
AC_ARG_PROGRAM
|
AC_ARG_PROGRAM
|
||||||
|
|
||||||
|
AC_PROG_AWK
|
||||||
|
|
||||||
|
AC_CHECK_TOOL(CC,gcc)
|
||||||
AC_CHECK_TOOL(RANLIB,ranlib)
|
AC_CHECK_TOOL(RANLIB,ranlib)
|
||||||
AC_CHECK_TOOL(AS,as)
|
AC_CHECK_TOOL(AS,as)
|
||||||
AC_CHECK_TOOL(AR,ar)
|
AC_CHECK_TOOL(AR,ar)
|
||||||
@@ -41,8 +34,6 @@ export cross_compiling
|
|||||||
|
|
||||||
AM_PROG_LIBTOOL
|
AM_PROG_LIBTOOL
|
||||||
|
|
||||||
AM_INIT_AUTOMAKE(libgtop, 0.01)
|
|
||||||
|
|
||||||
dnl If you want to use libgtop without gnome, comment the following line out.
|
dnl If you want to use libgtop without gnome, comment the following line out.
|
||||||
GNOME_INIT_HOOK(gnome_found=yes)
|
GNOME_INIT_HOOK(gnome_found=yes)
|
||||||
|
|
||||||
@@ -111,6 +102,30 @@ AC_CHECK_FUNCS(getcwd gettimeofday getwd putenv strdup strtoul uname)
|
|||||||
ALL_LINGUAS="fr"
|
ALL_LINGUAS="fr"
|
||||||
AM_GNU_GETTEXT
|
AM_GNU_GETTEXT
|
||||||
|
|
||||||
|
AC_PATH_XTRA
|
||||||
|
|
||||||
|
dnl The construct foo=`echo $w1 $w2 $w3` fails on some systems if $w1 = -e or -n
|
||||||
|
dnl So we use the following instead.
|
||||||
|
dnl XE_SPACE(var, words)
|
||||||
|
define([XE_SPACE],[
|
||||||
|
T=""
|
||||||
|
for W in $2; do if test -z "$T"; then T="$W"; else T="$T $W"; fi; done
|
||||||
|
$1="$T"
|
||||||
|
])dnl
|
||||||
|
|
||||||
|
dnl Autodetect Xauth
|
||||||
|
dnl -lXau is only used by gnuclient, so use a special variable for Xauth X libs
|
||||||
|
test -z "$with_xauth" && test "$window_system" = "none" && with_xauth=no
|
||||||
|
test -z "$with_xauth" && { AC_CHECK_HEADER(X11/Xauth.h, ,with_xauth=no) }
|
||||||
|
test -z "$with_xauth" && { AC_CHECK_LIB(Xau, XauGetAuthByAddr,[:],with_xauth=no, $X_LIBS) }
|
||||||
|
test -z "$with_xauth" && with_xauth=yes
|
||||||
|
if test "$with_xauth" = "yes"; then
|
||||||
|
AC_DEFINE(HAVE_XAUTH)
|
||||||
|
XE_SPACE(libs_xauth, $X_LIBS -lXau)
|
||||||
|
fi
|
||||||
|
AC_SUBST(libs_xauth)
|
||||||
|
|
||||||
|
|
||||||
CFLAGS="$CFLAGS -D_IN_LIBGTOP"
|
CFLAGS="$CFLAGS -D_IN_LIBGTOP"
|
||||||
|
|
||||||
AC_SUBST(CFLAGS)
|
AC_SUBST(CFLAGS)
|
||||||
@@ -139,7 +154,7 @@ AC_SUBST(LIBSUPPORT)
|
|||||||
AC_SUBST(SUPPORTINCS)
|
AC_SUBST(SUPPORTINCS)
|
||||||
|
|
||||||
dnl These definitions are expanded in make.
|
dnl These definitions are expanded in make.
|
||||||
LIBGTOP_LIBS='-L$(libdir)'
|
LIBGTOP_LIBS='-L$(libdir) -lgtop'
|
||||||
LIBGTOP_INCS='-I$(includedir)'
|
LIBGTOP_INCS='-I$(includedir)'
|
||||||
LIBGTOP_GUILE_LIBS="$LIBGTOP_LIBS"
|
LIBGTOP_GUILE_LIBS="$LIBGTOP_LIBS"
|
||||||
LIBGTOP_GUILE_INCS="$LIBGTOP_INCS"
|
LIBGTOP_GUILE_INCS="$LIBGTOP_INCS"
|
||||||
@@ -171,8 +186,8 @@ fi
|
|||||||
|
|
||||||
AC_SUBST(libgtop_want_guile_names)
|
AC_SUBST(libgtop_want_guile_names)
|
||||||
|
|
||||||
LIBGTOP_LIBS="$LIBGTOP_LIBS -lgtop_common"
|
LIBGTOP_LIBS="$LIBGTOP_LIBS -lgtop_common $libs_xauth"
|
||||||
LIBGTOP_GUILE_LIBS="$LIBGTOP_GUILE_LIBS -lgtop_common"
|
LIBGTOP_GUILE_LIBS="$LIBGTOP_GUILE_LIBS -lgtop_common $libs_xauth"
|
||||||
|
|
||||||
if test "x$need_server" = "xyes" ; then
|
if test "x$need_server" = "xyes" ; then
|
||||||
LIBGTOP_LIBS="$LIBGTOP_LIBS -lgtop"
|
LIBGTOP_LIBS="$LIBGTOP_LIBS -lgtop"
|
||||||
@@ -226,9 +241,11 @@ sysdeps/stub/Makefile
|
|||||||
sysdeps/sun4/Makefile
|
sysdeps/sun4/Makefile
|
||||||
sysdeps/osf1/Makefile
|
sysdeps/osf1/Makefile
|
||||||
sysdeps/linux/Makefile
|
sysdeps/linux/Makefile
|
||||||
|
sysdeps/kernel/Makefile
|
||||||
src/Makefile
|
src/Makefile
|
||||||
src/server/Makefile
|
src/server/Makefile
|
||||||
src/proxy/Makefile
|
src/proxy/Makefile
|
||||||
|
src/daemon/Makefile
|
||||||
lib/Makefile
|
lib/Makefile
|
||||||
examples/Makefile
|
examples/Makefile
|
||||||
support/Makefile
|
support/Makefile
|
||||||
|
@@ -1,3 +1,7 @@
|
|||||||
|
1998-06-12 Martin Baulig <martin@home-of-linux.org>
|
||||||
|
|
||||||
|
* test.scm: New file.
|
||||||
|
|
||||||
1998-06-07 Martin Baulig <martin@home-of-linux.org>
|
1998-06-07 Martin Baulig <martin@home-of-linux.org>
|
||||||
|
|
||||||
* Makefile.am (CFLAGS): Disable optimize.
|
* Makefile.am (CFLAGS): Disable optimize.
|
||||||
|
@@ -16,20 +16,20 @@ bin_PROGRAMS = first first_static second second_static \
|
|||||||
EXTRA_PROGRAMS = third third_static
|
EXTRA_PROGRAMS = third third_static
|
||||||
|
|
||||||
first_SOURCES = first.c
|
first_SOURCES = first.c
|
||||||
first_LDADD = $(top_builddir)/sysdeps/common/libgtop_common.la \
|
first_LDADD = $(top_builddir)/lib/libgtop.la \
|
||||||
$(top_builddir)/lib/libgtop.la \
|
$(top_builddir)/sysdeps/common/libgtop_common.la \
|
||||||
$(top_builddir)/sysdeps/@sysdeps_dir@/libgtop_sysdeps.la \
|
$(top_builddir)/sysdeps/@sysdeps_dir@/libgtop_sysdeps.la \
|
||||||
@INTLLIBS@ @LIBSUPPORT@
|
@INTLLIBS@ @LIBSUPPORT@ @libs_xauth@
|
||||||
|
|
||||||
first_static_SOURCES = $(first_SOURCES)
|
first_static_SOURCES = $(first_SOURCES)
|
||||||
first_static_LDADD = $(first_LDADD)
|
first_static_LDADD = $(first_LDADD)
|
||||||
first_static_LDFLAGS = -static
|
first_static_LDFLAGS = -static
|
||||||
|
|
||||||
second_SOURCES = second.c
|
second_SOURCES = second.c
|
||||||
second_LDADD = $(top_builddir)/sysdeps/common/libgtop_common.la \
|
second_LDADD = $(top_builddir)/lib/libgtop.la \
|
||||||
$(top_builddir)/lib/libgtop.la \
|
$(top_builddir)/sysdeps/common/libgtop_common.la \
|
||||||
$(top_builddir)/sysdeps/@sysdeps_dir@/libgtop_sysdeps.la \
|
$(top_builddir)/sysdeps/@sysdeps_dir@/libgtop_sysdeps.la \
|
||||||
@INTLLIBS@ @LIBSUPPORT@
|
@INTLLIBS@ @LIBSUPPORT@ @libs_xauth@
|
||||||
|
|
||||||
second_static_SOURCES = $(second_SOURCES)
|
second_static_SOURCES = $(second_SOURCES)
|
||||||
second_static_LDADD = $(second_LDADD)
|
second_static_LDADD = $(second_LDADD)
|
||||||
@@ -46,7 +46,7 @@ third_LDADD = $(top_builddir)/sysdeps/guile/libgtop_guile.la \
|
|||||||
$(top_builddir)/lib/libgtop.la \
|
$(top_builddir)/lib/libgtop.la \
|
||||||
$(top_builddir)/sysdeps/common/libgtop_common.la \
|
$(top_builddir)/sysdeps/common/libgtop_common.la \
|
||||||
$(top_builddir)/sysdeps/@sysdeps_dir@/libgtop_sysdeps.la \
|
$(top_builddir)/sysdeps/@sysdeps_dir@/libgtop_sysdeps.la \
|
||||||
@GUILE_LIBS@ @INTLLIBS@ @LIBSUPPORT@
|
@GUILE_LIBS@ @INTLLIBS@ @LIBSUPPORT@ @libs_xauth@
|
||||||
|
|
||||||
third_static_SOURCES = $(third_SOURCES)
|
third_static_SOURCES = $(third_SOURCES)
|
||||||
third_static_LDADD = $(third_LDADD)
|
third_static_LDADD = $(third_LDADD)
|
||||||
|
371
examples/first.c
371
examples/first.c
@@ -26,6 +26,8 @@
|
|||||||
#include <glibtop/close.h>
|
#include <glibtop/close.h>
|
||||||
#include <glibtop/xmalloc.h>
|
#include <glibtop/xmalloc.h>
|
||||||
|
|
||||||
|
#include <glibtop/parameter.h>
|
||||||
|
|
||||||
#include <glibtop/union.h>
|
#include <glibtop/union.h>
|
||||||
#include <glibtop/sysdeps.h>
|
#include <glibtop/sysdeps.h>
|
||||||
|
|
||||||
@@ -38,7 +40,8 @@ main (int argc, char *argv [])
|
|||||||
{
|
{
|
||||||
glibtop_union data;
|
glibtop_union data;
|
||||||
glibtop_sysdeps sysdeps;
|
glibtop_sysdeps sysdeps;
|
||||||
unsigned c, count, i, *ptr;
|
unsigned c, method, count, port, i, *ptr;
|
||||||
|
char buffer [BUFSIZ];
|
||||||
pid_t pid, ppid;
|
pid_t pid, ppid;
|
||||||
|
|
||||||
count = PROFILE_COUNT;
|
count = PROFILE_COUNT;
|
||||||
@@ -47,98 +50,114 @@ main (int argc, char *argv [])
|
|||||||
bindtextdomain (PACKAGE, GTOPLOCALEDIR);
|
bindtextdomain (PACKAGE, GTOPLOCALEDIR);
|
||||||
textdomain (PACKAGE);
|
textdomain (PACKAGE);
|
||||||
|
|
||||||
glibtop_init ();
|
glibtop_init_r (&glibtop_global_server, 0, GLIBTOP_INIT_NO_OPEN);
|
||||||
|
|
||||||
|
glibtop_get_parameter (GLIBTOP_PARAM_METHOD, &method, sizeof (method));
|
||||||
|
|
||||||
|
printf ("Method = %d\n", method);
|
||||||
|
|
||||||
|
count = glibtop_get_parameter (GLIBTOP_PARAM_COMMAND, buffer, BUFSIZ);
|
||||||
|
buffer [count] = 0;
|
||||||
|
|
||||||
|
printf ("Command = '%s'\n", buffer);
|
||||||
|
|
||||||
|
count = glibtop_get_parameter (GLIBTOP_PARAM_HOST, buffer, BUFSIZ);
|
||||||
|
buffer [count] = 0;
|
||||||
|
|
||||||
|
glibtop_get_parameter (GLIBTOP_PARAM_PORT, &port, sizeof (port));
|
||||||
|
|
||||||
|
printf ("Host = '%s' - %u\n\n", buffer, port);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_cpu (&data.cpu);
|
glibtop_get_cpu (&data.cpu);
|
||||||
|
|
||||||
fprintf (stderr, "CPU (0x%08lx): %lu, %lu, %lu, %lu, %lu, %lu\n",
|
printf ("CPU (0x%08lx): %lu, %lu, %lu, %lu, %lu, %lu\n",
|
||||||
data.cpu.flags, data.cpu.total, data.cpu.user, data.cpu.nice,
|
data.cpu.flags, data.cpu.total, data.cpu.user, data.cpu.nice,
|
||||||
data.cpu.sys, data.cpu.idle, data.cpu.frequency);
|
data.cpu.sys, data.cpu.idle, data.cpu.frequency);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_mem (&data.mem);
|
glibtop_get_mem (&data.mem);
|
||||||
|
|
||||||
fprintf (stderr, "Memory (0x%08lx): %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu\n",
|
printf ("Memory (0x%08lx): %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu\n",
|
||||||
data.mem.flags, data.mem.total, data.mem.used, data.mem.free,
|
data.mem.flags, data.mem.total, data.mem.used, data.mem.free,
|
||||||
data.mem.shared, data.mem.buffer, data.mem.cached,
|
data.mem.shared, data.mem.buffer, data.mem.cached,
|
||||||
data.mem.user, data.mem.locked);
|
data.mem.user, data.mem.locked);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_swap (&data.swap);
|
glibtop_get_swap (&data.swap);
|
||||||
|
|
||||||
fprintf (stderr, "Swap (0x%08lx): %lu, %lu, %lu\n", data.swap.flags,
|
printf ("Swap (0x%08lx): %lu, %lu, %lu\n", data.swap.flags,
|
||||||
data.swap.total, data.swap.used, data.swap.free);
|
data.swap.total, data.swap.used, data.swap.free);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_uptime (&data.uptime);
|
glibtop_get_uptime (&data.uptime);
|
||||||
|
|
||||||
fprintf (stderr, "Uptime (0x%08lx): %f, %f\n", data.uptime.flags,
|
printf ("Uptime (0x%08lx): %f, %f\n", data.uptime.flags,
|
||||||
data.uptime.uptime, data.uptime.idletime);
|
data.uptime.uptime, data.uptime.idletime);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_loadavg (&data.loadavg);
|
glibtop_get_loadavg (&data.loadavg);
|
||||||
|
|
||||||
fprintf (stderr, "Loadavg (0x%08lx): %f, %f, %f\n", data.loadavg.flags,
|
printf ("Loadavg (0x%08lx): %f, %f, %f\n", data.loadavg.flags,
|
||||||
data.loadavg.loadavg [0], data.loadavg.loadavg [1],
|
data.loadavg.loadavg [0], data.loadavg.loadavg [1],
|
||||||
data.loadavg.loadavg [2]);
|
data.loadavg.loadavg [2]);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_shm_limits (&data.shm_limits);
|
glibtop_get_shm_limits (&data.shm_limits);
|
||||||
|
|
||||||
fprintf (stderr, "Shm Limits (0x%08lx): %ld, %ld, %ld, %ld, %ld\n",
|
printf ("Shm Limits (0x%08lx): %ld, %ld, %ld, %ld, %ld\n",
|
||||||
data.shm_limits.flags, data.shm_limits.shmmax,
|
data.shm_limits.flags, data.shm_limits.shmmax,
|
||||||
data.shm_limits.shmmin, data.shm_limits.shmmni,
|
data.shm_limits.shmmin, data.shm_limits.shmmni,
|
||||||
data.shm_limits.shmseg, data.shm_limits.shmall);
|
data.shm_limits.shmseg, data.shm_limits.shmall);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_msg_limits (&data.msg_limits);
|
glibtop_get_msg_limits (&data.msg_limits);
|
||||||
|
|
||||||
fprintf (stderr, "Msg Limits (0x%08lx): %ld, %ld, %ld, %ld, %ld, %ld, %ld\n",
|
printf ("Msg Limits (0x%08lx): %ld, %ld, %ld, %ld, %ld, %ld, %ld\n",
|
||||||
data.msg_limits.flags, data.msg_limits.msgpool,
|
data.msg_limits.flags, data.msg_limits.msgpool,
|
||||||
data.msg_limits.msgmap, data.msg_limits.msgmax,
|
data.msg_limits.msgmap, data.msg_limits.msgmax,
|
||||||
data.msg_limits.msgmnb, data.msg_limits.msgmni,
|
data.msg_limits.msgmnb, data.msg_limits.msgmni,
|
||||||
data.msg_limits.msgssz, data.msg_limits.msgtql);
|
data.msg_limits.msgssz, data.msg_limits.msgtql);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_sem_limits (&data.sem_limits);
|
glibtop_get_sem_limits (&data.sem_limits);
|
||||||
|
|
||||||
fprintf (stderr, "Sem Limits (0x%08lx): "
|
printf ("Sem Limits (0x%08lx): "
|
||||||
"%ld, %ld, %ld, %ld, %ld, %ld, %ld, %ld, %ld, %ld\n",
|
"%ld, %ld, %ld, %ld, %ld, %ld, %ld, %ld, %ld, %ld\n",
|
||||||
data.sem_limits.flags, data.sem_limits.semmap,
|
data.sem_limits.flags, data.sem_limits.semmap,
|
||||||
data.sem_limits.semmni, data.sem_limits.semmns,
|
data.sem_limits.semmni, data.sem_limits.semmns,
|
||||||
data.sem_limits.semmnu, data.sem_limits.semmsl,
|
data.sem_limits.semmnu, data.sem_limits.semmsl,
|
||||||
data.sem_limits.semopm, data.sem_limits.semume,
|
data.sem_limits.semopm, data.sem_limits.semume,
|
||||||
data.sem_limits.semusz, data.sem_limits.semvmx,
|
data.sem_limits.semusz, data.sem_limits.semvmx,
|
||||||
data.sem_limits.semaem);
|
data.sem_limits.semaem);
|
||||||
|
|
||||||
fprintf (stderr, "\n");
|
printf ("\n");
|
||||||
|
|
||||||
glibtop_get_sysdeps (&sysdeps);
|
glibtop_get_sysdeps (&sysdeps);
|
||||||
|
|
||||||
fprintf (stderr, "Sysdeps (0x%08lx): %lu, %lu, %lu, %lu, %lu, "
|
printf ("Sysdeps (0x%08lx): %lu, %lu, %lu, %lu, %lu, "
|
||||||
"%lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu\n",
|
"%lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu\n",
|
||||||
sysdeps.flags, sysdeps.cpu, sysdeps.mem, sysdeps.swap,
|
sysdeps.flags, sysdeps.cpu, sysdeps.mem, sysdeps.swap,
|
||||||
sysdeps.uptime, sysdeps.loadavg, sysdeps.shm_limits,
|
sysdeps.uptime, sysdeps.loadavg, sysdeps.shm_limits,
|
||||||
sysdeps.msg_limits, sysdeps.sem_limits,
|
sysdeps.msg_limits, sysdeps.sem_limits,
|
||||||
sysdeps.proclist, sysdeps.proc_state,
|
sysdeps.proclist, sysdeps.proc_state,
|
||||||
sysdeps.proc_uid, sysdeps.proc_mem,
|
sysdeps.proc_uid, sysdeps.proc_mem,
|
||||||
sysdeps.proc_time, sysdeps.proc_signal,
|
sysdeps.proc_time, sysdeps.proc_signal,
|
||||||
sysdeps.proc_kernel, sysdeps.proc_segment);
|
sysdeps.proc_kernel, sysdeps.proc_segment);
|
||||||
|
|
||||||
fprintf (stderr, "\n");
|
printf ("\n");
|
||||||
|
|
||||||
ptr = glibtop_get_proclist (&data.proclist);
|
ptr = glibtop_get_proclist (&data.proclist);
|
||||||
|
|
||||||
fprintf (stderr, "Proclist (0x%08lx): %ld, %ld, %ld\n",
|
printf ("Proclist (0x%08lx): %ld, %ld, %ld\n",
|
||||||
data.proclist.flags, data.proclist.number,
|
data.proclist.flags, data.proclist.number,
|
||||||
data.proclist.size, data.proclist.total);
|
data.proclist.size, data.proclist.total);
|
||||||
|
|
||||||
if (ptr) {
|
if (ptr) {
|
||||||
fprintf (stderr, "\nProcess: ");
|
printf ("\nProcess: ");
|
||||||
for (i = 0; i < data.proclist.number; i++)
|
for (i = 0; i < data.proclist.number; i++)
|
||||||
fprintf (stderr, "%s%u", i ? ", " : "", ptr [i]);
|
printf ("%s%u", i ? ", " : "", ptr [i]);
|
||||||
fprintf (stderr, "\n");
|
printf ("\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
glibtop_free (ptr);
|
glibtop_free (ptr);
|
||||||
@@ -146,218 +165,218 @@ main (int argc, char *argv [])
|
|||||||
pid = getpid ();
|
pid = getpid ();
|
||||||
ppid = getppid ();
|
ppid = getppid ();
|
||||||
|
|
||||||
fprintf (stderr, "\n");
|
printf ("\n");
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_state (&data.proc_state, pid);
|
glibtop_get_proc_state (&data.proc_state, pid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_State PID %5u (0x%08lx): '%s', %c, %u, %u\n",
|
printf ("Proc_State PID %5u (0x%08lx): '%s', %c, %u, %u\n",
|
||||||
pid, data.proc_state.flags, data.proc_state.cmd,
|
pid, data.proc_state.flags, data.proc_state.cmd,
|
||||||
data.proc_state.state, data.proc_state.uid,
|
data.proc_state.state, data.proc_state.uid,
|
||||||
data.proc_state.gid);
|
data.proc_state.gid);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_uid (&data.proc_uid, pid);
|
glibtop_get_proc_uid (&data.proc_uid, pid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Uid PID %5u (0x%08lx): "
|
printf ("Proc_Uid PID %5u (0x%08lx): "
|
||||||
"%d %d %d %d %d %d %d %d %d %d %d %d\n",
|
"%d %d %d %d %d %d %d %d %d %d %d %d\n",
|
||||||
pid, data.proc_uid.flags, data.proc_uid.uid,
|
pid, data.proc_uid.flags, data.proc_uid.uid,
|
||||||
data.proc_uid.euid, data.proc_uid.gid,
|
data.proc_uid.euid, data.proc_uid.gid,
|
||||||
data.proc_uid.egid, data.proc_uid.pid,
|
data.proc_uid.egid, data.proc_uid.pid,
|
||||||
data.proc_uid.ppid, data.proc_uid.pgrp,
|
data.proc_uid.ppid, data.proc_uid.pgrp,
|
||||||
data.proc_uid.session, data.proc_uid.tty,
|
data.proc_uid.session, data.proc_uid.tty,
|
||||||
data.proc_uid.tpgid, data.proc_uid.priority,
|
data.proc_uid.tpgid, data.proc_uid.priority,
|
||||||
data.proc_uid.nice);
|
data.proc_uid.nice);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_mem (&data.proc_mem, pid);
|
glibtop_get_proc_mem (&data.proc_mem, pid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Mem PID %5u (0x%08lx): "
|
printf ("Proc_Mem PID %5u (0x%08lx): "
|
||||||
"%ld %ld %ld %ld %ld %ld\n", pid, data.proc_mem.flags,
|
"%ld %ld %ld %ld %ld %ld\n", pid, data.proc_mem.flags,
|
||||||
data.proc_mem.size, data.proc_mem.vsize,
|
data.proc_mem.size, data.proc_mem.vsize,
|
||||||
data.proc_mem.resident, data.proc_mem.share,
|
data.proc_mem.resident, data.proc_mem.share,
|
||||||
data.proc_mem.rss, data.proc_mem.rss_rlim);
|
data.proc_mem.rss, data.proc_mem.rss_rlim);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_time (&data.proc_time, pid);
|
glibtop_get_proc_time (&data.proc_time, pid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Time PID %5u (0x%08lx): "
|
printf ("Proc_Time PID %5u (0x%08lx): "
|
||||||
"%ld %ld %ld %ld %ld %ld %ld\n", pid, data.proc_time.flags,
|
"%ld %ld %ld %ld %ld %ld %ld\n", pid, data.proc_time.flags,
|
||||||
data.proc_time.start_time, data.proc_time.utime,
|
data.proc_time.start_time, data.proc_time.utime,
|
||||||
data.proc_time.stime, data.proc_time.cutime,
|
data.proc_time.stime, data.proc_time.cutime,
|
||||||
data.proc_time.cstime, data.proc_time.timeout,
|
data.proc_time.cstime, data.proc_time.timeout,
|
||||||
data.proc_time.it_real_value);
|
data.proc_time.it_real_value);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_signal (&data.proc_signal, pid);
|
glibtop_get_proc_signal (&data.proc_signal, pid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Signal PID %5u (0x%08lx): "
|
printf ("Proc_Signal PID %5u (0x%08lx): "
|
||||||
"%d %d %d %d\n", pid, data.proc_signal.flags,
|
"%d %d %d %d\n", pid, data.proc_signal.flags,
|
||||||
data.proc_signal.signal, data.proc_signal.blocked,
|
data.proc_signal.signal, data.proc_signal.blocked,
|
||||||
data.proc_signal.sigignore, data.proc_signal.sigcatch);
|
data.proc_signal.sigignore, data.proc_signal.sigcatch);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_kernel (&data.proc_kernel, pid);
|
glibtop_get_proc_kernel (&data.proc_kernel, pid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Kernel PID %5u (0x%08lx): "
|
printf ("Proc_Kernel PID %5u (0x%08lx): "
|
||||||
"%lu %lu %lu %lu %lu %lu %lu %lu\n", pid,
|
"%lu %lu %lu %lu %lu %lu %lu %lu\n", pid,
|
||||||
data.proc_kernel.flags, data.proc_kernel.k_flags,
|
data.proc_kernel.flags, data.proc_kernel.k_flags,
|
||||||
data.proc_kernel.min_flt, data.proc_kernel.maj_flt,
|
data.proc_kernel.min_flt, data.proc_kernel.maj_flt,
|
||||||
data.proc_kernel.cmin_flt, data.proc_kernel.cmaj_flt,
|
data.proc_kernel.cmin_flt, data.proc_kernel.cmaj_flt,
|
||||||
data.proc_kernel.kstk_esp, data.proc_kernel.kstk_eip,
|
data.proc_kernel.kstk_esp, data.proc_kernel.kstk_eip,
|
||||||
data.proc_kernel.wchan);
|
data.proc_kernel.wchan);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_segment (&data.proc_segment, pid);
|
glibtop_get_proc_segment (&data.proc_segment, pid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Segment PID %5u (0x%08lx): "
|
printf ("Proc_Segment PID %5u (0x%08lx): "
|
||||||
"%ld %ld %ld %ld %lu %lu %lu\n", pid, data.proc_segment.flags,
|
"%ld %ld %ld %ld %lu %lu %lu\n", pid, data.proc_segment.flags,
|
||||||
data.proc_segment.trs, data.proc_segment.lrs,
|
data.proc_segment.trs, data.proc_segment.lrs,
|
||||||
data.proc_segment.drs, data.proc_segment.dt,
|
data.proc_segment.drs, data.proc_segment.dt,
|
||||||
data.proc_segment.start_code, data.proc_segment.end_code,
|
data.proc_segment.start_code, data.proc_segment.end_code,
|
||||||
data.proc_segment.start_stack);
|
data.proc_segment.start_stack);
|
||||||
|
|
||||||
fprintf (stderr, "\n");
|
printf ("\n");
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_state (&data.proc_state, ppid);
|
glibtop_get_proc_state (&data.proc_state, ppid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_State PPID %5u (0x%08lx): '%s', %c, %u, %u\n",
|
printf ("Proc_State PPID %5u (0x%08lx): '%s', %c, %u, %u\n",
|
||||||
ppid, data.proc_state.flags, data.proc_state.cmd,
|
ppid, data.proc_state.flags, data.proc_state.cmd,
|
||||||
data.proc_state.state, data.proc_state.uid,
|
data.proc_state.state, data.proc_state.uid,
|
||||||
data.proc_state.gid);
|
data.proc_state.gid);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_uid (&data.proc_uid, ppid);
|
glibtop_get_proc_uid (&data.proc_uid, ppid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Uid PPID %5u (0x%08lx): "
|
printf ("Proc_Uid PPID %5u (0x%08lx): "
|
||||||
"%d %d %d %d %d %d %d %d %d %d %d %d\n",
|
"%d %d %d %d %d %d %d %d %d %d %d %d\n",
|
||||||
ppid, data.proc_uid.flags, data.proc_uid.uid,
|
ppid, data.proc_uid.flags, data.proc_uid.uid,
|
||||||
data.proc_uid.euid, data.proc_uid.gid,
|
data.proc_uid.euid, data.proc_uid.gid,
|
||||||
data.proc_uid.egid, data.proc_uid.pid,
|
data.proc_uid.egid, data.proc_uid.pid,
|
||||||
data.proc_uid.ppid, data.proc_uid.pgrp,
|
data.proc_uid.ppid, data.proc_uid.pgrp,
|
||||||
data.proc_uid.session, data.proc_uid.tty,
|
data.proc_uid.session, data.proc_uid.tty,
|
||||||
data.proc_uid.tpgid, data.proc_uid.priority,
|
data.proc_uid.tpgid, data.proc_uid.priority,
|
||||||
data.proc_uid.nice);
|
data.proc_uid.nice);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_mem (&data.proc_mem, ppid);
|
glibtop_get_proc_mem (&data.proc_mem, ppid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Mem PPID %5u (0x%08lx): "
|
printf ("Proc_Mem PPID %5u (0x%08lx): "
|
||||||
"%ld %ld %ld %ld %ld %ld\n", ppid, data.proc_mem.flags,
|
"%ld %ld %ld %ld %ld %ld\n", ppid, data.proc_mem.flags,
|
||||||
data.proc_mem.size, data.proc_mem.vsize,
|
data.proc_mem.size, data.proc_mem.vsize,
|
||||||
data.proc_mem.resident, data.proc_mem.share,
|
data.proc_mem.resident, data.proc_mem.share,
|
||||||
data.proc_mem.rss, data.proc_mem.rss_rlim);
|
data.proc_mem.rss, data.proc_mem.rss_rlim);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_time (&data.proc_time, ppid);
|
glibtop_get_proc_time (&data.proc_time, ppid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Time PPID %5u (0x%08lx): "
|
printf ("Proc_Time PPID %5u (0x%08lx): "
|
||||||
"%ld %ld %ld %ld %ld %ld %ld\n", ppid, data.proc_time.flags,
|
"%ld %ld %ld %ld %ld %ld %ld\n", ppid, data.proc_time.flags,
|
||||||
data.proc_time.start_time, data.proc_time.utime,
|
data.proc_time.start_time, data.proc_time.utime,
|
||||||
data.proc_time.stime, data.proc_time.cutime,
|
data.proc_time.stime, data.proc_time.cutime,
|
||||||
data.proc_time.cstime, data.proc_time.timeout,
|
data.proc_time.cstime, data.proc_time.timeout,
|
||||||
data.proc_time.it_real_value);
|
data.proc_time.it_real_value);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_signal (&data.proc_signal, ppid);
|
glibtop_get_proc_signal (&data.proc_signal, ppid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Signal PPID %5u (0x%08lx): "
|
printf ("Proc_Signal PPID %5u (0x%08lx): "
|
||||||
"%d %d %d %d\n", ppid, data.proc_signal.flags,
|
"%d %d %d %d\n", ppid, data.proc_signal.flags,
|
||||||
data.proc_signal.signal, data.proc_signal.blocked,
|
data.proc_signal.signal, data.proc_signal.blocked,
|
||||||
data.proc_signal.sigignore, data.proc_signal.sigcatch);
|
data.proc_signal.sigignore, data.proc_signal.sigcatch);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_kernel (&data.proc_kernel, ppid);
|
glibtop_get_proc_kernel (&data.proc_kernel, ppid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Kernel PPID %5u (0x%08lx): "
|
printf ("Proc_Kernel PPID %5u (0x%08lx): "
|
||||||
"%lu %lu %lu %lu %lu %lu %lu %lu\n", ppid,
|
"%lu %lu %lu %lu %lu %lu %lu %lu\n", ppid,
|
||||||
data.proc_kernel.flags, data.proc_kernel.k_flags,
|
data.proc_kernel.flags, data.proc_kernel.k_flags,
|
||||||
data.proc_kernel.min_flt, data.proc_kernel.maj_flt,
|
data.proc_kernel.min_flt, data.proc_kernel.maj_flt,
|
||||||
data.proc_kernel.cmin_flt, data.proc_kernel.cmaj_flt,
|
data.proc_kernel.cmin_flt, data.proc_kernel.cmaj_flt,
|
||||||
data.proc_kernel.kstk_esp, data.proc_kernel.kstk_eip,
|
data.proc_kernel.kstk_esp, data.proc_kernel.kstk_eip,
|
||||||
data.proc_kernel.wchan);
|
data.proc_kernel.wchan);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_segment (&data.proc_segment, ppid);
|
glibtop_get_proc_segment (&data.proc_segment, ppid);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Segment PPID %5u (0x%08lx): "
|
printf ("Proc_Segment PPID %5u (0x%08lx): "
|
||||||
"%ld %ld %ld %ld %lu %lu %lu\n", ppid, data.proc_segment.flags,
|
"%ld %ld %ld %ld %lu %lu %lu\n", ppid, data.proc_segment.flags,
|
||||||
data.proc_segment.trs, data.proc_segment.lrs,
|
data.proc_segment.trs, data.proc_segment.lrs,
|
||||||
data.proc_segment.drs, data.proc_segment.dt,
|
data.proc_segment.drs, data.proc_segment.dt,
|
||||||
data.proc_segment.start_code, data.proc_segment.end_code,
|
data.proc_segment.start_code, data.proc_segment.end_code,
|
||||||
data.proc_segment.start_stack);
|
data.proc_segment.start_stack);
|
||||||
|
|
||||||
fprintf (stderr, "\n");
|
printf ("\n");
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_state (&data.proc_state, 1);
|
glibtop_get_proc_state (&data.proc_state, 1);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_State INIT %5u (0x%08lx): '%s', %c, %u, %u\n",
|
printf ("Proc_State INIT %5u (0x%08lx): '%s', %c, %u, %u\n",
|
||||||
1, data.proc_state.flags, data.proc_state.cmd,
|
1, data.proc_state.flags, data.proc_state.cmd,
|
||||||
data.proc_state.state, data.proc_state.uid,
|
data.proc_state.state, data.proc_state.uid,
|
||||||
data.proc_state.gid);
|
data.proc_state.gid);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_uid (&data.proc_uid, 1);
|
glibtop_get_proc_uid (&data.proc_uid, 1);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Uid INIT %5u (0x%08lx): "
|
printf ("Proc_Uid INIT %5u (0x%08lx): "
|
||||||
"%d %d %d %d %d %d %d %d %d %d %d %d\n",
|
"%d %d %d %d %d %d %d %d %d %d %d %d\n",
|
||||||
1, data.proc_uid.flags, data.proc_uid.uid,
|
1, data.proc_uid.flags, data.proc_uid.uid,
|
||||||
data.proc_uid.euid, data.proc_uid.gid,
|
data.proc_uid.euid, data.proc_uid.gid,
|
||||||
data.proc_uid.egid, data.proc_uid.pid,
|
data.proc_uid.egid, data.proc_uid.pid,
|
||||||
data.proc_uid.ppid, data.proc_uid.pgrp,
|
data.proc_uid.ppid, data.proc_uid.pgrp,
|
||||||
data.proc_uid.session, data.proc_uid.tty,
|
data.proc_uid.session, data.proc_uid.tty,
|
||||||
data.proc_uid.tpgid, data.proc_uid.priority,
|
data.proc_uid.tpgid, data.proc_uid.priority,
|
||||||
data.proc_uid.nice);
|
data.proc_uid.nice);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_mem (&data.proc_mem, 1);
|
glibtop_get_proc_mem (&data.proc_mem, 1);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Mem INIT %5u (0x%08lx): "
|
printf ("Proc_Mem INIT %5u (0x%08lx): "
|
||||||
"%ld %ld %ld %ld %ld %ld\n", 1, data.proc_mem.flags,
|
"%ld %ld %ld %ld %ld %ld\n", 1, data.proc_mem.flags,
|
||||||
data.proc_mem.size, data.proc_mem.vsize,
|
data.proc_mem.size, data.proc_mem.vsize,
|
||||||
data.proc_mem.resident, data.proc_mem.share,
|
data.proc_mem.resident, data.proc_mem.share,
|
||||||
data.proc_mem.rss, data.proc_mem.rss_rlim);
|
data.proc_mem.rss, data.proc_mem.rss_rlim);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_time (&data.proc_time, 1);
|
glibtop_get_proc_time (&data.proc_time, 1);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Time INIT %5u (0x%08lx): "
|
printf ("Proc_Time INIT %5u (0x%08lx): "
|
||||||
"%ld %ld %ld %ld %ld %ld %ld\n", 1, data.proc_time.flags,
|
"%ld %ld %ld %ld %ld %ld %ld\n", 1, data.proc_time.flags,
|
||||||
data.proc_time.start_time, data.proc_time.utime,
|
data.proc_time.start_time, data.proc_time.utime,
|
||||||
data.proc_time.stime, data.proc_time.cutime,
|
data.proc_time.stime, data.proc_time.cutime,
|
||||||
data.proc_time.cstime, data.proc_time.timeout,
|
data.proc_time.cstime, data.proc_time.timeout,
|
||||||
data.proc_time.it_real_value);
|
data.proc_time.it_real_value);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_signal (&data.proc_signal, 1);
|
glibtop_get_proc_signal (&data.proc_signal, 1);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Signal INIT %5u (0x%08lx): "
|
printf ("Proc_Signal INIT %5u (0x%08lx): "
|
||||||
"%d %d %d %d\n", 1, data.proc_signal.flags,
|
"%d %d %d %d\n", 1, data.proc_signal.flags,
|
||||||
data.proc_signal.signal, data.proc_signal.blocked,
|
data.proc_signal.signal, data.proc_signal.blocked,
|
||||||
data.proc_signal.sigignore, data.proc_signal.sigcatch);
|
data.proc_signal.sigignore, data.proc_signal.sigcatch);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_kernel (&data.proc_kernel, 1);
|
glibtop_get_proc_kernel (&data.proc_kernel, 1);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Kernel INIT %5u (0x%08lx): "
|
printf ("Proc_Kernel INIT %5u (0x%08lx): "
|
||||||
"%lu %lu %lu %lu %lu %lu %lu %lu\n", 1,
|
"%lu %lu %lu %lu %lu %lu %lu %lu\n", 1,
|
||||||
data.proc_kernel.flags, data.proc_kernel.k_flags,
|
data.proc_kernel.flags, data.proc_kernel.k_flags,
|
||||||
data.proc_kernel.min_flt, data.proc_kernel.maj_flt,
|
data.proc_kernel.min_flt, data.proc_kernel.maj_flt,
|
||||||
data.proc_kernel.cmin_flt, data.proc_kernel.cmaj_flt,
|
data.proc_kernel.cmin_flt, data.proc_kernel.cmaj_flt,
|
||||||
data.proc_kernel.kstk_esp, data.proc_kernel.kstk_eip,
|
data.proc_kernel.kstk_esp, data.proc_kernel.kstk_eip,
|
||||||
data.proc_kernel.wchan);
|
data.proc_kernel.wchan);
|
||||||
|
|
||||||
for (c = 0; c < count; c++)
|
for (c = 0; c < count; c++)
|
||||||
glibtop_get_proc_segment (&data.proc_segment, 1);
|
glibtop_get_proc_segment (&data.proc_segment, 1);
|
||||||
|
|
||||||
fprintf (stderr, "Proc_Segment INIT %5u (0x%08lx): "
|
printf ("Proc_Segment INIT %5u (0x%08lx): "
|
||||||
"%ld %ld %ld %ld %lu %lu %lu\n", 1, data.proc_segment.flags,
|
"%ld %ld %ld %ld %lu %lu %lu\n", 1, data.proc_segment.flags,
|
||||||
data.proc_segment.trs, data.proc_segment.lrs,
|
data.proc_segment.trs, data.proc_segment.lrs,
|
||||||
data.proc_segment.drs, data.proc_segment.dt,
|
data.proc_segment.drs, data.proc_segment.dt,
|
||||||
data.proc_segment.start_code, data.proc_segment.end_code,
|
data.proc_segment.start_code, data.proc_segment.end_code,
|
||||||
data.proc_segment.start_stack);
|
data.proc_segment.start_stack);
|
||||||
|
|
||||||
exit (0);
|
exit (0);
|
||||||
}
|
}
|
||||||
|
80
examples/test.scm
Normal file
80
examples/test.scm
Normal file
@@ -0,0 +1,80 @@
|
|||||||
|
(display (glibtop-names-sysdeps)) (newline)
|
||||||
|
(display (glibtop-labels-sysdeps)) (newline)
|
||||||
|
(display (glibtop-descriptions-sysdeps)) (newline)
|
||||||
|
(display (glibtop-types-sysdeps)) (newline)
|
||||||
|
|
||||||
|
(newline)
|
||||||
|
|
||||||
|
(display (glibtop-names-cpu)) (newline)
|
||||||
|
(display (glibtop-names-mem)) (newline)
|
||||||
|
(display (glibtop-names-swap)) (newline)
|
||||||
|
(display (glibtop-names-uptime)) (newline)
|
||||||
|
(display (glibtop-names-loadavg)) (newline)
|
||||||
|
(display (glibtop-names-shm_limits)) (newline)
|
||||||
|
(display (glibtop-names-msg_limits)) (newline)
|
||||||
|
(display (glibtop-names-sem_limits)) (newline)
|
||||||
|
(display (glibtop-names-proclist)) (newline)
|
||||||
|
(display (glibtop-names-proc_state)) (newline)
|
||||||
|
(display (glibtop-names-proc_uid)) (newline)
|
||||||
|
(display (glibtop-names-proc_mem)) (newline)
|
||||||
|
(display (glibtop-names-proc_time)) (newline)
|
||||||
|
(display (glibtop-names-proc_signal)) (newline)
|
||||||
|
(display (glibtop-names-proc_kernel)) (newline)
|
||||||
|
(display (glibtop-names-proc_segment)) (newline)
|
||||||
|
|
||||||
|
(newline)
|
||||||
|
|
||||||
|
(display (glibtop-labels-cpu)) (newline)
|
||||||
|
(display (glibtop-labels-mem)) (newline)
|
||||||
|
(display (glibtop-labels-swap)) (newline)
|
||||||
|
(display (glibtop-labels-uptime)) (newline)
|
||||||
|
(display (glibtop-labels-loadavg)) (newline)
|
||||||
|
(display (glibtop-labels-shm_limits)) (newline)
|
||||||
|
(display (glibtop-labels-msg_limits)) (newline)
|
||||||
|
(display (glibtop-labels-sem_limits)) (newline)
|
||||||
|
(display (glibtop-labels-proclist)) (newline)
|
||||||
|
(display (glibtop-labels-proc_state)) (newline)
|
||||||
|
(display (glibtop-labels-proc_uid)) (newline)
|
||||||
|
(display (glibtop-labels-proc_mem)) (newline)
|
||||||
|
(display (glibtop-labels-proc_time)) (newline)
|
||||||
|
(display (glibtop-labels-proc_signal)) (newline)
|
||||||
|
(display (glibtop-labels-proc_kernel)) (newline)
|
||||||
|
(display (glibtop-labels-proc_segment)) (newline)
|
||||||
|
|
||||||
|
(newline)
|
||||||
|
|
||||||
|
(display (glibtop-descriptions-cpu)) (newline)
|
||||||
|
(display (glibtop-descriptions-mem)) (newline)
|
||||||
|
(display (glibtop-descriptions-swap)) (newline)
|
||||||
|
(display (glibtop-descriptions-uptime)) (newline)
|
||||||
|
(display (glibtop-descriptions-loadavg)) (newline)
|
||||||
|
(display (glibtop-descriptions-shm_limits)) (newline)
|
||||||
|
(display (glibtop-descriptions-msg_limits)) (newline)
|
||||||
|
(display (glibtop-descriptions-sem_limits)) (newline)
|
||||||
|
(display (glibtop-descriptions-proclist)) (newline)
|
||||||
|
(display (glibtop-descriptions-proc_state)) (newline)
|
||||||
|
(display (glibtop-descriptions-proc_uid)) (newline)
|
||||||
|
(display (glibtop-descriptions-proc_mem)) (newline)
|
||||||
|
(display (glibtop-descriptions-proc_time)) (newline)
|
||||||
|
(display (glibtop-descriptions-proc_signal)) (newline)
|
||||||
|
(display (glibtop-descriptions-proc_kernel)) (newline)
|
||||||
|
(display (glibtop-descriptions-proc_segment)) (newline)
|
||||||
|
|
||||||
|
(newline)
|
||||||
|
|
||||||
|
(display (glibtop-types-cpu)) (newline)
|
||||||
|
(display (glibtop-types-mem)) (newline)
|
||||||
|
(display (glibtop-types-swap)) (newline)
|
||||||
|
(display (glibtop-types-uptime)) (newline)
|
||||||
|
(display (glibtop-types-loadavg)) (newline)
|
||||||
|
(display (glibtop-types-shm_limits)) (newline)
|
||||||
|
(display (glibtop-types-msg_limits)) (newline)
|
||||||
|
(display (glibtop-types-sem_limits)) (newline)
|
||||||
|
(display (glibtop-types-proclist)) (newline)
|
||||||
|
(display (glibtop-types-proc_state)) (newline)
|
||||||
|
(display (glibtop-types-proc_uid)) (newline)
|
||||||
|
(display (glibtop-types-proc_mem)) (newline)
|
||||||
|
(display (glibtop-types-proc_time)) (newline)
|
||||||
|
(display (glibtop-types-proc_signal)) (newline)
|
||||||
|
(display (glibtop-types-proc_kernel)) (newline)
|
||||||
|
(display (glibtop-types-proc_segment)) (newline)
|
16
features.def
Normal file
16
features.def
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
cpu ulong(total,user,nice,sys,idle,frequency)
|
||||||
|
mem ulong(total,used,free,shared,buffer,cached,user,locked)
|
||||||
|
swap ulong(total,used,free)
|
||||||
|
uptime double(uptime,idletime)
|
||||||
|
loadavg double(loadavg[0],loadavg[1],loadavg[2])
|
||||||
|
shm_limits ulong(shmmax,shmmin,shmmni,shmseg,shmall)
|
||||||
|
msg_limits ulong(msgpool,msgmap,msgmax,msgmnb,msgmni,msgssz,msgtql)
|
||||||
|
sem_limits ulong(semmap,semmni,semmns,semmnu,semmsl,semopm,semume,semusz,semvmx,semaem)
|
||||||
|
proclist ulong(number,size,total)
|
||||||
|
proc_state str(cmd):char(state):ulong(uid,gid)
|
||||||
|
proc_uid long(uid,euid,gid,egid,pid,ppid,pgrp,session,tty,tpgid,priority,nice)
|
||||||
|
proc_mem long(size,vsize,resident,share,rss,rss_rlim)
|
||||||
|
proc_time long(start_time,utime,stime,cutime,cstime,timeout,it_real_value)
|
||||||
|
proc_signal long(signal,blocked,sigignore,sigcatch)
|
||||||
|
proc_kernel ulong(k_flags,min_flt,maj_flt,cmin_flt,cmaj_flt,kstk_esp,kstk_eip,wchan)
|
||||||
|
proc_segment long(trs,lrs,drs,dt):ulong(start_code,end_code,start_stack)
|
@@ -35,12 +35,14 @@ typedef struct _glibtop glibtop;
|
|||||||
|
|
||||||
struct _glibtop
|
struct _glibtop
|
||||||
{
|
{
|
||||||
int fd; /* Server file descriptor */
|
unsigned flags;
|
||||||
|
unsigned method; /* Server Method */
|
||||||
#ifdef HAVE_GLIBTOP_MACHINE_H
|
#ifdef HAVE_GLIBTOP_MACHINE_H
|
||||||
glibtop_machine machine; /* Machine dependent data */
|
glibtop_machine machine; /* Machine dependent data */
|
||||||
#endif
|
#endif
|
||||||
int input [2]; /* Pipe client <- server */
|
int input [2]; /* Pipe client <- server */
|
||||||
int output [2]; /* Pipe client -> server */
|
int output [2]; /* Pipe client -> server */
|
||||||
|
int socket; /* Accepted connection of a socket */
|
||||||
unsigned long os_version_code; /* Version code of the operating system */
|
unsigned long os_version_code; /* Version code of the operating system */
|
||||||
const char *name; /* Program name for error messages */
|
const char *name; /* Program name for error messages */
|
||||||
const char *server_command; /* Command used to invoke server */
|
const char *server_command; /* Command used to invoke server */
|
||||||
@@ -48,6 +50,7 @@ struct _glibtop
|
|||||||
const char *server_user; /* Name of the user on the target host */
|
const char *server_user; /* Name of the user on the target host */
|
||||||
const char *server_rsh; /* Command used to connect to the target host */
|
const char *server_rsh; /* Command used to connect to the target host */
|
||||||
unsigned long features; /* Server is required for this features */
|
unsigned long features; /* Server is required for this features */
|
||||||
|
unsigned long server_port; /* Port on which daemon is listening */
|
||||||
pid_t pid; /* PID of the server */
|
pid_t pid; /* PID of the server */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@@ -5,4 +5,5 @@ glibtop_HEADERS = close.h loadavg.h prockernel.h procstate.h \
|
|||||||
proctime.h shm_limits.h version.h cpu.h msg_limits.h \
|
proctime.h shm_limits.h version.h cpu.h msg_limits.h \
|
||||||
procmem.h procuid.h swap.h write.h error.h open.h \
|
procmem.h procuid.h swap.h write.h error.h open.h \
|
||||||
procsegment.h read.h sysdeps.h xmalloc.h global.h \
|
procsegment.h read.h sysdeps.h xmalloc.h global.h \
|
||||||
output.h procsignal.h read_data.h union.h
|
output.h procsignal.h read_data.h union.h types.h \
|
||||||
|
parameter.h
|
||||||
|
@@ -50,13 +50,30 @@ __BEGIN_DECLS
|
|||||||
|
|
||||||
#define GLIBTOP_MAX_CMND 18
|
#define GLIBTOP_MAX_CMND 18
|
||||||
|
|
||||||
typedef struct _glibtop_command glibtop_command;
|
#define _GLIBTOP_PARAM_SIZE 16
|
||||||
|
|
||||||
|
typedef struct _glibtop_command glibtop_command;
|
||||||
|
typedef struct _glibtop_response glibtop_response;
|
||||||
|
|
||||||
struct _glibtop_command
|
struct _glibtop_command
|
||||||
{
|
{
|
||||||
glibtop server;
|
glibtop server;
|
||||||
unsigned command;
|
unsigned command;
|
||||||
size_t size;
|
size_t size, data_size;
|
||||||
|
char parameter [_GLIBTOP_PARAM_SIZE];
|
||||||
|
};
|
||||||
|
|
||||||
|
union _glibtop_response_union
|
||||||
|
{
|
||||||
|
glibtop_union data;
|
||||||
|
glibtop_sysdeps sysdeps;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _glibtop_response
|
||||||
|
{
|
||||||
|
off_t offset;
|
||||||
|
size_t size, data_size;
|
||||||
|
union _glibtop_response_union u;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define glibtop_call(p1, p2, p3, p4) glibtop_call_r(glibtop_global_server, p1, p2, p3, p4)
|
#define glibtop_call(p1, p2, p3, p4) glibtop_call_r(glibtop_global_server, p1, p2, p3, p4)
|
||||||
|
@@ -27,8 +27,16 @@
|
|||||||
__BEGIN_DECLS
|
__BEGIN_DECLS
|
||||||
|
|
||||||
#define glibtop_error(p1, args...) glibtop_error_r(glibtop_global_server , p1 , ## args)
|
#define glibtop_error(p1, args...) glibtop_error_r(glibtop_global_server , p1 , ## args)
|
||||||
|
#define glibtop_warn(p1, args...) glibtop_warn_r(glibtop_global_server , p1 , ## args)
|
||||||
|
|
||||||
|
#define glibtop_error_io(p1, args...) glibtop_error_io_r(glibtop_global_server , p1 , ## args)
|
||||||
|
#define glibtop_warn_io(p1, args...) glibtop_warn_io_r(glibtop_global_server , p1 , ## args)
|
||||||
|
|
||||||
extern void glibtop_error_r __P((glibtop *, char *, ...));
|
extern void glibtop_error_r __P((glibtop *, char *, ...));
|
||||||
|
extern void glibtop_warn_r __P((glibtop *, char *, ...));
|
||||||
|
|
||||||
|
extern void glibtop_error_io_r __P((glibtop *, char *, ...));
|
||||||
|
extern void glibtop_warn_io_r __P((glibtop *, char *, ...));
|
||||||
|
|
||||||
__END_DECLS
|
__END_DECLS
|
||||||
|
|
||||||
|
@@ -51,6 +51,22 @@
|
|||||||
# define __P(protos) ()
|
# define __P(protos) ()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if TIME_WITH_SYS_TIME
|
||||||
|
# include <sys/time.h>
|
||||||
|
# include <time.h>
|
||||||
|
#else
|
||||||
|
# if HAVE_SYS_TIME_H
|
||||||
|
# include <sys/time.h>
|
||||||
|
# else
|
||||||
|
# include <time.h>
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef WITHOUT_GUILE
|
||||||
|
#undef HAVE_GUILE
|
||||||
|
#undef GLIBTOP_GUILE_NAMES
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_GUILE
|
#ifdef HAVE_GUILE
|
||||||
#include <guile/gh.h>
|
#include <guile/gh.h>
|
||||||
#endif
|
#endif
|
||||||
@@ -67,7 +83,10 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
|
||||||
|
#ifdef HAVE_UNISTD_H
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_MEMORY_H
|
#ifdef HAVE_MEMORY_H
|
||||||
#include <memory.h>
|
#include <memory.h>
|
||||||
@@ -75,7 +94,9 @@
|
|||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
#include <sys/param.h>
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
|
193
include/glibtop/gnuserv.h
Normal file
193
include/glibtop/gnuserv.h
Normal file
@@ -0,0 +1,193 @@
|
|||||||
|
/* -*-C-*-
|
||||||
|
|
||||||
|
Header file for the GNU Emacs server and client C code.
|
||||||
|
|
||||||
|
This file is part of GNU Emacs.
|
||||||
|
|
||||||
|
Copying is permitted under those conditions described by the GNU
|
||||||
|
General Public License.
|
||||||
|
|
||||||
|
Copyright (C) 1989 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
Author: Andy Norman (ange@hplb.hpl.hp.com), based on
|
||||||
|
'etc/server.c' and 'etc/emacsclient.c' from the 18.52 GNU
|
||||||
|
Emacs distribution.
|
||||||
|
|
||||||
|
Please mail bugs and suggestions to the author at the above address.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* HISTORY
|
||||||
|
* 11-Nov-1990 bristor@simba
|
||||||
|
* Added EOT stuff.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This file incorporates new features added by Bob Weiner <weiner@mot.com>,
|
||||||
|
* Darrell Kindred <dkindred@cmu.edu> and Arup Mukherjee <arup@cmu.edu>.
|
||||||
|
* Please see the note at the end of the README file for details.
|
||||||
|
*
|
||||||
|
* (If gnuserv came bundled with your emacs, the README file is probably
|
||||||
|
* ../etc/gnuserv.README relative to the directory containing this file)
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
static char header_rcsid [] = "!Header: gnuserv.h,v 2.4 95/02/16 11:58:11 arup alpha !";
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define NO_SHORTNAMES
|
||||||
|
|
||||||
|
#define PATCHLEVEL 2
|
||||||
|
|
||||||
|
#define NO_SHORTNAMES
|
||||||
|
/* gnuserv should not be compiled using SOCKS */
|
||||||
|
#define DO_NOT_SOCKSIFY
|
||||||
|
#include <glibtop.h>
|
||||||
|
#include <glibtop/error.h>
|
||||||
|
#undef read
|
||||||
|
#undef write
|
||||||
|
#undef open
|
||||||
|
#undef close
|
||||||
|
#undef signal
|
||||||
|
|
||||||
|
/* Define the communication method between server and clients:
|
||||||
|
* You can have either or both kinds of sockets, but you can't mix
|
||||||
|
* sockets with sysv ipc
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#define INTERNET_DOMAIN_SOCKETS
|
||||||
|
// #define UNIX_DOMAIN_SOCKETS
|
||||||
|
// #define SYSV_IPC
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Define additional authentication protocols to be used. These methods will
|
||||||
|
* be tried before falling back to the default gnuserv protocol (based on
|
||||||
|
* the GNU_SECURE environment variable). Currently, only MIT-MAGIC-COOKIE-1
|
||||||
|
* is also supported.
|
||||||
|
*
|
||||||
|
* Comment out the next line(s) if you don't want to enable the
|
||||||
|
* appropriate authentication protocol.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if defined (HAVE_XAUTH)
|
||||||
|
#define AUTH_MAGIC_COOKIE
|
||||||
|
#endif /* HAVE_XAUTH */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* stuff related to supporting MIT-MAGIC-COOKIE-1
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define MCOOKIE_SCREEN "42980" /* screen # to use as the gnuserv cookie */
|
||||||
|
#define MCOOKIE_NAME "MAGIC-1" /* authentication protocol name */
|
||||||
|
#define MCOOKIE_X_NAME "MIT-MAGIC-COOKIE-1" /* as needed by X */
|
||||||
|
|
||||||
|
|
||||||
|
#define DEFAUTH_NAME "GNU-SECURE" /* name of default auth protocol */
|
||||||
|
#define AUTH_TIMEOUT 15 /* # seconds to wait for auth data */
|
||||||
|
#define AUTH_NAMESZ 15 /* max allows auth protocol name size */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Pick a default communication scheme, if none was specified.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if !defined(SYSV_IPC) && !defined(UNIX_DOMAIN_SOCKETS) && !defined(INTERNET_DOMAIN_SOCKETS)
|
||||||
|
|
||||||
|
#ifdef HAVE_SYSVIPC
|
||||||
|
#define SYSV_IPC /* SYSV systems use SYSV IPC by default */
|
||||||
|
#endif /* HAVE_SYSVIPC */
|
||||||
|
|
||||||
|
#ifdef BSD
|
||||||
|
#define UNIX_DOMAIN_SOCKETS /* BSD systems use Unix Domain sockets by default */
|
||||||
|
#endif /* BSD */
|
||||||
|
|
||||||
|
#endif /* No communication method pre-defined */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If you are using SYSV_IPC, you might want to make the buffer size bigger
|
||||||
|
* since it limits the size of requests and responses. Don't make it bigger
|
||||||
|
* than your system's max message size though (usually a couple of k) or else
|
||||||
|
* msgsend will start failing. For sockets, using the system BUFSIZ is usually
|
||||||
|
* what you want.
|
||||||
|
*/
|
||||||
|
|
||||||
|
# define GSERV_BUFSZ BUFSIZ
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef SYSV_IPC
|
||||||
|
#include <sys/ipc.h>
|
||||||
|
#include <sys/msg.h>
|
||||||
|
|
||||||
|
#define send_string(s,str) \
|
||||||
|
if (strlen(msgp->mtext) + strlen(str) < GSERV_BUFSZ) \
|
||||||
|
strcat(msgp->mtext,str); \
|
||||||
|
else \
|
||||||
|
{ \
|
||||||
|
fprintf(stderr,"%s: not enough message buffer space\n",progname); \
|
||||||
|
exit(1); \
|
||||||
|
} \
|
||||||
|
|
||||||
|
#endif /* SYSV_IPC */
|
||||||
|
|
||||||
|
#if defined(INTERNET_DOMAIN_SOCKETS) || defined(UNIX_DOMAIN_SOCKETS)
|
||||||
|
#include <sys/socket.h>
|
||||||
|
#endif /* INTERNET_DOMAIN_SOCKETS || UNIX_DOMAIN_SOCKETS */
|
||||||
|
|
||||||
|
#ifdef INTERNET_DOMAIN_SOCKETS
|
||||||
|
#include <netdb.h>
|
||||||
|
#include <netinet/in.h>
|
||||||
|
#include <arpa/inet.h>
|
||||||
|
#define TABLE_SIZE 101 /* The number of entries in the hash table */
|
||||||
|
#define HASH(host) host /* Rather simplistic hash function */
|
||||||
|
#define DEFAULT_PORT 21490 /* default port number to use is
|
||||||
|
* DEFAULT_PORT + uid */
|
||||||
|
#endif /* INTERNET_DOMAIN_SOCKETS */
|
||||||
|
|
||||||
|
#ifdef UNIX_DOMAIN_SOCKETS
|
||||||
|
#include <sys/un.h>
|
||||||
|
#define HIDE_UNIX_SOCKET /* put the unix socket in a protected dir */
|
||||||
|
#endif /* UNIX_DOMAIN_SOCKETS */
|
||||||
|
|
||||||
|
#define HOSTNAMSZ 255 /* max size of a hostname */
|
||||||
|
#define REPLYSIZ 300 /* max size of reply from server to client */
|
||||||
|
#undef FALSE
|
||||||
|
#define FALSE 0
|
||||||
|
#undef TRUE
|
||||||
|
#define TRUE 1
|
||||||
|
|
||||||
|
// extern char *optarg;
|
||||||
|
// extern int optind;
|
||||||
|
|
||||||
|
/* The casts shut Sun's compiler up and are safe in the context these
|
||||||
|
are actually used. */
|
||||||
|
#define max2(x,y) (((int) (x) > (int) (y)) ? (x) : (y))
|
||||||
|
#define min2(x,y) (((int) (x) < (int) (y)) ? (x) : (y))
|
||||||
|
|
||||||
|
#ifndef _NFILE /* rough guess at maximum number of open files */
|
||||||
|
#define _NFILE 20
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define EOT_STR "\004"
|
||||||
|
#define EOT_CHR '\004'
|
||||||
|
|
||||||
|
/* connection types */
|
||||||
|
#define CONN_UNIX 0
|
||||||
|
#define CONN_INTERNET 1
|
||||||
|
#define CONN_IPC 2
|
||||||
|
|
||||||
|
/* function declarations */
|
||||||
|
extern int glibtop_make_connection __P((const char *, int, int *));
|
||||||
|
|
||||||
|
#ifdef SYSV_IPC
|
||||||
|
void disconnect_from_ipc_server();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(INTERNET_DOMAIN_SOCKETS) || defined(UNIX_DOMAIN_SOCKETS)
|
||||||
|
// void send_string (int s, const char *msg);
|
||||||
|
// void disconnect_from_server (int s, int echo);
|
||||||
|
// int read_line (int s, char *dest);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef INTERNET_DOMAIN_SOCKETS
|
||||||
|
extern long glibtop_internet_addr __P((const char *));
|
||||||
|
#endif
|
@@ -79,7 +79,7 @@ extern SCM glibtop_guile_descriptions_loadavg __P((void));
|
|||||||
/* You need to link with -lgtop_names to get this stuff here. */
|
/* You need to link with -lgtop_names to get this stuff here. */
|
||||||
|
|
||||||
extern const char *glibtop_names_loadavg [];
|
extern const char *glibtop_names_loadavg [];
|
||||||
extern const char *glibtop_types_loadavg [];
|
extern const unsigned glibtop_types_loadavg [];
|
||||||
extern const char *glibtop_labels_loadavg [];
|
extern const char *glibtop_labels_loadavg [];
|
||||||
extern const char *glibtop_descriptions_loadavg [];
|
extern const char *glibtop_descriptions_loadavg [];
|
||||||
|
|
||||||
|
@@ -26,8 +26,19 @@
|
|||||||
|
|
||||||
__BEGIN_DECLS
|
__BEGIN_DECLS
|
||||||
|
|
||||||
|
#define _GLIBTOP_INIT_STATE_INIT 0x10000
|
||||||
|
#define _GLIBTOP_INIT_STATE_OPEN 0x20000
|
||||||
|
#define _GLIBTOP_INIT_STATE_SERVER 0x40000
|
||||||
|
|
||||||
|
#define GLIBTOP_INIT_NO_OPEN 1
|
||||||
|
#define GLIBTOP_INIT_NO_INIT 2
|
||||||
|
|
||||||
#define GLIBTOP_OPEN_NO_OVERRIDE 1
|
#define GLIBTOP_OPEN_NO_OVERRIDE 1
|
||||||
|
|
||||||
|
#define GLIBTOP_METHOD_DIRECT 1
|
||||||
|
#define GLIBTOP_METHOD_PIPE 2
|
||||||
|
#define GLIBTOP_METHOD_INET 3
|
||||||
|
|
||||||
extern void glibtop_open_l __P((glibtop *, const char *, const unsigned long, const unsigned));
|
extern void glibtop_open_l __P((glibtop *, const char *, const unsigned long, const unsigned));
|
||||||
|
|
||||||
extern void glibtop_open_r __P((glibtop *, const char *, const unsigned long, const unsigned));
|
extern void glibtop_open_r __P((glibtop *, const char *, const unsigned long, const unsigned));
|
||||||
|
@@ -1,5 +1,3 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
||||||
This file is part of the Gnome Top Library.
|
This file is part of the Gnome Top Library.
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
||||||
@@ -19,34 +17,26 @@
|
|||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||||
Boston, MA 02111-1307, USA. */
|
Boston, MA 02111-1307, USA. */
|
||||||
|
|
||||||
|
#ifndef __GLIBTOP_PARAMETER_H__
|
||||||
|
#define __GLIBTOP_PARAMETER_H__
|
||||||
|
|
||||||
#include <glibtop.h>
|
#include <glibtop.h>
|
||||||
#include <glibtop/xmalloc.h>
|
#include <glibtop/open.h>
|
||||||
#include <glibtop/proclist.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
__BEGIN_DECLS
|
||||||
|
|
||||||
SCM
|
#define GLIBTOP_PARAM_METHOD 1
|
||||||
glibtop_guile_get_proclist (void)
|
#define GLIBTOP_PARAM_FEATURES 2
|
||||||
{
|
#define GLIBTOP_PARAM_COMMAND 3
|
||||||
glibtop_proclist proclist;
|
#define GLIBTOP_PARAM_HOST 4
|
||||||
unsigned *ptr;
|
#define GLIBTOP_PARAM_PORT 5
|
||||||
unsigned i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
ptr = glibtop_get_proclist (&proclist);
|
#define glibtop_get_parameter(p1,p2,p3) glibtop_get_parameter_l(glibtop_global_server,p1,p2,p3)
|
||||||
|
#define glibtop_set_parameter(p1,p2,p3) glibtop_set_parameter_l(glibtop_global_server,p1,p2,p3)
|
||||||
|
|
||||||
list = gh_list (gh_ulong2scm (proclist.flags),
|
extern size_t glibtop_get_parameter_l __P((glibtop *, const unsigned, void *, size_t));
|
||||||
gh_ulong2scm (proclist.number),
|
extern void glibtop_set_parameter_l __P((glibtop *, const unsigned, const void *, size_t));
|
||||||
gh_ulong2scm (proclist.size),
|
|
||||||
gh_ulong2scm (proclist.total),
|
|
||||||
SCM_UNDEFINED);
|
|
||||||
|
|
||||||
if (ptr) {
|
__END_DECLS
|
||||||
for (i = 0; i < proclist.number; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_ulong2scm ((unsigned long) ptr [i]), SCM_UNDEFINED));
|
|
||||||
}
|
|
||||||
|
|
||||||
glibtop_free (ptr);
|
#endif
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -27,7 +27,7 @@
|
|||||||
|
|
||||||
__BEGIN_DECLS
|
__BEGIN_DECLS
|
||||||
|
|
||||||
#define GLIBTOP_SYSDEPS_DUMMY 0
|
#define GLIBTOP_SYSDEPS_FEATURES 0
|
||||||
#define GLIBTOP_SYSDEPS_CPU 1
|
#define GLIBTOP_SYSDEPS_CPU 1
|
||||||
#define GLIBTOP_SYSDEPS_MEM 2
|
#define GLIBTOP_SYSDEPS_MEM 2
|
||||||
#define GLIBTOP_SYSDEPS_SWAP 3
|
#define GLIBTOP_SYSDEPS_SWAP 3
|
||||||
@@ -101,7 +101,7 @@ extern SCM glibtop_guile_descriptions_sysdeps __P((void));
|
|||||||
/* You need to link with -lgtop_names to get this stuff here. */
|
/* You need to link with -lgtop_names to get this stuff here. */
|
||||||
|
|
||||||
extern const char *glibtop_names_sysdeps [];
|
extern const char *glibtop_names_sysdeps [];
|
||||||
extern const char *glibtop_types_sysdeps [];
|
extern const unsigned glibtop_types_sysdeps [];
|
||||||
extern const char *glibtop_labels_sysdeps [];
|
extern const char *glibtop_labels_sysdeps [];
|
||||||
extern const char *glibtop_descriptions_sysdeps [];
|
extern const char *glibtop_descriptions_sysdeps [];
|
||||||
|
|
||||||
|
@@ -30,11 +30,13 @@ __BEGIN_DECLS
|
|||||||
#define glibtop_malloc(p1) glibtop_malloc_r(glibtop_global_server, p1)
|
#define glibtop_malloc(p1) glibtop_malloc_r(glibtop_global_server, p1)
|
||||||
#define glibtop_calloc(p1, p2) glibtop_calloc_r(glibtop_global_server, p1, p2)
|
#define glibtop_calloc(p1, p2) glibtop_calloc_r(glibtop_global_server, p1, p2)
|
||||||
#define glibtop_realloc(p1, p2) glibtop_realloc_r(glibtop_global_server, p1, p2)
|
#define glibtop_realloc(p1, p2) glibtop_realloc_r(glibtop_global_server, p1, p2)
|
||||||
|
#define glibtop_strdup(p2) glibtop_strdup_r(glibtop_global_server, p1)
|
||||||
#define glibtop_free(p1) glibtop_free_r(glibtop_global_server, p1)
|
#define glibtop_free(p1) glibtop_free_r(glibtop_global_server, p1)
|
||||||
|
|
||||||
extern void *glibtop_malloc_r __P((glibtop *, size_t));
|
extern void *glibtop_malloc_r __P((glibtop *, size_t));
|
||||||
extern void *glibtop_calloc_r __P((glibtop *, size_t, size_t));
|
extern void *glibtop_calloc_r __P((glibtop *, size_t, size_t));
|
||||||
extern void *glibtop_realloc_r __P((glibtop *, void *, size_t));
|
extern void *glibtop_realloc_r __P((glibtop *, void *, size_t));
|
||||||
|
extern char *glibtop_strdup_r __P((glibtop *, const char *));
|
||||||
extern void glibtop_free_r __P((glibtop *, void *));
|
extern void glibtop_free_r __P((glibtop *, void *));
|
||||||
|
|
||||||
__END_DECLS
|
__END_DECLS
|
||||||
|
6
kernel/ChangeLog
Normal file
6
kernel/ChangeLog
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
1998-06-14 Martin Baulig <baulig@taurus.uni-trier.de>
|
||||||
|
|
||||||
|
* README: Added README.
|
||||||
|
|
||||||
|
* kernel.patch: Patch for the Linux kernel to add the
|
||||||
|
new system call.
|
21
kernel/README
Normal file
21
kernel/README
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
This is a new system call `table ()' for the Linux table. It is faster
|
||||||
|
than reading from /proc and can be used to fetch all information required
|
||||||
|
for libgtop until whe have some other function (extended sysctl, ...) in
|
||||||
|
standard kernels.
|
||||||
|
|
||||||
|
I didn't want to change sysctl or some other function myself cause this may
|
||||||
|
cause other applications relying upon those function to fail. This is
|
||||||
|
something for the ``real'' kernel gurus ...
|
||||||
|
|
||||||
|
To use this new system call for libgtop, do the following:
|
||||||
|
|
||||||
|
* Copy this directory to /usr/src/linux/table
|
||||||
|
* Make /usr/src/linux/include/linux/table.h symlink to /usr/src/linux/table/table.h
|
||||||
|
* Apply the patch `kernel.patch' to the kernel, compile, install and reboot
|
||||||
|
* Recompile libgtop (remove `config.cache' and run the `autogen.sh' again).
|
||||||
|
|
||||||
|
If you want to change and/or add something - feel free to do so !
|
||||||
|
|
||||||
|
Have fun,
|
||||||
|
|
||||||
|
Martin
|
49
kernel/kernel.patch
Normal file
49
kernel/kernel.patch
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
diff -ur linux-2.0.32/Makefile linux-hacked/Makefile
|
||||||
|
--- linux-2.0.32/Makefile Fri Nov 7 19:51:05 1997
|
||||||
|
+++ linux-hacked/Makefile Thu Jun 11 20:41:12 1998
|
||||||
|
@@ -87,7 +87,7 @@
|
||||||
|
# standard CFLAGS
|
||||||
|
#
|
||||||
|
|
||||||
|
-CFLAGS = -Wall -Wstrict-prototypes -O2 -fomit-frame-pointer -fno-strength-reduce
|
||||||
|
+CFLAGS = -Wall -Wstrict-prototypes -g -O2 -fomit-frame-pointer -fno-strength-reduce
|
||||||
|
|
||||||
|
ifdef CONFIG_CPP
|
||||||
|
CFLAGS := $(CFLAGS) -x c++
|
||||||
|
@@ -113,12 +113,12 @@
|
||||||
|
# Include the make variables (CC, etc...)
|
||||||
|
#
|
||||||
|
|
||||||
|
-ARCHIVES =kernel/kernel.o mm/mm.o fs/fs.o ipc/ipc.o net/network.a
|
||||||
|
+ARCHIVES =kernel/kernel.o mm/mm.o fs/fs.o ipc/ipc.o net/network.a table/table.o
|
||||||
|
FILESYSTEMS =fs/filesystems.a
|
||||||
|
DRIVERS =drivers/block/block.a \
|
||||||
|
drivers/char/char.a
|
||||||
|
LIBS =$(TOPDIR)/lib/lib.a
|
||||||
|
-SUBDIRS =kernel drivers mm fs net ipc lib
|
||||||
|
+SUBDIRS =kernel drivers mm fs net ipc lib table
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_ISDN),y)
|
||||||
|
DRIVERS := $(DRIVERS) drivers/isdn/isdn.a
|
||||||
|
diff -ur linux-2.0.32/arch/i386/kernel/entry.S linux-hacked/arch/i386/kernel/entry.S
|
||||||
|
--- linux-2.0.32/arch/i386/kernel/entry.S Tue Sep 16 23:42:45 1997
|
||||||
|
+++ linux-hacked/arch/i386/kernel/entry.S Thu Jun 11 21:37:20 1998
|
||||||
|
@@ -699,4 +699,6 @@
|
||||||
|
.long SYMBOL_NAME(sys_mremap)
|
||||||
|
.long 0,0
|
||||||
|
.long SYMBOL_NAME(sys_vm86)
|
||||||
|
- .space (NR_syscalls-166)*4
|
||||||
|
+ .long 0
|
||||||
|
+ .long SYMBOL_NAME(sys_table)
|
||||||
|
+ .space (NR_syscalls-168)*4
|
||||||
|
diff -ur linux-2.0.32/include/asm-i386/unistd.h linux-hacked/include/asm-i386/unistd.h
|
||||||
|
--- linux-2.0.32/include/asm-i386/unistd.h Fri Mar 22 07:34:02 1996
|
||||||
|
+++ linux-hacked/include/asm-i386/unistd.h Thu Jun 11 21:37:03 1998
|
||||||
|
@@ -169,6 +169,7 @@
|
||||||
|
#define __NR_sched_rr_get_interval 161
|
||||||
|
#define __NR_nanosleep 162
|
||||||
|
#define __NR_mremap 163
|
||||||
|
+#define __NR_table 168
|
||||||
|
|
||||||
|
/* XXX - _foo needs to be __foo, while __NR_bar could be _NR_bar. */
|
||||||
|
#define _syscall0(type,name) \
|
341
kernel/main.c
341
kernel/main.c
@@ -28,11 +28,168 @@
|
|||||||
|
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
|
|
||||||
|
#if defined(__i386__)
|
||||||
|
# define KSTK_EIP(tsk) (((unsigned long *)tsk->kernel_stack_page)[1019])
|
||||||
|
# define KSTK_ESP(tsk) (((unsigned long *)tsk->kernel_stack_page)[1022])
|
||||||
|
#elif defined(__alpha__)
|
||||||
|
/*
|
||||||
|
* See arch/alpha/kernel/ptrace.c for details.
|
||||||
|
*/
|
||||||
|
# define PT_REG(reg) (PAGE_SIZE - sizeof(struct pt_regs) \
|
||||||
|
+ (long)&((struct pt_regs *)0)->reg)
|
||||||
|
# define KSTK_EIP(tsk) (*(unsigned long *)(tsk->kernel_stack_page + PT_REG(pc)))
|
||||||
|
# define KSTK_ESP(tsk) ((tsk) == current ? rdusp() : (tsk)->tss.usp)
|
||||||
|
#elif defined(__sparc__)
|
||||||
|
# define PT_REG(reg) (PAGE_SIZE - sizeof(struct pt_regs) \
|
||||||
|
+ (long)&((struct pt_regs *)0)->reg)
|
||||||
|
# define KSTK_EIP(tsk) (*(unsigned long *)(tsk->kernel_stack_page + PT_REG(pc)))
|
||||||
|
# define KSTK_ESP(tsk) (*(unsigned long *)(tsk->kernel_stack_page + PT_REG(u_regs[UREG_FP])))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static struct task_struct *
|
||||||
|
get_task (pid_t pid)
|
||||||
|
{
|
||||||
|
struct task_struct ** p;
|
||||||
|
|
||||||
|
p = task;
|
||||||
|
while (++p < task+NR_TASKS) {
|
||||||
|
if (*p && (*p)->pid == pid)
|
||||||
|
return *p;
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void statm_pte_range(pmd_t * pmd, unsigned long address, unsigned long size,
|
||||||
|
int * pages, int * shared, int * dirty, int * total)
|
||||||
|
{
|
||||||
|
pte_t * pte;
|
||||||
|
unsigned long end;
|
||||||
|
|
||||||
|
if (pmd_none(*pmd))
|
||||||
|
return;
|
||||||
|
if (pmd_bad(*pmd)) {
|
||||||
|
printk("statm_pte_range: bad pmd (%08lx)\n", pmd_val(*pmd));
|
||||||
|
pmd_clear(pmd);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
pte = pte_offset(pmd, address);
|
||||||
|
address &= ~PMD_MASK;
|
||||||
|
end = address + size;
|
||||||
|
if (end > PMD_SIZE)
|
||||||
|
end = PMD_SIZE;
|
||||||
|
do {
|
||||||
|
pte_t page = *pte;
|
||||||
|
|
||||||
|
address += PAGE_SIZE;
|
||||||
|
pte++;
|
||||||
|
if (pte_none(page))
|
||||||
|
continue;
|
||||||
|
++*total;
|
||||||
|
if (!pte_present(page))
|
||||||
|
continue;
|
||||||
|
++*pages;
|
||||||
|
if (pte_dirty(page))
|
||||||
|
++*dirty;
|
||||||
|
if (pte_page(page) >= high_memory)
|
||||||
|
continue;
|
||||||
|
if (mem_map[MAP_NR(pte_page(page))].count > 1)
|
||||||
|
++*shared;
|
||||||
|
} while (address < end);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void statm_pmd_range(pgd_t * pgd, unsigned long address, unsigned long size,
|
||||||
|
int * pages, int * shared, int * dirty, int * total)
|
||||||
|
{
|
||||||
|
pmd_t * pmd;
|
||||||
|
unsigned long end;
|
||||||
|
|
||||||
|
if (pgd_none(*pgd))
|
||||||
|
return;
|
||||||
|
if (pgd_bad(*pgd)) {
|
||||||
|
printk("statm_pmd_range: bad pgd (%08lx)\n", pgd_val(*pgd));
|
||||||
|
pgd_clear(pgd);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
pmd = pmd_offset(pgd, address);
|
||||||
|
address &= ~PGDIR_MASK;
|
||||||
|
end = address + size;
|
||||||
|
if (end > PGDIR_SIZE)
|
||||||
|
end = PGDIR_SIZE;
|
||||||
|
do {
|
||||||
|
statm_pte_range(pmd, address, end - address, pages, shared, dirty, total);
|
||||||
|
address = (address + PMD_SIZE) & PMD_MASK;
|
||||||
|
pmd++;
|
||||||
|
} while (address < end);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void statm_pgd_range(pgd_t * pgd, unsigned long address, unsigned long end,
|
||||||
|
int * pages, int * shared, int * dirty, int * total)
|
||||||
|
{
|
||||||
|
while (address < end) {
|
||||||
|
statm_pmd_range(pgd, address, end - address, pages, shared, dirty, total);
|
||||||
|
address = (address + PGDIR_SIZE) & PGDIR_MASK;
|
||||||
|
pgd++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static unsigned long
|
||||||
|
get_wchan (struct task_struct *p)
|
||||||
|
{
|
||||||
|
if (!p || p == current || p->state == TASK_RUNNING)
|
||||||
|
return 0;
|
||||||
|
#if defined(__i386__)
|
||||||
|
{
|
||||||
|
unsigned long ebp, eip;
|
||||||
|
unsigned long stack_page;
|
||||||
|
int count = 0;
|
||||||
|
|
||||||
|
stack_page = p->kernel_stack_page;
|
||||||
|
if (!stack_page)
|
||||||
|
return 0;
|
||||||
|
ebp = p->tss.ebp;
|
||||||
|
do {
|
||||||
|
if (ebp < stack_page || ebp >= 4092+stack_page)
|
||||||
|
return 0;
|
||||||
|
eip = *(unsigned long *) (ebp+4);
|
||||||
|
if (eip < (unsigned long) interruptible_sleep_on
|
||||||
|
|| eip >= (unsigned long) add_timer)
|
||||||
|
return eip;
|
||||||
|
ebp = *(unsigned long *) ebp;
|
||||||
|
} while (count++ < 16);
|
||||||
|
}
|
||||||
|
#elif defined(__alpha__)
|
||||||
|
/*
|
||||||
|
* This one depends on the frame size of schedule(). Do a
|
||||||
|
* "disass schedule" in gdb to find the frame size. Also, the
|
||||||
|
* code assumes that sleep_on() follows immediately after
|
||||||
|
* interruptible_sleep_on() and that add_timer() follows
|
||||||
|
* immediately after interruptible_sleep(). Ugly, isn't it?
|
||||||
|
* Maybe adding a wchan field to task_struct would be better,
|
||||||
|
* after all...
|
||||||
|
*/
|
||||||
|
{
|
||||||
|
unsigned long schedule_frame;
|
||||||
|
unsigned long pc;
|
||||||
|
|
||||||
|
pc = thread_saved_pc(&p->tss);
|
||||||
|
if (pc >= (unsigned long) interruptible_sleep_on && pc < (unsigned long) add_timer) {
|
||||||
|
schedule_frame = ((unsigned long *)p->tss.ksp)[6];
|
||||||
|
return ((unsigned long *)schedule_frame)[12];
|
||||||
|
}
|
||||||
|
return pc;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
asmlinkage int
|
asmlinkage int
|
||||||
sys_table (int type, union table *buf)
|
sys_table (int type, union table *buf, const void *param)
|
||||||
{
|
{
|
||||||
union table tbl;
|
union table tbl;
|
||||||
struct sysinfo i;
|
struct sysinfo i;
|
||||||
|
struct task_struct *tsk = NULL;
|
||||||
|
pid_t pid;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
if (type == TABLE_VERSION)
|
if (type == TABLE_VERSION)
|
||||||
@@ -41,6 +198,31 @@ sys_table (int type, union table *buf)
|
|||||||
if (!buf)
|
if (!buf)
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
|
|
||||||
|
memset (&tbl, 0, sizeof (union table));
|
||||||
|
|
||||||
|
/* For TABLE_PROC_*, read pid and get task_struct */
|
||||||
|
|
||||||
|
switch (type) {
|
||||||
|
case TABLE_PROC_UID:
|
||||||
|
case TABLE_PROC_MEM:
|
||||||
|
case TABLE_PROC_SEGMENT:
|
||||||
|
case TABLE_PROC_TIME:
|
||||||
|
case TABLE_PROC_STATE:
|
||||||
|
case TABLE_PROC_SIGNAL:
|
||||||
|
case TABLE_PROC_KERNEL:
|
||||||
|
err = verify_area (VERIFY_READ, param, sizeof (pid_t));
|
||||||
|
if (err)
|
||||||
|
return err;
|
||||||
|
memcpy_fromfs (&pid, param, sizeof (pid_t));
|
||||||
|
|
||||||
|
tsk = get_task (pid);
|
||||||
|
if (tsk == NULL)
|
||||||
|
return -ESRCH;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Main function dispatcher */
|
||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case TABLE_CPU:
|
case TABLE_CPU:
|
||||||
tbl.cpu.total = jiffies;
|
tbl.cpu.total = jiffies;
|
||||||
@@ -66,9 +248,9 @@ sys_table (int type, union table *buf)
|
|||||||
tbl.swap.free = i.freeswap;
|
tbl.swap.free = i.freeswap;
|
||||||
break;
|
break;
|
||||||
case TABLE_LOADAVG:
|
case TABLE_LOADAVG:
|
||||||
tbl.loadavg.loadavg [0] = avenrun [0];
|
tbl.loadavg.loadavg [0] = (double) avenrun [0] / (1 << FSHIFT);
|
||||||
tbl.loadavg.loadavg [1] = avenrun [1];
|
tbl.loadavg.loadavg [1] = (double) avenrun [1] / (1 << FSHIFT);
|
||||||
tbl.loadavg.loadavg [2] = avenrun [2];
|
tbl.loadavg.loadavg [2] = (double) avenrun [2] / (1 << FSHIFT);
|
||||||
tbl.loadavg.nr_running = nr_running;
|
tbl.loadavg.nr_running = nr_running;
|
||||||
tbl.loadavg.nr_tasks = nr_tasks;
|
tbl.loadavg.nr_tasks = nr_tasks;
|
||||||
tbl.loadavg.last_pid = last_pid;
|
tbl.loadavg.last_pid = last_pid;
|
||||||
@@ -77,6 +259,157 @@ sys_table (int type, union table *buf)
|
|||||||
tbl.uptime.uptime = jiffies;
|
tbl.uptime.uptime = jiffies;
|
||||||
tbl.uptime.idle = task[0]->utime + task[0]->stime;
|
tbl.uptime.idle = task[0]->utime + task[0]->stime;
|
||||||
break;
|
break;
|
||||||
|
case TABLE_PROC_STATE:
|
||||||
|
tbl.proc_state.state = tsk->state;
|
||||||
|
tbl.proc_state.flags = tsk->flags;
|
||||||
|
memcpy (tbl.proc_state.comm, tsk->comm, sizeof (tbl.proc_state.comm));
|
||||||
|
break;
|
||||||
|
case TABLE_PROC_UID:
|
||||||
|
tbl.proc_uid.uid = tsk->uid;
|
||||||
|
tbl.proc_uid.euid = tsk->euid;
|
||||||
|
tbl.proc_uid.suid = tsk->suid;
|
||||||
|
tbl.proc_uid.fsuid = tsk->fsuid;
|
||||||
|
|
||||||
|
tbl.proc_uid.gid = tsk->gid;
|
||||||
|
tbl.proc_uid.egid = tsk->egid;
|
||||||
|
tbl.proc_uid.sgid = tsk->sgid;
|
||||||
|
tbl.proc_uid.fsgid = tsk->fsgid;
|
||||||
|
|
||||||
|
tbl.proc_uid.pid = tsk->pid;
|
||||||
|
tbl.proc_uid.pgrp = tsk->pgrp;
|
||||||
|
tbl.proc_uid.ppid = tsk->p_pptr->pid;
|
||||||
|
|
||||||
|
tbl.proc_uid.session = tsk->session;
|
||||||
|
tbl.proc_uid.tty = tsk->tty ? kdev_t_to_nr (tsk->tty->device) : 0;
|
||||||
|
tbl.proc_uid.tpgid = tsk->tty ? tsk->tty->pgrp : -1;
|
||||||
|
|
||||||
|
tbl.proc_uid.priority = tsk->priority;
|
||||||
|
tbl.proc_uid.counter = tsk->counter;
|
||||||
|
tbl.proc_uid.def_priority = DEF_PRIORITY;
|
||||||
|
break;
|
||||||
|
case TABLE_PROC_SIGNAL:
|
||||||
|
tbl.proc_signal.signal = tsk->signal;
|
||||||
|
tbl.proc_signal.blocked = tsk->blocked;
|
||||||
|
|
||||||
|
if (tsk->sig) {
|
||||||
|
struct sigaction * action = tsk->sig->action;
|
||||||
|
unsigned long sig_ign = 0, sig_caught = 0;
|
||||||
|
unsigned long bit = 1;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < 32; i++) {
|
||||||
|
switch((unsigned long) action->sa_handler) {
|
||||||
|
case 0:
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
sig_ign |= bit;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
sig_caught |= bit;
|
||||||
|
}
|
||||||
|
bit <<= 1;
|
||||||
|
action++;
|
||||||
|
}
|
||||||
|
|
||||||
|
tbl.proc_signal.ignored = sig_ign;
|
||||||
|
tbl.proc_signal.caught = sig_caught;
|
||||||
|
} else {
|
||||||
|
tbl.proc_signal.ignored = 0;
|
||||||
|
tbl.proc_signal.caught = 0;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TABLE_PROC_MEM:
|
||||||
|
if (tsk->mm && tsk->mm != &init_mm) {
|
||||||
|
tbl.proc_mem.context = tsk->mm->context;
|
||||||
|
tbl.proc_mem.start_code = tsk->mm->start_code;
|
||||||
|
tbl.proc_mem.end_code = tsk->mm->end_code;
|
||||||
|
tbl.proc_mem.start_data = tsk->mm-> start_data;
|
||||||
|
tbl.proc_mem.end_data = tsk->mm->end_data;
|
||||||
|
tbl.proc_mem.start_brk = tsk->mm->start_brk;
|
||||||
|
tbl.proc_mem.brk = tsk->mm->brk;
|
||||||
|
tbl.proc_mem.start_stack = tsk->mm->start_stack;
|
||||||
|
tbl.proc_mem.start_mmap = tsk->mm->start_mmap;
|
||||||
|
tbl.proc_mem.arg_start = tsk->mm->arg_start;
|
||||||
|
tbl.proc_mem.arg_end = tsk->mm->arg_end;
|
||||||
|
tbl.proc_mem.env_start = tsk->mm->env_start;
|
||||||
|
tbl.proc_mem.env_end = tsk->mm->env_end;
|
||||||
|
tbl.proc_mem.rss = tsk->mm->rss;
|
||||||
|
tbl.proc_mem.total_vm = tsk->mm->total_vm;
|
||||||
|
tbl.proc_mem.locked_vm = tsk->mm->locked_vm;
|
||||||
|
}
|
||||||
|
tbl.proc_mem.rlim = tsk->rlim ? tsk->rlim[RLIMIT_RSS].rlim_cur : 0;
|
||||||
|
break;
|
||||||
|
case TABLE_PROC_SEGMENT:
|
||||||
|
if (tsk->mm && tsk->mm != &init_mm) {
|
||||||
|
unsigned long vsize = 0;
|
||||||
|
int size = 0, resident = 0, share = 0;
|
||||||
|
int trs = 0, lrs = 0, drs = 0, dt = 0;
|
||||||
|
struct vm_area_struct * vma = tsk->mm->mmap;
|
||||||
|
|
||||||
|
while (vma) {
|
||||||
|
pgd_t *pgd = pgd_offset(tsk->mm, vma->vm_start);
|
||||||
|
int pages = 0, shared = 0, dirty = 0, total = 0;
|
||||||
|
|
||||||
|
vsize += vma->vm_end - vma->vm_start;
|
||||||
|
|
||||||
|
statm_pgd_range (pgd, vma->vm_start, vma->vm_end,
|
||||||
|
&pages, &shared, &dirty, &total);
|
||||||
|
resident += pages;
|
||||||
|
share += shared;
|
||||||
|
dt += dirty;
|
||||||
|
size += total;
|
||||||
|
if (vma->vm_flags & VM_EXECUTABLE)
|
||||||
|
trs += pages; /* text */
|
||||||
|
else if (vma->vm_flags & VM_GROWSDOWN)
|
||||||
|
drs += pages; /* stack */
|
||||||
|
else if (vma->vm_end > 0x60000000)
|
||||||
|
lrs += pages; /* library */
|
||||||
|
else
|
||||||
|
drs += pages;
|
||||||
|
vma = vma->vm_next;
|
||||||
|
}
|
||||||
|
|
||||||
|
tbl.proc_segment.vsize = vsize;
|
||||||
|
tbl.proc_segment.size = size;
|
||||||
|
tbl.proc_segment.resident = resident;
|
||||||
|
tbl.proc_segment.shared = share;
|
||||||
|
tbl.proc_segment.trs = trs;
|
||||||
|
tbl.proc_segment.lrs = lrs;
|
||||||
|
tbl.proc_segment.dt = dt;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TABLE_PROC_TIME:
|
||||||
|
tbl.proc_time.utime = tsk->utime;
|
||||||
|
tbl.proc_time.stime = tsk->stime;
|
||||||
|
tbl.proc_time.cutime = tsk->cutime;
|
||||||
|
tbl.proc_time.cstime = tsk->cstime;
|
||||||
|
|
||||||
|
tbl.proc_time.start_time = tsk->start_time;
|
||||||
|
tbl.proc_time.timeout = tsk->timeout;
|
||||||
|
tbl.proc_time.policy = tsk->policy;
|
||||||
|
tbl.proc_time.rt_priority = tsk->rt_priority;
|
||||||
|
|
||||||
|
tbl.proc_time.it_real_value = tsk->it_real_value;
|
||||||
|
tbl.proc_time.it_prof_value = tsk->it_prof_value;
|
||||||
|
tbl.proc_time.it_virt_value = tsk->it_virt_value;
|
||||||
|
tbl.proc_time.it_real_incr = tsk->it_real_incr;
|
||||||
|
tbl.proc_time.it_prof_incr = tsk->it_prof_incr;
|
||||||
|
tbl.proc_time.it_virt_incr = tsk->it_virt_incr;
|
||||||
|
break;
|
||||||
|
case TABLE_PROC_KERNEL:
|
||||||
|
tbl.proc_kernel.min_flt = tsk->min_flt;
|
||||||
|
tbl.proc_kernel.cmin_flt = tsk->cmin_flt;
|
||||||
|
tbl.proc_kernel.maj_flt = tsk->maj_flt;
|
||||||
|
tbl.proc_kernel.cmaj_flt = tsk->cmaj_flt;
|
||||||
|
|
||||||
|
tbl.proc_kernel.kesp = tsk->kernel_stack_page ? KSTK_EIP(tsk) : 0;
|
||||||
|
tbl.proc_kernel.keip = tsk->kernel_stack_page ? KSTK_ESP(tsk) : 0;
|
||||||
|
|
||||||
|
tbl.proc_kernel.nswap = tsk->nswap;
|
||||||
|
tbl.proc_kernel.cnswap = tsk->cnswap;
|
||||||
|
|
||||||
|
tbl.proc_kernel.wchan = get_wchan (tsk);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
@@ -1,13 +1,23 @@
|
|||||||
#ifndef _LINUX_TABLE_H
|
#ifndef _LINUX_TABLE_H
|
||||||
#define _LINUX_TABLE_H
|
#define _LINUX_TABLE_H
|
||||||
#include <linux/types.h>
|
|
||||||
|
|
||||||
#define TABLE_VERSION 0
|
#ifdef _KERNEL
|
||||||
#define TABLE_CPU 1
|
#include <linux/types.h>
|
||||||
#define TABLE_MEM 2
|
#endif
|
||||||
#define TABLE_SWAP 3
|
|
||||||
#define TABLE_LOADAVG 4
|
#define TABLE_VERSION 0
|
||||||
#define TABLE_UPTIME 5
|
#define TABLE_CPU 1
|
||||||
|
#define TABLE_MEM 2
|
||||||
|
#define TABLE_SWAP 3
|
||||||
|
#define TABLE_LOADAVG 4
|
||||||
|
#define TABLE_UPTIME 5
|
||||||
|
#define TABLE_PROC_UID 6
|
||||||
|
#define TABLE_PROC_MEM 7
|
||||||
|
#define TABLE_PROC_SEGMENT 8
|
||||||
|
#define TABLE_PROC_TIME 9
|
||||||
|
#define TABLE_PROC_STATE 10
|
||||||
|
#define TABLE_PROC_SIGNAL 11
|
||||||
|
#define TABLE_PROC_KERNEL 12
|
||||||
|
|
||||||
/* CPU Usage (in jiffies = 1/100th seconds) */
|
/* CPU Usage (in jiffies = 1/100th seconds) */
|
||||||
|
|
||||||
@@ -46,7 +56,7 @@ struct table_swap
|
|||||||
|
|
||||||
struct table_loadavg
|
struct table_loadavg
|
||||||
{
|
{
|
||||||
unsigned long loadavg [3];
|
double loadavg [3];
|
||||||
unsigned nr_running;
|
unsigned nr_running;
|
||||||
unsigned nr_tasks;
|
unsigned nr_tasks;
|
||||||
unsigned last_pid;
|
unsigned last_pid;
|
||||||
@@ -60,6 +70,67 @@ struct table_uptime
|
|||||||
unsigned long idle;
|
unsigned long idle;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* Information about processes. */
|
||||||
|
|
||||||
|
struct table_proc_state
|
||||||
|
{
|
||||||
|
long state;
|
||||||
|
unsigned long flags;
|
||||||
|
char comm[16];
|
||||||
|
};
|
||||||
|
|
||||||
|
struct table_proc_uid
|
||||||
|
{
|
||||||
|
int uid, euid, suid, fsuid;
|
||||||
|
int gid, egid, sgid, fsgid;
|
||||||
|
int pid, pgrp, ppid;
|
||||||
|
int session;
|
||||||
|
unsigned int tty;
|
||||||
|
int tpgid;
|
||||||
|
long priority;
|
||||||
|
long counter;
|
||||||
|
long def_priority;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct table_proc_mem
|
||||||
|
{
|
||||||
|
unsigned long context;
|
||||||
|
unsigned long start_code, end_code, start_data, end_data;
|
||||||
|
unsigned long start_brk, brk, start_stack, start_mmap;
|
||||||
|
unsigned long arg_start, arg_end, env_start, env_end;
|
||||||
|
unsigned long rss, rlim, total_vm, locked_vm;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct table_proc_segment
|
||||||
|
{
|
||||||
|
unsigned long vsize;
|
||||||
|
int size, resident, shared;
|
||||||
|
int trs, lrs, drs, dt;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct table_proc_time
|
||||||
|
{
|
||||||
|
long utime, stime, cutime, cstime, start_time;
|
||||||
|
unsigned long timeout, policy, rt_priority;
|
||||||
|
unsigned long it_real_value, it_prof_value, it_virt_value;
|
||||||
|
unsigned long it_real_incr, it_prof_incr, it_virt_incr;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct table_proc_signal
|
||||||
|
{
|
||||||
|
unsigned long signal;
|
||||||
|
unsigned long blocked; /* bitmap of masked signals */
|
||||||
|
unsigned long ignored; /* mask of ignored signals */
|
||||||
|
unsigned long caught; /* mask of caught signals */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct table_proc_kernel
|
||||||
|
{
|
||||||
|
unsigned long keip, kesp, wchan;
|
||||||
|
unsigned long min_flt, maj_flt, cmin_flt, cmaj_flt;
|
||||||
|
unsigned long nswap, cnswap;
|
||||||
|
};
|
||||||
|
|
||||||
/* Union */
|
/* Union */
|
||||||
|
|
||||||
union table
|
union table
|
||||||
@@ -69,12 +140,15 @@ union table
|
|||||||
struct table_swap swap;
|
struct table_swap swap;
|
||||||
struct table_loadavg loadavg;
|
struct table_loadavg loadavg;
|
||||||
struct table_uptime uptime;
|
struct table_uptime uptime;
|
||||||
|
struct table_proc_uid proc_uid;
|
||||||
|
struct table_proc_mem proc_mem;
|
||||||
|
struct table_proc_segment proc_segment;
|
||||||
|
struct table_proc_time proc_time;
|
||||||
|
struct table_proc_state proc_state;
|
||||||
|
struct table_proc_signal proc_signal;
|
||||||
|
struct table_proc_kernel proc_kernel;
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef __KERNEL__
|
|
||||||
|
|
||||||
#endif /* __KERNEL__ */
|
|
||||||
|
|
||||||
#endif /* _LINUX_IPC_H */
|
#endif /* _LINUX_IPC_H */
|
||||||
|
|
||||||
|
|
||||||
|
@@ -7,15 +7,16 @@
|
|||||||
|
|
||||||
#include <syscall.h>
|
#include <syscall.h>
|
||||||
|
|
||||||
static inline _syscall2 (int, table, int, type, union table *, tbl);
|
static inline _syscall3 (int, table, int, type, union table *, tbl, const void *, param);
|
||||||
|
|
||||||
int
|
int
|
||||||
main (void)
|
main (void)
|
||||||
{
|
{
|
||||||
union table tbl;
|
union table tbl;
|
||||||
|
unsigned count;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
ret = table (TABLE_VERSION, NULL);
|
ret = table (TABLE_VERSION, NULL, NULL);
|
||||||
|
|
||||||
if (ret == -1) {
|
if (ret == -1) {
|
||||||
fprintf (stderr, "table(%u): %s\n", TABLE_VERSION, sys_errlist [errno]);
|
fprintf (stderr, "table(%u): %s\n", TABLE_VERSION, sys_errlist [errno]);
|
||||||
@@ -24,18 +25,20 @@ main (void)
|
|||||||
|
|
||||||
fprintf (stderr, "Table (%u) = %u\n", TABLE_VERSION, ret);
|
fprintf (stderr, "Table (%u) = %u\n", TABLE_VERSION, ret);
|
||||||
|
|
||||||
ret = table (TABLE_CPU, &tbl);
|
for (count = 0; count < 5; count++) {
|
||||||
|
ret = table (TABLE_CPU, &tbl, NULL);
|
||||||
|
|
||||||
if (ret == -1) {
|
if (ret == -1) {
|
||||||
fprintf (stderr, "table(%u): %s\n", TABLE_CPU, sys_errlist [errno]);
|
fprintf (stderr, "table(%u): %s\n", TABLE_CPU, sys_errlist [errno]);
|
||||||
exit (-errno);
|
exit (-errno);
|
||||||
|
}
|
||||||
|
|
||||||
|
fprintf (stderr, "Table (%u) = %lu, %lu, %lu, %lu, %lu, %lu\n",
|
||||||
|
TABLE_CPU, tbl.cpu.total, tbl.cpu.user, tbl.cpu.nice,
|
||||||
|
tbl.cpu.sys, tbl.cpu.idle, tbl.cpu.frequency);
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf (stderr, "Table (%u) = %lu, %lu, %lu, %lu, %lu, %lu\n",
|
ret = table (TABLE_MEM, &tbl, NULL);
|
||||||
TABLE_CPU, tbl.cpu.total, tbl.cpu.user, tbl.cpu.nice,
|
|
||||||
tbl.cpu.sys, tbl.cpu.idle, tbl.cpu.frequency);
|
|
||||||
|
|
||||||
ret = table (TABLE_MEM, &tbl);
|
|
||||||
|
|
||||||
if (ret == -1) {
|
if (ret == -1) {
|
||||||
fprintf (stderr, "table(%u): %s\n", TABLE_MEM, sys_errlist [errno]);
|
fprintf (stderr, "table(%u): %s\n", TABLE_MEM, sys_errlist [errno]);
|
||||||
@@ -46,7 +49,7 @@ main (void)
|
|||||||
TABLE_MEM, tbl.mem.total, tbl.mem.used, tbl.mem.free,
|
TABLE_MEM, tbl.mem.total, tbl.mem.used, tbl.mem.free,
|
||||||
tbl.mem.shared, tbl.mem.buffer, tbl.mem.cached);
|
tbl.mem.shared, tbl.mem.buffer, tbl.mem.cached);
|
||||||
|
|
||||||
ret = table (TABLE_SWAP, &tbl);
|
ret = table (TABLE_SWAP, &tbl, NULL);
|
||||||
|
|
||||||
if (ret == -1) {
|
if (ret == -1) {
|
||||||
fprintf (stderr, "table(%u): %s\n", TABLE_SWAP, sys_errlist [errno]);
|
fprintf (stderr, "table(%u): %s\n", TABLE_SWAP, sys_errlist [errno]);
|
||||||
@@ -56,7 +59,7 @@ main (void)
|
|||||||
fprintf (stderr, "Table (%u) = %lu, %lu, %lu\n",
|
fprintf (stderr, "Table (%u) = %lu, %lu, %lu\n",
|
||||||
TABLE_SWAP, tbl.swap.total, tbl.swap.used, tbl.swap.free);
|
TABLE_SWAP, tbl.swap.total, tbl.swap.used, tbl.swap.free);
|
||||||
|
|
||||||
ret = table (TABLE_LOADAVG, &tbl);
|
ret = table (TABLE_LOADAVG, &tbl, NULL);
|
||||||
|
|
||||||
if (ret == -1) {
|
if (ret == -1) {
|
||||||
fprintf (stderr, "table(%u): %s\n", TABLE_LOADAVG, sys_errlist [errno]);
|
fprintf (stderr, "table(%u): %s\n", TABLE_LOADAVG, sys_errlist [errno]);
|
||||||
@@ -68,7 +71,7 @@ main (void)
|
|||||||
tbl.loadavg.loadavg [2], tbl.loadavg.nr_running,
|
tbl.loadavg.loadavg [2], tbl.loadavg.nr_running,
|
||||||
tbl.loadavg.nr_tasks, tbl.loadavg.last_pid);
|
tbl.loadavg.nr_tasks, tbl.loadavg.last_pid);
|
||||||
|
|
||||||
ret = table (TABLE_UPTIME, &tbl);
|
ret = table (TABLE_UPTIME, &tbl, NULL);
|
||||||
|
|
||||||
if (ret == -1) {
|
if (ret == -1) {
|
||||||
fprintf (stderr, "table(%u): %s\n", TABLE_UPTIME, sys_errlist [errno]);
|
fprintf (stderr, "table(%u): %s\n", TABLE_UPTIME, sys_errlist [errno]);
|
||||||
|
@@ -32,3 +32,4 @@ sysinfo.lo
|
|||||||
uptime.lo
|
uptime.lo
|
||||||
write.lo
|
write.lo
|
||||||
xmalloc.lo
|
xmalloc.lo
|
||||||
|
lib.c
|
||||||
|
@@ -4,14 +4,20 @@ INCLUDES = -I$(top_builddir) -I$(top_srcdir) @machine_incs@ \
|
|||||||
-I$(top_srcdir)/include -I$(top_srcdir)/intl @GUILE_INCS@ \
|
-I$(top_srcdir)/include -I$(top_srcdir)/intl @GUILE_INCS@ \
|
||||||
-DGTOPLOCALEDIR=\"$(datadir)/locale\" -D_GNU_SOURCE
|
-DGTOPLOCALEDIR=\"$(datadir)/locale\" -D_GNU_SOURCE
|
||||||
|
|
||||||
CFLAGS = -Wall -W @CFLAGS@ -DGTOP_SERVER=\""@LIBGTOP_SERVER@"\"
|
CFLAGS = -Wall -W @CFLAGS@ -DGTOP_SERVER=\""@LIBGTOP_SERVER@"\" -DDEBUG
|
||||||
|
|
||||||
lib_LTLIBRARIES = libgtop.la
|
lib_LTLIBRARIES = libgtop.la
|
||||||
|
|
||||||
libgtop_la_SOURCES = init.c open.c close.c read.c read_data.c \
|
libgtop_la_SOURCES = init.c open.c close.c command.c read.c read_data.c \
|
||||||
write.c command.c cpu.c mem.c swap.c uptime.c \
|
write.c lib.c parameter.c
|
||||||
loadavg.c shm_limits.c msg_limits.c \
|
|
||||||
sem_limits.c proclist.c procstate.c procuid.c \
|
BUILT_SOURCES = lib.c
|
||||||
proctime.c procmem.c procsignal.c prockernel.c \
|
|
||||||
procsegment.c
|
lib.c: lib.awk $(top_builddir)/config.h $(top_builddir)/features.def
|
||||||
|
$(AWK) -f $(srcdir)/lib.awk < $(top_builddir)/features.def > lib-t
|
||||||
|
mv lib-t lib.c
|
||||||
|
|
||||||
|
EXTRA_DIST = lib.awk
|
||||||
|
|
||||||
|
CLEANFILES = lib.c
|
||||||
|
|
||||||
|
@@ -28,27 +28,52 @@
|
|||||||
|
|
||||||
void *
|
void *
|
||||||
glibtop_call_l (glibtop *server, unsigned command, size_t send_size, void *send_buf,
|
glibtop_call_l (glibtop *server, unsigned command, size_t send_size, void *send_buf,
|
||||||
size_t recv_size, void *recv_buf)
|
size_t recv_size, void *recv_buf)
|
||||||
{
|
{
|
||||||
glibtop_command *cmnd;
|
glibtop_command cmnd;
|
||||||
void *ptr;
|
glibtop_response response;
|
||||||
|
|
||||||
glibtop_init_r (&server, 0, 0);
|
glibtop_init_r (&server, 0, 0);
|
||||||
|
|
||||||
cmnd = glibtop_calloc_r (server, 1, sizeof (glibtop_command));
|
memset (&cmnd, 0, sizeof (glibtop_command));
|
||||||
|
|
||||||
|
memcpy (&cmnd.server, server, sizeof (glibtop));
|
||||||
|
|
||||||
memcpy (&cmnd->server, server, sizeof (glibtop));
|
cmnd.command = command;
|
||||||
|
|
||||||
|
/* If send_size is less than _GLIBTOP_PARAM_SIZE (normally 16 Bytes), we
|
||||||
|
* send it together with command, so we only need one system call instead
|
||||||
|
* of two. */
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
// fprintf (stderr, "COMMAND: send_size = %d; command = %d; sizeof (cmnd) = %d\n",
|
||||||
|
// send_size, command, sizeof (glibtop_command));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (send_size <= _GLIBTOP_PARAM_SIZE) {
|
||||||
|
memcpy (cmnd.parameter, send_buf, send_size);
|
||||||
|
cmnd.size = send_size;
|
||||||
|
} else {
|
||||||
|
cmnd.data_size = send_size;
|
||||||
|
}
|
||||||
|
|
||||||
cmnd->command = command;
|
glibtop_write_l (server, sizeof (glibtop_command), &cmnd);
|
||||||
cmnd->size = send_size;
|
// glibtop_write_l (server, cmnd.data_size, send_buf);
|
||||||
|
|
||||||
glibtop_write_l (server, sizeof (glibtop_command), cmnd);
|
glibtop_read_l (server, sizeof (glibtop_response), &response);
|
||||||
glibtop_write_l (server, send_size, send_buf);
|
|
||||||
glibtop_read_l (server, recv_size, recv_buf);
|
fprintf (stderr, "RESPONSE: %d - %d\n", response.offset, response.data_size);
|
||||||
|
|
||||||
ptr = glibtop_read_data_l (server);
|
if (recv_buf)
|
||||||
|
memcpy (recv_buf, ((char *) &response) + response.offset, recv_size);
|
||||||
glibtop_free_r (server, cmnd);
|
|
||||||
|
if (response.data_size) {
|
||||||
return ptr;
|
void *ptr = glibtop_malloc_r (server, response.data_size);
|
||||||
|
|
||||||
|
glibtop_read_l (server, response.data_size, ptr);
|
||||||
|
|
||||||
|
return ptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
169
lib/init.c
169
lib/init.c
@@ -20,23 +20,168 @@
|
|||||||
Boston, MA 02111-1307, USA. */
|
Boston, MA 02111-1307, USA. */
|
||||||
|
|
||||||
#include <glibtop.h>
|
#include <glibtop.h>
|
||||||
#include <glibtop/open.h>
|
#include <glibtop/xmalloc.h>
|
||||||
|
#include <glibtop/parameter.h>
|
||||||
|
|
||||||
static glibtop _glibtop_global_server;
|
#ifndef DEFAULT_PORT
|
||||||
glibtop *glibtop_global_server = NULL;
|
#define DEFAULT_PORT 42800
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static glibtop _glibtop_global_server;
|
||||||
|
glibtop *glibtop_global_server = &_glibtop_global_server;
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
_init_server (glibtop *server, const unsigned features)
|
||||||
|
{
|
||||||
|
char *command, *temp;
|
||||||
|
|
||||||
|
/* Try to get server command, but don't override if already
|
||||||
|
* set via glibtop_set_parameter () */
|
||||||
|
|
||||||
|
if (server->server_command == NULL) {
|
||||||
|
const char *temp = getenv ("LIBGTOP_SERVER") ?
|
||||||
|
getenv ("LIBGTOP_SERVER") : GTOP_SERVER;
|
||||||
|
|
||||||
|
server->server_command = glibtop_strdup_r (server, temp);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (server->server_rsh == NULL) {
|
||||||
|
const char *temp = getenv ("LIBGTOP_RSH") ?
|
||||||
|
getenv ("LIBGTOP_RSH") : "/usr/bin/ssh";
|
||||||
|
|
||||||
|
server->server_rsh = glibtop_strdup_r (server, temp);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Try to get server method, but don't override if already
|
||||||
|
* set via glibtop_set_parameter () */
|
||||||
|
|
||||||
|
if (server->method) return;
|
||||||
|
|
||||||
|
/* If server->command doesn't start with a colon, then it is
|
||||||
|
* the full pathname of the server executable. */
|
||||||
|
|
||||||
|
if (server->server_command [0] != ':') {
|
||||||
|
if (features & glibtop_server_features) {
|
||||||
|
|
||||||
|
/* We really need the server. */
|
||||||
|
|
||||||
|
server->method = GLIBTOP_METHOD_PIPE;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
|
||||||
|
/* Fine. No server is needed, so we call the
|
||||||
|
* sysdeps functions directly. */
|
||||||
|
|
||||||
|
server->method = GLIBTOP_METHOD_DIRECT;
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* If the first character of 'server_command' is a colon,
|
||||||
|
* the first field is the method to connect to the server. */
|
||||||
|
|
||||||
|
/* Everything up to the next colon is the method. */
|
||||||
|
|
||||||
|
command = glibtop_strdup_r (server, server->server_command+1);
|
||||||
|
temp = strstr (command, ":");
|
||||||
|
if (temp) *temp = 0;
|
||||||
|
|
||||||
|
/* Dispatch method. */
|
||||||
|
|
||||||
|
if (!strcmp (command, "direct")) {
|
||||||
|
|
||||||
|
/* Use sysdeps dir instead of connecting to server
|
||||||
|
* even if using the server would be required on
|
||||||
|
* the current system. */
|
||||||
|
|
||||||
|
server->method = GLIBTOP_METHOD_DIRECT;
|
||||||
|
|
||||||
|
} else if (!strcmp (command, "inet")) {
|
||||||
|
|
||||||
|
server->method = GLIBTOP_METHOD_INET;
|
||||||
|
|
||||||
|
/* Connect to internet server. */
|
||||||
|
|
||||||
|
if (temp == NULL) {
|
||||||
|
/* If no value was set, we use 'localhost'. */
|
||||||
|
if (server->server_host == NULL)
|
||||||
|
server->server_host = glibtop_strdup_r
|
||||||
|
(server, "localhost");
|
||||||
|
} else {
|
||||||
|
char *temp2 = strstr (temp+1, ":");
|
||||||
|
if (temp2) *temp2 = 0;
|
||||||
|
|
||||||
|
/* Override default. */
|
||||||
|
if (server->server_host)
|
||||||
|
glibtop_free_r (server, (char *) server->server_host);
|
||||||
|
|
||||||
|
server->server_host = glibtop_strdup_r
|
||||||
|
(server, temp+1);
|
||||||
|
|
||||||
|
temp = temp2;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (temp == NULL) {
|
||||||
|
/* If no value was set, we use DEFAULT_PORT. */
|
||||||
|
if (server->server_port == 0)
|
||||||
|
server->server_port = DEFAULT_PORT;
|
||||||
|
} else {
|
||||||
|
char *temp2 = strstr (temp+1, ":");
|
||||||
|
if (temp2) *temp2 = 0;
|
||||||
|
|
||||||
|
if (sscanf (temp+1, "%ld", &server->server_port) != 1)
|
||||||
|
server->server_port = DEFAULT_PORT;
|
||||||
|
|
||||||
|
temp = temp2 ? temp2 + 1 : temp2;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
glibtop_error_r (server, "Unknown server method '%s'",
|
||||||
|
server->server_command+1);
|
||||||
|
}
|
||||||
|
|
||||||
|
glibtop_free_r (server, command);
|
||||||
|
}
|
||||||
|
|
||||||
glibtop *
|
glibtop *
|
||||||
glibtop_init_r (glibtop **server, const unsigned long features,
|
glibtop_init_r (glibtop **server_ptr, const unsigned long features,
|
||||||
const unsigned flags)
|
const unsigned flags)
|
||||||
{
|
{
|
||||||
if (*server != NULL)
|
glibtop *server;
|
||||||
return *server;
|
|
||||||
|
|
||||||
if (glibtop_global_server == NULL) {
|
if (server_ptr == NULL)
|
||||||
glibtop_global_server = &_glibtop_global_server;
|
return NULL;
|
||||||
glibtop_open_l (glibtop_global_server, "glibtop",
|
|
||||||
features, flags);
|
if (*server_ptr == NULL)
|
||||||
|
*server_ptr = glibtop_global_server;
|
||||||
|
|
||||||
|
server = *server_ptr;
|
||||||
|
|
||||||
|
/* Should we do the initialization? */
|
||||||
|
|
||||||
|
if (flags & GLIBTOP_INIT_NO_INIT)
|
||||||
|
return server;
|
||||||
|
|
||||||
|
/* Do the initialization, but only if not already initialized. */
|
||||||
|
|
||||||
|
if ((server->flags & _GLIBTOP_INIT_STATE_INIT) == 0) {
|
||||||
|
_init_server (server, features);
|
||||||
|
|
||||||
|
server->flags |= _GLIBTOP_INIT_STATE_INIT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Should we open the server? */
|
||||||
|
|
||||||
|
if (flags & GLIBTOP_INIT_NO_OPEN)
|
||||||
|
return server;
|
||||||
|
|
||||||
|
/* Open server, but only if not already opened. */
|
||||||
|
|
||||||
return *server = glibtop_global_server;
|
if ((server->flags & _GLIBTOP_INIT_STATE_OPEN) == 0)
|
||||||
|
glibtop_open_l (glibtop_global_server, "glibtop",
|
||||||
|
features, flags);
|
||||||
|
|
||||||
|
return server;
|
||||||
}
|
}
|
||||||
|
55
lib/lib.awk
Normal file
55
lib/lib.awk
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
BEGIN {
|
||||||
|
print "/* lib.c */";
|
||||||
|
print "/* This is a generated file. Please modify `lib.awk' */";
|
||||||
|
print "";
|
||||||
|
|
||||||
|
print "#include <glibtop.h>";
|
||||||
|
print "#include <glibtop/open.h>";
|
||||||
|
print "#include <glibtop/sysdeps.h>";
|
||||||
|
print "#include <glibtop/command.h>";
|
||||||
|
|
||||||
|
print "";
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function output(feature) {
|
||||||
|
if (feature ~ /^proclist$/) {
|
||||||
|
print "unsigned *";
|
||||||
|
prefix = "return ";
|
||||||
|
} else {
|
||||||
|
prefix = "";
|
||||||
|
print "void";
|
||||||
|
}
|
||||||
|
if (feature ~ /^proc_/) {
|
||||||
|
param = ", pid_t pid";
|
||||||
|
} else {
|
||||||
|
param = "";
|
||||||
|
}
|
||||||
|
|
||||||
|
print "glibtop_get_"feature"_l (glibtop *server, glibtop_"feature" *buf"param")";
|
||||||
|
print "{";
|
||||||
|
print "\tglibtop_init_r (&server, GLIBTOP_SYSDEPS_"toupper(feature)", 0);";
|
||||||
|
print "";
|
||||||
|
print "\tif ((server->flags & _GLIBTOP_INIT_STATE_SERVER) &&";
|
||||||
|
print "\t (server->features & GLIBTOP_SYSDEPS_"toupper(feature)"))";
|
||||||
|
print "\t{";
|
||||||
|
|
||||||
|
if (feature ~ /^proc_/) {
|
||||||
|
print "\t\t"prefix"glibtop_call_l (server, GLIBTOP_CMND_"toupper(feature)", sizeof (pid_t),";
|
||||||
|
print "\t\t\t\t&pid, sizeof (glibtop_"feature"), buf);";
|
||||||
|
print "\t} else {";
|
||||||
|
print "\t\t"prefix"glibtop_get_"feature"_r (server, buf, pid);";
|
||||||
|
} else {
|
||||||
|
print "\t\t"prefix"glibtop_call_l (server, GLIBTOP_CMND_"toupper(feature)", 0, NULL,";
|
||||||
|
print "\t\t\t sizeof (glibtop_"feature"), buf);";
|
||||||
|
print "\t} else {";
|
||||||
|
print "\t\t"prefix"glibtop_get_"feature"_r (server, buf);";
|
||||||
|
}
|
||||||
|
print "\t}";
|
||||||
|
print "}";
|
||||||
|
print "";
|
||||||
|
}
|
||||||
|
|
||||||
|
/^(\w+)/ { output($1) }
|
||||||
|
|
||||||
|
|
138
lib/open.c
138
lib/open.c
@@ -25,132 +25,44 @@
|
|||||||
#include <glibtop/command.h>
|
#include <glibtop/command.h>
|
||||||
#include <glibtop/xmalloc.h>
|
#include <glibtop/xmalloc.h>
|
||||||
|
|
||||||
|
#include <glibtop/gnuserv.h>
|
||||||
|
|
||||||
/* Opens pipe to gtop server. Returns 0 on success and -1 on error. */
|
/* Opens pipe to gtop server. Returns 0 on success and -1 on error. */
|
||||||
|
|
||||||
void
|
void
|
||||||
glibtop_open_l (glibtop *server, const char *program_name,
|
glibtop_open_l (glibtop *server, const char *program_name,
|
||||||
const unsigned long features, const unsigned flags)
|
const unsigned long features, const unsigned flags)
|
||||||
{
|
{
|
||||||
char version [BUFSIZ], buffer [BUFSIZ];
|
|
||||||
char *server_command, *server_rsh, *temp;
|
|
||||||
char *server_host, *server_user;
|
|
||||||
glibtop_sysdeps sysdeps;
|
|
||||||
|
|
||||||
memset (server, 0, sizeof (glibtop));
|
|
||||||
|
|
||||||
server->name = program_name;
|
server->name = program_name;
|
||||||
|
|
||||||
/* Is the user allowed to override the server ? */
|
/* It is important to set _GLIBTOP_INIT_STATE_OPEN here when we
|
||||||
|
* do recursive calls to glibtop_init_r (). */
|
||||||
|
|
||||||
if ((flags & GLIBTOP_OPEN_NO_OVERRIDE) == 0) {
|
server->flags |= _GLIBTOP_INIT_STATE_OPEN;
|
||||||
|
|
||||||
/* Try to get data from environment. */
|
if (server->method == GLIBTOP_METHOD_INET) {
|
||||||
|
int connect_type;
|
||||||
|
|
||||||
|
fprintf (stderr, "Connecting to '%s' port %d.\n",
|
||||||
|
server->server_host, server->server_port);
|
||||||
|
|
||||||
temp = getenv ("LIBGTOP_SERVER") ?
|
connect_type = glibtop_make_connection
|
||||||
getenv ("LIBGTOP_SERVER") : GTOP_SERVER;
|
(server->server_host, server->server_port,
|
||||||
|
&server->socket);
|
||||||
|
|
||||||
server_command = glibtop_malloc_r (server, strlen (temp) + 1);
|
server->features = -1;
|
||||||
|
|
||||||
strcpy (server_command, temp);
|
return;
|
||||||
|
|
||||||
temp = getenv ("LIBGTOP_RSH") ?
|
|
||||||
getenv ("LIBGTOP_RSH") : "rsh";
|
|
||||||
|
|
||||||
server_rsh = glibtop_malloc_r (server, strlen (temp) + 1);
|
|
||||||
|
|
||||||
strcpy (server_rsh, temp);
|
|
||||||
|
|
||||||
/* Extract host and user information. */
|
|
||||||
|
|
||||||
temp = strstr (server_command, ":");
|
|
||||||
|
|
||||||
if (temp) {
|
|
||||||
*temp = 0;
|
|
||||||
server_host = server_command;
|
|
||||||
server_command = temp+1;
|
|
||||||
|
|
||||||
temp = strstr (server_host, "@");
|
|
||||||
|
|
||||||
if (temp) {
|
|
||||||
*temp = 0;
|
|
||||||
server_user = server_host;
|
|
||||||
server_host = temp+1;
|
|
||||||
} else {
|
|
||||||
server_user = NULL;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
server_host = NULL;
|
|
||||||
server_user = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Store everything in `server'. */
|
|
||||||
|
|
||||||
server->server_command = server_command;
|
|
||||||
server->server_host = server_host;
|
|
||||||
server->server_user = server_user;
|
|
||||||
server->server_rsh = server_rsh;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Get server features. */
|
|
||||||
|
|
||||||
if (server->server_host == NULL) {
|
|
||||||
server->features = glibtop_server_features;
|
|
||||||
|
|
||||||
if (server->features == 0)
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Fork and exec server. */
|
/* If the server has been started, ask it for its features. */
|
||||||
|
|
||||||
if (pipe (server->input) || pipe (server->output))
|
if (server->flags & _GLIBTOP_INIT_STATE_SERVER) {
|
||||||
glibtop_error_r (server, _("cannot make a pipe: %s\n"),
|
glibtop_sysdeps sysdeps;
|
||||||
strerror (errno));
|
|
||||||
|
glibtop_call_l (server, GLIBTOP_CMND_SYSDEPS, 0, NULL,
|
||||||
server->pid = fork ();
|
sizeof (glibtop_sysdeps), &sysdeps);
|
||||||
|
|
||||||
if (server->pid < 0) {
|
server->features = sysdeps.features;
|
||||||
glibtop_error_r (server, _("%s: fork failed: %s\n"),
|
|
||||||
strerror (errno));
|
|
||||||
} else if (server->pid == 0) {
|
|
||||||
close (0); close (1); /* close (2); */
|
|
||||||
close (server->input [0]); close (server->output [1]);
|
|
||||||
dup2 (server->input [1], 1); /* dup2 (server->input [1], 2); */
|
|
||||||
dup2 (server->output [0], 0);
|
|
||||||
|
|
||||||
if (server_host) {
|
|
||||||
if (server_user) {
|
|
||||||
execl (server->server_rsh, "-l",
|
|
||||||
server->server_user, server->server_host,
|
|
||||||
server->server_command, NULL);
|
|
||||||
} else {
|
|
||||||
execl (server->server_rsh,
|
|
||||||
server->server_host, server_command, NULL);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
execl (server->server_command, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
_exit (2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf (stderr, "PID: %d\n", server->pid);
|
|
||||||
|
|
||||||
close (server->input [1]);
|
|
||||||
close (server->output [0]);
|
|
||||||
|
|
||||||
sprintf (version, "%s server %s ready.\n", PACKAGE, VERSION);
|
|
||||||
|
|
||||||
glibtop_read_l (server, strlen (version), buffer);
|
|
||||||
|
|
||||||
if (memcmp (version, buffer, strlen (version)))
|
|
||||||
glibtop_error_r (server, _("server version is not %s"), VERSION);
|
|
||||||
|
|
||||||
fprintf (stderr, "Calling GLITOP_CMND_SYSDEPS ...\n");
|
|
||||||
|
|
||||||
glibtop_call_l (server, GLIBTOP_CMND_SYSDEPS, 0, NULL,
|
|
||||||
sizeof (glibtop_sysdeps), &sysdeps);
|
|
||||||
|
|
||||||
server->features = sysdeps.features;
|
|
||||||
|
|
||||||
fprintf (stderr, "Features: %lu\n", server->features);
|
|
||||||
}
|
}
|
||||||
|
62
lib/parameter.c
Normal file
62
lib/parameter.c
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
/* $Id$ */
|
||||||
|
|
||||||
|
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
||||||
|
This file is part of the Gnome Top Library.
|
||||||
|
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
||||||
|
|
||||||
|
The Gnome Top Library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Library General Public License as
|
||||||
|
published by the Free Software Foundation; either version 2 of the
|
||||||
|
License, or (at your option) any later version.
|
||||||
|
|
||||||
|
The Gnome Top Library 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
|
||||||
|
Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public
|
||||||
|
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
||||||
|
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||||
|
Boston, MA 02111-1307, USA. */
|
||||||
|
|
||||||
|
#include <glibtop.h>
|
||||||
|
#include <glibtop/parameter.h>
|
||||||
|
|
||||||
|
#define _write_data(ptr,size) \
|
||||||
|
if ((data_ptr == NULL) || (data_size < size)) return -size; \
|
||||||
|
if (ptr == NULL) { strcpy (data_ptr, ""); return 1; } \
|
||||||
|
memcpy (data_ptr, ptr, size); \
|
||||||
|
return size;
|
||||||
|
|
||||||
|
#define _strlen(ptr) (ptr ? strlen (ptr) : 0)
|
||||||
|
|
||||||
|
size_t
|
||||||
|
glibtop_get_parameter_l (glibtop *server, const unsigned parameter,
|
||||||
|
void *data_ptr, size_t data_size)
|
||||||
|
{
|
||||||
|
switch (parameter) {
|
||||||
|
case GLIBTOP_PARAM_METHOD:
|
||||||
|
_write_data (&server->method,
|
||||||
|
sizeof (server->method));
|
||||||
|
case GLIBTOP_PARAM_FEATURES:
|
||||||
|
_write_data (&server->features,
|
||||||
|
sizeof (server->features));
|
||||||
|
case GLIBTOP_PARAM_COMMAND:
|
||||||
|
_write_data (server->server_command,
|
||||||
|
_strlen(server->server_command));
|
||||||
|
case GLIBTOP_PARAM_HOST:
|
||||||
|
_write_data (server->server_host,
|
||||||
|
_strlen(server->server_host));
|
||||||
|
case GLIBTOP_PARAM_PORT:
|
||||||
|
_write_data (&server->server_port,
|
||||||
|
sizeof (server->server_port));
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
glibtop_set_parameter_l (glibtop *server, const unsigned parameter,
|
||||||
|
const void *data_ptr, size_t data_size)
|
||||||
|
{
|
||||||
|
}
|
@@ -1,40 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/prockernel.h>
|
|
||||||
#include <glibtop/command.h>
|
|
||||||
|
|
||||||
/* Provides detailed information about a process. */
|
|
||||||
|
|
||||||
void
|
|
||||||
glibtop_get_proc_kernel_l (glibtop *server, glibtop_proc_kernel *buf,
|
|
||||||
pid_t pid)
|
|
||||||
{
|
|
||||||
glibtop_init_r (&server, GLIBTOP_SYSDEPS_PROC_KERNEL, 0);
|
|
||||||
|
|
||||||
if (server->features & GLIBTOP_SYSDEPS_PROC_KERNEL) {
|
|
||||||
glibtop_call_l (server, GLIBTOP_CMND_PROC_KERNEL, sizeof (pid_t),
|
|
||||||
&pid, sizeof (glibtop_proc_kernel), buf);
|
|
||||||
} else {
|
|
||||||
glibtop_get_proc_kernel_r (server, buf, pid);
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,40 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/procsegment.h>
|
|
||||||
#include <glibtop/command.h>
|
|
||||||
|
|
||||||
/* Provides detailed information about a process. */
|
|
||||||
|
|
||||||
void
|
|
||||||
glibtop_get_proc_segment_l (glibtop *server, glibtop_proc_segment *buf,
|
|
||||||
pid_t pid)
|
|
||||||
{
|
|
||||||
glibtop_init_r (&server, GLIBTOP_SYSDEPS_PROC_SEGMENT, 0);
|
|
||||||
|
|
||||||
if (server->features & GLIBTOP_SYSDEPS_PROC_SEGMENT) {
|
|
||||||
glibtop_call_l (server, GLIBTOP_CMND_PROC_SEGMENT, sizeof (pid_t),
|
|
||||||
&pid, sizeof (glibtop_proc_segment), buf);
|
|
||||||
} else {
|
|
||||||
glibtop_get_proc_segment_r (server, buf, pid);
|
|
||||||
}
|
|
||||||
}
|
|
49
lib/read.c
49
lib/read.c
@@ -23,19 +23,48 @@
|
|||||||
|
|
||||||
/* Reads some data from server. */
|
/* Reads some data from server. */
|
||||||
|
|
||||||
|
static void
|
||||||
|
do_read (int s, void *ptr, size_t total_size)
|
||||||
|
{
|
||||||
|
int nread;
|
||||||
|
size_t already_read = 0, remaining = total_size;
|
||||||
|
|
||||||
|
while (already_read < total_size) {
|
||||||
|
nread = recv (s, ptr, remaining, 0);
|
||||||
|
|
||||||
|
if (nread == 0) {
|
||||||
|
close (s);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (nread <= 0) {
|
||||||
|
glibtop_error_io ("recv");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
already_read += nread;
|
||||||
|
remaining -= nread;
|
||||||
|
(char *) ptr += nread;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
glibtop_read_l (glibtop *server, size_t size, void *buf)
|
glibtop_read_l (glibtop *server, size_t size, void *buf)
|
||||||
{
|
{
|
||||||
size_t ssize;
|
int ret = 0;
|
||||||
|
|
||||||
glibtop_init_r (&server, 0, 0);
|
glibtop_init_r (&server, 0, 0);
|
||||||
|
|
||||||
if (read (server->input [0], &ssize, sizeof (size_t)) < 0)
|
#ifdef DEBUG
|
||||||
glibtop_error_r (server, _("read size: %s"), strerror (errno));
|
fprintf (stderr, "LIBRARY: really reading %d bytes.\n", size);
|
||||||
|
#endif
|
||||||
if (size != ssize)
|
|
||||||
glibtop_error_r (server, _("got %d bytes but requested %d"), ssize, size);
|
if (server->socket) {
|
||||||
|
do_read (server->socket, buf, size);
|
||||||
if (read (server->input [0], buf, size) < 0)
|
} else {
|
||||||
glibtop_error_r (server, _("read %d bytes: %s"), size, strerror (errno));
|
ret = read (server->input [0], buf, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ret < 0)
|
||||||
|
glibtop_error_io_r (server, _("read %d bytes"), size);
|
||||||
}
|
}
|
||||||
|
@@ -29,20 +29,39 @@ glibtop_read_data_l (glibtop *server)
|
|||||||
{
|
{
|
||||||
size_t size;
|
size_t size;
|
||||||
void *ptr;
|
void *ptr;
|
||||||
|
int ret;
|
||||||
|
|
||||||
glibtop_init_r (&server, 0, 0);
|
glibtop_init_r (&server, 0, 0);
|
||||||
|
|
||||||
if (read (server->input [0], &size, sizeof (size_t)) < 0)
|
#ifdef DEBUG
|
||||||
glibtop_error_r (server, _("read data size: %s"),
|
fprintf (stderr, "LIBRARY: reading %d data bytes.\n", sizeof (size_t));
|
||||||
strerror (errno));
|
#endif
|
||||||
|
|
||||||
|
if (server->socket) {
|
||||||
|
ret = recv (server->socket, &size, sizeof (size_t), 0);
|
||||||
|
} else {
|
||||||
|
ret = read (server->input [0], &size, sizeof (size_t));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ret < 0)
|
||||||
|
glibtop_error_io_r (server, _("read data size"));
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
fprintf (stderr, "LIBRARY: really reading %d data bytes (ret = %d).\n", size, ret);
|
||||||
|
#endif
|
||||||
|
|
||||||
if (!size) return NULL;
|
if (!size) return NULL;
|
||||||
|
|
||||||
ptr = glibtop_malloc_r (server, size);
|
ptr = glibtop_malloc_r (server, size);
|
||||||
|
|
||||||
if (read (server->input [0], ptr, size) < 0)
|
if (server->socket) {
|
||||||
glibtop_error_r (server, _("read data %d bytes: %s"),
|
ret = recv (server->socket, ptr, size, 0);
|
||||||
size, strerror (errno));
|
} else {
|
||||||
|
ret = read (server->input [0], ptr, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ret < 0)
|
||||||
|
glibtop_error_io_r (server, _("read data %d bytes"));
|
||||||
|
|
||||||
return ptr;
|
return ptr;
|
||||||
}
|
}
|
||||||
|
21
lib/write.c
21
lib/write.c
@@ -26,13 +26,22 @@
|
|||||||
void
|
void
|
||||||
glibtop_write_l (glibtop *server, size_t size, void *buf)
|
glibtop_write_l (glibtop *server, size_t size, void *buf)
|
||||||
{
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
glibtop_init_r (&server, 0, 0);
|
glibtop_init_r (&server, 0, 0);
|
||||||
|
|
||||||
if (write (server->output [1], &size, sizeof (size_t)) < 0)
|
if (size == 0) return;
|
||||||
glibtop_error_r (server, _("write size: %s"), strerror (errno));
|
|
||||||
|
|
||||||
if (!size) return;
|
#ifdef DEBUG
|
||||||
|
fprintf (stderr, "LIBRARY: really writing %d bytes.\n", size);
|
||||||
if (write (server->output [1], buf, size) < 0)
|
#endif
|
||||||
glibtop_error_r (server, _("write %d bytes: %s"), size, strerror (errno));
|
|
||||||
|
if (server->socket) {
|
||||||
|
ret = send (server->socket, buf, size, 0);
|
||||||
|
} else {
|
||||||
|
ret = write (server->output [1], buf, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ret < 0)
|
||||||
|
glibtop_error_io_r (server, _("write %d bytes"), size);
|
||||||
}
|
}
|
||||||
|
1
perl/.cvsignore
Normal file
1
perl/.cvsignore
Normal file
@@ -0,0 +1 @@
|
|||||||
|
Libgtop.xs Makefile blib pm_to_blib Libgtop.c Libgtop.bs Makefile.PL
|
5
perl/Changes
Normal file
5
perl/Changes
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
Revision history for Perl extension Libgtop.
|
||||||
|
|
||||||
|
0.01 Sun Jun 21 21:00:59 1998
|
||||||
|
- original version; created by h2xs 1.18
|
||||||
|
|
26
perl/Libgtop.pm
Normal file
26
perl/Libgtop.pm
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
package Libgtop;
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use vars qw($VERSION @ISA @EXPORT @EXPORT_OK);
|
||||||
|
|
||||||
|
require Exporter;
|
||||||
|
require DynaLoader;
|
||||||
|
require AutoLoader;
|
||||||
|
|
||||||
|
@ISA = qw(Exporter DynaLoader);
|
||||||
|
# Items to export into callers namespace by default. Note: do not export
|
||||||
|
# names by default without a very good reason. Use EXPORT_OK instead.
|
||||||
|
# Do not simply export all your public functions/methods/constants.
|
||||||
|
@EXPORT = qw(
|
||||||
|
|
||||||
|
);
|
||||||
|
$VERSION = '0.01';
|
||||||
|
|
||||||
|
bootstrap Libgtop $VERSION;
|
||||||
|
|
||||||
|
# Preloaded methods go here.
|
||||||
|
|
||||||
|
# Autoload methods go after __END__, and are processed by the autosplit program.
|
||||||
|
|
||||||
|
1;
|
||||||
|
__END__
|
8
perl/MANIFEST
Normal file
8
perl/MANIFEST
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
.cvsignore
|
||||||
|
Changes
|
||||||
|
Libgtop.pm
|
||||||
|
MANIFEST
|
||||||
|
Makefile.PL.in
|
||||||
|
new.pl
|
||||||
|
perl.awk
|
||||||
|
test.pl
|
10
perl/Makefile.PL.in
Normal file
10
perl/Makefile.PL.in
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
# -*-cperl-*-
|
||||||
|
use ExtUtils::MakeMaker;
|
||||||
|
# See lib/ExtUtils/MakeMaker.pm for details of how to influence
|
||||||
|
# the contents of the Makefile that is written.
|
||||||
|
WriteMakefile('NAME' => 'Libgtop',
|
||||||
|
'VERSION_FROM' => 'Libgtop.pm',
|
||||||
|
'LIBS' => ['@LIBGTOP_GUILE_LIBS@'],
|
||||||
|
'DEFINE' => '',
|
||||||
|
'INC' => '@LIBGTOP_GUILE_INCS@',
|
||||||
|
);
|
13
perl/new.pl
Executable file
13
perl/new.pl
Executable file
@@ -0,0 +1,13 @@
|
|||||||
|
#!/usr/bin/perl -w
|
||||||
|
|
||||||
|
require 5.004;
|
||||||
|
|
||||||
|
use blib;
|
||||||
|
use strict;
|
||||||
|
use Libgtop;
|
||||||
|
|
||||||
|
print "CPU Usage: ".join (':', Libgtop::cpu)."\n";
|
||||||
|
print "Memory Usage: ".join (':', Libgtop::mem)."\n";
|
||||||
|
print "Swap Usage: ".join (':', Libgtop::swap)."\n";
|
||||||
|
|
||||||
|
|
86
perl/perl.awk
Normal file
86
perl/perl.awk
Normal file
@@ -0,0 +1,86 @@
|
|||||||
|
BEGIN {
|
||||||
|
print "/* Libgtop.xs */";
|
||||||
|
print "/* This is a generated file. Please modify `perl.awk' */";
|
||||||
|
print "";
|
||||||
|
|
||||||
|
print "#ifdef __cplusplus";
|
||||||
|
print "extern \"C\" {";
|
||||||
|
print "#endif";
|
||||||
|
print "#include \"EXTERN.h\"";
|
||||||
|
print "#include \"perl.h\"";
|
||||||
|
print "#include \"XSUB.h\"";
|
||||||
|
print "#ifdef __cplusplus";
|
||||||
|
print "}";
|
||||||
|
print "#endif";
|
||||||
|
print "";
|
||||||
|
print "#undef PACKAGE";
|
||||||
|
print "";
|
||||||
|
print "#include <glibtop.h>";
|
||||||
|
print "#include <glibtop/union.h>";
|
||||||
|
print "";
|
||||||
|
print "MODULE = Libgtop\t\tPACKAGE = Libgtop";
|
||||||
|
print "";
|
||||||
|
|
||||||
|
convert["long"] = "newSViv";
|
||||||
|
convert["ulong"] = "newSViv";
|
||||||
|
convert["double"] = "newSVnv";
|
||||||
|
}
|
||||||
|
|
||||||
|
/^(\w+)/ {
|
||||||
|
feature = $1;
|
||||||
|
|
||||||
|
print "void";
|
||||||
|
if (feature ~ /^proc_/) {
|
||||||
|
print feature"(pid)";
|
||||||
|
print "\tunsigned\tpid;";
|
||||||
|
} else {
|
||||||
|
print feature"()";
|
||||||
|
}
|
||||||
|
|
||||||
|
print "PREINIT:";
|
||||||
|
print "\tglibtop_"feature" "feature";";
|
||||||
|
|
||||||
|
if (feature ~ /^proclist/) {
|
||||||
|
print "\tunsigned i, *ptr;";
|
||||||
|
print "PPCODE:";
|
||||||
|
print "\tptr = glibtop_get_proclist (&proclist);";
|
||||||
|
print "";
|
||||||
|
print "\tif (ptr) {";
|
||||||
|
print "\t\tfor (i = 0; i < proclist.number; i++)";
|
||||||
|
print "\t\t\tXPUSHs (sv_2mortal (newSViv (ptr [i])));";
|
||||||
|
print "\t}";
|
||||||
|
print "";
|
||||||
|
print "\tglibtop_free (ptr);";
|
||||||
|
} else {
|
||||||
|
print "PPCODE:";
|
||||||
|
if (feature ~ /^proc_/) {
|
||||||
|
print "\tglibtop_get_"feature" (&"feature", pid);";
|
||||||
|
} else {
|
||||||
|
print "\tglibtop_get_"feature" (&"feature");";
|
||||||
|
}
|
||||||
|
print "";
|
||||||
|
|
||||||
|
nr_elements = split ($2, elements, /:/);
|
||||||
|
for (element = 1; element <= nr_elements; element++) {
|
||||||
|
list = elements[element];
|
||||||
|
type = elements[element];
|
||||||
|
sub(/\(.*/, "", type);
|
||||||
|
sub(/^\w+\(/, "", list); sub(/\)$/, "", list);
|
||||||
|
count = split (list, fields, /,/);
|
||||||
|
for (field = 1; field <= count; field++) {
|
||||||
|
if (type ~ /^str$/) {
|
||||||
|
print "\tXPUSHs (sv_2mortal (newSVpv ("$1"."fields[field]", 0)));";
|
||||||
|
} else {
|
||||||
|
if (type ~ /^char$/) {
|
||||||
|
print "\tXPUSHs (sv_2mortal (newSVpv (&"$1"."fields[field]", 1)));";
|
||||||
|
} else {
|
||||||
|
print "\tXPUSHs (sv_2mortal ("convert[type]" ("$1"."fields[field]")));";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
print "";
|
||||||
|
}
|
||||||
|
|
20
perl/test.pl
Normal file
20
perl/test.pl
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
# Before `make install' is performed this script should be runnable with
|
||||||
|
# `make test'. After `make install' it should work as `perl test.pl'
|
||||||
|
|
||||||
|
######################### We start with some black magic to print on failure.
|
||||||
|
|
||||||
|
# Change 1..1 below to 1..last_test_to_print .
|
||||||
|
# (It may become useful if the test is moved to ./t subdirectory.)
|
||||||
|
|
||||||
|
BEGIN { $| = 1; print "1..1\n"; }
|
||||||
|
END {print "not ok 1\n" unless $loaded;}
|
||||||
|
use Libgtop;
|
||||||
|
$loaded = 1;
|
||||||
|
print "ok 1\n";
|
||||||
|
|
||||||
|
######################### End of black magic.
|
||||||
|
|
||||||
|
# Insert your test code below (better if it prints "ok 13"
|
||||||
|
# (correspondingly "not ok 13") depending on the success of chunk 13
|
||||||
|
# of the test code):
|
||||||
|
|
@@ -1,17 +1,8 @@
|
|||||||
lib/close.c
|
lib/close.c
|
||||||
lib/command.c
|
lib/command.c
|
||||||
lib/cpu.c
|
|
||||||
lib/mem.c
|
|
||||||
lib/open.c
|
lib/open.c
|
||||||
lib/read.c
|
lib/read.c
|
||||||
lib/swap.c
|
|
||||||
lib/write.c
|
lib/write.c
|
||||||
lib/uptime.c
|
|
||||||
lib/loadavg.c
|
|
||||||
lib/shm_limits.c
|
|
||||||
lib/msg_limits.c
|
|
||||||
lib/sem_limits.c
|
|
||||||
lib/proclist.c
|
|
||||||
lib/read_data.c
|
lib/read_data.c
|
||||||
acconfig.h
|
acconfig.h
|
||||||
glibtop.h
|
glibtop.h
|
||||||
|
124
po/fr.po
124
po/fr.po
@@ -6,7 +6,7 @@
|
|||||||
msgid ""
|
msgid ""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: libgtop VERSION\n"
|
"Project-Id-Version: libgtop VERSION\n"
|
||||||
"POT-Creation-Date: 1998-05-31 22:31+0200\n"
|
"POT-Creation-Date: 1998-06-20 15:28+0200\n"
|
||||||
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
||||||
"Last-Translator: Vincent Renardias <vincent@waw.com>\n"
|
"Last-Translator: Vincent Renardias <vincent@waw.com>\n"
|
||||||
"Language-Team: Vincent Renardias <vincent@waw.com>\n"
|
"Language-Team: Vincent Renardias <vincent@waw.com>\n"
|
||||||
@@ -17,67 +17,67 @@ msgstr ""
|
|||||||
#: lib/open.c:36
|
#: lib/open.c:36
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "cannot make a pipe: %s\n"
|
msgid "cannot make a pipe: %s\n"
|
||||||
msgstr ""
|
msgstr "impossible de cr<63><72>r un tube: %s\n"
|
||||||
|
|
||||||
#: lib/open.c:41
|
#: lib/open.c:41
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s: fork failed: %s\n"
|
msgid "%s: fork failed: %s\n"
|
||||||
msgstr ""
|
msgstr "%s: duplication <20>chou<6F>e: %s\n"
|
||||||
|
|
||||||
#: lib/open.c:59
|
#: lib/open.c:59
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "server version is not %s"
|
msgid "server version is not %s"
|
||||||
msgstr ""
|
msgstr "la version du serveur n'est pas %s"
|
||||||
|
|
||||||
#: lib/read.c:34
|
#: lib/read.c:34
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "read size: %s"
|
msgid "read size: %s"
|
||||||
msgstr ""
|
msgstr "taille lue: %s"
|
||||||
|
|
||||||
#: lib/read.c:37
|
#: lib/read.c:37
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "got %d bytes but requested %d"
|
msgid "got %d bytes but requested %d"
|
||||||
msgstr ""
|
msgstr "obtenu %d octets, mais %d <20>taient demand<6E>s"
|
||||||
|
|
||||||
#: lib/read.c:40
|
#: lib/read.c:40
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "read %d bytes: %s"
|
msgid "read %d bytes: %s"
|
||||||
msgstr ""
|
msgstr "lecture de %d octets: %s"
|
||||||
|
|
||||||
#: lib/write.c:32
|
#: lib/write.c:32
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "write size: %s"
|
msgid "write size: %s"
|
||||||
msgstr ""
|
msgstr "taille <20>crite: %s"
|
||||||
|
|
||||||
#: lib/write.c:37
|
#: lib/write.c:37
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "write %d bytes: %s"
|
msgid "write %d bytes: %s"
|
||||||
msgstr ""
|
msgstr "<EFBFBD>crit %d octets: %s"
|
||||||
|
|
||||||
#: lib/read_data.c:36
|
#: lib/read_data.c:36
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "read data size: %s"
|
msgid "read data size: %s"
|
||||||
msgstr ""
|
msgstr "taille de la lecture: %s"
|
||||||
|
|
||||||
#: lib/read_data.c:46
|
#: lib/read_data.c:46
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "read data %d bytes: %s"
|
msgid "read data %d bytes: %s"
|
||||||
msgstr ""
|
msgstr "lecture de %d octets de donn<6E>es: %s"
|
||||||
|
|
||||||
#: sysdeps/common/xmalloc.c:32
|
#: sysdeps/common/xmalloc.c:32
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "malloc %d bytes: %s"
|
msgid "malloc %d bytes: %s"
|
||||||
msgstr ""
|
msgstr "malloc de %d octets: %s"
|
||||||
|
|
||||||
#: sysdeps/common/xmalloc.c:44
|
#: sysdeps/common/xmalloc.c:44
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "calloc %d block (%d bytes each): %s"
|
msgid "calloc %d block (%d bytes each): %s"
|
||||||
msgstr ""
|
msgstr "calloc de %d blocks (%d octets chacuns): %s"
|
||||||
|
|
||||||
#: sysdeps/common/xmalloc.c:56
|
#: sysdeps/common/xmalloc.c:56
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "realloc %d bytes: %s"
|
msgid "realloc %d bytes: %s"
|
||||||
msgstr ""
|
msgstr "realloc de %d octets: %s"
|
||||||
|
|
||||||
#: sysdeps/names/sysdeps.c:42 sysdeps/names/sysdeps.c:62
|
#: sysdeps/names/sysdeps.c:42 sysdeps/names/sysdeps.c:62
|
||||||
msgid "CPU Usage"
|
msgid "CPU Usage"
|
||||||
@@ -93,7 +93,7 @@ msgstr "Utilisation du Swap"
|
|||||||
|
|
||||||
#: sysdeps/names/sysdeps.c:45 sysdeps/names/sysdeps.c:65
|
#: sysdeps/names/sysdeps.c:45 sysdeps/names/sysdeps.c:65
|
||||||
msgid "System Uptime"
|
msgid "System Uptime"
|
||||||
msgstr ""
|
msgstr "Uptime du syst<73>me"
|
||||||
|
|
||||||
#: sysdeps/names/sysdeps.c:46 sysdeps/names/sysdeps.c:66
|
#: sysdeps/names/sysdeps.c:46 sysdeps/names/sysdeps.c:66
|
||||||
msgid "Load Averange"
|
msgid "Load Averange"
|
||||||
@@ -117,31 +117,31 @@ msgstr "Liste des taches en cours d'
|
|||||||
|
|
||||||
#: sysdeps/names/sysdeps.c:51 sysdeps/names/sysdeps.c:71
|
#: sysdeps/names/sysdeps.c:51 sysdeps/names/sysdeps.c:71
|
||||||
msgid "Process Status information"
|
msgid "Process Status information"
|
||||||
msgstr ""
|
msgstr "Information sur l'<27>tat du processus"
|
||||||
|
|
||||||
#: sysdeps/names/sysdeps.c:52 sysdeps/names/sysdeps.c:72
|
#: sysdeps/names/sysdeps.c:52 sysdeps/names/sysdeps.c:72
|
||||||
msgid "Process UID and TTY information"
|
msgid "Process UID and TTY information"
|
||||||
msgstr ""
|
msgstr "Information UID et TTY du processus"
|
||||||
|
|
||||||
#: sysdeps/names/sysdeps.c:53 sysdeps/names/sysdeps.c:73
|
#: sysdeps/names/sysdeps.c:53 sysdeps/names/sysdeps.c:73
|
||||||
msgid "Process Memory information"
|
msgid "Process Memory information"
|
||||||
msgstr ""
|
msgstr "Information M<>moire du Processus"
|
||||||
|
|
||||||
#: sysdeps/names/sysdeps.c:54 sysdeps/names/sysdeps.c:74
|
#: sysdeps/names/sysdeps.c:54 sysdeps/names/sysdeps.c:74
|
||||||
msgid "Process Time information"
|
msgid "Process Time information"
|
||||||
msgstr ""
|
msgstr "Information Temporelle sur le processus"
|
||||||
|
|
||||||
#: sysdeps/names/sysdeps.c:55 sysdeps/names/sysdeps.c:75
|
#: sysdeps/names/sysdeps.c:55 sysdeps/names/sysdeps.c:75
|
||||||
msgid "Process Signal information"
|
msgid "Process Signal information"
|
||||||
msgstr ""
|
msgstr "Information sur les signaux du processus"
|
||||||
|
|
||||||
#: sysdeps/names/sysdeps.c:56 sysdeps/names/sysdeps.c:76
|
#: sysdeps/names/sysdeps.c:56 sysdeps/names/sysdeps.c:76
|
||||||
msgid "Process Kernel Data information"
|
msgid "Process Kernel Data information"
|
||||||
msgstr ""
|
msgstr "Information sur les donn<6E>es noyau du processus"
|
||||||
|
|
||||||
#: sysdeps/names/sysdeps.c:57 sysdeps/names/sysdeps.c:77
|
#: sysdeps/names/sysdeps.c:57 sysdeps/names/sysdeps.c:77
|
||||||
msgid "Process Segment information"
|
msgid "Process Segment information"
|
||||||
msgstr ""
|
msgstr "Information sur la segmentation du processus"
|
||||||
|
|
||||||
#: sysdeps/names/cpu.c:37
|
#: sysdeps/names/cpu.c:37
|
||||||
msgid "Total CPU Time"
|
msgid "Total CPU Time"
|
||||||
@@ -153,7 +153,7 @@ msgstr "Temps CPU en mode utilisateur"
|
|||||||
|
|
||||||
#: sysdeps/names/cpu.c:39
|
#: sysdeps/names/cpu.c:39
|
||||||
msgid "CPU Time in User Mode (nice)"
|
msgid "CPU Time in User Mode (nice)"
|
||||||
msgstr ""
|
msgstr "Temps CPU en mode utilisateur (nice)"
|
||||||
|
|
||||||
#: sysdeps/names/cpu.c:40
|
#: sysdeps/names/cpu.c:40
|
||||||
msgid "CPU Time in System Mode"
|
msgid "CPU Time in System Mode"
|
||||||
@@ -165,7 +165,7 @@ msgstr "Temps CPU pour la tache inactive"
|
|||||||
|
|
||||||
#: sysdeps/names/cpu.c:42
|
#: sysdeps/names/cpu.c:42
|
||||||
msgid "Tick Frequency"
|
msgid "Tick Frequency"
|
||||||
msgstr ""
|
msgstr "Fr<EFBFBD>quence des ticks"
|
||||||
|
|
||||||
#: sysdeps/names/cpu.c:47
|
#: sysdeps/names/cpu.c:47
|
||||||
msgid "The number of jiffies (1/100ths of a second) since system boot"
|
msgid "The number of jiffies (1/100ths of a second) since system boot"
|
||||||
@@ -175,31 +175,31 @@ msgstr "Nombre de jiffies (1/100e de seconde) depuis le boot du syst
|
|||||||
msgid ""
|
msgid ""
|
||||||
"The number of jiffies (1/100ths of a second) that the system spent in user "
|
"The number of jiffies (1/100ths of a second) that the system spent in user "
|
||||||
"mode"
|
"mode"
|
||||||
msgstr ""
|
msgstr "Le nombre de jiffies (1/100<30>me de seconde) que le systme a pass<73> en mode utilisateur"
|
||||||
|
|
||||||
#: sysdeps/names/cpu.c:51
|
#: sysdeps/names/cpu.c:51
|
||||||
msgid ""
|
msgid ""
|
||||||
"The number of jiffies (1/100ths of a second) that the system spent in user "
|
"The number of jiffies (1/100ths of a second) that the system spent in user "
|
||||||
"mode with low priority (nice)"
|
"mode with low priority (nice)"
|
||||||
msgstr ""
|
msgstr "Le nombre de jiffies (1/100<30>me de seconde) que le syst<73>me a pass<73> en mode utilisateur en priorit<69> basse (nice)"
|
||||||
|
|
||||||
#: sysdeps/names/cpu.c:53
|
#: sysdeps/names/cpu.c:53
|
||||||
msgid ""
|
msgid ""
|
||||||
"The number of jiffies (1/100ths of a second) that the system spent in system "
|
"The number of jiffies (1/100ths of a second) that the system spent in system "
|
||||||
"mode"
|
"mode"
|
||||||
msgstr ""
|
msgstr "Le nombre de jiffies (1/100<30>me de seconde) que le syst<73>me a pass<73> en mode syst<73>me"
|
||||||
|
|
||||||
#: sysdeps/names/cpu.c:55
|
#: sysdeps/names/cpu.c:55
|
||||||
msgid ""
|
msgid ""
|
||||||
"The number of jiffies (1/100ths of a second) that the system spend in the "
|
"The number of jiffies (1/100ths of a second) that the system spend in the "
|
||||||
"idle task"
|
"idle task"
|
||||||
msgstr ""
|
msgstr "Le nombre de jiffies (1/100<30>me de seconde) que le systme a pass<73> dans le processus inactif (idle task)"
|
||||||
|
|
||||||
#: sysdeps/names/cpu.c:57
|
#: sysdeps/names/cpu.c:57
|
||||||
msgid ""
|
msgid ""
|
||||||
"All of the above values are in jiffies (1/100ths of a second) unless "
|
"All of the above values are in jiffies (1/100ths of a second) unless "
|
||||||
"otherwise stated in this field (i.e. 'frequency != 100')"
|
"otherwise stated in this field (i.e. 'frequency != 100')"
|
||||||
msgstr ""
|
msgstr "Toutes les valeurs ci-dessus sont exprim<69>es en jiffies (1/100<30>me de seconde) sauf pr<70>cision contraire (i.e.: fr<66>quence != 100)"
|
||||||
|
|
||||||
#: sysdeps/names/loadavg.c:36
|
#: sysdeps/names/loadavg.c:36
|
||||||
msgid "Load Average"
|
msgid "Load Average"
|
||||||
@@ -207,7 +207,7 @@ msgstr "Charge Moyenne"
|
|||||||
|
|
||||||
#: sysdeps/names/loadavg.c:41
|
#: sysdeps/names/loadavg.c:41
|
||||||
msgid "Number of jobs running simultaneously averaged over 1, 5 and 15 minutes"
|
msgid "Number of jobs running simultaneously averaged over 1, 5 and 15 minutes"
|
||||||
msgstr ""
|
msgstr "Nombre de processus tournant simultannement en moyenne sur 1, 5 et 15 minutes"
|
||||||
|
|
||||||
#: sysdeps/names/mem.c:39
|
#: sysdeps/names/mem.c:39
|
||||||
msgid "Total Memory"
|
msgid "Total Memory"
|
||||||
@@ -231,7 +231,7 @@ msgstr "Tampons"
|
|||||||
|
|
||||||
#: sysdeps/names/mem.c:44
|
#: sysdeps/names/mem.c:44
|
||||||
msgid "Cached"
|
msgid "Cached"
|
||||||
msgstr ""
|
msgstr "Dans le cache"
|
||||||
|
|
||||||
#: sysdeps/names/mem.c:45
|
#: sysdeps/names/mem.c:45
|
||||||
msgid "User"
|
msgid "User"
|
||||||
@@ -247,83 +247,83 @@ msgstr "M
|
|||||||
|
|
||||||
#: sysdeps/names/mem.c:52
|
#: sysdeps/names/mem.c:52
|
||||||
msgid "Used memory size in kB"
|
msgid "Used memory size in kB"
|
||||||
msgstr ""
|
msgstr "M<EFBFBD>moire utilis<69>e en Ko"
|
||||||
|
|
||||||
#: sysdeps/names/mem.c:53
|
#: sysdeps/names/mem.c:53
|
||||||
msgid "Free memory size in kB"
|
msgid "Free memory size in kB"
|
||||||
msgstr ""
|
msgstr "M<EFBFBD>moire libre en Ko"
|
||||||
|
|
||||||
#: sysdeps/names/mem.c:54
|
#: sysdeps/names/mem.c:54
|
||||||
msgid "Shared memory size in kB"
|
msgid "Shared memory size in kB"
|
||||||
msgstr ""
|
msgstr "M<EFBFBD>moire partag<61>e en Ko"
|
||||||
|
|
||||||
#: sysdeps/names/mem.c:55
|
#: sysdeps/names/mem.c:55
|
||||||
msgid "Size of buffers kB"
|
msgid "Size of buffers kB"
|
||||||
msgstr ""
|
msgstr "Taille des tampons en Ko"
|
||||||
|
|
||||||
#: sysdeps/names/mem.c:56
|
#: sysdeps/names/mem.c:56
|
||||||
msgid "Size of cached memory in kB"
|
msgid "Size of cached memory in kB"
|
||||||
msgstr ""
|
msgstr "Taille de la m<>moire dans le cache en Ko"
|
||||||
|
|
||||||
#: sysdeps/names/mem.c:57
|
#: sysdeps/names/mem.c:57
|
||||||
msgid "Memory used from user processes in kB"
|
msgid "Memory used from user processes in kB"
|
||||||
msgstr ""
|
msgstr "M<EFBFBD>moire utilis<69>e par les processus utilisateurs en Ko"
|
||||||
|
|
||||||
#: sysdeps/names/mem.c:58
|
#: sysdeps/names/mem.c:58
|
||||||
msgid "Memory in locked pages in kB"
|
msgid "Memory in locked pages in kB"
|
||||||
msgstr ""
|
msgstr "M<EFBFBD>moire dans les pages v<>rouill<6C>es en Ko"
|
||||||
|
|
||||||
#: sysdeps/names/swap.c:36 sysdeps/names/swap.c:43
|
#: sysdeps/names/swap.c:36 sysdeps/names/swap.c:43
|
||||||
msgid "Total Swap Space"
|
msgid "Total Swap Space"
|
||||||
msgstr ""
|
msgstr "Taille totalle de la zone d'<27>change"
|
||||||
|
|
||||||
#: sysdeps/names/swap.c:37 sysdeps/names/swap.c:44
|
#: sysdeps/names/swap.c:37 sysdeps/names/swap.c:44
|
||||||
msgid "Used Swap Space"
|
msgid "Used Swap Space"
|
||||||
msgstr ""
|
msgstr "Taille utilis<69>e de la zone d'<27>change"
|
||||||
|
|
||||||
#: sysdeps/names/swap.c:38 sysdeps/names/swap.c:45
|
#: sysdeps/names/swap.c:38 sysdeps/names/swap.c:45
|
||||||
msgid "Free Swap Space"
|
msgid "Free Swap Space"
|
||||||
msgstr ""
|
msgstr "Espace libre de la zone d'<27>change"
|
||||||
|
|
||||||
#: sysdeps/names/uptime.c:36
|
#: sysdeps/names/uptime.c:36
|
||||||
msgid "Uptime"
|
msgid "Uptime"
|
||||||
msgstr ""
|
msgstr "Uptime"
|
||||||
|
|
||||||
#: sysdeps/names/uptime.c:37
|
#: sysdeps/names/uptime.c:37
|
||||||
msgid "Idletime"
|
msgid "Idletime"
|
||||||
msgstr ""
|
msgstr "Idletime"
|
||||||
|
|
||||||
#: sysdeps/names/uptime.c:42
|
#: sysdeps/names/uptime.c:42
|
||||||
msgid "Time in seconds since system boot"
|
msgid "Time in seconds since system boot"
|
||||||
msgstr ""
|
msgstr "Temps en secondes depuis le d<>marrage du syst<73>me"
|
||||||
|
|
||||||
#: sysdeps/names/uptime.c:43
|
#: sysdeps/names/uptime.c:43
|
||||||
msgid "Time in seconds the system spent in the idle task since system boot"
|
msgid "Time in seconds the system spent in the idle task since system boot"
|
||||||
msgstr ""
|
msgstr "Temps en secondes pass<73> dans le processus inactif depuis le d<>marrage du syst<73>me"
|
||||||
|
|
||||||
#: sysdeps/names/shm_limits.c:37 sysdeps/names/shm_limits.c:46
|
#: sysdeps/names/shm_limits.c:37 sysdeps/names/shm_limits.c:46
|
||||||
msgid "Max segment size"
|
msgid "Max segment size"
|
||||||
msgstr ""
|
msgstr "Taille maximum des segments"
|
||||||
|
|
||||||
#: sysdeps/names/shm_limits.c:38 sysdeps/names/shm_limits.c:47
|
#: sysdeps/names/shm_limits.c:38 sysdeps/names/shm_limits.c:47
|
||||||
msgid "Min segment size"
|
msgid "Min segment size"
|
||||||
msgstr ""
|
msgstr "Taille minimum des segments"
|
||||||
|
|
||||||
#: sysdeps/names/shm_limits.c:39 sysdeps/names/shm_limits.c:48
|
#: sysdeps/names/shm_limits.c:39 sysdeps/names/shm_limits.c:48
|
||||||
msgid "Max number of segments"
|
msgid "Max number of segments"
|
||||||
msgstr ""
|
msgstr "Nombre maximum des segments"
|
||||||
|
|
||||||
#: sysdeps/names/shm_limits.c:40 sysdeps/names/shm_limits.c:49
|
#: sysdeps/names/shm_limits.c:40 sysdeps/names/shm_limits.c:49
|
||||||
msgid "Max shared segments per process"
|
msgid "Max shared segments per process"
|
||||||
msgstr ""
|
msgstr "Nombre maximum de segments partag<61>s par processus"
|
||||||
|
|
||||||
#: sysdeps/names/shm_limits.c:41 sysdeps/names/shm_limits.c:50
|
#: sysdeps/names/shm_limits.c:41 sysdeps/names/shm_limits.c:50
|
||||||
msgid "Max total shared memory"
|
msgid "Max total shared memory"
|
||||||
msgstr ""
|
msgstr "Taille totalle de la m<>moire partag<61>e"
|
||||||
|
|
||||||
#: sysdeps/names/msg_limits.c:37 sysdeps/names/msg_limits.c:48
|
#: sysdeps/names/msg_limits.c:37 sysdeps/names/msg_limits.c:48
|
||||||
msgid "Size in kilobytes of message pool"
|
msgid "Size in kilobytes of message pool"
|
||||||
msgstr ""
|
msgstr "Taille en kilo-octets du pool de messages"
|
||||||
|
|
||||||
#: sysdeps/names/msg_limits.c:38 sysdeps/names/msg_limits.c:49
|
#: sysdeps/names/msg_limits.c:38 sysdeps/names/msg_limits.c:49
|
||||||
msgid "Number of entries in message map"
|
msgid "Number of entries in message map"
|
||||||
@@ -331,23 +331,23 @@ msgstr ""
|
|||||||
|
|
||||||
#: sysdeps/names/msg_limits.c:39 sysdeps/names/msg_limits.c:50
|
#: sysdeps/names/msg_limits.c:39 sysdeps/names/msg_limits.c:50
|
||||||
msgid "Max size of message"
|
msgid "Max size of message"
|
||||||
msgstr ""
|
msgstr "Taille maximum des messages"
|
||||||
|
|
||||||
#: sysdeps/names/msg_limits.c:40 sysdeps/names/msg_limits.c:51
|
#: sysdeps/names/msg_limits.c:40 sysdeps/names/msg_limits.c:51
|
||||||
msgid "Default max size of queue"
|
msgid "Default max size of queue"
|
||||||
msgstr ""
|
msgstr "Taille maximum par d<>faut de la queue"
|
||||||
|
|
||||||
#: sysdeps/names/msg_limits.c:41 sysdeps/names/msg_limits.c:52
|
#: sysdeps/names/msg_limits.c:41 sysdeps/names/msg_limits.c:52
|
||||||
msgid "Max queues system wide"
|
msgid "Max queues system wide"
|
||||||
msgstr ""
|
msgstr "Nombre maximum de queues dans le syst<73>me"
|
||||||
|
|
||||||
#: sysdeps/names/msg_limits.c:42 sysdeps/names/msg_limits.c:53
|
#: sysdeps/names/msg_limits.c:42 sysdeps/names/msg_limits.c:53
|
||||||
msgid "Message segment size"
|
msgid "Message segment size"
|
||||||
msgstr ""
|
msgstr "Taille des segments de messages"
|
||||||
|
|
||||||
#: sysdeps/names/msg_limits.c:43 sysdeps/names/msg_limits.c:54
|
#: sysdeps/names/msg_limits.c:43 sysdeps/names/msg_limits.c:54
|
||||||
msgid "Number of system message headers"
|
msgid "Number of system message headers"
|
||||||
msgstr ""
|
msgstr "Nombre d'entetes de messages syst<73>me"
|
||||||
|
|
||||||
#: sysdeps/names/sem_limits.c:39 sysdeps/names/sem_limits.c:53
|
#: sysdeps/names/sem_limits.c:39 sysdeps/names/sem_limits.c:53
|
||||||
msgid "Number of entries in semaphore map"
|
msgid "Number of entries in semaphore map"
|
||||||
@@ -355,19 +355,19 @@ msgstr ""
|
|||||||
|
|
||||||
#: sysdeps/names/sem_limits.c:40 sysdeps/names/sem_limits.c:54
|
#: sysdeps/names/sem_limits.c:40 sysdeps/names/sem_limits.c:54
|
||||||
msgid "Max number of arrays"
|
msgid "Max number of arrays"
|
||||||
msgstr ""
|
msgstr "Nombre maximum de tables"
|
||||||
|
|
||||||
#: sysdeps/names/sem_limits.c:41 sysdeps/names/sem_limits.c:55
|
#: sysdeps/names/sem_limits.c:41 sysdeps/names/sem_limits.c:55
|
||||||
msgid "Max semaphores system wide"
|
msgid "Max semaphores system wide"
|
||||||
msgstr ""
|
msgstr "Nombre maximum de s<>maphores dans le syst<73>me"
|
||||||
|
|
||||||
#: sysdeps/names/sem_limits.c:42 sysdeps/names/sem_limits.c:56
|
#: sysdeps/names/sem_limits.c:42 sysdeps/names/sem_limits.c:56
|
||||||
msgid "Number of undo structures system wide"
|
msgid "Number of undo structures system wide"
|
||||||
msgstr ""
|
msgstr "Nombre de structures 'undo' dans le syst<73>me"
|
||||||
|
|
||||||
#: sysdeps/names/sem_limits.c:43 sysdeps/names/sem_limits.c:57
|
#: sysdeps/names/sem_limits.c:43 sysdeps/names/sem_limits.c:57
|
||||||
msgid "Max semaphores per array"
|
msgid "Max semaphores per array"
|
||||||
msgstr ""
|
msgstr "Nombre maximum de s<>maphores par table"
|
||||||
|
|
||||||
#: sysdeps/names/sem_limits.c:44 sysdeps/names/sem_limits.c:58
|
#: sysdeps/names/sem_limits.c:44 sysdeps/names/sem_limits.c:58
|
||||||
msgid "Max ops per semop call"
|
msgid "Max ops per semop call"
|
||||||
@@ -379,11 +379,11 @@ msgstr ""
|
|||||||
|
|
||||||
#: sysdeps/names/sem_limits.c:46 sysdeps/names/sem_limits.c:60
|
#: sysdeps/names/sem_limits.c:46 sysdeps/names/sem_limits.c:60
|
||||||
msgid "sizeof struct sem_undo"
|
msgid "sizeof struct sem_undo"
|
||||||
msgstr ""
|
msgstr "sizeof struct sem_undo"
|
||||||
|
|
||||||
#: sysdeps/names/sem_limits.c:47 sysdeps/names/sem_limits.c:61
|
#: sysdeps/names/sem_limits.c:47 sysdeps/names/sem_limits.c:61
|
||||||
msgid "Semaphore max value"
|
msgid "Semaphore max value"
|
||||||
msgstr ""
|
msgstr "Valeur maximum d'un s<>maphore"
|
||||||
|
|
||||||
#: sysdeps/names/sem_limits.c:48 sysdeps/names/sem_limits.c:62
|
#: sysdeps/names/sem_limits.c:48 sysdeps/names/sem_limits.c:62
|
||||||
msgid "Adjust on exit max value"
|
msgid "Adjust on exit max value"
|
||||||
|
@@ -1 +1 @@
|
|||||||
SUBDIRS = server proxy
|
SUBDIRS = server proxy daemon
|
||||||
|
3
src/daemon/.cvsignore
Normal file
3
src/daemon/.cvsignore
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
Makefile.in
|
||||||
|
Makefile
|
||||||
|
gnuserv
|
25
src/daemon/Makefile.am
Normal file
25
src/daemon/Makefile.am
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
LINK = $(LIBTOOL) --mode=link $(CC) $(CFLAGS) $(LDFLAGS) -o $@
|
||||||
|
|
||||||
|
INCLUDES = -I$(top_builddir) -I$(top_srcdir) @machine_incs@ \
|
||||||
|
-I$(top_srcdir)/include -I$(top_srcdir)/intl @GUILE_INCS@ \
|
||||||
|
-DGTOPLOCALEDIR=\"$(datadir)/locale\" -D_GNU_SOURCE
|
||||||
|
|
||||||
|
CFLAGS = -Wall -W @CFLAGS@ -DGTOP_SERVER=\""@LIBGTOP_SERVER@"\" -DDEBUG -DREAL_DEBUG
|
||||||
|
|
||||||
|
bin_PROGRAMS = gnuserv
|
||||||
|
|
||||||
|
EXTRA_PROGRAMS = gtop_daemon
|
||||||
|
|
||||||
|
gnuserv_SOURCES = gnuserv.c main.c
|
||||||
|
gnuserv_LDADD = $(top_builddir)/lib/libgtop.la \
|
||||||
|
$(top_builddir)/sysdeps/common/libgtop_common.la \
|
||||||
|
$(top_builddir)/sysdeps/@sysdeps_dir@/libgtop_sysdeps.la \
|
||||||
|
@INTLLIBS@ @LIBSUPPORT@ @X_LIBS@ -lXau
|
||||||
|
gnuserv_LDFLAGS = -static
|
||||||
|
|
||||||
|
gtop_daemon_SOURCES = main.c inet.c loop.c output.c version.c
|
||||||
|
gtop_daemon_LDADD = $(top_builddir)/lib/libgtop.la \
|
||||||
|
$(top_builddir)/sysdeps/common/libgtop_common.la \
|
||||||
|
$(top_builddir)/sysdeps/@sysdeps_dir@/libgtop_sysdeps.la \
|
||||||
|
@INTLLIBS@ @LIBSUPPORT@
|
||||||
|
gtop_daemon_LDFLAGS = -static
|
835
src/daemon/gnuserv.c
Normal file
835
src/daemon/gnuserv.c
Normal file
@@ -0,0 +1,835 @@
|
|||||||
|
/* -*-C-*-
|
||||||
|
Server code for handling requests from clients and forwarding them
|
||||||
|
on to the GNU Emacs process.
|
||||||
|
|
||||||
|
This file is part of GNU Emacs.
|
||||||
|
|
||||||
|
Copying is permitted under those conditions described by the GNU
|
||||||
|
General Public License.
|
||||||
|
|
||||||
|
Copyright (C) 1989 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
Author: Andy Norman (ange@hplb.hpl.hp.com), based on 'etc/server.c'
|
||||||
|
from the 18.52 GNU Emacs distribution.
|
||||||
|
|
||||||
|
Please mail bugs and suggestions to the author at the above address.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* HISTORY
|
||||||
|
* 11-Nov-1990 bristor@simba
|
||||||
|
* Added EOT stuff.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This file incorporates new features added by Bob Weiner <weiner@mot.com>,
|
||||||
|
* Darrell Kindred <dkindred@cmu.edu> and Arup Mukherjee <arup@cmu.edu>.
|
||||||
|
* Please see the note at the end of the README file for details.
|
||||||
|
*
|
||||||
|
* (If gnuserv came bundled with your emacs, the README file is probably
|
||||||
|
* ../etc/gnuserv.README relative to the directory containing this file)
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
static char rcsid [] = "!Header: gnuserv.c,v 2.1 95/02/16 11:58:27 arup alpha !";
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define DEBUG
|
||||||
|
|
||||||
|
#include <glibtop/gnuserv.h>
|
||||||
|
#include <glibtop/open.h>
|
||||||
|
|
||||||
|
#ifdef AIX
|
||||||
|
#include <sys/select.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern void handle_socket_connection __P((glibtop *, int));
|
||||||
|
|
||||||
|
#if !defined(SYSV_IPC) && !defined(UNIX_DOMAIN_SOCKETS) && !defined(INTERNET_DOMAIN_SOCKETS)
|
||||||
|
main ()
|
||||||
|
{
|
||||||
|
fprintf (stderr,"Sorry, the Emacs server is only supported on systems that have\n");
|
||||||
|
fprintf (stderr,"Unix Domain sockets, Internet Domain sockets or System V IPC\n");
|
||||||
|
exit (1);
|
||||||
|
} /* main */
|
||||||
|
#else /* SYSV_IPC || UNIX_DOMAIN_SOCKETS || INTERNET_DOMAIN_SOCKETS */
|
||||||
|
|
||||||
|
#ifdef SYSV_IPC
|
||||||
|
|
||||||
|
int ipc_qid = 0; /* ipc message queue id */
|
||||||
|
int ipc_wpid = 0; /* watchdog task pid */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
ipc_exit -- clean up the queue id and queue, then kill the watchdog task
|
||||||
|
if it exists. exit with the given status.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
ipc_exit (int stat)
|
||||||
|
{
|
||||||
|
msgctl (ipc_qid,IPC_RMID,0);
|
||||||
|
|
||||||
|
if (ipc_wpid != 0)
|
||||||
|
kill (ipc_wpid, SIGKILL);
|
||||||
|
|
||||||
|
exit (stat);
|
||||||
|
} /* ipc_exit */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
ipc_handle_signal -- catch the signal given and clean up.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
ipc_handle_signal(int sig)
|
||||||
|
{
|
||||||
|
ipc_exit (0);
|
||||||
|
} /* ipc_handle_signal */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
ipc_spawn_watchdog -- spawn a watchdog task to clean up the message queue should the
|
||||||
|
server process die.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
ipc_spawn_watchdog (void)
|
||||||
|
{
|
||||||
|
if ((ipc_wpid = fork ()) == 0)
|
||||||
|
{ /* child process */
|
||||||
|
int ppid = getppid (); /* parent's process id */
|
||||||
|
|
||||||
|
setpgrp(); /* gnu kills process group on exit */
|
||||||
|
|
||||||
|
while (1)
|
||||||
|
{
|
||||||
|
if (kill (ppid, 0) < 0) /* ppid is no longer valid, parent
|
||||||
|
may have died */
|
||||||
|
{
|
||||||
|
ipc_exit (0);
|
||||||
|
} /* if */
|
||||||
|
|
||||||
|
sleep(10); /* have another go later */
|
||||||
|
} /* while */
|
||||||
|
} /* if */
|
||||||
|
|
||||||
|
} /* ipc_spawn_watchdog */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
ipc_init -- initialize server, setting the global msqid that can be listened on.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
ipc_init (struct msgbuf **msgpp)
|
||||||
|
{
|
||||||
|
key_t key; /* messge key */
|
||||||
|
char buf[GSERV_BUFSZ]; /* pathname for key */
|
||||||
|
|
||||||
|
sprintf (buf,"/tmp/lgtd%d",(int)geteuid ());
|
||||||
|
creat (buf,0600);
|
||||||
|
key = ftok (buf,1);
|
||||||
|
|
||||||
|
if ((ipc_qid = msgget (key,0600|IPC_CREAT)) == -1)
|
||||||
|
glibtop_error_io ("unable to create msg queue");
|
||||||
|
|
||||||
|
ipc_spawn_watchdog ();
|
||||||
|
|
||||||
|
signal (SIGTERM,ipc_handle_signal);
|
||||||
|
signal (SIGINT,ipc_handle_signal);
|
||||||
|
|
||||||
|
if ((*msgpp = (struct msgbuf *)
|
||||||
|
malloc (sizeof **msgpp + GSERV_BUFSZ)) == NULL)
|
||||||
|
{
|
||||||
|
glibtop_warn_io ("unable to allocate space for message buffer");
|
||||||
|
ipc_exit(1);
|
||||||
|
} /* if */
|
||||||
|
} /* ipc_init */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
handle_ipc_request -- accept a request from a client, pass the request on
|
||||||
|
to the GNU Emacs process, then wait for its reply and
|
||||||
|
pass that on to the client.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
handle_ipc_request (struct msgbuf *msgp)
|
||||||
|
{
|
||||||
|
struct msqid_ds msg_st; /* message status */
|
||||||
|
char buf[GSERV_BUFSZ];
|
||||||
|
int len; /* length of message / read */
|
||||||
|
int s, result_len; /* tag fields on the response from emacs */
|
||||||
|
int offset = 0;
|
||||||
|
int total = 1; /* # bytes that will actually be sent off */
|
||||||
|
|
||||||
|
if ((len = msgrcv (ipc_qid, msgp, GSERV_BUFSZ - 1, 1, 0)) < 0)
|
||||||
|
{
|
||||||
|
glibtop_warn_io ("msgrcv");
|
||||||
|
ipc_exit (1);
|
||||||
|
} /* if */
|
||||||
|
|
||||||
|
msgctl (ipc_qid, IPC_STAT, &msg_st);
|
||||||
|
strncpy (buf, msgp->mtext, len);
|
||||||
|
buf[len] = '\0'; /* terminate */
|
||||||
|
|
||||||
|
printf ("%d %s", ipc_qid, buf);
|
||||||
|
fflush (stdout);
|
||||||
|
|
||||||
|
/* now for the response from gnu */
|
||||||
|
msgp->mtext[0] = '\0';
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
if ((len = read(0,buf,GSERV_BUFSZ-1)) < 0)
|
||||||
|
{
|
||||||
|
glibtop_warn_io ("read");
|
||||||
|
ipc_exit (1);
|
||||||
|
} /* if */
|
||||||
|
|
||||||
|
sscanf (buf, "%d:%[^\n]\n", &junk, msgp->mtext);
|
||||||
|
#else
|
||||||
|
|
||||||
|
/* read in "n/m:" (n=client fd, m=message length) */
|
||||||
|
|
||||||
|
while (offset < (GSERV_BUFSZ-1) &&
|
||||||
|
((len = read (0, buf + offset, 1)) > 0) &&
|
||||||
|
buf[offset] != ':')
|
||||||
|
{
|
||||||
|
offset += len;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (len < 0)
|
||||||
|
glibtop_error_io ("read");
|
||||||
|
|
||||||
|
/* parse the response from emacs, getting client fd & result length */
|
||||||
|
buf[offset] = '\0';
|
||||||
|
sscanf (buf, "%d/%d", &s, &result_len);
|
||||||
|
|
||||||
|
while (result_len > 0)
|
||||||
|
{
|
||||||
|
if ((len = read(0, buf, min2 (result_len, GSERV_BUFSZ - 1))) < 0)
|
||||||
|
glibtop_error_io ("read");
|
||||||
|
|
||||||
|
/* Send this string off, but only if we have enough space */
|
||||||
|
|
||||||
|
if (GSERV_BUFSZ > total)
|
||||||
|
{
|
||||||
|
if (total + len <= GSERV_BUFSZ)
|
||||||
|
buf[len] = 0;
|
||||||
|
else
|
||||||
|
buf[GSERV_BUFSZ - total] = 0;
|
||||||
|
|
||||||
|
send_string(s,buf);
|
||||||
|
total += strlen(buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
result_len -= len;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* eat the newline */
|
||||||
|
while ((len = read (0,buf,1)) == 0)
|
||||||
|
;
|
||||||
|
if (len < 0)
|
||||||
|
glibtop_error_io ("read");
|
||||||
|
|
||||||
|
if (buf[0] != '\n')
|
||||||
|
glibtop_error ("garbage after result [%c]", buf[0]);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Send a response back to the client. */
|
||||||
|
|
||||||
|
msgp->mtype = msg_st.msg_lspid;
|
||||||
|
if (msgsnd (ipc_qid,msgp,strlen(msgp->mtext)+1,0) < 0)
|
||||||
|
glibtop_warn_io ("msgsend(gnuserv)");
|
||||||
|
|
||||||
|
} /* handle_ipc_request */
|
||||||
|
#endif /* SYSV_IPC */
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(INTERNET_DOMAIN_SOCKETS) || defined(UNIX_DOMAIN_SOCKETS)
|
||||||
|
/*
|
||||||
|
echo_request -- read request from a given socket descriptor, and send the information
|
||||||
|
to stdout (the gnu process).
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
echo_request (int s)
|
||||||
|
{
|
||||||
|
char buf[GSERV_BUFSZ];
|
||||||
|
int len;
|
||||||
|
|
||||||
|
printf("%d ",s);
|
||||||
|
|
||||||
|
/* read until we get a newline or no characters */
|
||||||
|
while ((len = recv(s,buf,GSERV_BUFSZ-1,0)) > 0) {
|
||||||
|
buf[len] = '\0';
|
||||||
|
printf("%s",buf);
|
||||||
|
|
||||||
|
if (buf[len-1] == EOT_CHR) {
|
||||||
|
fflush(stdout);
|
||||||
|
break; /* end of message */
|
||||||
|
}
|
||||||
|
|
||||||
|
} /* while */
|
||||||
|
|
||||||
|
if (len < 0)
|
||||||
|
glibtop_error_io ("recv");
|
||||||
|
|
||||||
|
} /* echo_request */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
handle_response -- accept a response from stdin (the gnu process) and pass the
|
||||||
|
information on to the relevant client.
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
handle_response (void)
|
||||||
|
{
|
||||||
|
#if 0
|
||||||
|
char buf[GSERV_BUFSZ+1];
|
||||||
|
int offset=0;
|
||||||
|
int s;
|
||||||
|
int len;
|
||||||
|
int result_len;
|
||||||
|
|
||||||
|
/* read in "n/m:" (n=client fd, m=message length) */
|
||||||
|
while (offset < GSERV_BUFSZ &&
|
||||||
|
((len = read(0,buf+offset,1)) > 0) &&
|
||||||
|
buf[offset] != ':') {
|
||||||
|
offset += len;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (len < 0)
|
||||||
|
glibtop_error_io ("read");
|
||||||
|
|
||||||
|
/* parse the response from emacs, getting client fd & result length */
|
||||||
|
buf[offset] = '\0';
|
||||||
|
sscanf(buf,"%d/%d", &s, &result_len);
|
||||||
|
|
||||||
|
while (result_len > 0) {
|
||||||
|
if ((len = read(0,buf,min2(result_len,GSERV_BUFSZ))) < 0)
|
||||||
|
glibtop_error_io ("read");
|
||||||
|
|
||||||
|
buf[len] = '\0';
|
||||||
|
send_string(s,buf);
|
||||||
|
result_len -= len;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* eat the newline */
|
||||||
|
while ((len = read(0,buf,1)) == 0)
|
||||||
|
;
|
||||||
|
if (len < 0)
|
||||||
|
glibtop_error_io ("read");
|
||||||
|
|
||||||
|
if (buf[0] != '\n')
|
||||||
|
glibtop_error ("garbage after result");
|
||||||
|
|
||||||
|
/* send the newline */
|
||||||
|
buf[1] = '\0';
|
||||||
|
send_string(s,buf);
|
||||||
|
close(s);
|
||||||
|
#else
|
||||||
|
glibtop_error ("handle_response (): Function not implemented");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
} /* handle_response */
|
||||||
|
#endif /* INTERNET_DOMAIN_SOCKETS || UNIX_DOMAIN_SOCKETS */
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef INTERNET_DOMAIN_SOCKETS
|
||||||
|
struct entry {
|
||||||
|
u_long host_addr;
|
||||||
|
struct entry *next;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct entry *permitted_hosts[TABLE_SIZE];
|
||||||
|
|
||||||
|
#ifdef AUTH_MAGIC_COOKIE
|
||||||
|
# include <X11/X.h>
|
||||||
|
# include <X11/Xauth.h>
|
||||||
|
|
||||||
|
static Xauth *server_xauth = NULL;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static int
|
||||||
|
timed_read (int fd, char *buf, int max, int timeout, int one_line)
|
||||||
|
{
|
||||||
|
fd_set rmask;
|
||||||
|
struct timeval tv; /* = {timeout, 0}; */
|
||||||
|
char c = 0;
|
||||||
|
int nbytes = 0;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
tv.tv_sec = timeout;
|
||||||
|
tv.tv_usec = 0;
|
||||||
|
|
||||||
|
FD_ZERO(&rmask);
|
||||||
|
FD_SET(fd, &rmask);
|
||||||
|
|
||||||
|
do
|
||||||
|
{
|
||||||
|
r = select(fd + 1, &rmask, NULL, NULL, &tv);
|
||||||
|
|
||||||
|
if (r > 0)
|
||||||
|
{
|
||||||
|
if (read (fd, &c, 1) == 1 )
|
||||||
|
{
|
||||||
|
*buf++ = c;
|
||||||
|
++nbytes;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
glibtop_warn_io ("read error on socket");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (r == 0)
|
||||||
|
{
|
||||||
|
glibtop_warn ("read timed out");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
glibtop_warn_io ("error in select");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
} while ((nbytes < max) && !(one_line && (c == '\n')));
|
||||||
|
|
||||||
|
--buf;
|
||||||
|
if (one_line && *buf == '\n')
|
||||||
|
{
|
||||||
|
*buf = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return nbytes;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
permitted -- return whether a given host is allowed to connect to the server.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
permitted (u_long host_addr, int fd)
|
||||||
|
{
|
||||||
|
int key;
|
||||||
|
struct entry *entry;
|
||||||
|
|
||||||
|
char auth_protocol[128];
|
||||||
|
char buf[1024];
|
||||||
|
int auth_data_len;
|
||||||
|
|
||||||
|
if (fd > 0)
|
||||||
|
{
|
||||||
|
/* we are checking permission on a real connection */
|
||||||
|
|
||||||
|
/* Read auth protocol name */
|
||||||
|
|
||||||
|
if (timed_read(fd, auth_protocol, AUTH_NAMESZ, AUTH_TIMEOUT, 1) <= 0)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
fprintf (stderr, "Client sent authenticatin protocol '%s'\n", auth_protocol);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (strcmp (auth_protocol, DEFAUTH_NAME) &&
|
||||||
|
strcmp (auth_protocol, MCOOKIE_NAME))
|
||||||
|
{
|
||||||
|
glibtop_warn ("Authentication protocol from client is invalid", auth_protocol);
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!strcmp (auth_protocol, MCOOKIE_NAME))
|
||||||
|
{
|
||||||
|
|
||||||
|
/*
|
||||||
|
* doing magic cookie auth
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (timed_read (fd, buf, 10, AUTH_TIMEOUT, 1) <= 0)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
auth_data_len = atoi (buf);
|
||||||
|
|
||||||
|
if (timed_read (fd, buf, auth_data_len, AUTH_TIMEOUT, 0) != auth_data_len)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
#ifdef AUTH_MAGIC_COOKIE
|
||||||
|
if (server_xauth && server_xauth->data &&
|
||||||
|
!memcmp (buf, server_xauth->data, auth_data_len))
|
||||||
|
{
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
glibtop_warn ("client tried Xauth, but server is not compiled with Xauth");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* auth failed, but allow this to fall through to the GNU_SECURE
|
||||||
|
* protocol....
|
||||||
|
*/
|
||||||
|
|
||||||
|
glibtop_warn ("Xauth authentication failed, trying GNU_SECURE auth...");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Other auth protocols go here, and should execute only if the
|
||||||
|
* auth_protocol name matches.
|
||||||
|
*/
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Now, try the old GNU_SECURE stuff... */
|
||||||
|
|
||||||
|
/* First find the hash key */
|
||||||
|
key = HASH(host_addr) % TABLE_SIZE;
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
fprintf (stderr, "Doing GNU_SECURE auth ...\n");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Now check the chain for that hash key */
|
||||||
|
for(entry = permitted_hosts [key]; entry != NULL; entry = entry->next) {
|
||||||
|
#ifdef DEBUG
|
||||||
|
fprintf (stderr, "Trying %ld\n", entry->host_addr);
|
||||||
|
#endif
|
||||||
|
if (host_addr == entry->host_addr)
|
||||||
|
return(TRUE);
|
||||||
|
}
|
||||||
|
|
||||||
|
return(FALSE);
|
||||||
|
|
||||||
|
} /* permitted */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
add_host -- add the given host to the list of permitted hosts, provided it isn't
|
||||||
|
already there.
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
add_host (u_long host_addr)
|
||||||
|
{
|
||||||
|
int key;
|
||||||
|
struct entry *new_entry;
|
||||||
|
|
||||||
|
if (!permitted (host_addr, -1))
|
||||||
|
{
|
||||||
|
if ((new_entry = (struct entry *) malloc(sizeof(struct entry))) == NULL)
|
||||||
|
glibtop_error_io ("unable to malloc space for permitted host entry");
|
||||||
|
|
||||||
|
new_entry->host_addr = host_addr;
|
||||||
|
key = HASH(host_addr) % TABLE_SIZE;
|
||||||
|
new_entry->next = permitted_hosts[key];
|
||||||
|
permitted_hosts[key] = new_entry;
|
||||||
|
} /* if */
|
||||||
|
|
||||||
|
} /* add_host */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
setup_table -- initialise the table of hosts allowed to contact the server,
|
||||||
|
by reading from the file specified by the GNU_SECURE
|
||||||
|
environment variable
|
||||||
|
Put in the local machine, and, if a security file is specifed,
|
||||||
|
add each host that is named in the file.
|
||||||
|
Return the number of hosts added.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
setup_table (void)
|
||||||
|
{
|
||||||
|
FILE *host_file;
|
||||||
|
char *file_name;
|
||||||
|
char hostname[HOSTNAMSZ];
|
||||||
|
u_int host_addr;
|
||||||
|
int i, hosts=0;
|
||||||
|
|
||||||
|
/* Make sure every entry is null */
|
||||||
|
for (i = 0; i < TABLE_SIZE; i++)
|
||||||
|
permitted_hosts [i] = NULL;
|
||||||
|
|
||||||
|
gethostname (hostname, HOSTNAMSZ);
|
||||||
|
|
||||||
|
if (((long) host_addr = glibtop_internet_addr (hostname)) == -1)
|
||||||
|
glibtop_error ("unable to find %s in /etc/hosts or from YP", hostname);
|
||||||
|
|
||||||
|
#ifdef AUTH_MAGIC_COOKIE
|
||||||
|
|
||||||
|
server_xauth = XauGetAuthByAddr (FamilyInternet,
|
||||||
|
sizeof(host_addr), (char *)&host_addr,
|
||||||
|
strlen(MCOOKIE_SCREEN), MCOOKIE_SCREEN,
|
||||||
|
strlen(MCOOKIE_X_NAME), MCOOKIE_X_NAME);
|
||||||
|
hosts++;
|
||||||
|
|
||||||
|
#endif /* AUTH_MAGIC_COOKIE */
|
||||||
|
|
||||||
|
|
||||||
|
#if 0 /* Don't even want to allow access from the local host by default */
|
||||||
|
add_host (host_addr); /* add local host */
|
||||||
|
hosts++;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (((file_name = getenv ("GNU_SECURE")) != NULL && /* security file */
|
||||||
|
(host_file = fopen (file_name, "r")) != NULL)) /* opened ok */
|
||||||
|
{
|
||||||
|
while ((fscanf (host_file, "%s", hostname) != EOF)) /* find a host */
|
||||||
|
if (((long) host_addr = glibtop_internet_addr (hostname)) != -1)/* get its addr */
|
||||||
|
{
|
||||||
|
add_host (host_addr); /* add the addr */
|
||||||
|
hosts++;
|
||||||
|
}
|
||||||
|
fclose (host_file);
|
||||||
|
} /* if */
|
||||||
|
|
||||||
|
return hosts;
|
||||||
|
} /* setup_table */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
internet_init -- initialize server, returning an internet socket that can
|
||||||
|
be listened on.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
internet_init (void)
|
||||||
|
{
|
||||||
|
int ls; /* socket descriptor */
|
||||||
|
struct servent *sp; /* pointer to service information */
|
||||||
|
struct sockaddr_in server; /* for local socket address */
|
||||||
|
char *ptr; /* ptr to return from getenv */
|
||||||
|
|
||||||
|
if (setup_table() == 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
/* clear out address structure */
|
||||||
|
memset((char *)&server, 0, sizeof (struct sockaddr_in));
|
||||||
|
|
||||||
|
/* Set up address structure for the listen socket. */
|
||||||
|
server.sin_family = AF_INET;
|
||||||
|
server.sin_addr.s_addr = INADDR_ANY;
|
||||||
|
|
||||||
|
/* Find the information for the gnu server
|
||||||
|
* in order to get the needed port number.
|
||||||
|
*/
|
||||||
|
if ((ptr = getenv ("GNU_PORT")) != NULL)
|
||||||
|
server.sin_port = htons (atoi (ptr));
|
||||||
|
else if ((sp = getservbyname ("gnuserv", "tcp")) == NULL)
|
||||||
|
server.sin_port = htons (DEFAULT_PORT+getuid());
|
||||||
|
else
|
||||||
|
server.sin_port = sp->s_port;
|
||||||
|
|
||||||
|
/* Create the listen socket. */
|
||||||
|
if ((ls = socket (AF_INET,SOCK_STREAM, 0)) == -1)
|
||||||
|
glibtop_error_io ("unable to create socket");
|
||||||
|
|
||||||
|
/* Bind the listen address to the socket. */
|
||||||
|
if (bind(ls,(struct sockaddr *) &server,sizeof(struct sockaddr_in)) == -1)
|
||||||
|
glibtop_error_io ("bind");
|
||||||
|
|
||||||
|
/* Initiate the listen on the socket so remote users
|
||||||
|
* can connect.
|
||||||
|
*/
|
||||||
|
if (listen(ls,20) == -1)
|
||||||
|
glibtop_error_io ("listen");
|
||||||
|
|
||||||
|
return(ls);
|
||||||
|
|
||||||
|
} /* internet_init */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
handle_internet_request -- accept a request from a client and send the information
|
||||||
|
to stdout (the gnu process).
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
handle_internet_request (int ls)
|
||||||
|
{
|
||||||
|
int s;
|
||||||
|
size_t addrlen = sizeof(struct sockaddr_in);
|
||||||
|
struct sockaddr_in peer; /* for peer socket address */
|
||||||
|
|
||||||
|
memset((char *)&peer, 0, sizeof (struct sockaddr_in));
|
||||||
|
|
||||||
|
if ((s = accept (ls, (struct sockaddr *)&peer, (void *) &addrlen)) == -1)
|
||||||
|
glibtop_error_io ("accept");
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
fprintf (stderr, "Connection was made from %s.\n", inet_ntoa (peer.sin_addr));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Check that access is allowed - if not return crud to the client */
|
||||||
|
if (!permitted (peer.sin_addr.s_addr, s))
|
||||||
|
{
|
||||||
|
close(s);
|
||||||
|
glibtop_warn ("Refused connection from %s.", inet_ntoa (peer.sin_addr));
|
||||||
|
return;
|
||||||
|
} /* if */
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
fprintf (stderr, "Accepted connection from %s.\n", inet_ntoa (peer.sin_addr));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
handle_socket_connection (&glibtop_global_server, s);
|
||||||
|
|
||||||
|
close (s);
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
fprintf (stderr, "Closed connection to %s.\n", inet_ntoa (peer.sin_addr));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
} /* handle_internet_request */
|
||||||
|
#endif /* INTERNET_DOMAIN_SOCKETS */
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef UNIX_DOMAIN_SOCKETS
|
||||||
|
/*
|
||||||
|
unix_init -- initialize server, returning an unix-domain socket that can
|
||||||
|
be listened on.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
unix_init (void)
|
||||||
|
{
|
||||||
|
int ls; /* socket descriptor */
|
||||||
|
struct sockaddr_un server; /* unix socket address */
|
||||||
|
int bindlen;
|
||||||
|
|
||||||
|
if ((ls = socket (AF_UNIX,SOCK_STREAM, 0)) < 0)
|
||||||
|
glibtop_error_io ("unable to create socket");
|
||||||
|
|
||||||
|
/* Set up address structure for the listen socket. */
|
||||||
|
#ifdef HIDE_UNIX_SOCKET
|
||||||
|
sprintf (server.sun_path, "/tmp/lgtddir%d", (int)geteuid());
|
||||||
|
if (mkdir (server.sun_path, 0700) < 0)
|
||||||
|
{
|
||||||
|
/* assume it already exists, and try to set perms */
|
||||||
|
if (chmod (server.sun_path, 0700) < 0)
|
||||||
|
glibtop_error_io ("Can't set permissions on %s", server.sun_path);
|
||||||
|
}
|
||||||
|
strcat(server.sun_path, "/lgtd");
|
||||||
|
unlink(server.sun_path); /* remove old file if it exists */
|
||||||
|
#else /* HIDE_UNIX_SOCKET */
|
||||||
|
sprintf(server.sun_path, "/tmp/lgtd%d", (int)geteuid());
|
||||||
|
unlink(server.sun_path); /* remove old file if it exists */
|
||||||
|
#endif /* HIDE_UNIX_SOCKET */
|
||||||
|
|
||||||
|
server.sun_family = AF_UNIX;
|
||||||
|
#ifdef HAVE_SOCKADDR_SUN_LEN
|
||||||
|
/* See W. R. Stevens "Advanced Programming in the Unix Environment"
|
||||||
|
p. 502 */
|
||||||
|
bindlen = (sizeof (server.sun_len) + sizeof (server.sun_family)
|
||||||
|
+ strlen (server.sun_path) + 1);
|
||||||
|
server.sun_len = bindlen;
|
||||||
|
#else
|
||||||
|
bindlen = strlen (server.sun_path) + sizeof (server.sun_family);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (bind (ls, (struct sockaddr *)&server, bindlen) < 0)
|
||||||
|
glibtop_error_io ("bind");
|
||||||
|
|
||||||
|
chmod(server.sun_path,0700); /* only this user can send commands */
|
||||||
|
|
||||||
|
if (listen(ls,20) < 0)
|
||||||
|
glibtop_error_io ("listen");
|
||||||
|
|
||||||
|
/* #### there are also better ways of dealing with this when
|
||||||
|
sigvec() is present. */
|
||||||
|
#if defined (HAVE_SIGPROCMASK)
|
||||||
|
{
|
||||||
|
sigset_t _mask;
|
||||||
|
sigemptyset (&_mask);
|
||||||
|
sigaddset (&_mask, SIGPIPE);
|
||||||
|
sigprocmask (SIG_BLOCK, &_mask, NULL);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
signal (SIGPIPE, SIG_IGN); /* in case user kills client */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return (ls);
|
||||||
|
|
||||||
|
} /* unix_init */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
handle_unix_request -- accept a request from a client and send the information
|
||||||
|
to stdout (the gnu process).
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
handle_unix_request (int ls)
|
||||||
|
{
|
||||||
|
int s;
|
||||||
|
size_t len = sizeof(struct sockaddr_un);
|
||||||
|
struct sockaddr_un server; /* for unix socket address */
|
||||||
|
|
||||||
|
server.sun_family = AF_UNIX;
|
||||||
|
|
||||||
|
if ((s = accept (ls, (struct sockaddr *)&server, (void *)&len)) < 0)
|
||||||
|
glibtop_error_io ("accept");
|
||||||
|
|
||||||
|
echo_request(s);
|
||||||
|
|
||||||
|
} /* handle_unix_request */
|
||||||
|
#endif /* UNIX_DOMAIN_SOCKETS */
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
main(argc,argv)
|
||||||
|
int argc;
|
||||||
|
char *argv[];
|
||||||
|
{
|
||||||
|
int chan; /* temporary channel number */
|
||||||
|
int ils = -1; /* internet domain listen socket */
|
||||||
|
int uls = -1; /* unix domain listen socket */
|
||||||
|
#ifdef SYSV_IPC
|
||||||
|
struct msgbuf *msgp; /* message buffer */
|
||||||
|
#endif /* SYSV_IPC */
|
||||||
|
|
||||||
|
glibtop_init_r (&glibtop_global_server, 0, GLIBTOP_OPEN_NO_OVERRIDE);
|
||||||
|
|
||||||
|
for(chan=3; chan < _NFILE; close(chan++)) /* close unwanted channels */
|
||||||
|
;
|
||||||
|
|
||||||
|
#ifdef SYSV_IPC
|
||||||
|
ipc_init(&msgp); /* get a msqid to listen on, and a message buffer */
|
||||||
|
#endif /* SYSV_IPC */
|
||||||
|
|
||||||
|
#ifdef INTERNET_DOMAIN_SOCKETS
|
||||||
|
ils = internet_init(); /* get a internet domain socket to listen on */
|
||||||
|
#endif /* INTERNET_DOMAIN_SOCKETS */
|
||||||
|
|
||||||
|
#ifdef UNIX_DOMAIN_SOCKETS
|
||||||
|
uls = unix_init(); /* get a unix domain socket to listen on */
|
||||||
|
#endif /* UNIX_DOMAIN_SOCKETS */
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
#ifdef SYSV_IPC
|
||||||
|
handle_ipc_request(msgp);
|
||||||
|
#else /* NOT SYSV_IPC */
|
||||||
|
fd_set rmask;
|
||||||
|
FD_ZERO(&rmask);
|
||||||
|
FD_SET(fileno(stdin), &rmask);
|
||||||
|
if (uls >= 0)
|
||||||
|
FD_SET(uls, &rmask);
|
||||||
|
if (ils >= 0)
|
||||||
|
FD_SET(ils, &rmask);
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
fprintf (stderr, "Server ready and waiting for connections.\n");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (select(max2(fileno(stdin),max2(uls,ils)) + 1, &rmask,
|
||||||
|
(fd_set *)NULL, (fd_set *)NULL, (struct timeval *)NULL) < 0)
|
||||||
|
glibtop_error_io ("select");
|
||||||
|
|
||||||
|
#ifdef UNIX_DOMAIN_SOCKETS
|
||||||
|
if (uls > 0 && FD_ISSET(uls, &rmask))
|
||||||
|
handle_unix_request(uls);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef INTERNET_DOMAIN_SOCKETS
|
||||||
|
if (ils > 0 && FD_ISSET(ils, &rmask))
|
||||||
|
handle_internet_request(ils);
|
||||||
|
#endif /* INTERNET_DOMAIN_SOCKETS */
|
||||||
|
|
||||||
|
if (FD_ISSET(fileno(stdin), &rmask)) /* from stdin (gnu process) */
|
||||||
|
handle_response();
|
||||||
|
#endif /* NOT SYSV_IPC */
|
||||||
|
} /* while */
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
} /* main */
|
||||||
|
|
||||||
|
#endif /* SYSV_IPC || UNIX_DOMAIN_SOCKETS || INTERNET_DOMAIN_SOCKETS */
|
218
src/daemon/main.c
Normal file
218
src/daemon/main.c
Normal file
@@ -0,0 +1,218 @@
|
|||||||
|
/* $Id$ */
|
||||||
|
|
||||||
|
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
||||||
|
This file is part of the Gnome Top Library.
|
||||||
|
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
||||||
|
|
||||||
|
The Gnome Top Library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Library General Public License as
|
||||||
|
published by the Free Software Foundation; either version 2 of the
|
||||||
|
License, or (at your option) any later version.
|
||||||
|
|
||||||
|
The Gnome Top Library 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
|
||||||
|
Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public
|
||||||
|
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
||||||
|
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||||
|
Boston, MA 02111-1307, USA. */
|
||||||
|
|
||||||
|
#include <glibtop/gnuserv.h>
|
||||||
|
|
||||||
|
#include <glibtop/command.h>
|
||||||
|
#include <glibtop/version.h>
|
||||||
|
#include <glibtop/xmalloc.h>
|
||||||
|
#include <glibtop/union.h>
|
||||||
|
#include <glibtop/open.h>
|
||||||
|
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <locale.h>
|
||||||
|
|
||||||
|
#if defined(HAVE_GETDTABLESIZE)
|
||||||
|
#define GET_MAX_FDS() getdtablesize()
|
||||||
|
#else
|
||||||
|
/* Fallthrough case - please add other #elif cases above
|
||||||
|
for different OS's as necessary */
|
||||||
|
#define GET_MAX_FDS() 256
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define _offset_union(p) ((char *) &response.u.p - (char *) &response)
|
||||||
|
#define _offset_data(p) _offset_union (data.p)
|
||||||
|
|
||||||
|
static void
|
||||||
|
do_output (int s, glibtop_response *response, off_t offset,
|
||||||
|
size_t data_size, const void *data)
|
||||||
|
{
|
||||||
|
#ifdef REAL_DEBUG
|
||||||
|
fprintf (stderr, "Really writing %d bytes at offset %d.\n",
|
||||||
|
sizeof (glibtop_response), offset);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
response->offset = offset;
|
||||||
|
response->data_size = data_size;
|
||||||
|
|
||||||
|
if (send (s, response, sizeof (glibtop_response), 0) < 0)
|
||||||
|
glibtop_warn_io ("send");
|
||||||
|
|
||||||
|
if (response->data_size) {
|
||||||
|
#ifdef REAL_DEBUG
|
||||||
|
fprintf (stderr, "Writing %d bytes of data.\n", response->data_size);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (send (s, data, response->data_size, 0) , 0)
|
||||||
|
glibtop_warn_io ("send");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
do_read (int s, void *ptr, size_t total_size)
|
||||||
|
{
|
||||||
|
int nread;
|
||||||
|
size_t already_read = 0, remaining = total_size;
|
||||||
|
|
||||||
|
while (already_read < total_size) {
|
||||||
|
nread = recv (s, ptr, remaining, 0);
|
||||||
|
|
||||||
|
if (nread <= 0) {
|
||||||
|
glibtop_error_io ("recv");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
already_read += nread;
|
||||||
|
remaining -= nread;
|
||||||
|
(char *) ptr += nread;
|
||||||
|
|
||||||
|
fprintf (stderr, "READ (%d): %d - %d - %d\n",
|
||||||
|
nread, already_read, remaining, total_size);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
handle_socket_connection (glibtop *server, int s)
|
||||||
|
{
|
||||||
|
pid_t pid;
|
||||||
|
char parameter [BUFSIZ];
|
||||||
|
struct timeval tv;
|
||||||
|
glibtop_response response;
|
||||||
|
glibtop_command cmnd;
|
||||||
|
void *ptr;
|
||||||
|
|
||||||
|
tv.tv_sec = 5;
|
||||||
|
tv.tv_usec = 0;
|
||||||
|
|
||||||
|
while(1) {
|
||||||
|
do_read (s, &cmnd, sizeof (glibtop_command));
|
||||||
|
|
||||||
|
#ifdef REAL_DEBUG
|
||||||
|
fprintf (stderr, "Received command %d from client.\n", cmnd.command);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (cmnd.data_size >= BUFSIZ) {
|
||||||
|
glibtop_warn ("Client sent %d bytes, but buffer is %d", cmnd.size, BUFSIZ);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
memset (parameter, 0, sizeof (parameter));
|
||||||
|
|
||||||
|
if (cmnd.data_size) {
|
||||||
|
#ifdef REAL_DEBUG
|
||||||
|
fprintf (stderr, "Client has %d bytes of data.\n", cmnd.data_size);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
do_read (s, parameter, cmnd.data_size);
|
||||||
|
|
||||||
|
} else if (cmnd.size) {
|
||||||
|
memcpy (parameter, cmnd.parameter, cmnd.size);
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (cmnd.command) {
|
||||||
|
case GLIBTOP_CMND_SYSDEPS:
|
||||||
|
response.u.sysdeps.features = GLIBTOP_SYSDEPS_ALL;
|
||||||
|
do_output (s, &response, _offset_union (sysdeps), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_CPU:
|
||||||
|
glibtop_get_cpu_l (server, &response.u.data.cpu);
|
||||||
|
do_output (s, &response, _offset_data (cpu), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_MEM:
|
||||||
|
glibtop_get_mem_l (server, &response.u.data.mem);
|
||||||
|
do_output (s, &response, _offset_data (mem), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_SWAP:
|
||||||
|
glibtop_get_swap_l (server, &response.u.data.swap);
|
||||||
|
do_output (s, &response, _offset_data (swap), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_UPTIME:
|
||||||
|
glibtop_get_uptime_l (server, &response.u.data.uptime);
|
||||||
|
do_output (s, &response, _offset_data (uptime), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_LOADAVG:
|
||||||
|
glibtop_get_loadavg_l (server, &response.u.data.loadavg);
|
||||||
|
do_output (s, &response, _offset_data (loadavg), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_SHM_LIMITS:
|
||||||
|
glibtop_get_shm_limits_l (server, &response.u.data.shm_limits);
|
||||||
|
do_output (s, &response, _offset_data (shm_limits), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_MSG_LIMITS:
|
||||||
|
glibtop_get_msg_limits_l (server, &response.u.data.msg_limits);
|
||||||
|
do_output (s, &response, _offset_data (msg_limits), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_SEM_LIMITS:
|
||||||
|
glibtop_get_sem_limits_l (server, &response.u.data.sem_limits);
|
||||||
|
do_output (s, &response, _offset_data (sem_limits), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_PROCLIST:
|
||||||
|
ptr = glibtop_get_proclist_l (server, &response.u.data.proclist);
|
||||||
|
do_output (s, &response, _offset_data (proclist),
|
||||||
|
response.u.data.proclist.total, ptr);
|
||||||
|
glibtop_free_r (server, ptr);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_PROC_STATE:
|
||||||
|
memcpy (&pid, parameter, sizeof (pid_t));
|
||||||
|
glibtop_get_proc_state_l
|
||||||
|
(server, &response.u.data.proc_state, pid);
|
||||||
|
do_output (s, &response, _offset_data (proc_state), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_PROC_UID:
|
||||||
|
pid = 1;
|
||||||
|
memcpy (&pid, parameter, sizeof (pid_t));
|
||||||
|
glibtop_get_proc_uid_l
|
||||||
|
(server, &response.u.data.proc_uid, pid);
|
||||||
|
do_output (s, &response, _offset_data (proc_uid), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_PROC_MEM:
|
||||||
|
memcpy (&pid, parameter, sizeof (pid_t));
|
||||||
|
glibtop_get_proc_mem_l
|
||||||
|
(server, &response.u.data.proc_mem, pid);
|
||||||
|
do_output (s, &response, _offset_data (proc_mem), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_PROC_TIME:
|
||||||
|
memcpy (&pid, parameter, sizeof (pid_t));
|
||||||
|
glibtop_get_proc_time_l
|
||||||
|
(server, &response.u.data.proc_time, pid);
|
||||||
|
do_output (s, &response, _offset_data (proc_time), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_PROC_SIGNAL:
|
||||||
|
memcpy (&pid, parameter, sizeof (pid_t));
|
||||||
|
glibtop_get_proc_signal_l
|
||||||
|
(server, &response.u.data.proc_signal, pid);
|
||||||
|
do_output (s, &response, _offset_data (proc_signal), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_PROC_KERNEL:
|
||||||
|
memcpy (&pid, parameter, sizeof (pid_t));
|
||||||
|
glibtop_get_proc_kernel_l
|
||||||
|
(server, &response.u.data.proc_kernel, pid);
|
||||||
|
do_output (s, &response, _offset_data (proc_kernel), 0, NULL);
|
||||||
|
break;
|
||||||
|
case GLIBTOP_CMND_PROC_SEGMENT:
|
||||||
|
memcpy (&pid, parameter, sizeof (pid_t));
|
||||||
|
glibtop_get_proc_segment_l
|
||||||
|
(server, &response.u.data.proc_segment, pid);
|
||||||
|
do_output (s, &response, _offset_data (proc_segment), 0, NULL);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@@ -12,5 +12,5 @@ gtop_proxy_SOURCES = main.c output.c version.c
|
|||||||
gtop_proxy_LDADD = $(top_builddir)/lib/libgtop.la \
|
gtop_proxy_LDADD = $(top_builddir)/lib/libgtop.la \
|
||||||
$(top_builddir)/sysdeps/common/libgtop_common.la \
|
$(top_builddir)/sysdeps/common/libgtop_common.la \
|
||||||
$(top_builddir)/sysdeps/@sysdeps_dir@/libgtop_sysdeps.la \
|
$(top_builddir)/sysdeps/@sysdeps_dir@/libgtop_sysdeps.la \
|
||||||
@INTLLIBS@ @LIBSUPPORT@
|
@INTLLIBS@ @LIBSUPPORT@ @libs_xauth@
|
||||||
gtop_proxy_LDFLAGS = -static
|
gtop_proxy_LDFLAGS = -static
|
||||||
|
@@ -12,4 +12,4 @@ endif
|
|||||||
|
|
||||||
SUBDIRS = @sysdeps_dir@ common $(names_SUBDIRS) $(guile_SUBDIRS)
|
SUBDIRS = @sysdeps_dir@ common $(names_SUBDIRS) $(guile_SUBDIRS)
|
||||||
|
|
||||||
DIST_SUBDIRS = common guile linux names osf1 stub sun4
|
DIST_SUBDIRS = common guile linux kernel names osf1 stub sun4
|
||||||
|
@@ -8,5 +8,4 @@ CFLAGS = -Wall -W @CFLAGS@
|
|||||||
|
|
||||||
lib_LTLIBRARIES = libgtop_common.la
|
lib_LTLIBRARIES = libgtop_common.la
|
||||||
|
|
||||||
libgtop_common_la_SOURCES = sysdeps.c xmalloc.c error.c
|
libgtop_common_la_SOURCES = sysdeps.c xmalloc.c error.c gnuslib.c
|
||||||
|
|
||||||
|
@@ -37,3 +37,46 @@ glibtop_error_r (glibtop *server, char *format, ...)
|
|||||||
va_end (ap);
|
va_end (ap);
|
||||||
exit (1);
|
exit (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
glibtop_error_io_r (glibtop *server, char *format, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
|
va_start (ap, format);
|
||||||
|
|
||||||
|
fprintf (stderr, "%s: ", server->name);
|
||||||
|
vfprintf (stderr, format, ap);
|
||||||
|
fprintf (stderr, ": %s\n", strerror (errno));
|
||||||
|
|
||||||
|
va_end (ap);
|
||||||
|
exit (1);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
glibtop_warn_r (glibtop *server, char *format, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
|
va_start (ap, format);
|
||||||
|
|
||||||
|
fprintf (stderr, "%s: ", server->name);
|
||||||
|
vfprintf (stderr, format, ap);
|
||||||
|
fprintf (stderr, "\n");
|
||||||
|
|
||||||
|
va_end (ap);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
glibtop_warn_io_r (glibtop *server, char *format, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
|
va_start (ap, format);
|
||||||
|
|
||||||
|
fprintf (stderr, "%s: ", server->name);
|
||||||
|
vfprintf (stderr, format, ap);
|
||||||
|
fprintf (stderr, ": %s\n", strerror (errno));
|
||||||
|
|
||||||
|
va_end (ap);
|
||||||
|
}
|
||||||
|
274
sysdeps/common/fsusage.c
Normal file
274
sysdeps/common/fsusage.c
Normal file
@@ -0,0 +1,274 @@
|
|||||||
|
/* fsusage.c -- return space usage of mounted filesystems
|
||||||
|
Copyright (C) 1991, 1992, 1996 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2, or (at your option)
|
||||||
|
any later version.
|
||||||
|
|
||||||
|
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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
|
||||||
|
|
||||||
|
#if HAVE_CONFIG_H
|
||||||
|
# include <config.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include "fsusage.h"
|
||||||
|
|
||||||
|
int statfs ();
|
||||||
|
|
||||||
|
#if HAVE_SYS_PARAM_H
|
||||||
|
# include <sys/param.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if HAVE_SYS_MOUNT_H
|
||||||
|
# include <sys/mount.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if HAVE_SYS_VFS_H
|
||||||
|
# include <sys/vfs.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if HAVE_SYS_FS_S5PARAM_H /* Fujitsu UXP/V */
|
||||||
|
# include <sys/fs/s5param.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (HAVE_SYS_FILSYS_H) && !defined (_CRAY)
|
||||||
|
# include <sys/filsys.h> /* SVR2 */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if HAVE_FCNTL_H
|
||||||
|
# include <fcntl.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if HAVE_SYS_STATFS_H
|
||||||
|
# include <sys/statfs.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if HAVE_DUSTAT_H /* AIX PS/2 */
|
||||||
|
# include <sys/dustat.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if HAVE_SYS_STATVFS_H /* SVR4 */
|
||||||
|
# include <sys/statvfs.h>
|
||||||
|
int statvfs ();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int safe_read ();
|
||||||
|
|
||||||
|
/* Return the number of TOSIZE-byte blocks used by
|
||||||
|
BLOCKS FROMSIZE-byte blocks, rounding away from zero.
|
||||||
|
TOSIZE must be positive. Return -1 if FROMSIZE is not positive. */
|
||||||
|
|
||||||
|
static long
|
||||||
|
adjust_blocks (blocks, fromsize, tosize)
|
||||||
|
long blocks;
|
||||||
|
int fromsize, tosize;
|
||||||
|
{
|
||||||
|
if (tosize <= 0)
|
||||||
|
abort ();
|
||||||
|
if (fromsize <= 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
if (fromsize == tosize) /* e.g., from 512 to 512 */
|
||||||
|
return blocks;
|
||||||
|
else if (fromsize > tosize) /* e.g., from 2048 to 512 */
|
||||||
|
return blocks * (fromsize / tosize);
|
||||||
|
else /* e.g., from 256 to 512 */
|
||||||
|
return (blocks + (blocks < 0 ? -1 : 1)) / (tosize / fromsize);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Fill in the fields of FSP with information about space usage for
|
||||||
|
the filesystem on which PATH resides.
|
||||||
|
DISK is the device on which PATH is mounted, for space-getting
|
||||||
|
methods that need to know it.
|
||||||
|
Return 0 if successful, -1 if not. When returning -1, ensure that
|
||||||
|
ERRNO is either a system error value, or zero if DISK is NULL
|
||||||
|
on a system that requires a non-NULL value. */
|
||||||
|
int
|
||||||
|
get_fs_usage (path, disk, fsp)
|
||||||
|
const char *path;
|
||||||
|
const char *disk;
|
||||||
|
struct fs_usage *fsp;
|
||||||
|
{
|
||||||
|
#ifdef STAT_STATFS3_OSF1
|
||||||
|
# define CONVERT_BLOCKS(B) adjust_blocks ((B), fsd.f_fsize, 512)
|
||||||
|
|
||||||
|
struct statfs fsd;
|
||||||
|
|
||||||
|
if (statfs (path, &fsd, sizeof (struct statfs)) != 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
#endif /* STAT_STATFS3_OSF1 */
|
||||||
|
|
||||||
|
#ifdef STAT_STATFS2_FS_DATA /* Ultrix */
|
||||||
|
# define CONVERT_BLOCKS(B) adjust_blocks ((B), 1024, 512)
|
||||||
|
|
||||||
|
struct fs_data fsd;
|
||||||
|
|
||||||
|
if (statfs (path, &fsd) != 1)
|
||||||
|
return -1;
|
||||||
|
fsp->fsu_blocks = CONVERT_BLOCKS (fsd.fd_req.btot);
|
||||||
|
fsp->fsu_bfree = CONVERT_BLOCKS (fsd.fd_req.bfree);
|
||||||
|
fsp->fsu_bavail = CONVERT_BLOCKS (fsd.fd_req.bfreen);
|
||||||
|
fsp->fsu_files = fsd.fd_req.gtot;
|
||||||
|
fsp->fsu_ffree = fsd.fd_req.gfree;
|
||||||
|
|
||||||
|
#endif /* STAT_STATFS2_FS_DATA */
|
||||||
|
|
||||||
|
#ifdef STAT_READ_FILSYS /* SVR2 */
|
||||||
|
# ifndef SUPERBOFF
|
||||||
|
# define SUPERBOFF (SUPERB * 512)
|
||||||
|
# endif
|
||||||
|
# define CONVERT_BLOCKS(B) \
|
||||||
|
adjust_blocks ((B), (fsd.s_type == Fs2b ? 1024 : 512), 512)
|
||||||
|
|
||||||
|
struct filsys fsd;
|
||||||
|
int fd;
|
||||||
|
|
||||||
|
if (! disk)
|
||||||
|
{
|
||||||
|
errno = 0;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
fd = open (disk, O_RDONLY);
|
||||||
|
if (fd < 0)
|
||||||
|
return -1;
|
||||||
|
lseek (fd, (long) SUPERBOFF, 0);
|
||||||
|
if (safe_read (fd, (char *) &fsd, sizeof fsd) != sizeof fsd)
|
||||||
|
{
|
||||||
|
close (fd);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
close (fd);
|
||||||
|
fsp->fsu_blocks = CONVERT_BLOCKS (fsd.s_fsize);
|
||||||
|
fsp->fsu_bfree = CONVERT_BLOCKS (fsd.s_tfree);
|
||||||
|
fsp->fsu_bavail = CONVERT_BLOCKS (fsd.s_tfree);
|
||||||
|
fsp->fsu_files = (fsd.s_isize - 2) * INOPB * (fsd.s_type == Fs2b ? 2 : 1);
|
||||||
|
fsp->fsu_ffree = fsd.s_tinode;
|
||||||
|
|
||||||
|
#endif /* STAT_READ_FILSYS */
|
||||||
|
|
||||||
|
#ifdef STAT_STATFS2_BSIZE /* 4.3BSD, SunOS 4, HP-UX, AIX */
|
||||||
|
# define CONVERT_BLOCKS(B) adjust_blocks ((B), fsd.f_bsize, 512)
|
||||||
|
|
||||||
|
struct statfs fsd;
|
||||||
|
|
||||||
|
if (statfs (path, &fsd) < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
# ifdef STATFS_TRUNCATES_BLOCK_COUNTS
|
||||||
|
|
||||||
|
/* In SunOS 4.1.2, 4.1.3, and 4.1.3_U1, the block counts in the
|
||||||
|
struct statfs are truncated to 2GB. These conditions detect that
|
||||||
|
truncation, presumably without botching the 4.1.1 case, in which
|
||||||
|
the values are not truncated. The correct counts are stored in
|
||||||
|
undocumented spare fields. */
|
||||||
|
if (fsd.f_blocks == 0x1fffff && fsd.f_spare[0] > 0)
|
||||||
|
{
|
||||||
|
fsd.f_blocks = fsd.f_spare[0];
|
||||||
|
fsd.f_bfree = fsd.f_spare[1];
|
||||||
|
fsd.f_bavail = fsd.f_spare[2];
|
||||||
|
}
|
||||||
|
# endif /* STATFS_TRUNCATES_BLOCK_COUNTS */
|
||||||
|
|
||||||
|
#endif /* STAT_STATFS2_BSIZE */
|
||||||
|
|
||||||
|
#ifdef STAT_STATFS2_FSIZE /* 4.4BSD */
|
||||||
|
# define CONVERT_BLOCKS(B) adjust_blocks ((B), fsd.f_fsize, 512)
|
||||||
|
|
||||||
|
struct statfs fsd;
|
||||||
|
|
||||||
|
if (statfs (path, &fsd) < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
#endif /* STAT_STATFS2_FSIZE */
|
||||||
|
|
||||||
|
#ifdef STAT_STATFS4 /* SVR3, Dynix, Irix, AIX */
|
||||||
|
# if _AIX || defined(_CRAY)
|
||||||
|
# define CONVERT_BLOCKS(B) adjust_blocks ((B), fsd.f_bsize, 512)
|
||||||
|
# ifdef _CRAY
|
||||||
|
# define f_bavail f_bfree
|
||||||
|
# endif
|
||||||
|
# else
|
||||||
|
# define CONVERT_BLOCKS(B) (B)
|
||||||
|
# ifndef _SEQUENT_ /* _SEQUENT_ is DYNIX/ptx */
|
||||||
|
# ifndef DOLPHIN /* DOLPHIN 3.8.alfa/7.18 has f_bavail */
|
||||||
|
# define f_bavail f_bfree
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
|
||||||
|
struct statfs fsd;
|
||||||
|
|
||||||
|
if (statfs (path, &fsd, sizeof fsd, 0) < 0)
|
||||||
|
return -1;
|
||||||
|
/* Empirically, the block counts on most SVR3 and SVR3-derived
|
||||||
|
systems seem to always be in terms of 512-byte blocks,
|
||||||
|
no matter what value f_bsize has. */
|
||||||
|
|
||||||
|
#endif /* STAT_STATFS4 */
|
||||||
|
|
||||||
|
#ifdef STAT_STATVFS /* SVR4 */
|
||||||
|
# define CONVERT_BLOCKS(B) \
|
||||||
|
adjust_blocks ((B), fsd.f_frsize ? fsd.f_frsize : fsd.f_bsize, 512)
|
||||||
|
|
||||||
|
struct statvfs fsd;
|
||||||
|
|
||||||
|
if (statvfs (path, &fsd) < 0)
|
||||||
|
return -1;
|
||||||
|
/* f_frsize isn't guaranteed to be supported. */
|
||||||
|
|
||||||
|
#endif /* STAT_STATVFS */
|
||||||
|
|
||||||
|
#if !defined(STAT_STATFS2_FS_DATA) && !defined(STAT_READ_FILSYS)
|
||||||
|
/* !Ultrix && !SVR2 */
|
||||||
|
|
||||||
|
fsp->fsu_blocks = CONVERT_BLOCKS (fsd.f_blocks);
|
||||||
|
fsp->fsu_bfree = CONVERT_BLOCKS (fsd.f_bfree);
|
||||||
|
fsp->fsu_bavail = CONVERT_BLOCKS (fsd.f_bavail);
|
||||||
|
fsp->fsu_files = fsd.f_files;
|
||||||
|
fsp->fsu_ffree = fsd.f_ffree;
|
||||||
|
|
||||||
|
#endif /* not STAT_STATFS2_FS_DATA && not STAT_READ_FILSYS */
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined(_AIX) && defined(_I386)
|
||||||
|
/* AIX PS/2 does not supply statfs. */
|
||||||
|
|
||||||
|
int
|
||||||
|
statfs (path, fsb)
|
||||||
|
char *path;
|
||||||
|
struct statfs *fsb;
|
||||||
|
{
|
||||||
|
struct stat stats;
|
||||||
|
struct dustat fsd;
|
||||||
|
|
||||||
|
if (stat (path, &stats))
|
||||||
|
return -1;
|
||||||
|
if (dustat (stats.st_dev, 0, &fsd, sizeof (fsd)))
|
||||||
|
return -1;
|
||||||
|
fsb->f_type = 0;
|
||||||
|
fsb->f_bsize = fsd.du_bsize;
|
||||||
|
fsb->f_blocks = fsd.du_fsize - fsd.du_isize;
|
||||||
|
fsb->f_bfree = fsd.du_tfree;
|
||||||
|
fsb->f_bavail = fsd.du_tfree;
|
||||||
|
fsb->f_files = (fsd.du_isize - 2) * fsd.du_inopb;
|
||||||
|
fsb->f_ffree = fsd.du_tinode;
|
||||||
|
fsb->f_fsid.val[0] = fsd.du_site;
|
||||||
|
fsb->f_fsid.val[1] = fsd.du_pckno;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* _AIX && _I386 */
|
37
sysdeps/common/fsusage.h
Normal file
37
sysdeps/common/fsusage.h
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
/* fsusage.h -- declarations for filesystem space usage info
|
||||||
|
Copyright (C) 1991, 1992 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2, or (at your option)
|
||||||
|
any later version.
|
||||||
|
|
||||||
|
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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
|
||||||
|
|
||||||
|
/* Space usage statistics for a filesystem. Blocks are 512-byte. */
|
||||||
|
struct fs_usage
|
||||||
|
{
|
||||||
|
long fsu_blocks; /* Total blocks. */
|
||||||
|
long fsu_bfree; /* Free blocks available to superuser. */
|
||||||
|
long fsu_bavail; /* Free blocks available to non-superuser. */
|
||||||
|
long fsu_files; /* Total file nodes. */
|
||||||
|
long fsu_ffree; /* Free file nodes. */
|
||||||
|
};
|
||||||
|
|
||||||
|
#ifndef __P
|
||||||
|
#if defined (__GNUC__) || (defined (__STDC__) && __STDC__)
|
||||||
|
#define __P(args) args
|
||||||
|
#else
|
||||||
|
#define __P(args) ()
|
||||||
|
#endif /* GCC. */
|
||||||
|
#endif /* Not __P. */
|
||||||
|
|
||||||
|
int get_fs_usage __P ((const char *path, const char *disk,
|
||||||
|
struct fs_usage *fsp));
|
433
sysdeps/common/gnuslib.c
Normal file
433
sysdeps/common/gnuslib.c
Normal file
@@ -0,0 +1,433 @@
|
|||||||
|
/* -*-C-*-
|
||||||
|
Common library code for the GNU Emacs server and client.
|
||||||
|
|
||||||
|
This file is part of GNU Emacs.
|
||||||
|
|
||||||
|
Copying is permitted under those conditions described by the GNU
|
||||||
|
General Public License.
|
||||||
|
|
||||||
|
Copyright (C) 1989 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
Author: Andy Norman (ange@hplb.hpl.hp.com), based on
|
||||||
|
'etc/server.c' and 'etc/emacsclient.c' from the 18.52 GNU
|
||||||
|
Emacs distribution.
|
||||||
|
|
||||||
|
Please mail bugs and suggestions to the author at the above address.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* HISTORY
|
||||||
|
* 11-Nov-1990 bristor@simba
|
||||||
|
* Added EOT stuff.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This file incorporates new features added by Bob Weiner <weiner@mot.com>,
|
||||||
|
* Darrell Kindred <dkindred@cmu.edu> and Arup Mukherjee <arup@cmu.edu>.
|
||||||
|
* Please see the note at the end of the README file for details.
|
||||||
|
*
|
||||||
|
* (If gnuserv came bundled with your emacs, the README file is probably
|
||||||
|
* ../etc/gnuserv.README relative to the directory containing this file)
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
static char rcsid [] = "!Header: gnuslib.c,v 2.4 95/02/16 11:57:37 arup alpha !";
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <glibtop/gnuserv.h>
|
||||||
|
|
||||||
|
#include <fcntl.h>
|
||||||
|
|
||||||
|
#ifdef SYSV_IPC
|
||||||
|
static int connect_to_ipc_server (void);
|
||||||
|
#endif
|
||||||
|
#ifdef UNIX_DOMAIN_SOCKETS
|
||||||
|
static int connect_to_unix_server (void);
|
||||||
|
#endif
|
||||||
|
#ifdef INTERNET_DOMAIN_SOCKETS
|
||||||
|
static int connect_to_internet_server (const char *serverhost, u_short port);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* On some systems, e.g. DGUX, inet_addr returns a 'struct in_addr'. */
|
||||||
|
#ifdef HAVE_BROKEN_INET_ADDR
|
||||||
|
# define IN_ADDR struct in_addr
|
||||||
|
# define NUMERIC_ADDR_ERROR (numeric_addr.s_addr == -1)
|
||||||
|
#else
|
||||||
|
# if (LONGBITS > 32)
|
||||||
|
# define IN_ADDR unsigned int
|
||||||
|
# else
|
||||||
|
# define IN_ADDR unsigned long
|
||||||
|
# endif
|
||||||
|
# define NUMERIC_ADDR_ERROR (numeric_addr == (IN_ADDR) -1)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <arpa/inet.h>
|
||||||
|
|
||||||
|
int
|
||||||
|
glibtop_make_connection (hostarg, portarg, s)
|
||||||
|
const char *hostarg;
|
||||||
|
int portarg;
|
||||||
|
int *s;
|
||||||
|
{
|
||||||
|
#ifdef INTERNET_DOMAIN_SOCKETS
|
||||||
|
char *ptr;
|
||||||
|
if (hostarg == NULL)
|
||||||
|
hostarg = getenv ("LIBGTOP_HOST");
|
||||||
|
if (portarg == 0 && (ptr = getenv("LIBGTOP_PORT")) != NULL)
|
||||||
|
portarg = atoi (ptr);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (hostarg != NULL) {
|
||||||
|
/* hostname was given explicitly, via cmd line arg or LIBGTOP_HOST,
|
||||||
|
* so obey it. */
|
||||||
|
#ifdef UNIX_DOMAIN_SOCKETS
|
||||||
|
if (!strcmp (hostarg, "unix")) {
|
||||||
|
*s = connect_to_unix_server ();
|
||||||
|
return (int) CONN_UNIX;
|
||||||
|
}
|
||||||
|
#endif /* UNIX_DOMAIN_SOCKETS */
|
||||||
|
#ifdef INTERNET_DOMAIN_SOCKETS
|
||||||
|
*s = connect_to_internet_server (hostarg, portarg);
|
||||||
|
return (int) CONN_INTERNET;
|
||||||
|
#endif
|
||||||
|
#ifdef SYSV_IPC
|
||||||
|
return -1; /* hostarg should always be NULL for SYSV_IPC */
|
||||||
|
#endif
|
||||||
|
} else {
|
||||||
|
/* no hostname given. Use unix-domain/sysv-ipc, or
|
||||||
|
* internet-domain connection to local host if they're not available. */
|
||||||
|
#if defined(UNIX_DOMAIN_SOCKETS)
|
||||||
|
*s = connect_to_unix_server ();
|
||||||
|
return (int) CONN_UNIX;
|
||||||
|
#elif defined(SYSV_IPC)
|
||||||
|
*s = connect_to_ipc_server ();
|
||||||
|
return (int) CONN_IPC;
|
||||||
|
#elif defined(INTERNET_DOMAIN_SOCKETS)
|
||||||
|
{
|
||||||
|
char localhost [HOSTNAMSZ];
|
||||||
|
gethostname (localhost, HOSTNAMSZ); /* use this host by default */
|
||||||
|
*s = connect_to_internet_server (localhost, portarg);
|
||||||
|
return (int) CONN_INTERNET;
|
||||||
|
}
|
||||||
|
#endif /* IPC type */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef SYSV_IPC
|
||||||
|
/*
|
||||||
|
connect_to_ipc_server -- establish connection with server process via SYSV IPC
|
||||||
|
Returns msqid for server if successful.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
connect_to_ipc_server (void)
|
||||||
|
{
|
||||||
|
int s; /* connected msqid */
|
||||||
|
key_t key; /* message key */
|
||||||
|
char buf [GSERV_BUFSZ+1]; /* buffer for filename */
|
||||||
|
|
||||||
|
sprintf (buf, "/tmp/lgtd%d", (int)geteuid());
|
||||||
|
creat (buf, 0600);
|
||||||
|
if ((key = ftok (buf, 1)) == -1)
|
||||||
|
glibtop_error_io ("unable to get ipc key from %s", buf);
|
||||||
|
|
||||||
|
if ((s = msgget (key, 0600)) == -1)
|
||||||
|
glibtop_error_io ("unable to access msg queue");
|
||||||
|
|
||||||
|
return(s);
|
||||||
|
|
||||||
|
} /* connect_to_ipc_server */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
disconnect_from_ipc_server -- inform the server that sending has finished,
|
||||||
|
and wait for its reply.
|
||||||
|
*/
|
||||||
|
void disconnect_from_ipc_server(s,msgp,echo)
|
||||||
|
int s;
|
||||||
|
struct msgbuf *msgp;
|
||||||
|
int echo;
|
||||||
|
{
|
||||||
|
int len; /* length of received message */
|
||||||
|
|
||||||
|
send_string(s,EOT_STR); /* EOT terminates this message */
|
||||||
|
msgp->mtype = 1;
|
||||||
|
|
||||||
|
if(msgsnd(s,msgp,strlen(msgp->mtext)+1,0) < 0) {
|
||||||
|
perror(progname);
|
||||||
|
fprintf(stderr,"%s: unable to send message to server\n",progname);
|
||||||
|
exit(1);
|
||||||
|
}; /* if */
|
||||||
|
|
||||||
|
if((len = msgrcv(s,msgp,GSERV_BUFSZ,getpid(),0)) < 0) {
|
||||||
|
perror(progname);
|
||||||
|
fprintf(stderr,"%s: unable to receive message from server\n",progname);
|
||||||
|
exit(1);
|
||||||
|
}; /* if */
|
||||||
|
|
||||||
|
if (echo) {
|
||||||
|
msgp->mtext[len] = '\0'; /* string terminate message */
|
||||||
|
fputs(msgp->mtext, stdout);
|
||||||
|
if (msgp->mtext[len-1] != '\n') putchar ('\n');
|
||||||
|
}; /* if */
|
||||||
|
|
||||||
|
} /* disconnect_from_ipc_server */
|
||||||
|
#endif /* SYSV_IPC */
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(INTERNET_DOMAIN_SOCKETS) || defined(UNIX_DOMAIN_SOCKETS)
|
||||||
|
/*
|
||||||
|
send_string -- send string to socket.
|
||||||
|
*/
|
||||||
|
#if 0
|
||||||
|
static void
|
||||||
|
send_string(s,msg)
|
||||||
|
int s;
|
||||||
|
const char *msg;
|
||||||
|
{
|
||||||
|
#if 0
|
||||||
|
if (send(s,msg,strlen(msg),0) < 0) {
|
||||||
|
perror(progname);
|
||||||
|
fprintf(stderr,"%s: unable to send\n",progname);
|
||||||
|
exit(1);
|
||||||
|
}; /* if */
|
||||||
|
#else
|
||||||
|
int len, left=strlen(msg);
|
||||||
|
while (left > 0) {
|
||||||
|
if ((len=write(s,msg,min2(left,GSERV_BUFSZ))) < 0) {
|
||||||
|
/* XEmacs addition: robertl@arnet.com */
|
||||||
|
if (errno == EPIPE) {
|
||||||
|
return ;
|
||||||
|
}
|
||||||
|
perror(progname);
|
||||||
|
fprintf(stderr,"%s: unable to send\n",progname);
|
||||||
|
exit(1);
|
||||||
|
}; /* if */
|
||||||
|
left -= len;
|
||||||
|
msg += len;
|
||||||
|
}; /* while */
|
||||||
|
#endif
|
||||||
|
} /* send_string */
|
||||||
|
|
||||||
|
/*
|
||||||
|
read_line -- read a \n terminated line from a socket
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
read_line(int s, char *dest)
|
||||||
|
{
|
||||||
|
int length;
|
||||||
|
int offset=0;
|
||||||
|
char buffer[GSERV_BUFSZ+1];
|
||||||
|
|
||||||
|
while ((length=read(s,buffer+offset,1)>0) && buffer[offset]!='\n'
|
||||||
|
&& buffer[offset] != EOT_CHR) {
|
||||||
|
offset += length;
|
||||||
|
if (offset >= GSERV_BUFSZ)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
buffer[offset] = '\0';
|
||||||
|
strcpy(dest,buffer);
|
||||||
|
return 1;
|
||||||
|
} /* read_line */
|
||||||
|
#endif
|
||||||
|
#endif /* INTERNET_DOMAIN_SOCKETS || UNIX_DOMAIN_SOCKETS */
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef UNIX_DOMAIN_SOCKETS
|
||||||
|
/*
|
||||||
|
connect_to_unix_server -- establish connection with server process via a unix-
|
||||||
|
domain socket. Returns socket descriptor for server
|
||||||
|
if successful.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
connect_to_unix_server (void)
|
||||||
|
{
|
||||||
|
int s; /* connected socket descriptor */
|
||||||
|
struct sockaddr_un server; /* for unix connections */
|
||||||
|
|
||||||
|
if ((s = socket (AF_UNIX, SOCK_STREAM, 0)) < 0)
|
||||||
|
glibtop_error_io ("unable to create socket");
|
||||||
|
|
||||||
|
server.sun_family = AF_UNIX;
|
||||||
|
#ifdef HIDE_UNIX_SOCKET
|
||||||
|
sprintf(server.sun_path, "/tmp/lgtddir%d/lgtd", (int)geteuid());
|
||||||
|
#else /* HIDE_UNIX_SOCKET */
|
||||||
|
sprintf(server.sun_path, "/tmp/lgtd%d", (int)geteuid());
|
||||||
|
#endif /* HIDE_UNIX_SOCKET */
|
||||||
|
if (connect (s, (struct sockaddr *)&server, strlen(server.sun_path)+2) < 0)
|
||||||
|
glibtop_error_io ("unable to connect to local");
|
||||||
|
|
||||||
|
return(s);
|
||||||
|
|
||||||
|
} /* connect_to_unix_server */
|
||||||
|
#endif /* UNIX_DOMAIN_SOCKETS */
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef INTERNET_DOMAIN_SOCKETS
|
||||||
|
/*
|
||||||
|
internet_addr -- return the internet addr of the hostname or
|
||||||
|
internet address passed. Return -1 on error.
|
||||||
|
*/
|
||||||
|
long glibtop_internet_addr (host)
|
||||||
|
const char *host;
|
||||||
|
{
|
||||||
|
struct hostent *hp; /* pointer to host info for remote host */
|
||||||
|
IN_ADDR numeric_addr; /* host address */
|
||||||
|
|
||||||
|
numeric_addr = inet_addr (host);
|
||||||
|
if (!NUMERIC_ADDR_ERROR)
|
||||||
|
return numeric_addr;
|
||||||
|
else if ((hp = gethostbyname (host)) != NULL)
|
||||||
|
return ((struct in_addr *)(hp->h_addr))->s_addr;
|
||||||
|
else {
|
||||||
|
glibtop_warn_io ("gethostbyname (%s)", host);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
} /* glibtop_internet_addr */
|
||||||
|
|
||||||
|
#ifdef AUTH_MAGIC_COOKIE
|
||||||
|
# include <X11/X.h>
|
||||||
|
# include <X11/Xauth.h>
|
||||||
|
|
||||||
|
static Xauth *server_xauth = NULL;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
connect_to_internet_server -- establish connection with server process via
|
||||||
|
an internet domain socket. Returns socket
|
||||||
|
descriptor for server if successful.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
connect_to_internet_server (const char *serverhost, u_short port)
|
||||||
|
{
|
||||||
|
int s; /* connected socket descriptor */
|
||||||
|
struct servent *sp; /* pointer to service information */
|
||||||
|
struct sockaddr_in peeraddr_in; /* for peer socket address */
|
||||||
|
char buf[512]; /* temporary buffer */
|
||||||
|
|
||||||
|
/* clear out address structures */
|
||||||
|
memset((char *)&peeraddr_in, 0, sizeof(struct sockaddr_in));
|
||||||
|
|
||||||
|
/* Set up the peer address to which we will connect. */
|
||||||
|
peeraddr_in.sin_family = AF_INET;
|
||||||
|
|
||||||
|
/* look up the server host's internet address */
|
||||||
|
if (((long) peeraddr_in.sin_addr.s_addr = glibtop_internet_addr (serverhost)) == -1)
|
||||||
|
glibtop_error ("unable to find %s in /etc/hosts or from YP", serverhost);
|
||||||
|
|
||||||
|
if (port == 0) {
|
||||||
|
if ((sp = getservbyname ("gtopd","tcp")) == NULL)
|
||||||
|
peeraddr_in.sin_port = htons (DEFAULT_PORT+getuid());
|
||||||
|
else
|
||||||
|
peeraddr_in.sin_port = sp->s_port;
|
||||||
|
} /* if */
|
||||||
|
else
|
||||||
|
peeraddr_in.sin_port = htons (port);
|
||||||
|
|
||||||
|
/* Create the socket. */
|
||||||
|
if ((s = socket (AF_INET, SOCK_STREAM, 0))== -1)
|
||||||
|
glibtop_error_io ("unable to create socket");
|
||||||
|
|
||||||
|
/* Try to connect to the remote server at the address
|
||||||
|
* which was just built into peeraddr.
|
||||||
|
*/
|
||||||
|
if (connect(s, (struct sockaddr *)&peeraddr_in,
|
||||||
|
sizeof(struct sockaddr_in)) == -1)
|
||||||
|
glibtop_error_io ("unable to connect to remote");
|
||||||
|
|
||||||
|
#ifdef AUTH_MAGIC_COOKIE
|
||||||
|
|
||||||
|
/* send credentials using MIT-MAGIC-COOKIE-1 protocol */
|
||||||
|
|
||||||
|
server_xauth =
|
||||||
|
XauGetAuthByAddr(FamilyInternet,
|
||||||
|
sizeof(peeraddr_in.sin_addr.s_addr),
|
||||||
|
(char *) &peeraddr_in.sin_addr.s_addr,
|
||||||
|
strlen(MCOOKIE_SCREEN), MCOOKIE_SCREEN,
|
||||||
|
strlen(MCOOKIE_X_NAME), MCOOKIE_X_NAME);
|
||||||
|
|
||||||
|
if (server_xauth && server_xauth->data) {
|
||||||
|
sprintf(buf, "%s\n%d\n", MCOOKIE_NAME, server_xauth->data_length);
|
||||||
|
write (s, buf, strlen(buf));
|
||||||
|
write (s, server_xauth->data, server_xauth->data_length);
|
||||||
|
|
||||||
|
return (s);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* AUTH_MAGIC_COOKIE */
|
||||||
|
|
||||||
|
sprintf (buf, "%s\n", DEFAUTH_NAME);
|
||||||
|
write (s, buf, strlen(buf));
|
||||||
|
|
||||||
|
return(s);
|
||||||
|
|
||||||
|
} /* connect_to_internet_server */
|
||||||
|
#endif /* INTERNET_DOMAIN_SOCKETS */
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(INTERNET_DOMAIN_SOCKETS) || defined(UNIX_DOMAIN_SOCKETS)
|
||||||
|
/*
|
||||||
|
disconnect_from_server -- inform the server that sending has finished, and wait for
|
||||||
|
its reply.
|
||||||
|
*/
|
||||||
|
#if 0
|
||||||
|
static void
|
||||||
|
disconnect_from_server(s,echo)
|
||||||
|
int s;
|
||||||
|
int echo;
|
||||||
|
{
|
||||||
|
#if 0
|
||||||
|
char buffer[REPLYSIZ+1];
|
||||||
|
#else
|
||||||
|
char buffer[GSERV_BUFSZ+1];
|
||||||
|
#endif
|
||||||
|
int add_newline = 1;
|
||||||
|
int length;
|
||||||
|
|
||||||
|
send_string(s,EOT_STR); /* make sure server gets string */
|
||||||
|
|
||||||
|
#if !defined (linux) && !defined (_SCO_DS)
|
||||||
|
/*
|
||||||
|
* shutdown is completely hozed under linux. If s is a unix domain socket,
|
||||||
|
* you'll get EOPNOTSUPP back from it. If s is an internet socket, you get
|
||||||
|
* a broken pipe when you try to read a bit later. The latter
|
||||||
|
* problem is fixed for linux versions >= 1.1.46, but the problem
|
||||||
|
* with unix sockets persists. Sigh.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (shutdown(s,1) == -1) {
|
||||||
|
perror(progname);
|
||||||
|
fprintf(stderr, "%s: unable to shutdown socket\n",progname);
|
||||||
|
exit(1);
|
||||||
|
}; /* if */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
while((length = recv(s,buffer,REPLYSIZ,0)) > 0) {
|
||||||
|
buffer[length] = '\0';
|
||||||
|
if (echo) fputs(buffer,stdout);
|
||||||
|
add_newline = (buffer[length-1] != '\n');
|
||||||
|
}; /* while */
|
||||||
|
#else
|
||||||
|
while ((length = read(s,buffer,GSERV_BUFSZ)) > 0 ||
|
||||||
|
(length == -1 && errno == EINTR)) {
|
||||||
|
if (length) {
|
||||||
|
buffer[length] = '\0';
|
||||||
|
if (echo) {
|
||||||
|
fputs(buffer,stdout);
|
||||||
|
add_newline = (buffer[length-1] != '\n');
|
||||||
|
}; /* if */
|
||||||
|
}; /* if */
|
||||||
|
}; /* while */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (echo && add_newline) putchar('\n');
|
||||||
|
|
||||||
|
if(length < 0) {
|
||||||
|
perror(progname);
|
||||||
|
fprintf(stderr,"%s: unable to read the reply from the server\n",progname);
|
||||||
|
exit(1);
|
||||||
|
}; /* if */
|
||||||
|
|
||||||
|
} /* disconnect_from_server */
|
||||||
|
#endif
|
||||||
|
#endif /* INTERNET_DOMAIN_SOCKETS || UNIX_DOMAIN_SOCKETS */
|
577
sysdeps/common/mountlist.c
Normal file
577
sysdeps/common/mountlist.c
Normal file
@@ -0,0 +1,577 @@
|
|||||||
|
/* mountlist.c -- return a list of mounted filesystems
|
||||||
|
Copyright (C) 1991, 1992 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2, or (at your option)
|
||||||
|
any later version.
|
||||||
|
|
||||||
|
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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include <config.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include "mountlist.h"
|
||||||
|
|
||||||
|
#ifdef STDC_HEADERS
|
||||||
|
#include <stdlib.h>
|
||||||
|
#else
|
||||||
|
void free ();
|
||||||
|
#endif
|
||||||
|
#if defined(STDC_HEADERS) || defined(HAVE_STRING_H)
|
||||||
|
#include <string.h>
|
||||||
|
#else
|
||||||
|
#include <strings.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
char *strstr ();
|
||||||
|
char *xmalloc ();
|
||||||
|
char *xrealloc ();
|
||||||
|
char *xstrdup ();
|
||||||
|
void error ();
|
||||||
|
|
||||||
|
#ifdef HAVE_SYS_PARAM_H
|
||||||
|
#include <sys/param.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (MOUNTED_GETFSSTAT) /* __alpha running OSF_1 */
|
||||||
|
# include <sys/mount.h>
|
||||||
|
# include <sys/fs_types.h>
|
||||||
|
#endif /* MOUNTED_GETFSSTAT */
|
||||||
|
|
||||||
|
#ifdef MOUNTED_GETMNTENT1 /* 4.3BSD, SunOS, HP-UX, Dynix, Irix. */
|
||||||
|
#include <mntent.h>
|
||||||
|
#if !defined(MOUNTED)
|
||||||
|
# if defined(MNT_MNTTAB) /* HP-UX. */
|
||||||
|
# define MOUNTED MNT_MNTTAB
|
||||||
|
# endif
|
||||||
|
# if defined(MNTTABNAME) /* Dynix. */
|
||||||
|
# define MOUNTED MNTTABNAME
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef MOUNTED_GETMNTINFO /* 4.4BSD. */
|
||||||
|
#include <sys/mount.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef MOUNTED_GETMNT /* Ultrix. */
|
||||||
|
#include <sys/mount.h>
|
||||||
|
#include <sys/fs_types.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef MOUNTED_FREAD /* SVR2. */
|
||||||
|
#include <mnttab.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef MOUNTED_FREAD_FSTYP /* SVR3. */
|
||||||
|
#include <mnttab.h>
|
||||||
|
#include <sys/fstyp.h>
|
||||||
|
#include <sys/statfs.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef MOUNTED_LISTMNTENT
|
||||||
|
#include <mntent.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef MOUNTED_GETMNTENT2 /* SVR4. */
|
||||||
|
#include <sys/mnttab.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef MOUNTED_VMOUNT /* AIX. */
|
||||||
|
#include <fshelp.h>
|
||||||
|
#include <sys/vfs.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef DOLPHIN
|
||||||
|
/* So special that it's not worth putting this in autoconf. */
|
||||||
|
#undef MOUNTED_FREAD_FSTYP
|
||||||
|
#define MOUNTED_GETMNTTBL
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef MOUNTED_GETMNTENT1 /* 4.3BSD, SunOS, HP-UX, Dynix, Irix. */
|
||||||
|
/* Return the value of the hexadecimal number represented by CP.
|
||||||
|
No prefix (like '0x') or suffix (like 'h') is expected to be
|
||||||
|
part of CP. */
|
||||||
|
|
||||||
|
static int
|
||||||
|
xatoi (cp)
|
||||||
|
char *cp;
|
||||||
|
{
|
||||||
|
int val;
|
||||||
|
|
||||||
|
val = 0;
|
||||||
|
while (*cp)
|
||||||
|
{
|
||||||
|
if (*cp >= 'a' && *cp <= 'f')
|
||||||
|
val = val * 16 + *cp - 'a' + 10;
|
||||||
|
else if (*cp >= 'A' && *cp <= 'F')
|
||||||
|
val = val * 16 + *cp - 'A' + 10;
|
||||||
|
else if (*cp >= '0' && *cp <= '9')
|
||||||
|
val = val * 16 + *cp - '0';
|
||||||
|
else
|
||||||
|
break;
|
||||||
|
cp++;
|
||||||
|
}
|
||||||
|
return val;
|
||||||
|
}
|
||||||
|
#endif /* MOUNTED_GETMNTENT1. */
|
||||||
|
|
||||||
|
#if defined (MOUNTED_GETMNTINFO) && !defined (__NetBSD__)
|
||||||
|
static char *
|
||||||
|
fstype_to_string (t)
|
||||||
|
short t;
|
||||||
|
{
|
||||||
|
switch (t)
|
||||||
|
{
|
||||||
|
#ifdef MOUNT_PC
|
||||||
|
case MOUNT_PC:
|
||||||
|
return "pc";
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_MFS
|
||||||
|
case MOUNT_MFS:
|
||||||
|
return "mfs";
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_LO
|
||||||
|
case MOUNT_LO:
|
||||||
|
return "lo";
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_TFS
|
||||||
|
case MOUNT_TFS:
|
||||||
|
return "tfs";
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_TMP
|
||||||
|
case MOUNT_TMP:
|
||||||
|
return "tmp";
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_UFS
|
||||||
|
case MOUNT_UFS:
|
||||||
|
return "ufs" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_NFS
|
||||||
|
case MOUNT_NFS:
|
||||||
|
return "nfs" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_MSDOS
|
||||||
|
case MOUNT_MSDOS:
|
||||||
|
return "msdos" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_LFS
|
||||||
|
case MOUNT_LFS:
|
||||||
|
return "lfs" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_LOFS
|
||||||
|
case MOUNT_LOFS:
|
||||||
|
return "lofs" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_FDESC
|
||||||
|
case MOUNT_FDESC:
|
||||||
|
return "fdesc" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_PORTAL
|
||||||
|
case MOUNT_PORTAL:
|
||||||
|
return "portal" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_NULL
|
||||||
|
case MOUNT_NULL:
|
||||||
|
return "null" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_UMAP
|
||||||
|
case MOUNT_UMAP:
|
||||||
|
return "umap" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_KERNFS
|
||||||
|
case MOUNT_KERNFS:
|
||||||
|
return "kernfs" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_PROCFS
|
||||||
|
case MOUNT_PROCFS:
|
||||||
|
return "procfs" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_AFS
|
||||||
|
case MOUNT_AFS:
|
||||||
|
return "afs" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_CD9660
|
||||||
|
case MOUNT_CD9660:
|
||||||
|
return "cd9660" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_UNION
|
||||||
|
case MOUNT_UNION:
|
||||||
|
return "union" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_DEVFS
|
||||||
|
case MOUNT_DEVFS:
|
||||||
|
return "devfs" ;
|
||||||
|
#endif
|
||||||
|
#ifdef MOUNT_EXT2FS
|
||||||
|
case MOUNT_EXT2FS:
|
||||||
|
return "ext2fs" ;
|
||||||
|
#endif
|
||||||
|
default:
|
||||||
|
return "?";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif /* MOUNTED_GETMNTINFO */
|
||||||
|
|
||||||
|
#ifdef MOUNTED_VMOUNT /* AIX. */
|
||||||
|
static char *
|
||||||
|
fstype_to_string (t)
|
||||||
|
int t;
|
||||||
|
{
|
||||||
|
struct vfs_ent *e;
|
||||||
|
|
||||||
|
e = getvfsbytype (t);
|
||||||
|
if (!e || !e->vfsent_name)
|
||||||
|
return "none";
|
||||||
|
else
|
||||||
|
return e->vfsent_name;
|
||||||
|
}
|
||||||
|
#endif /* MOUNTED_VMOUNT */
|
||||||
|
|
||||||
|
/* Return a list of the currently mounted filesystems, or NULL on error.
|
||||||
|
Add each entry to the tail of the list so that they stay in order.
|
||||||
|
If NEED_FS_TYPE is nonzero, ensure that the filesystem type fields in
|
||||||
|
the returned list are valid. Otherwise, they might not be.
|
||||||
|
If ALL_FS is zero, do not return entries for filesystems that
|
||||||
|
are automounter (dummy) entries. */
|
||||||
|
|
||||||
|
struct mount_entry *
|
||||||
|
read_filesystem_list (need_fs_type, all_fs)
|
||||||
|
int need_fs_type, all_fs;
|
||||||
|
{
|
||||||
|
struct mount_entry *mount_list;
|
||||||
|
struct mount_entry *me;
|
||||||
|
struct mount_entry *mtail;
|
||||||
|
|
||||||
|
/* Start the list off with a dummy entry. */
|
||||||
|
me = (struct mount_entry *) xmalloc (sizeof (struct mount_entry));
|
||||||
|
me->me_next = NULL;
|
||||||
|
mount_list = mtail = me;
|
||||||
|
|
||||||
|
#ifdef MOUNTED_LISTMNTENT
|
||||||
|
{
|
||||||
|
struct tabmntent *mntlist, *p;
|
||||||
|
struct mntent *mnt;
|
||||||
|
struct mount_entry *me;
|
||||||
|
|
||||||
|
/* the third and fourth arguments could be used to filter mounts,
|
||||||
|
but Crays doesn't seem to have any mounts that we want to
|
||||||
|
remove. Specifically, automount create normal NFS mounts.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if(listmntent(&mntlist, KMTAB, NULL, NULL) < 0)
|
||||||
|
return NULL;
|
||||||
|
p = mntlist;
|
||||||
|
while(p){
|
||||||
|
mnt = p->ment;
|
||||||
|
me = (struct mount_entry*) xmalloc(sizeof (struct mount_entry));
|
||||||
|
me->me_devname = xstrdup(mnt->mnt_fsname);
|
||||||
|
me->me_mountdir = xstrdup(mnt->mnt_dir);
|
||||||
|
me->me_type = xstrdup(mnt->mnt_type);
|
||||||
|
me->me_dev = -1;
|
||||||
|
me->me_next = NULL;
|
||||||
|
mtail->me_next = me;
|
||||||
|
mtail = me;
|
||||||
|
p = p->next;
|
||||||
|
}
|
||||||
|
freemntlist(mntlist);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef MOUNTED_GETMNTENT1 /* 4.3BSD, SunOS, HP-UX, Dynix, Irix. */
|
||||||
|
{
|
||||||
|
struct mntent *mnt;
|
||||||
|
char *table = MOUNTED;
|
||||||
|
FILE *fp;
|
||||||
|
char *devopt;
|
||||||
|
|
||||||
|
fp = setmntent (table, "r");
|
||||||
|
if (fp == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
while ((mnt = getmntent (fp)))
|
||||||
|
{
|
||||||
|
if (!all_fs && (!strcmp (mnt->mnt_type, "ignore")
|
||||||
|
|| !strcmp (mnt->mnt_type, "auto")))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
me = (struct mount_entry *) xmalloc (sizeof (struct mount_entry));
|
||||||
|
me->me_devname = xstrdup (mnt->mnt_fsname);
|
||||||
|
me->me_mountdir = xstrdup (mnt->mnt_dir);
|
||||||
|
me->me_type = xstrdup (mnt->mnt_type);
|
||||||
|
devopt = strstr (mnt->mnt_opts, "dev=");
|
||||||
|
if (devopt)
|
||||||
|
{
|
||||||
|
if (devopt[4] == '0' && (devopt[5] == 'x' || devopt[5] == 'X'))
|
||||||
|
me->me_dev = xatoi (devopt + 6);
|
||||||
|
else
|
||||||
|
me->me_dev = xatoi (devopt + 4);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
me->me_dev = (dev_t) -1; /* Magic; means not known yet. */
|
||||||
|
me->me_next = NULL;
|
||||||
|
|
||||||
|
/* Add to the linked list. */
|
||||||
|
mtail->me_next = me;
|
||||||
|
mtail = me;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (endmntent (fp) == 0)
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
#endif /* MOUNTED_GETMNTENT1. */
|
||||||
|
|
||||||
|
#ifdef MOUNTED_GETMNTINFO /* 4.4BSD. */
|
||||||
|
{
|
||||||
|
struct statfs *fsp;
|
||||||
|
int entries;
|
||||||
|
|
||||||
|
entries = getmntinfo (&fsp, MNT_NOWAIT);
|
||||||
|
if (entries < 0)
|
||||||
|
return NULL;
|
||||||
|
while (entries-- > 0)
|
||||||
|
{
|
||||||
|
me = (struct mount_entry *) xmalloc (sizeof (struct mount_entry));
|
||||||
|
me->me_devname = xstrdup (fsp->f_mntfromname);
|
||||||
|
me->me_mountdir = xstrdup (fsp->f_mntonname);
|
||||||
|
#ifdef __NetBSD__
|
||||||
|
me->me_type = xstrdup (fsp->f_fstypename);
|
||||||
|
#else
|
||||||
|
me->me_type = fstype_to_string (fsp->f_type);
|
||||||
|
#endif
|
||||||
|
me->me_dev = (dev_t) -1; /* Magic; means not known yet. */
|
||||||
|
me->me_next = NULL;
|
||||||
|
|
||||||
|
/* Add to the linked list. */
|
||||||
|
mtail->me_next = me;
|
||||||
|
mtail = me;
|
||||||
|
fsp++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif /* MOUNTED_GETMNTINFO */
|
||||||
|
|
||||||
|
#ifdef MOUNTED_GETMNT /* Ultrix. */
|
||||||
|
{
|
||||||
|
int offset = 0;
|
||||||
|
int val;
|
||||||
|
struct fs_data fsd;
|
||||||
|
|
||||||
|
while ((val = getmnt (&offset, &fsd, sizeof (fsd), NOSTAT_MANY,
|
||||||
|
(char *) 0)) > 0)
|
||||||
|
{
|
||||||
|
me = (struct mount_entry *) xmalloc (sizeof (struct mount_entry));
|
||||||
|
me->me_devname = xstrdup (fsd.fd_req.devname);
|
||||||
|
me->me_mountdir = xstrdup (fsd.fd_req.path);
|
||||||
|
me->me_type = gt_names[fsd.fd_req.fstype];
|
||||||
|
me->me_dev = fsd.fd_req.dev;
|
||||||
|
me->me_next = NULL;
|
||||||
|
|
||||||
|
/* Add to the linked list. */
|
||||||
|
mtail->me_next = me;
|
||||||
|
mtail = me;
|
||||||
|
}
|
||||||
|
if (val < 0)
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
#endif /* MOUNTED_GETMNT. */
|
||||||
|
|
||||||
|
#if defined (MOUNTED_GETFSSTAT) /* __alpha running OSF_1 */
|
||||||
|
{
|
||||||
|
int numsys, counter, bufsize;
|
||||||
|
struct statfs *stats;
|
||||||
|
|
||||||
|
numsys = getfsstat ((struct statfs *)0, 0L, MNT_WAIT);
|
||||||
|
if (numsys < 0)
|
||||||
|
return (NULL);
|
||||||
|
|
||||||
|
bufsize = (1 + numsys) * sizeof (struct statfs);
|
||||||
|
stats = (struct statfs *)xmalloc (bufsize);
|
||||||
|
numsys = getfsstat (stats, bufsize, MNT_WAIT);
|
||||||
|
|
||||||
|
if (numsys < 0)
|
||||||
|
{
|
||||||
|
free (stats);
|
||||||
|
return (NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (counter = 0; counter < numsys; counter++)
|
||||||
|
{
|
||||||
|
me = (struct mount_entry *) xmalloc (sizeof (struct mount_entry));
|
||||||
|
me->me_devname = xstrdup (stats[counter].f_mntfromname);
|
||||||
|
me->me_mountdir = xstrdup (stats[counter].f_mntonname);
|
||||||
|
me->me_type = mnt_names[stats[counter].f_type];
|
||||||
|
me->me_dev = (dev_t) -1; /* Magic; means not known yet. */
|
||||||
|
me->me_next = NULL;
|
||||||
|
|
||||||
|
/* Add to the linked list. */
|
||||||
|
mtail->me_next = me;
|
||||||
|
mtail = me;
|
||||||
|
}
|
||||||
|
|
||||||
|
free (stats);
|
||||||
|
}
|
||||||
|
#endif /* MOUNTED_GETFSSTAT */
|
||||||
|
|
||||||
|
#if defined (MOUNTED_FREAD) || defined (MOUNTED_FREAD_FSTYP) /* SVR[23]. */
|
||||||
|
{
|
||||||
|
struct mnttab mnt;
|
||||||
|
char *table = "/etc/mnttab";
|
||||||
|
FILE *fp;
|
||||||
|
|
||||||
|
fp = fopen (table, "r");
|
||||||
|
if (fp == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
while (fread (&mnt, sizeof mnt, 1, fp) > 0)
|
||||||
|
{
|
||||||
|
me = (struct mount_entry *) xmalloc (sizeof (struct mount_entry));
|
||||||
|
#ifdef GETFSTYP /* SVR3. */
|
||||||
|
me->me_devname = xstrdup (mnt.mt_dev);
|
||||||
|
#else
|
||||||
|
me->me_devname = xmalloc (strlen (mnt.mt_dev) + 6);
|
||||||
|
strcpy (me->me_devname, "/dev/");
|
||||||
|
strcpy (me->me_devname + 5, mnt.mt_dev);
|
||||||
|
#endif
|
||||||
|
me->me_mountdir = xstrdup (mnt.mt_filsys);
|
||||||
|
me->me_dev = (dev_t) -1; /* Magic; means not known yet. */
|
||||||
|
me->me_type = "";
|
||||||
|
#ifdef GETFSTYP /* SVR3. */
|
||||||
|
if (need_fs_type)
|
||||||
|
{
|
||||||
|
struct statfs fsd;
|
||||||
|
char typebuf[FSTYPSZ];
|
||||||
|
|
||||||
|
if (statfs (me->me_mountdir, &fsd, sizeof fsd, 0) != -1
|
||||||
|
&& sysfs (GETFSTYP, fsd.f_fstyp, typebuf) != -1)
|
||||||
|
me->me_type = xstrdup (typebuf);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
me->me_next = NULL;
|
||||||
|
|
||||||
|
/* Add to the linked list. */
|
||||||
|
mtail->me_next = me;
|
||||||
|
mtail = me;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (fclose (fp) == EOF)
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
#endif /* MOUNTED_FREAD || MOUNTED_FREAD_FSTYP. */
|
||||||
|
|
||||||
|
#ifdef MOUNTED_GETMNTTBL /* DolphinOS goes it's own way */
|
||||||
|
{
|
||||||
|
struct mntent **mnttbl=getmnttbl(),**ent;
|
||||||
|
for (ent=mnttbl;*ent;ent++)
|
||||||
|
{
|
||||||
|
me = (struct mount_entry *) xmalloc (sizeof (struct mount_entry));
|
||||||
|
me->me_devname = xstrdup ( (*ent)->mt_resource);
|
||||||
|
me->me_mountdir = xstrdup( (*ent)->mt_directory);
|
||||||
|
me->me_type = xstrdup ((*ent)->mt_fstype);
|
||||||
|
me->me_dev = (dev_t) -1; /* Magic; means not known yet. */
|
||||||
|
me->me_next = NULL;
|
||||||
|
|
||||||
|
/* Add to the linked list. */
|
||||||
|
mtail->me_next = me;
|
||||||
|
mtail = me;
|
||||||
|
}
|
||||||
|
endmnttbl();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef MOUNTED_GETMNTENT2 /* SVR4. */
|
||||||
|
{
|
||||||
|
struct mnttab mnt;
|
||||||
|
char *table = MNTTAB;
|
||||||
|
FILE *fp;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
fp = fopen (table, "r");
|
||||||
|
if (fp == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
while ((ret = getmntent (fp, &mnt)) == 0)
|
||||||
|
{
|
||||||
|
me = (struct mount_entry *) xmalloc (sizeof (struct mount_entry));
|
||||||
|
me->me_devname = xstrdup (mnt.mnt_special);
|
||||||
|
me->me_mountdir = xstrdup (mnt.mnt_mountp);
|
||||||
|
me->me_type = xstrdup (mnt.mnt_fstype);
|
||||||
|
me->me_dev = (dev_t) -1; /* Magic; means not known yet. */
|
||||||
|
me->me_next = NULL;
|
||||||
|
|
||||||
|
/* Add to the linked list. */
|
||||||
|
mtail->me_next = me;
|
||||||
|
mtail = me;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ret > 0)
|
||||||
|
return NULL;
|
||||||
|
if (fclose (fp) == EOF)
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
#endif /* MOUNTED_GETMNTENT2. */
|
||||||
|
|
||||||
|
#ifdef MOUNTED_VMOUNT /* AIX. */
|
||||||
|
{
|
||||||
|
int bufsize;
|
||||||
|
char *entries, *thisent;
|
||||||
|
struct vmount *vmp;
|
||||||
|
|
||||||
|
/* Ask how many bytes to allocate for the mounted filesystem info. */
|
||||||
|
mntctl (MCTL_QUERY, sizeof bufsize, (struct vmount *) &bufsize);
|
||||||
|
entries = xmalloc (bufsize);
|
||||||
|
|
||||||
|
/* Get the list of mounted filesystems. */
|
||||||
|
mntctl (MCTL_QUERY, bufsize, (struct vmount *) entries);
|
||||||
|
|
||||||
|
for (thisent = entries; thisent < entries + bufsize;
|
||||||
|
thisent += vmp->vmt_length)
|
||||||
|
{
|
||||||
|
vmp = (struct vmount *) thisent;
|
||||||
|
me = (struct mount_entry *) xmalloc (sizeof (struct mount_entry));
|
||||||
|
if (vmp->vmt_flags & MNT_REMOTE)
|
||||||
|
{
|
||||||
|
char *host, *path;
|
||||||
|
|
||||||
|
/* Prepend the remote pathname. */
|
||||||
|
host = thisent + vmp->vmt_data[VMT_HOSTNAME].vmt_off;
|
||||||
|
path = thisent + vmp->vmt_data[VMT_OBJECT].vmt_off;
|
||||||
|
me->me_devname = xmalloc (strlen (host) + strlen (path) + 2);
|
||||||
|
strcpy (me->me_devname, host);
|
||||||
|
strcat (me->me_devname, ":");
|
||||||
|
strcat (me->me_devname, path);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
me->me_devname = xstrdup (thisent +
|
||||||
|
vmp->vmt_data[VMT_OBJECT].vmt_off);
|
||||||
|
}
|
||||||
|
me->me_mountdir = xstrdup (thisent + vmp->vmt_data[VMT_STUB].vmt_off);
|
||||||
|
me->me_type = xstrdup (fstype_to_string (vmp->vmt_gfstype));
|
||||||
|
me->me_dev = (dev_t) -1; /* vmt_fsid might be the info we want. */
|
||||||
|
me->me_next = NULL;
|
||||||
|
|
||||||
|
/* Add to the linked list. */
|
||||||
|
mtail->me_next = me;
|
||||||
|
mtail = me;
|
||||||
|
}
|
||||||
|
free (entries);
|
||||||
|
}
|
||||||
|
#endif /* MOUNTED_VMOUNT. */
|
||||||
|
|
||||||
|
/* Free the dummy head. */
|
||||||
|
me = mount_list;
|
||||||
|
mount_list = mount_list->me_next;
|
||||||
|
free (me);
|
||||||
|
return mount_list;
|
||||||
|
}
|
32
sysdeps/common/mountlist.h
Normal file
32
sysdeps/common/mountlist.h
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
/* mountlist.h -- declarations for list of mounted filesystems
|
||||||
|
Copyright (C) 1991, 1992 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2, or (at your option)
|
||||||
|
any later version.
|
||||||
|
|
||||||
|
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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
|
||||||
|
|
||||||
|
/* A mount table entry. */
|
||||||
|
struct mount_entry
|
||||||
|
{
|
||||||
|
char *me_devname; /* Device node pathname, including "/dev/". */
|
||||||
|
char *me_mountdir; /* Mount point directory pathname. */
|
||||||
|
char *me_type; /* "nfs", "4.2", etc. */
|
||||||
|
dev_t me_dev; /* Device number of me_mountdir. */
|
||||||
|
struct mount_entry *me_next;
|
||||||
|
};
|
||||||
|
|
||||||
|
#if __STDC__
|
||||||
|
struct mount_entry *read_filesystem_list (int need_fs_type, int all_fs);
|
||||||
|
#else
|
||||||
|
struct mount_entry *read_filesystem_list ();
|
||||||
|
#endif
|
@@ -59,6 +59,12 @@ glibtop_realloc_r (glibtop *server, void *ptr, size_t size)
|
|||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *
|
||||||
|
glibtop_strdup_r (glibtop *server, const char *string)
|
||||||
|
{
|
||||||
|
return strcpy (glibtop_malloc_r (server, strlen (string) + 1), string);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
glibtop_free_r (glibtop *server, void *ptr)
|
glibtop_free_r (glibtop *server, void *ptr)
|
||||||
{
|
{
|
||||||
|
@@ -23,3 +23,4 @@ so_locations
|
|||||||
swap.lo
|
swap.lo
|
||||||
sysdeps.lo
|
sysdeps.lo
|
||||||
uptime.lo
|
uptime.lo
|
||||||
|
guile.c
|
||||||
|
@@ -14,8 +14,14 @@ CFLAGS = -Wall -W @CFLAGS@
|
|||||||
|
|
||||||
lib_LTLIBRARIES = libgtop_guile.la
|
lib_LTLIBRARIES = libgtop_guile.la
|
||||||
|
|
||||||
libgtop_guile_la_SOURCES = boot.c sysdeps.c cpu.c mem.c swap.c uptime.c \
|
libgtop_guile_la_SOURCES = guile.c
|
||||||
loadavg.c shm_limits.c msg_limits.c \
|
|
||||||
sem_limits.c proclist.c procstate.c procuid.c \
|
BUILT_SOURCES = guile.c
|
||||||
proctime.c procmem.c procsignal.c prockernel.c \
|
|
||||||
procsegment.c
|
guile.c: guile.awk $(top_builddir)/config.h $(top_builddir)/features.def
|
||||||
|
$(AWK) -f $(srcdir)/guile.awk < $(top_builddir)/features.def > gnc-t
|
||||||
|
mv gnc-t guile.c
|
||||||
|
|
||||||
|
EXTRA_DIST = guile.awk
|
||||||
|
|
||||||
|
CLEANFILES = guile.c
|
||||||
|
@@ -1,66 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/sysdeps.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
void
|
|
||||||
glibtop_boot_guile (void)
|
|
||||||
{
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-get-cpu", glibtop_guile_get_cpu);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-get-mem", glibtop_guile_get_mem);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-get-swap", glibtop_guile_get_swap);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-get-uptime", glibtop_guile_get_uptime);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-get-loadavg", glibtop_guile_get_loadavg);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-get-shm_limits",glibtop_guile_get_shm_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-get-msg_limits", glibtop_guile_get_msg_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-get-sem_limits", glibtop_guile_get_sem_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-get-sysdeps", glibtop_guile_get_sysdeps);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-get-proclist", glibtop_guile_get_proclist);
|
|
||||||
|
|
||||||
gh_new_procedure1_0
|
|
||||||
("glibtop-get-proc_state", glibtop_guile_get_proc_state);
|
|
||||||
gh_new_procedure1_0
|
|
||||||
("glibtop-get-proc_uid", glibtop_guile_get_proc_uid);
|
|
||||||
gh_new_procedure1_0
|
|
||||||
("glibtop-get-proc_mem", glibtop_guile_get_proc_mem);
|
|
||||||
gh_new_procedure1_0
|
|
||||||
("glibtop-get-proc_time", glibtop_guile_get_proc_time);
|
|
||||||
gh_new_procedure1_0
|
|
||||||
("glibtop-get-proc_signal", glibtop_guile_get_proc_signal);
|
|
||||||
gh_new_procedure1_0
|
|
||||||
("glibtop-get-proc_kernel", glibtop_guile_get_proc_kernel);
|
|
||||||
gh_new_procedure1_0
|
|
||||||
("glibtop-get-proc_segment", glibtop_guile_get_proc_segment);
|
|
||||||
|
|
||||||
}
|
|
@@ -1,41 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/cpu.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM glibtop_guile_get_cpu (void)
|
|
||||||
{
|
|
||||||
glibtop_cpu cpu;
|
|
||||||
|
|
||||||
glibtop_get_cpu (&cpu);
|
|
||||||
|
|
||||||
return gh_list (gh_ulong2scm (cpu.flags),
|
|
||||||
gh_ulong2scm (cpu.total),
|
|
||||||
gh_ulong2scm (cpu.user),
|
|
||||||
gh_ulong2scm (cpu.nice),
|
|
||||||
gh_ulong2scm (cpu.sys),
|
|
||||||
gh_ulong2scm (cpu.idle),
|
|
||||||
gh_ulong2scm (cpu.frequency),
|
|
||||||
SCM_UNDEFINED);
|
|
||||||
}
|
|
87
sysdeps/guile/guile.awk
Normal file
87
sysdeps/guile/guile.awk
Normal file
@@ -0,0 +1,87 @@
|
|||||||
|
BEGIN {
|
||||||
|
print "/* guile.c */";
|
||||||
|
print "/* This is a generated file. Please modify `guile.awk' */";
|
||||||
|
print "";
|
||||||
|
|
||||||
|
print "#include <glibtop.h>";
|
||||||
|
print "#include <glibtop/xmalloc.h>";
|
||||||
|
print "#include <glibtop/sysdeps.h>";
|
||||||
|
print "";
|
||||||
|
print "#include <guile/gh.h>";
|
||||||
|
|
||||||
|
print "";
|
||||||
|
|
||||||
|
convert["long"] = "gh_long2scm ";
|
||||||
|
convert["ulong"] = "gh_ulong2scm ";
|
||||||
|
convert["double"] = "gh_double2scm";
|
||||||
|
convert["str"] = "gh_str02scm ";
|
||||||
|
convert["char"] = "gh_char2scm ";
|
||||||
|
}
|
||||||
|
|
||||||
|
/^(\w+)/ {
|
||||||
|
features[$1] = $1;
|
||||||
|
if ($1 ~ /^proclist$/) {
|
||||||
|
output = "SCM\nglibtop_guile_get_proclist (void)\n{\n";
|
||||||
|
output = output"\tglibtop_proclist proclist;\n\tunsigned i, *ptr;\n";
|
||||||
|
output = output"\tSCM list;\n\n\tptr = glibtop_get_proclist (&proclist);\n\n";
|
||||||
|
output = output"\tlist = gh_list (gh_ulong2scm ("$1".flags),\n\t\t\t";
|
||||||
|
} else {
|
||||||
|
if ($1 ~ /^proc_/) {
|
||||||
|
output = "SCM\nglibtop_guile_get_"$1" (SCM pid)\n{\n";
|
||||||
|
output = output"\tglibtop_"$1" "$1";\n\n";
|
||||||
|
output = output"\tglibtop_get_"$1" (&"$1", (pid_t) gh_scm2long (pid));\n\n";
|
||||||
|
} else {
|
||||||
|
output = "SCM\nglibtop_guile_get_"$1" (void)\n{\n";
|
||||||
|
output = output"\tglibtop_"$1" "$1";\n\n";
|
||||||
|
output = output"\tglibtop_get_"$1" (&"$1");\n\n";
|
||||||
|
}
|
||||||
|
output = output"\treturn gh_list (gh_ulong2scm ("$1".flags),\n\t\t\t";
|
||||||
|
}
|
||||||
|
nr_elements = split ($2, elements, /:/);
|
||||||
|
for (element = 1; element <= nr_elements; element++) {
|
||||||
|
list = elements[element];
|
||||||
|
type = elements[element];
|
||||||
|
sub(/\(.*/, "", type);
|
||||||
|
sub(/^\w+\(/, "", list); sub(/\)$/, "", list);
|
||||||
|
count = split (list, fields, /,/);
|
||||||
|
for (field = 1; field <= count; field++) {
|
||||||
|
output = output""convert[type]" ("$1"."fields[field]"),\n\t\t\t";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
output = output"SCM_UNDEFINED);";
|
||||||
|
print output;
|
||||||
|
|
||||||
|
if ($1 ~ /^proclist$/) {
|
||||||
|
print "";
|
||||||
|
print "\tif (ptr) {";
|
||||||
|
print "\t\tfor (i = 0; i < proclist.number; i++)";
|
||||||
|
print "\t\t\tlist = scm_append";
|
||||||
|
print "\t\t\t\t(gh_list (list,";
|
||||||
|
print "\t\t\t\t\t gh_list (gh_ulong2scm ((unsigned long) ptr [i])),";
|
||||||
|
print "\t\t\t\t\t SCM_UNDEFINED));";
|
||||||
|
print "\t}";
|
||||||
|
print "";
|
||||||
|
print "\tglibtop_free (ptr);";
|
||||||
|
print "";
|
||||||
|
print "\treturn list;";
|
||||||
|
}
|
||||||
|
print "}";
|
||||||
|
print "";
|
||||||
|
}
|
||||||
|
|
||||||
|
END {
|
||||||
|
print "void";
|
||||||
|
print "glibtop_boot_guile (void)";
|
||||||
|
print "{";
|
||||||
|
|
||||||
|
for (feature in features) {
|
||||||
|
if (feature ~ /^proc_/) {
|
||||||
|
print "\tgh_new_procedure1_0";
|
||||||
|
} else {
|
||||||
|
print "\tgh_new_procedure0_0";
|
||||||
|
}
|
||||||
|
print "\t\t(\"glibtop-get-"feature"\", glibtop_guile_get_"feature");";
|
||||||
|
}
|
||||||
|
print "}";
|
||||||
|
}
|
||||||
|
|
@@ -1,38 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/loadavg.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM glibtop_guile_get_loadavg (void)
|
|
||||||
{
|
|
||||||
glibtop_loadavg loadavg;
|
|
||||||
|
|
||||||
glibtop_get_loadavg (&loadavg);
|
|
||||||
|
|
||||||
return gh_list (gh_ulong2scm (loadavg.flags),
|
|
||||||
gh_double2scm (loadavg.loadavg [0]),
|
|
||||||
gh_double2scm (loadavg.loadavg [1]),
|
|
||||||
gh_double2scm (loadavg.loadavg [2]),
|
|
||||||
SCM_UNDEFINED);
|
|
||||||
}
|
|
@@ -1,43 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/mem.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM glibtop_guile_get_mem (void)
|
|
||||||
{
|
|
||||||
glibtop_mem mem;
|
|
||||||
|
|
||||||
glibtop_get_mem (&mem);
|
|
||||||
|
|
||||||
return gh_list (gh_ulong2scm (mem.flags),
|
|
||||||
gh_ulong2scm (mem.total),
|
|
||||||
gh_ulong2scm (mem.used),
|
|
||||||
gh_ulong2scm (mem.free),
|
|
||||||
gh_ulong2scm (mem.shared),
|
|
||||||
gh_ulong2scm (mem.buffer),
|
|
||||||
gh_ulong2scm (mem.cached),
|
|
||||||
gh_ulong2scm (mem.user),
|
|
||||||
gh_ulong2scm (mem.locked),
|
|
||||||
SCM_UNDEFINED);
|
|
||||||
}
|
|
@@ -1,42 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/msg_limits.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM glibtop_guile_get_msg_limits (void)
|
|
||||||
{
|
|
||||||
glibtop_msg_limits msg_limits;
|
|
||||||
|
|
||||||
glibtop_get_msg_limits (&msg_limits);
|
|
||||||
|
|
||||||
return gh_list (gh_ulong2scm (msg_limits.flags),
|
|
||||||
gh_ulong2scm (msg_limits.msgpool),
|
|
||||||
gh_ulong2scm (msg_limits.msgmap),
|
|
||||||
gh_ulong2scm (msg_limits.msgmax),
|
|
||||||
gh_ulong2scm (msg_limits.msgmnb),
|
|
||||||
gh_ulong2scm (msg_limits.msgmni),
|
|
||||||
gh_ulong2scm (msg_limits.msgssz),
|
|
||||||
gh_ulong2scm (msg_limits.msgtql),
|
|
||||||
SCM_UNDEFINED);
|
|
||||||
}
|
|
@@ -24,3 +24,4 @@ so_locations
|
|||||||
swap.lo
|
swap.lo
|
||||||
sysdeps.lo
|
sysdeps.lo
|
||||||
uptime.lo
|
uptime.lo
|
||||||
|
guile-names.c
|
||||||
|
@@ -8,9 +8,15 @@ CFLAGS = -Wall -W @CFLAGS@
|
|||||||
|
|
||||||
lib_LTLIBRARIES = libgtop_guile_names.la
|
lib_LTLIBRARIES = libgtop_guile_names.la
|
||||||
|
|
||||||
libgtop_guile_names_la_SOURCES = boot.c sysdeps.c cpu.c mem.c swap.c uptime.c \
|
libgtop_guile_names_la_SOURCES = guile-names.c
|
||||||
loadavg.c shm_limits.c msg_limits.c \
|
|
||||||
sem_limits.c proclist.c procstate.c procuid.c \
|
BUILT_SOURCES = guile-names.c
|
||||||
proctime.c procmem.c procsignal.c prockernel.c \
|
|
||||||
procsegment.c
|
guile-names.c: guile-names.awk $(top_builddir)/config.h $(top_builddir)/features.def
|
||||||
|
$(AWK) -f $(srcdir)/guile-names.awk < $(top_builddir)/features.def > gnc-t
|
||||||
|
mv gnc-t guile-names.c
|
||||||
|
|
||||||
|
EXTRA_DIST = guile-names.awk
|
||||||
|
|
||||||
|
CLEANFILES = guile-names.c
|
||||||
|
|
||||||
|
@@ -1,174 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/sysdeps.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
void
|
|
||||||
glibtop_boot_guile_names (void)
|
|
||||||
{
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-cpu", glibtop_guile_names_cpu);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-mem", glibtop_guile_names_mem);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-swap", glibtop_guile_names_swap);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-uptime", glibtop_guile_names_uptime);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-loadavg", glibtop_guile_names_loadavg);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-shm_limits", glibtop_guile_names_shm_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-msg_limits", glibtop_guile_names_msg_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-sem_limits", glibtop_guile_names_sem_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-sysdeps", glibtop_guile_names_sysdeps);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-proclist", glibtop_guile_names_proclist);
|
|
||||||
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-proc_state", glibtop_guile_names_proc_state);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-proc_uid", glibtop_guile_names_proc_uid);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-proc_mem", glibtop_guile_names_proc_mem);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-proc_time", glibtop_guile_names_proc_time);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-proc_signal", glibtop_guile_names_proc_signal);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-proc_kernel", glibtop_guile_names_proc_kernel);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-names-proc_segment", glibtop_guile_names_proc_segment);
|
|
||||||
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-cpu", glibtop_guile_types_cpu);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-mem", glibtop_guile_types_mem);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-swap", glibtop_guile_types_swap);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-uptime", glibtop_guile_types_uptime);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-loadavg", glibtop_guile_types_loadavg);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-shm_limits", glibtop_guile_types_shm_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-msg_limits", glibtop_guile_types_msg_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-sem_limits", glibtop_guile_types_sem_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-sysdeps", glibtop_guile_types_sysdeps);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-proclist", glibtop_guile_types_proclist);
|
|
||||||
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-proc_state", glibtop_guile_types_proc_state);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-proc_uid", glibtop_guile_types_proc_uid);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-proc_mem", glibtop_guile_types_proc_mem);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-proc_time", glibtop_guile_types_proc_time);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-proc_signal", glibtop_guile_types_proc_signal);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-proc_kernel", glibtop_guile_types_proc_kernel);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-types-proc_segment", glibtop_guile_types_proc_segment);
|
|
||||||
|
|
||||||
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-cpu", glibtop_guile_labels_cpu);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-mem", glibtop_guile_labels_mem);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-swap", glibtop_guile_labels_swap);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-uptime", glibtop_guile_labels_uptime);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-loadavg", glibtop_guile_labels_loadavg);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-shm_limits", glibtop_guile_labels_shm_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-msg_limits", glibtop_guile_labels_msg_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-sem_limits", glibtop_guile_labels_sem_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-sysdeps", glibtop_guile_labels_sysdeps);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-proclist", glibtop_guile_labels_proclist);
|
|
||||||
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-proc_state", glibtop_guile_labels_proc_state);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-proc_uid", glibtop_guile_labels_proc_uid);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-proc_mem", glibtop_guile_labels_proc_mem);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-proc_time", glibtop_guile_labels_proc_time);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-proc_signal", glibtop_guile_labels_proc_signal);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-proc_kernel", glibtop_guile_labels_proc_kernel);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-labels-proc_segment", glibtop_guile_labels_proc_segment);
|
|
||||||
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-cpu", glibtop_guile_descriptions_cpu);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-mem", glibtop_guile_descriptions_mem);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-swap", glibtop_guile_descriptions_swap);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-uptime", glibtop_guile_descriptions_uptime);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-loadavg", glibtop_guile_descriptions_loadavg);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-shm_limits", glibtop_guile_descriptions_shm_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-msg_limits", glibtop_guile_descriptions_msg_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-sem_limits", glibtop_guile_descriptions_sem_limits);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-sysdeps", glibtop_guile_descriptions_sysdeps);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-proclist", glibtop_guile_descriptions_proclist);
|
|
||||||
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-proc_state", glibtop_guile_descriptions_proc_state);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-proc_uid", glibtop_guile_descriptions_proc_uid);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-proc_mem", glibtop_guile_descriptions_proc_mem);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-proc_time", glibtop_guile_descriptions_proc_time);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-proc_signal", glibtop_guile_descriptions_proc_signal);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-proc_kernel", glibtop_guile_descriptions_proc_kernel);
|
|
||||||
gh_new_procedure0_0
|
|
||||||
("glibtop-descriptions-proc_segment", glibtop_guile_descriptions_proc_segment);
|
|
||||||
}
|
|
@@ -1,95 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/cpu.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_cpu (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_CPU; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_names_cpu [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_cpu (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_CPU; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_types_cpu [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_cpu (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_CPU; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_labels_cpu [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_cpu (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_CPU; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_descriptions_cpu [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
121
sysdeps/guile/names/guile-names.awk
Normal file
121
sysdeps/guile/names/guile-names.awk
Normal file
@@ -0,0 +1,121 @@
|
|||||||
|
BEGIN {
|
||||||
|
print "/* guile_names.c */";
|
||||||
|
print "/* This is a generated file. Please modify `guile-names.awk' */";
|
||||||
|
print "";
|
||||||
|
|
||||||
|
print "#include <glibtop.h>";
|
||||||
|
print "#include <glibtop/sysdeps.h>";
|
||||||
|
print "";
|
||||||
|
print "#include <guile/gh.h>";
|
||||||
|
|
||||||
|
print "";
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function output(feature) {
|
||||||
|
print "SCM";
|
||||||
|
print "glibtop_guile_names_"feature" (void)";
|
||||||
|
print "{";
|
||||||
|
print "\tint i;";
|
||||||
|
print "\tSCM list;";
|
||||||
|
print "";
|
||||||
|
print "\tlist = gh_list (SCM_UNDEFINED);";
|
||||||
|
print "";
|
||||||
|
print "\tfor (i = 0; i < GLIBTOP_MAX_"toupper(feature)"; i++)";
|
||||||
|
print "\t\tlist = scm_append";
|
||||||
|
print "\t\t\t(gh_list (list,";
|
||||||
|
print "\t\t\t\t gh_list (gh_str02scm ((char *) glibtop_names_"feature" [i])),";
|
||||||
|
print "\t\t\t\t SCM_UNDEFINED));";
|
||||||
|
print "";
|
||||||
|
print "\treturn list;";
|
||||||
|
print "}";
|
||||||
|
|
||||||
|
print "";
|
||||||
|
|
||||||
|
print "SCM";
|
||||||
|
print "glibtop_guile_types_"feature" (void)";
|
||||||
|
print "{";
|
||||||
|
print "\tint i;";
|
||||||
|
print "\tSCM list;";
|
||||||
|
print "";
|
||||||
|
print "\tlist = gh_list (SCM_UNDEFINED);";
|
||||||
|
print "";
|
||||||
|
print "\tfor (i = 0; i < GLIBTOP_MAX_"toupper(feature)"; i++)";
|
||||||
|
print "\t\tlist = scm_append";
|
||||||
|
print "\t\t\t(gh_list (list,";
|
||||||
|
print "\t\t\t\t gh_list (gh_ulong2scm (glibtop_types_"feature" [i])),";
|
||||||
|
print "\t\t\t\t SCM_UNDEFINED));";
|
||||||
|
print "";
|
||||||
|
print "\treturn list;";
|
||||||
|
print "}";
|
||||||
|
|
||||||
|
print "";
|
||||||
|
|
||||||
|
print "SCM";
|
||||||
|
print "glibtop_guile_labels_"feature" (void)";
|
||||||
|
print "{";
|
||||||
|
print "\tint i;";
|
||||||
|
print "\tSCM list;";
|
||||||
|
print "";
|
||||||
|
print "\tlist = gh_list (SCM_UNDEFINED);";
|
||||||
|
print "";
|
||||||
|
print "\tfor (i = 0; i < GLIBTOP_MAX_"toupper(feature)"; i++)";
|
||||||
|
print "\t\tlist = scm_append";
|
||||||
|
print "\t\t\t(gh_list (list,";
|
||||||
|
print "\t\t\t\t gh_list (gh_str02scm (gettext";
|
||||||
|
print "\t\t\t\t\t\t\t(glibtop_labels_"feature" [i]))),";
|
||||||
|
print "\t\t\t\t SCM_UNDEFINED));";
|
||||||
|
print "";
|
||||||
|
print "\treturn list;";
|
||||||
|
print "}";
|
||||||
|
|
||||||
|
print "";
|
||||||
|
|
||||||
|
print "SCM";
|
||||||
|
print "glibtop_guile_descriptions_"feature" (void)";
|
||||||
|
print "{";
|
||||||
|
print "\tint i;";
|
||||||
|
print "\tSCM list;";
|
||||||
|
print "";
|
||||||
|
print "\tlist = gh_list (SCM_UNDEFINED);";
|
||||||
|
print "";
|
||||||
|
print "\tfor (i = 0; i < GLIBTOP_MAX_"toupper(feature)"; i++)";
|
||||||
|
print "\t\tlist = scm_append";
|
||||||
|
print "\t\t\t(gh_list (list,";
|
||||||
|
print "\t\t\t\t gh_list (gh_str02scm (gettext";
|
||||||
|
print "\t\t\t\t\t\t\t(glibtop_descriptions_"feature" [i]))),";
|
||||||
|
print "\t\t\t\t SCM_UNDEFINED));";
|
||||||
|
print "";
|
||||||
|
print "\treturn list;";
|
||||||
|
print "}";
|
||||||
|
|
||||||
|
print "";
|
||||||
|
}
|
||||||
|
|
||||||
|
/^(\w+)/ { features[$1] = $1 }
|
||||||
|
|
||||||
|
END {
|
||||||
|
for (feature in features) {
|
||||||
|
output(feature);
|
||||||
|
}
|
||||||
|
|
||||||
|
print "void";
|
||||||
|
print "glibtop_boot_guile_names (void)";
|
||||||
|
print "{";
|
||||||
|
|
||||||
|
for (feature in features) {
|
||||||
|
print "\tgh_new_procedure0_0";
|
||||||
|
print "\t\t(\"glibtop-names-"feature"\", glibtop_guile_names_"feature");";
|
||||||
|
print "";
|
||||||
|
print "\tgh_new_procedure0_0";
|
||||||
|
print "\t\t(\"glibtop-types-"feature"\", glibtop_guile_types_"feature");";
|
||||||
|
print "";
|
||||||
|
print "\tgh_new_procedure0_0";
|
||||||
|
print "\t\t(\"glibtop-labels-"feature"\", glibtop_guile_labels_"feature");";
|
||||||
|
print "";
|
||||||
|
print "\tgh_new_procedure0_0";
|
||||||
|
print "\t\t(\"glibtop-descriptions-"feature"\", glibtop_guile_descriptions_"feature");";
|
||||||
|
}
|
||||||
|
print "}";
|
||||||
|
}
|
||||||
|
|
@@ -1,95 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/loadavg.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_loadavg (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_LOADAVG; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_names_loadavg [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_loadavg (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_LOADAVG; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_types_loadavg [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_loadavg (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_LOADAVG; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_labels_loadavg [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_loadavg (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_LOADAVG; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_descriptions_loadavg [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,95 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/mem.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_mem (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_MEM; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_names_mem [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_mem (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_MEM; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_types_mem [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_mem (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_MEM; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_labels_mem [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_mem (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_MEM; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_descriptions_mem [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,95 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/msg_limits.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_msg_limits (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_MSG_LIMITS; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_names_msg_limits [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_msg_limits (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_MSG_LIMITS; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_types_msg_limits [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_msg_limits (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_MSG_LIMITS; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_labels_msg_limits [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_msg_limits (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_MSG_LIMITS; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_descriptions_msg_limits [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,95 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/prockernel.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_proc_kernel (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_KERNEL; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_names_proc_kernel [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_proc_kernel (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_KERNEL; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_types_proc_kernel [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_proc_kernel (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_KERNEL; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_labels_proc_kernel [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_proc_kernel (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_KERNEL; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_descriptions_proc_kernel [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,96 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/xmalloc.h>
|
|
||||||
#include <glibtop/proclist.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_proclist (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROCLIST; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_names_proclist [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_proclist (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROCLIST; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_types_proclist [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_proclist (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROCLIST; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_labels_proclist [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_proclist (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROCLIST; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_descriptions_proclist [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,95 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/procmem.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_proc_mem (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_MEM; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_names_proc_mem [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_proc_mem (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_MEM; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_types_proc_mem [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_proc_mem (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_MEM; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_labels_proc_mem [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_proc_mem (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_MEM; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_descriptions_proc_mem [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,95 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/procsegment.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_proc_segment (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_SEGMENT; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_names_proc_segment [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_proc_segment (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_SEGMENT; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_types_proc_segment [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_proc_segment (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_SEGMENT; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_labels_proc_segment [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_proc_segment (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_SEGMENT; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_descriptions_proc_segment [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,95 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/procsignal.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_proc_signal (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_SIGNAL; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_names_proc_signal [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_proc_signal (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_SIGNAL; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_types_proc_signal [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_proc_signal (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_SIGNAL; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_labels_proc_signal [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_proc_signal (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_SIGNAL; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_descriptions_proc_signal [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,95 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/procstate.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_proc_state (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_STATE; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_names_proc_state [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_proc_state (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_STATE; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_types_proc_state [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_proc_state (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_STATE; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_labels_proc_state [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_proc_state (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_STATE; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_descriptions_proc_state [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,95 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/proctime.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_proc_time (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_TIME; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_names_proc_time [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_proc_time (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_TIME; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_types_proc_time [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_proc_time (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_TIME; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_labels_proc_time [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_proc_time (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_TIME; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_descriptions_proc_time [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,95 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/procuid.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_proc_uid (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_UID; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_names_proc_uid [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_proc_uid (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_UID; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (glibtop_types_proc_uid [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_proc_uid (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_UID; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_labels_proc_uid [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_proc_uid (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_PROC_UID; i++)
|
|
||||||
list = gh_append2
|
|
||||||
(list, gh_list
|
|
||||||
(gh_str02scm (gettext
|
|
||||||
(glibtop_descriptions_proc_uid [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,85 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/sem_limits.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_sem_limits (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SEM_LIMITS; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (glibtop_names_sem_limits [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_sem_limits (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SEM_LIMITS; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_types_sem_limits [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_sem_limits (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SEM_LIMITS; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_labels_sem_limits [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_sem_limits (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SEM_LIMITS; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_descriptions_sem_limits [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,85 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/shm_limits.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_shm_limits (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SHM_LIMITS; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (glibtop_names_shm_limits [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_shm_limits (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SHM_LIMITS; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_types_shm_limits [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_shm_limits (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SHM_LIMITS; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_labels_shm_limits [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_shm_limits (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SHM_LIMITS; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_descriptions_shm_limits [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,84 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/swap.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_swap (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SWAP; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (glibtop_names_swap [i]), SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_swap (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SWAP; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_types_swap [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_swap (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SWAP; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_labels_swap [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_swap (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SWAP; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_descriptions_swap [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,85 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/sysdeps.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_sysdeps (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SYSDEPS; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (glibtop_names_sysdeps [i]),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_sysdeps (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SYSDEPS; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_types_sysdeps [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_sysdeps (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SYSDEPS; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_labels_sysdeps [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_sysdeps (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_SYSDEPS; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_descriptions_sysdeps [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,84 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/uptime.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_names_uptime (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_UPTIME; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (glibtop_names_uptime [i]), SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_types_uptime (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_UPTIME; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_types_uptime [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_labels_uptime (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_UPTIME; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_labels_uptime [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_descriptions_uptime (void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
SCM list;
|
|
||||||
|
|
||||||
list = gh_list (SCM_UNDEFINED);
|
|
||||||
|
|
||||||
for (i = 0; i < GLIBTOP_MAX_UPTIME; i++)
|
|
||||||
list = gh_append2 (list, gh_list (gh_str02scm (gettext (glibtop_descriptions_uptime [i])),
|
|
||||||
SCM_UNDEFINED));
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
@@ -1,44 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/prockernel.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_get_proc_kernel (SCM pid)
|
|
||||||
{
|
|
||||||
glibtop_proc_kernel p;
|
|
||||||
|
|
||||||
glibtop_get_proc_kernel (&p, (pid_t) gh_scm2long (pid));
|
|
||||||
|
|
||||||
return gh_list (gh_ulong2scm (p.flags),
|
|
||||||
gh_ulong2scm (p.k_flags),
|
|
||||||
gh_ulong2scm (p.min_flt),
|
|
||||||
gh_ulong2scm (p.maj_flt),
|
|
||||||
gh_ulong2scm (p.cmin_flt),
|
|
||||||
gh_ulong2scm (p.cmaj_flt),
|
|
||||||
gh_ulong2scm (p.kstk_esp),
|
|
||||||
gh_ulong2scm (p.kstk_eip),
|
|
||||||
gh_ulong2scm (p.wchan),
|
|
||||||
SCM_UNDEFINED);
|
|
||||||
}
|
|
@@ -1,42 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/procmem.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_get_proc_mem (SCM pid)
|
|
||||||
{
|
|
||||||
glibtop_proc_mem p;
|
|
||||||
|
|
||||||
glibtop_get_proc_mem (&p, (pid_t) gh_scm2long (pid));
|
|
||||||
|
|
||||||
return gh_list (gh_ulong2scm (p.flags),
|
|
||||||
gh_long2scm (p.size),
|
|
||||||
gh_long2scm (p.vsize),
|
|
||||||
gh_long2scm (p.resident),
|
|
||||||
gh_long2scm (p.share),
|
|
||||||
gh_long2scm (p.rss),
|
|
||||||
gh_long2scm (p.rss_rlim),
|
|
||||||
SCM_UNDEFINED);
|
|
||||||
}
|
|
@@ -1,43 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/procsegment.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_get_proc_segment (SCM pid)
|
|
||||||
{
|
|
||||||
glibtop_proc_segment p;
|
|
||||||
|
|
||||||
glibtop_get_proc_segment (&p, (pid_t) gh_scm2long (pid));
|
|
||||||
|
|
||||||
return gh_list (gh_ulong2scm (p.flags),
|
|
||||||
gh_long2scm (p.trs),
|
|
||||||
gh_long2scm (p.lrs),
|
|
||||||
gh_long2scm (p.drs),
|
|
||||||
gh_long2scm (p.dt),
|
|
||||||
gh_ulong2scm (p.start_code),
|
|
||||||
gh_ulong2scm (p.end_code),
|
|
||||||
gh_ulong2scm (p.start_stack),
|
|
||||||
SCM_UNDEFINED);
|
|
||||||
}
|
|
@@ -1,40 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/procsignal.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_get_proc_signal (SCM pid)
|
|
||||||
{
|
|
||||||
glibtop_proc_signal p;
|
|
||||||
|
|
||||||
glibtop_get_proc_signal (&p, (pid_t) gh_scm2long (pid));
|
|
||||||
|
|
||||||
return gh_list (gh_ulong2scm (p.flags),
|
|
||||||
gh_long2scm (p.signal),
|
|
||||||
gh_long2scm (p.blocked),
|
|
||||||
gh_long2scm (p.sigignore),
|
|
||||||
gh_long2scm (p.sigcatch),
|
|
||||||
SCM_UNDEFINED);
|
|
||||||
}
|
|
@@ -1,40 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/procstate.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_get_proc_state (SCM pid)
|
|
||||||
{
|
|
||||||
glibtop_proc_state p;
|
|
||||||
|
|
||||||
glibtop_get_proc_state (&p, (pid_t) gh_scm2long (pid));
|
|
||||||
|
|
||||||
return gh_list (gh_ulong2scm (p.flags),
|
|
||||||
gh_str02scm (p.cmd),
|
|
||||||
gh_char2scm (p.state),
|
|
||||||
gh_ulong2scm (p.uid),
|
|
||||||
gh_ulong2scm (p.gid),
|
|
||||||
SCM_UNDEFINED);
|
|
||||||
}
|
|
@@ -1,43 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/proctime.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_get_proc_time (SCM pid)
|
|
||||||
{
|
|
||||||
glibtop_proc_time p;
|
|
||||||
|
|
||||||
glibtop_get_proc_time (&p, (pid_t) gh_scm2long (pid));
|
|
||||||
|
|
||||||
return gh_list (gh_ulong2scm (p.flags),
|
|
||||||
gh_long2scm (p.start_time),
|
|
||||||
gh_long2scm (p.utime),
|
|
||||||
gh_long2scm (p.stime),
|
|
||||||
gh_long2scm (p.cutime),
|
|
||||||
gh_long2scm (p.cstime),
|
|
||||||
gh_long2scm (p.timeout),
|
|
||||||
gh_long2scm (p.it_real_value),
|
|
||||||
SCM_UNDEFINED);
|
|
||||||
}
|
|
@@ -1,48 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/procuid.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM
|
|
||||||
glibtop_guile_get_proc_uid (SCM pid)
|
|
||||||
{
|
|
||||||
glibtop_proc_uid p;
|
|
||||||
|
|
||||||
glibtop_get_proc_uid (&p, (pid_t) gh_scm2long (pid));
|
|
||||||
|
|
||||||
return gh_list (gh_ulong2scm (p.flags),
|
|
||||||
gh_long2scm (p.uid),
|
|
||||||
gh_long2scm (p.euid),
|
|
||||||
gh_long2scm (p.gid),
|
|
||||||
gh_long2scm (p.egid),
|
|
||||||
gh_long2scm (p.pid),
|
|
||||||
gh_long2scm (p.ppid),
|
|
||||||
gh_long2scm (p.pgrp),
|
|
||||||
gh_long2scm (p.session),
|
|
||||||
gh_long2scm (p.tty),
|
|
||||||
gh_long2scm (p.tpgid),
|
|
||||||
gh_long2scm (p.priority),
|
|
||||||
gh_long2scm (p.nice),
|
|
||||||
SCM_UNDEFINED);
|
|
||||||
}
|
|
@@ -1,45 +0,0 @@
|
|||||||
/* $Id$ */
|
|
||||||
|
|
||||||
/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
|
||||||
This file is part of the Gnome Top Library.
|
|
||||||
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
|
||||||
|
|
||||||
The Gnome Top Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The Gnome Top Library 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
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
||||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
Boston, MA 02111-1307, USA. */
|
|
||||||
|
|
||||||
#include <glibtop.h>
|
|
||||||
#include <glibtop/sem_limits.h>
|
|
||||||
|
|
||||||
#include <guile/gh.h>
|
|
||||||
|
|
||||||
SCM glibtop_guile_get_sem_limits (void)
|
|
||||||
{
|
|
||||||
glibtop_sem_limits sem_limits;
|
|
||||||
|
|
||||||
glibtop_get_sem_limits (&sem_limits);
|
|
||||||
|
|
||||||
return gh_list (gh_ulong2scm (sem_limits.flags),
|
|
||||||
gh_ulong2scm (sem_limits.semmap),
|
|
||||||
gh_ulong2scm (sem_limits.semmni),
|
|
||||||
gh_ulong2scm (sem_limits.semmns),
|
|
||||||
gh_ulong2scm (sem_limits.semmnu),
|
|
||||||
gh_ulong2scm (sem_limits.semmsl),
|
|
||||||
gh_ulong2scm (sem_limits.semopm),
|
|
||||||
gh_ulong2scm (sem_limits.semume),
|
|
||||||
gh_ulong2scm (sem_limits.semusz),
|
|
||||||
gh_ulong2scm (sem_limits.semvmx),
|
|
||||||
gh_ulong2scm (sem_limits.semaem),
|
|
||||||
SCM_UNDEFINED);
|
|
||||||
}
|
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user