* nis/nss_nisplus/nisplus-ethers.c (struct etherent): Removed.
authorAndreas Jaeger <aj@suse.de>
Thu, 21 Dec 2000 14:38:26 +0000 (14:38 +0000)
committerAndreas Jaeger <aj@suse.de>
Thu, 21 Dec 2000 14:38:26 +0000 (14:38 +0000)
* inet/ether_hton.c: Likewise
* inet/ether_ntoh.c: Likewise.
* nis/nss_nis/nis-ethers.c (_nss_nis_getntohost_r): Fix
declaration to match prototype.

* include/netinet/ether.h (struct etherent): Declare here so that
all implementations use the same struct.

* nis/nss_nis/nis-ethers.c: Include netinet/ether.h to get
prototypes.
(struct ether): Removed.
Use struct etherent instead of ether everywhere.

* include/rpc/auth.h (DECLARE_NSS_PROTOTYPES): New.

* include/rpc/auth_des.h (DECLARE_NSS_PROTOTYPES): New.

* sunrpc/publickey.c: Include auth_des.h for prototypes.

include/netinet/ether.h
include/rpc/auth.h
include/rpc/auth_des.h
inet/ether_hton.c
inet/ether_ntoh.c
nis/nss_nis/nis-ethers.c
nis/nss_nisplus/nisplus-ethers.c
sunrpc/publickey.c

index c0b1e2b..fc3460d 100644 (file)
@@ -1,7 +1,14 @@
 #ifndef _NETINET_ETHER_H
 #include <inet/netinet/ether.h>
 
-struct etherent;
+/* Because the `ethers' lookup does not fit so well in the scheme we
+   define a dummy struct here which helps us to use the available
+   functions.  */
+struct etherent
+{
+  const char *e_name;
+  struct ether_addr e_addr;
+};
 
 #define DECLARE_NSS_PROTOTYPES(service)                                        \
 extern enum nss_status _nss_ ## service ## _setetherent (void);                \
index 5721091..40e9501 100644 (file)
@@ -1 +1,15 @@
+#ifndef _RPC_AUTH_H
 #include <sunrpc/rpc/auth.h>
+
+#define DECLARE_NSS_PROTOTYPES(service)                                        \
+extern enum nss_status _nss_ ##service ## _netname2user                        \
+                       (char netname[MAXNETNAMELEN + 1], uid_t *uidp,  \
+                       gid_t *gidp, int *gidlenp, gid_t *gidlist,      \
+                       int *errnop);
+
+DECLARE_NSS_PROTOTYPES (nis)
+DECLARE_NSS_PROTOTYPES (nisplus)
+
+#undef DECLARE_NSS_PROTOTYPES
+
+#endif
index 02736aa..fa36227 100644 (file)
@@ -1 +1,18 @@
+#ifndef _RPC_AUTH_DES_H
+
 #include <sunrpc/rpc/auth_des.h>
+
+#define DECLARE_NSS_PROTOTYPES(service)                                        \
+extern enum nss_status _nss_ ## service ## _getpublickey               \
+                       (const char *netname, char *pkey, int *errnop); \
+extern enum nss_status _nss_ ## service ## _getsecretkey               \
+                       (const char *netname, char *skey, char *passwd, \
+                       int *errnop);
+
+DECLARE_NSS_PROTOTYPES (files)
+DECLARE_NSS_PROTOTYPES (nis)
+DECLARE_NSS_PROTOTYPES (nisplus)
+
+#undef DECLARE_NSS_PROTOTYPES
+
+#endif
index 8a1325b..66ec866 100644 (file)
 
 #include "../nss/nsswitch.h"
 
-/* Because the `ethers' lookup does not fit so well in the scheme so
-   we define a dummy struct here which helps us to use the available
-   functions.  */
-struct etherent
-{
-  const char *e_name;
-  struct ether_addr e_addr;
-};
-
-
 /* Type of the lookup function we need here.  */
 typedef int (*lookup_function) (const char *, struct etherent *, char *, int,
                                int *);
index 6937201..d26ec3b 100644 (file)
 
 #include <nss/nsswitch.h>
 
