diff options
author | Arthur de Jong <arthur@arthurdejong.org> | 2010-10-11 22:12:59 +0200 |
---|---|---|
committer | Arthur de Jong <arthur@arthurdejong.org> | 2010-10-11 22:12:59 +0200 |
commit | 90fec72d7d1390d0744622928c6648355d3f6f33 (patch) | |
tree | bd09214dd94179b152d738e8d4798bd9595b86df /nss/shadow.c | |
parent | 11428fdf252a18551d64fb6a119e44eab2d2c5d9 (diff) |
also try to support older Solaris releases that do not have the returnlen member of struct nss_XbyY_args
git-svn-id: http://arthurdejong.org/svn/nss-pam-ldapd/nss-pam-ldapd-solaris@1262 ef36b2f9-881f-0410-afb5-c4e39611909c
Diffstat (limited to 'nss/shadow.c')
-rw-r--r-- | nss/shadow.c | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/nss/shadow.c b/nss/shadow.c index ae025b4..fdcc74f 100644 --- a/nss/shadow.c +++ b/nss/shadow.c @@ -89,6 +89,8 @@ nss_status_t _nss_ldap_endspent(void) #ifdef NSS_FLAVOUR_SOLARIS +#ifdef HAVE_STRUCT_NSS_XBYY_ARGS_RETURNLEN + static nss_status_t read_spwdstring(TFILE *fp,nss_XbyY_args_t *args) { struct spwd result; @@ -153,8 +155,17 @@ static nss_status_t read_spwdstring(TFILE *fp,nss_XbyY_args_t *args) NSS_ARGS(args)->buf.result? \ read_spwd(fp,(struct spwd *)NSS_ARGS(args)->buf.result,NSS_ARGS(args)->buf.buffer,NSS_ARGS(args)->buf.buflen,&errno): \ read_spwdstring(fp,args); \ - if (NSS_ARGS(args)->buf.result) \ - NSS_ARGS(args)->returnval=NSS_ARGS(args)->buf.result + if ((NSS_ARGS(args)->buf.result)&&(retv=NSS_STATUS_SUCCESS)) \ + NSS_ARGS(args)->returnval=NSS_ARGS(args)->buf.result; + +#else /* not HAVE_STRUCT_NSS_XBYY_ARGS_RETURNLEN */ + +#define READ_RESULT(fp) \ + read_spwd(fp,(struct spwd *)NSS_ARGS(args)->buf.result,NSS_ARGS(args)->buf.buffer,NSS_ARGS(args)->buf.buflen,&errno); \ + if (retv=NSS_STATUS_SUCCESS) \ + NSS_ARGS(args)->returnval=NSS_ARGS(args)->buf.result; + +#endif /* not HAVE_STRUCT_NSS_XBYY_ARGS_RETURNLEN */ static nss_status_t get_getspnam_r(nss_backend_t UNUSED(*be),void *args) { |