Add an entry for the "check" command to the tdbtool manpage.
[Samba/gebeck_regimport.git] / source3 / lib / file_id.c
blob0633d4b88d6e1136c609ac74de0eff5d70d48f2f
1 /*
2 Unix SMB/CIFS implementation.
4 file_id structure handling
6 Copyright (C) Andrew Tridgell 2007
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>.
22 #include "includes.h"
25 return a file_id which gives a unique ID for a file given the device and
26 inode numbers
28 struct file_id file_id_create_dev(SMB_DEV_T dev, SMB_INO_T inode)
30 struct file_id key;
31 /* the ZERO_STRUCT ensures padding doesn't break using the key as a
32 * blob */
33 ZERO_STRUCT(key);
34 key.devid = dev;
35 key.inode = inode;
36 return key;
40 generate a file_id from a stat structure
42 struct file_id vfs_file_id_from_sbuf(connection_struct *conn, const SMB_STRUCT_STAT *sbuf)
44 return SMB_VFS_FILE_ID_CREATE(conn, sbuf->st_dev, sbuf->st_ino);
48 return True if two file_id structures are equal
50 bool file_id_equal(const struct file_id *id1, const struct file_id *id2)
52 return id1->inode == id2->inode && id1->devid == id2->devid;
56 a static string for a file_id structure
58 const char *file_id_string_tos(const struct file_id *id)
60 char *result = talloc_asprintf(talloc_tos(), "%llx:%llx",
61 (unsigned long long)id->devid,
62 (unsigned long long)id->inode);
63 SMB_ASSERT(result != NULL);
64 return result;
68 push a 16 byte version of a file id into a buffer
70 void push_file_id_16(char *buf, const struct file_id *id)
72 SIVAL(buf, 0, id->devid&0xFFFFFFFF);
73 SIVAL(buf, 4, id->devid>>32);
74 SIVAL(buf, 8, id->inode&0xFFFFFFFF);
75 SIVAL(buf, 12, id->inode>>32);
79 pul a 16 byte version of a file id from a buffer
81 void pull_file_id_16(char *buf, struct file_id *id)
83 ZERO_STRUCTP(id);
84 id->devid = IVAL(buf, 0);
85 id->devid |= ((uint64_t)IVAL(buf,4))<<32;
86 id->inode = IVAL(buf, 8);
87 id->inode |= ((uint64_t)IVAL(buf,12))<<32;