Update from db-2.3.12.
[kopensolaris-gnu/glibc.git] / db2 / os / os_fid.c
1 /*-
2  * See the file LICENSE for redistribution information.
3  *
4  * Copyright (c) 1996, 1997
5  *      Sleepycat Software.  All rights reserved.
6  */
7
8 #include "config.h"
9
10 #ifndef lint
11 static const char sccsid[] = "@(#)os_fid.c      10.9 (Sleepycat) 10/24/97";
12 #endif /* not lint */
13
14 #ifndef NO_SYSTEM_INCLUDES
15 #include <sys/types.h>
16 #include <sys/stat.h>
17
18 #include <errno.h>
19 #include <stdlib.h>
20 #include <string.h>
21 #include <time.h>
22 #endif
23
24 #include "db_int.h"
25 #include "common_ext.h"
26
27 /*
28  * __db_fileid --
29  *      Return a unique identifier for a file.
30  *
31  * PUBLIC: int __db_fileid __P((DB_ENV *, const char *, int, u_int8_t *));
32  */
33 int
34 __db_fileid(dbenv, fname, timestamp, fidp)
35         DB_ENV *dbenv;
36         const char *fname;
37         int timestamp;
38         u_int8_t *fidp;
39 {
40         struct stat sb;
41         size_t i;
42         time_t now;
43         u_int8_t *p;
44
45         /* Clear the buffer. */
46         memset(fidp, 0, DB_FILE_ID_LEN);
47
48         /* Check for the unthinkable. */
49         if (sizeof(sb.st_ino) +
50             sizeof(sb.st_dev) + sizeof(time_t) > DB_FILE_ID_LEN)
51                 return (EINVAL);
52
53         /* On UNIX, use a dev/inode pair. */
54         if (stat(fname, &sb)) {
55                 __db_err(dbenv, "%s: %s", fname, strerror(errno));
56                 return (errno);
57         }
58
59         /*
60          * Use the inode first and in reverse order, hopefully putting the
61          * distinguishing information early in the string.
62          */
63         for (p = (u_int8_t *)&sb.st_ino +
64             sizeof(sb.st_ino), i = 0; i < sizeof(sb.st_ino); ++i)
65                 *fidp++ = *--p;
66         for (p = (u_int8_t *)&sb.st_dev +
67             sizeof(sb.st_dev), i = 0; i < sizeof(sb.st_dev); ++i)
68                 *fidp++ = *--p;
69
70         if (timestamp) {
71                 (void)time(&now);
72                 for (p = (u_int8_t *)&now +
73                     sizeof(now), i = 0; i < sizeof(now); ++i)
74                         *fidp++ = *--p;
75         }
76         return (0);
77 }