X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Freadutmp.h;h=d122987e53553218ba6c36e042b6c4f1d95dfdca;hb=03d089ba4969314534caeaa7da66cb7f9dc98fb2;hp=a555e58eeaf421ccb8e2db5d3b6603f80dec1764;hpb=63258a536ed19fd4cfca19f49d072755652746fc;p=gnulib.git diff --git a/lib/readutmp.h b/lib/readutmp.h index a555e58ee..d122987e5 100644 --- a/lib/readutmp.h +++ b/lib/readutmp.h @@ -1,5 +1,7 @@ /* Declarations for GNU's read utmp module. - Copyright (C) 1992-2000 Free Software Foundation, Inc. + + Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, + 2001, 2002, 2003 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 @@ -20,43 +22,46 @@ #ifndef __READUTMP_H__ # define __READUTMP_H__ -# ifndef PARAMS -# if defined PROTOTYPES || (defined __STDC__ && __STDC__) -# define PARAMS(Args) Args -# else -# define PARAMS(Args) () -# endif -# endif - # include # ifdef HAVE_UTMPX_H +# ifdef HAVE_UTMP_H + /* HPUX 10.20 needs utmp.h, for the definition of e.g., UTMP_FILE. */ +# include +# endif # include # define UTMP_STRUCT_NAME utmpx # define UT_TIME_MEMBER(UT_PTR) ((UT_PTR)->ut_tv.tv_sec) # define SET_UTMP_ENT setutxent # define GET_UTMP_ENT getutxent # define END_UTMP_ENT endutxent -# define UTMP_NAME_FUNCTION utmpxname +# ifdef HAVE_UTMPXNAME +# define UTMP_NAME_FUNCTION utmpxname +# endif # else # include +# if !HAVE_DECL_GETUTENT + struct utmp *getutent(); +# endif # define UTMP_STRUCT_NAME utmp # define UT_TIME_MEMBER(UT_PTR) ((UT_PTR)->ut_time) # define SET_UTMP_ENT setutent # define GET_UTMP_ENT getutent # define END_UTMP_ENT endutent -# define UTMP_NAME_FUNCTION utmpname +# ifdef HAVE_UTMPNAME +# define UTMP_NAME_FUNCTION utmpname +# endif # endif /* Accessor macro for the member named ut_user or ut_name. */ # ifdef HAVE_UTMPX_H # if HAVE_STRUCT_UTMPX_UT_USER -# define UT_USER(Utmp) Utmp->ut_user +# define UT_USER(Utmp) ((Utmp)->ut_user) # endif # if HAVE_STRUCT_UTMPX_UT_NAME # undef UT_USER -# define UT_USER(Utmp) Utmp->ut_name +# define UT_USER(Utmp) ((Utmp)->ut_name) # endif # else @@ -71,6 +76,22 @@ # endif +# define HAVE_STRUCT_XTMP_UT_EXIT \ + (HAVE_STRUCT_UTMP_UT_EXIT \ + || HAVE_STRUCT_UTMPX_UT_EXIT) + +# define HAVE_STRUCT_XTMP_UT_ID \ + (HAVE_STRUCT_UTMP_UT_ID \ + || HAVE_STRUCT_UTMPX_UT_ID) + +# define HAVE_STRUCT_XTMP_UT_PID \ + (HAVE_STRUCT_UTMP_UT_PID \ + || HAVE_STRUCT_UTMPX_UT_PID) + +# define HAVE_STRUCT_XTMP_UT_TYPE \ + (HAVE_STRUCT_UTMP_UT_TYPE \ + || HAVE_STRUCT_UTMPX_UT_TYPE) + typedef struct UTMP_STRUCT_NAME STRUCT_UTMP; # include @@ -109,15 +130,7 @@ extern int errno; # define WTMP_FILE "/etc/wtmp" # endif -# undef PARAMS -# if defined (__STDC__) && __STDC__ -# define PARAMS(Args) Args -# else -# define PARAMS(Args) () -# endif - -extern char *extract_trimmed_name PARAMS ((const STRUCT_UTMP *ut)); -extern int read_utmp PARAMS ((const char *filename, - int *n_entries, STRUCT_UTMP **utmp_buf)); +char *extract_trimmed_name (const STRUCT_UTMP *ut); +int read_utmp (const char *filename, int *n_entries, STRUCT_UTMP **utmp_buf); #endif /* __READUTMP_H__ */