/* * Copyright (c) 1989 Jan-Simon Pendry * Copyright (c) 1989 Imperial College of Science, Technology & Medicine * Copyright (c) 1989, 1993 * The Regents of the University of California. All rights reserved. * * This code is derived from software contributed to Berkeley by * Jan-Simon Pendry at Imperial College, London. * * %sccs.include.redist.c% * * @(#)info_ndbm.c 8.1 (Berkeley) 06/06/93 * * $Id: info_ndbm.c,v 5.2.2.1 1992/02/09 15:08:31 jsp beta $ * */ /* * Get info from NDBM map */ #include "am.h" #ifdef HAS_NDBM_MAPS #include #include #include static int search_ndbm P((DBM *db, char *key, char **val)); static int search_ndbm(db, key, val) DBM *db; char *key; char **val; { datum k, v; k.dptr = key; k.dsize = strlen(key) + 1; v = dbm_fetch(db, k); if (v.dptr) { *val = strdup(v.dptr); return 0; } return ENOENT; } int ndbm_search P((mnt_map *m, char *map, char *key, char **pval, time_t *tp)); int ndbm_search(m, map, key, pval, tp) mnt_map *m; char *map; char *key; char **pval; time_t *tp; { DBM *db; db = dbm_open(map, O_RDONLY, 0); if (db) { struct stat stb; int error; error = fstat(dbm_pagfno(db), &stb); if (!error && *tp < stb.st_mtime) { *tp = stb.st_mtime; error = -1; } else { error = search_ndbm(db, key, pval); } (void) dbm_close(db); return error; } return errno; } int ndbm_init P((char *map, time_t *tp)); int ndbm_init(map, tp) char *map; time_t *tp; { DBM *db; db = dbm_open(map, O_RDONLY, 0); if (db) { struct stat stb; if (fstat(dbm_pagfno(db), &stb) < 0) *tp = clocktime(); else *tp = stb.st_mtime; dbm_close(db); return 0; } return errno; } #endif /* HAS_NDBM_MAPS */