X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Freadutmp.h;h=6f512fad646664b139470d12ef36674a45d09f42;hb=2c7648b6f92dd6a6dbb3fc72896b8500d525ccb1;hp=d7ad90c2686df1447d25f37ad908d7d394b08c2a;hpb=82ba66a9d9081daafb1f2f0ac449911408797d13;p=gnulib.git diff --git a/lib/readutmp.h b/lib/readutmp.h index d7ad90c26..6f512fad6 100644 --- a/lib/readutmp.h +++ b/lib/readutmp.h @@ -30,30 +30,56 @@ # 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 typedef struct UTMP_STRUCT_NAME STRUCT_UTMP;