From 9a2c3e7624985e6110634e07d6b216e96b209adb Mon Sep 17 00:00:00 2001 From: Arthur de Jong Date: Wed, 17 Jan 2007 22:16:09 +0000 Subject: ensure that all NSS functions can be generated by the marcos in common.h and spell out the read_..() function for every type git-svn-id: http://arthurdejong.org/svn/nss-pam-ldapd/nss-ldapd@227 ef36b2f9-881f-0410-afb5-c4e39611909c --- nss/passwd.c | 32 +++++++++++++++----------------- 1 file changed, 15 insertions(+), 17 deletions(-) (limited to 'nss/passwd.c') diff --git a/nss/passwd.c b/nss/passwd.c index e3bca05..64bf2b8 100644 --- a/nss/passwd.c +++ b/nss/passwd.c @@ -2,7 +2,7 @@ passwd.c - NSS lookup functions for passwd database Copyright (C) 2006 West Consulting - Copyright (C) 2006 Arthur de Jong + Copyright (C) 2006, 2007 Arthur de Jong This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public @@ -29,36 +29,34 @@ #include "prototypes.h" #include "common.h" -/* Macros for expanding the NSLCD_PASSWD macro. */ -#define NSLCD_STRING(field) READ_STRING_BUF(fp,field) -#define NSLCD_TYPE(field,type) READ_TYPE(fp,field,type) -#define PASSWD_NAME result->pw_name -#define PASSWD_PASSWD result->pw_passwd -#define PASSWD_UID result->pw_uid -#define PASSWD_GID result->pw_gid -#define PASSWD_GECOS result->pw_gecos -#define PASSWD_DIR result->pw_dir -#define PASSWD_SHELL result->pw_shell - - static enum nss_status read_passwd( FILE *fp,struct passwd *result, char *buffer,size_t buflen,int *errnop) { int32_t tmpint32; size_t bufptr=0; - NSLCD_PASSWD; + READ_STRING_BUF(fp,result->pw_name); + READ_STRING_BUF(fp,result->pw_passwd); + READ_TYPE(fp,result->pw_uid,uid_t); + READ_TYPE(fp,result->pw_gid,gid_t); + READ_STRING_BUF(fp,result->pw_gecos); + READ_STRING_BUF(fp,result->pw_dir); + READ_STRING_BUF(fp,result->pw_shell); return NSS_STATUS_SUCCESS; } enum nss_status _nss_ldap_getpwnam_r(const char *name,struct passwd *result,char *buffer,size_t buflen,int *errnop) { - NSS_BYNAME(NSLCD_ACTION_PASSWD_BYNAME,name,read_passwd); + NSS_BYNAME(NSLCD_ACTION_PASSWD_BYNAME, + name, + read_passwd(fp,result,buffer,buflen,errnop)); } enum nss_status _nss_ldap_getpwuid_r(uid_t uid,struct passwd *result,char *buffer,size_t buflen,int *errnop) { - NSS_BYTYPE(NSLCD_ACTION_PASSWD_BYUID,uid,uid_t,read_passwd); + NSS_BYTYPE(NSLCD_ACTION_PASSWD_BYUID, + uid,uid_t, + read_passwd(fp,result,buffer,buflen,errnop)); } /* thread-local file pointer to an ongoing request */ @@ -73,7 +71,7 @@ enum nss_status _nss_ldap_setpwent(int stayopen) /* read password data from an opened stream */ enum nss_status _nss_ldap_getpwent_r(struct passwd *result,char *buffer,size_t buflen,int *errnop) { - NSS_GETENT(pwentfp,read_passwd); + NSS_GETENT(pwentfp,read_passwd(pwentfp,result,buffer,buflen,errnop)); } /* close the stream opened with setpwent() above */ -- cgit v1.2.3