-/* Because the `ethers' lookup does not fit so well in the scheme so
-   we define a dummy struct here which helps us to use the available
-   functions.  */
-struct etherent
-{
-  const char *e_name;
-  struct ether_addr e_addr;
-};
-
 
 /* Type of the lookup function we need here.  */
 typedef int (*lookup_function) (const struct ether_addr *, struct etherent *,
index c900917..f7ff505 100644 (file)
@@ -24,6 +24,7 @@
 #include <bits/libc-lock.h>
 #include <rpcsvc/yp.h>
 #include <rpcsvc/ypclnt.h>
+#include <netinet/ether.h>
 #include <netinet/if_ether.h>
 
 #include "nss-nis.h"
 /* Protect global state against multiple changers */
 __libc_lock_define_initialized (static, lock)
 
-struct ether
-{
-  const char *e_name;
-  struct ether_addr e_addr;
-};
-
 /* Get the declaration of the parser function.  */
 #define ENTNAME etherent
-#define STRUCTURE ether
+#define STRUCTURE etherent
 #define EXTERN_PARSER
 #include <nss/nss_files/files-parse.c>
 
@@ -149,7 +144,7 @@ _nss_nis_endetherent (void)
 }
 
 static enum nss_status
-internal_nis_getetherent_r (struct ether *eth, char *buffer, size_t buflen,
+internal_nis_getetherent_r (struct etherent *eth, char *buffer, size_t buflen,
                            int *errnop)
 {
   struct parser_data *data = (void *) buffer;
@@ -184,7 +179,7 @@ internal_nis_getetherent_r (struct ether *eth, char *buffer, size_t buflen,
 }
 
 enum nss_status
-_nss_nis_getetherent_r (struct ether *result, char *buffer, size_t buflen,
+_nss_nis_getetherent_r (struct etherent *result, char *buffer, size_t buflen,
                        int *errnop)
 {
   int status;
@@ -199,7 +194,7 @@ _nss_nis_getetherent_r (struct ether *result, char *buffer, size_t buflen,
 }
 
 enum nss_status
-_nss_nis_gethostton_r (const char *name, struct ether *eth,
+_nss_nis_gethostton_r (const char *name, struct etherent *eth,
                       char *buffer, size_t buflen, int *errnop)
 {
   struct parser_data *data = (void *) buffer;
@@ -256,7 +251,7 @@ _nss_nis_gethostton_r (const char *name, struct ether *eth,
 }
 
 enum nss_status
-_nss_nis_getntohost_r (struct ether_addr *addr, struct ether *eth,
+_nss_nis_getntohost_r (const struct ether_addr *addr, struct etherent *eth,
                       char *buffer, size_t buflen, int *errnop)
 {
   struct parser_data *data = (void *) buffer;
index ddf6f7f..a8af456 100644 (file)
@@ -35,15 +35,6 @@ static nis_result *result = NULL;
 static nis_name tablename_val = NULL;
 static u_long tablename_len = 0;
 
-/* Because the `ethers' lookup does not fit so well in the scheme so
-   we define a dummy struct here which helps us to use the available
-   functions.  */
-struct etherent
-{
-  const char *e_name;
-  struct ether_addr e_addr;
-};
-struct etherent_data {};
 
 #define NISENTRYVAL(idx,col,res) \
         ((res)->objects.objects_val[(idx)].zo_data.objdata_u.en_data.en_cols.en_cols_val[(col)].ec_value.ec_value_val)
@@ -53,7 +44,7 @@ struct etherent_data {};
 
 static int
 _nss_nisplus_parse_etherent (nis_result *result, struct etherent *ether,
-                          char *buffer, size_t buflen, int *errnop)
+                            char *buffer, size_t buflen, int *errnop)
 {
   char *p = buffer;
   size_t room_left = buflen;
index 94d5499..ee51e3c 100644 (file)
@@ -20,6 +20,7 @@
 
 #include <errno.h>
 #include <rpc/netdb.h>
+#include <rpc/auth_des.h>
 
 #include "nsswitch.h"