4 * Copyright (c) 1997-2009 Erez Zadok
5 * Copyright (c) 1989 Jan-Simon Pendry
6 * Copyright (c) 1989 Imperial College of Science, Technology & Medicine
7 * Copyright (c) 1989 The Regents of the University of California.
10 * This code is derived from software contributed to Berkeley by
11 * Jan-Simon Pendry at Imperial College, London.
13 * Redistribution and use in source and binary forms, with or without
14 * modification, are permitted provided that the following conditions
16 * 1. Redistributions of source code must retain the above copyright
17 * notice, this list of conditions and the following disclaimer.
18 * 2. Redistributions in binary form must reproduce the above copyright
19 * notice, this list of conditions and the following disclaimer in the
20 * documentation and/or other materials provided with the distribution.
21 * 3. All advertising materials mentioning features or use of this software
22 * must display the following acknowledgment:
23 * This product includes software developed by the University of
24 * California, Berkeley and its contributors.
25 * 4. Neither the name of the University nor the names of its contributors
26 * may be used to endorse or promote products derived from this software
27 * without specific prior written permission.
29 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
30 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
31 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
32 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
33 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
34 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
35 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
36 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
37 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
38 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
42 * File: am-utils/amd/info_ndbm.c
47 * Get info from NDBM map
52 #endif /* HAVE_CONFIG_H */
57 /* forward declarations */
58 int ndbm_init(mnt_map
*m
, char *map
, time_t *tp
);
59 int ndbm_mtime(mnt_map
*m
, char *map
, time_t *tp
);
60 int ndbm_search(mnt_map
*m
, char *map
, char *key
, char **pval
, time_t *tp
);
64 search_ndbm(mnt_map
*m
, DBM
*db
, char *key
, char **val
)
69 k
.dsize
= strlen(key
) + 1;
72 if (m
->cfm
&& (m
->cfm
->cfm_flags
& CFM_SUN_MAP_SYNTAX
))
73 *val
= sun_entry2amd(key
, v
.dptr
);
75 *val
= strdup(v
.dptr
);
83 ndbm_search(mnt_map
*m
, char *map
, char *key
, char **pval
, time_t *tp
)
87 db
= dbm_open(map
, O_RDONLY
, 0);
94 xstrlcpy(dbfilename
, map
, sizeof(dbfilename
));
95 xstrlcat(dbfilename
, DBM_SUFFIX
, sizeof(dbfilename
));
96 error
= stat(dbfilename
, &stb
);
97 #else /* not DBM_SUFFIX */
98 error
= fstat(dbm_pagfno(db
), &stb
);
99 #endif /* not DBM_SUFFIX */
100 if (!error
&& *tp
< stb
.st_mtime
) {
104 error
= search_ndbm(m
, db
, key
, pval
);
106 (void) dbm_close(db
);
114 ndbm_init(mnt_map
*m
, char *map
, time_t *tp
)
118 db
= dbm_open(map
, O_RDONLY
, 0);
123 char dbfilename
[256];
125 xstrlcpy(dbfilename
, map
, sizeof(dbfilename
));
126 xstrlcat(dbfilename
, DBM_SUFFIX
, sizeof(dbfilename
));
127 error
= stat(dbfilename
, &stb
);
128 #else /* not DBM_SUFFIX */
129 error
= fstat(dbm_pagfno(db
), &stb
);
130 #endif /* not DBM_SUFFIX */
132 *tp
= clocktime(NULL
);
143 ndbm_mtime(mnt_map
*m
, char *map
, time_t *tp
)
145 return ndbm_init(m
,map
, tp
);