X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Freadutmp.h;h=b6c74a2e6f0697dcf1b8c8537f4195f497b1a742;hb=595d84818b6a914e6319a74d637bc866bea9bc9d;hp=d7ad90c2686df1447d25f37ad908d7d394b08c2a;hpb=82ba66a9d9081daafb1f2f0ac449911408797d13;p=gnulib.git diff --git a/lib/readutmp.h b/lib/readutmp.h index d7ad90c26..b6c74a2e6 100644 --- a/lib/readutmp.h +++ b/lib/readutmp.h @@ -1,5 +1,5 @@ /* Declarations for GNU's read utmp module. - Copyright (C) 1992-2000 Free Software Foundation, Inc. + Copyright (C) 1992-2002 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 @@ -30,32 +30,74 @@ # include -/* Accessor macro for the member named ut_user or ut_name. */ -# if HAVE_STRUCT_UTMPX_UT_USER || HAVE_STRUCT_UTMP_UT_USER -# define UT_USER(Utmp) Utmp->ut_user -# endif -# if HAVE_STRUCT_UTMPX_UT_NAME || HAVE_STRUCT_UTMP_UT_NAME -# define UT_USER(Utmp) Utmp->ut_name -# endif - # 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) +# endif +# if HAVE_STRUCT_UTMPX_UT_NAME +# undef UT_USER +# define UT_USER(Utmp) ((Utmp)->ut_name) +# endif + +# else + +# if HAVE_STRUCT_UTMP_UT_USER +# define UT_USER(Utmp) Utmp->ut_user +# endif +# if HAVE_STRUCT_UTMP_UT_NAME +# undef UT_USER +# define UT_USER(Utmp) Utmp->ut_name +# endif + +# 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