Tue Jul 2 10:44:37 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu>
authorroland <roland>
Tue, 2 Jul 1996 19:34:54 +0000 (19:34 +0000)
committerroland <roland>
Tue, 2 Jul 1996 19:34:54 +0000 (19:34 +0000)
* nss/nss_files/files-XXX.c (DB_LOOKUP): Add KEYSIZE and KEYPATTERN
args, ignored.
(DATAFILE): New macro.
* nss/nss_files/files-parse.c (GENERIC): If undefined, define to
"files-XXX.c".
* nss/nss_files/files-rpc.c: Include GENERIC instead of "files-XXX.c".
Pass db key args to DB_LOOKUP.
(DATAFILE): Macro removed.
(DATABASE): New macro replaces it, lacks "/etc/" prefix.
* nss/nss_files/files-service.c: Likewise.
* nss/nss_files/files-pwd.c: Likewise.
* nss/nss_files/files-proto.c: Likewise.
* nss/nss_files/files-grp.c: Likewise.
* nss/nss_files/files-ethers.c: Likewise.

nss/nss_files/files-XXX.c
nss/nss_files/files-ethers.c
nss/nss_files/files-proto.c
nss/nss_files/files-rpc.c
nss/nss_files/files-service.c

index b9c3579..7fa87c0 100644 (file)
@@ -27,13 +27,15 @@ Cambridge, MA 02139, USA.  */
 
    ENTNAME -- database name of the structure and functions (hostent, pwent).
    STRUCTURE -- struct name, define only if not ENTNAME (passwd, group).
-   DATAFILE -- string of the database file's name.
+   DATABASE -- string of the database file's name ("hosts", "passwd").
 
    NEED_H_ERRNO - defined iff an arg `int *herrnop' is used.
    MIDLINE_COMMENTS - defined iff # before \n terminates a database line.
 */
 
-#define ENTNAME_r CONCAT(ENTNAME,_r)
+#define ENTNAME_r      CONCAT(ENTNAME,_r)
+
+#define DATAFILE       "/etc/" DATABASE
 
 #ifdef NEED_H_ERRNO
 #define H_ERRNO_PROTO  , int *herrnop
@@ -194,13 +196,15 @@ CONCAT(_nss_files_get,ENTNAME_r) (struct STRUCTURE *result,
 
    NAME is the name of the lookup; e.g. `hostbyname'.
 
+   KEYSIZE and KEYPATTERN are ignored here but used by ../nss_db/db-XXX.c.
+
    PROTO describes the arguments for the lookup key;
    e.g. `const char *hostname'.
 
    BREAK_IF_MATCH is a block of code which compares `struct STRUCTURE *result'
    to the lookup key arguments and does `break;' if they match.  */
 
-#define DB_LOOKUP(name, break_if_match, proto...)                            \
+#define DB_LOOKUP(name, keysize, keypattern, break_if_match, proto...)       \
 enum nss_status                                                                      \
 _nss_files_get##name##_r (proto,                                             \
                          struct STRUCTURE *result,                           \
index b66a3c3..70f7d07 100644 (file)
@@ -30,7 +30,7 @@ struct etherent
 struct etherent_data {};
 
 #define ENTNAME                etherent
-#define DATAFILE       "/etc/ethers"
+#define DATABASE       "ethers"
 #include "files-parse.c"
 LINE_PARSER
 ("#",
@@ -56,15 +56,16 @@ LINE_PARSER
  )
 
 
-#include "files-XXX.c"
+#include GENERIC
 
-DB_LOOKUP (hostton,
+DB_LOOKUP (hostton, 1 + strlen (name), (".%s", name),
           {
             if (strcmp (result->e_name, name) == 0)
               break;
           }, const char *name)
 
-DB_LOOKUP (ntohost,
+DB_LOOKUP (ntohost, 7, ("=%c%c%c%c%c%c",
+                       addr[0], addr[1], addr[2], addr[3], addr[4], addr[5]),
           {
             if (memcmp (&result->e_addr, addr,
                         sizeof (struct ether_addr)) == 0)
index ef5a7c2..3cc14e7 100644 (file)
@@ -21,7 +21,7 @@ Cambridge, MA 02139, USA.  */
 
 
 #define ENTNAME                protoent
-#define DATAFILE       _PATH_PROTOCOLS
+#define DATABASE       "protocols"
 
 struct protoent_data {};
 
@@ -34,13 +34,13 @@ LINE_PARSER
  INT_FIELD (result->p_proto, isspace, 1, 10,);
  )
 
-#include "files-XXX.c"
+#include GENERIC
 
-DB_LOOKUP (protobyname,
+DB_LOOKUP (protobyname, 1 + strlen (name), (".%s", name),
           LOOKUP_NAME (p_name, p_aliases),
           const char *name)
 
-DB_LOOKUP (protobynumber,
+DB_LOOKUP (protobynumber, 20, ("=%d", proto),
           {
             if (result->p_proto == proto)
               break;
index f8bef45..0ad1e21 100644 (file)
@@ -21,7 +21,7 @@ Cambridge, MA 02139, USA.  */
 
 
 #define ENTNAME                rpcent
-#define DATAFILE       "/etc/rpc"
+#define DATABASE       "rpc"
 
 struct rpcent_data {};
 
@@ -34,13 +34,13 @@ LINE_PARSER
  INT_FIELD (result->r_number, isspace, 1, 10,);
  )
 
-#include "files-XXX.c"
+#include GENERIC
 
-DB_LOOKUP (rpcbyname,
+DB_LOOKUP (rpcbyname, 1 + strlen (name), (".%s", name),
           LOOKUP_NAME (r_name, r_aliases),
           const char *name)
 
-DB_LOOKUP (rpcbynumber,
+DB_LOOKUP (rpcbynumber, 20, ("=%d", number),
           {
             if (result->r_number == number)
               break;
index f0dba50..5dea476 100644 (file)
@@ -22,7 +22,7 @@ Cambridge, MA 02139, USA.  */
 
 
 #define ENTNAME                servent
-#define DATAFILE       _PATH_SERVICES
+#define DATABASE       "services"
 
 struct servent_data {};
 
@@ -37,13 +37,13 @@ LINE_PARSER
  STRING_FIELD (result->s_proto, isspace, 1);
  )
 
-#include "files-XXX.c"
+#include GENERIC
 
-DB_LOOKUP (servbyname,
+DB_LOOKUP (servbyname, 1 + strlen (name), (".%s", name),
           LOOKUP_NAME (s_name, s_aliases),
           const char *name)
 
-DB_LOOKUP (servbyport,
+DB_LOOKUP (servbyport, 20, ("=%d", port),
           {
             if (result->s_port == port)
               break;