#file #inode #read-file #index #system #unique-id

bin+lib file-id

Utility for reading inode numbers (Linux, MacOS) and file IDs (Windows)

4 releases

0.2.2 Oct 25, 2024
0.2.1 Aug 21, 2023
0.2.0 Aug 20, 2023
0.1.0 May 17, 2023

#311 in Filesystem

Download history 45767/week @ 2024-11-16 30001/week @ 2024-11-23 41795/week @ 2024-11-30 40828/week @ 2024-12-07 40969/week @ 2024-12-14 35076/week @ 2024-12-21 22299/week @ 2024-12-28 46072/week @ 2025-01-04 55940/week @ 2025-01-11 47586/week @ 2025-01-18 54918/week @ 2025-01-25 62170/week @ 2025-02-01 65726/week @ 2025-02-08 53992/week @ 2025-02-15 66676/week @ 2025-02-22 60452/week @ 2025-03-01

258,853 downloads per month
Used in 163 crates (4 directly)

MIT/Apache

13KB
171 lines

File Id

» Docs

A utility to read file IDs.

Modern file systems assign a unique ID to each file. On Linux and MacOS it is called an inode number, on Windows it is called file index. Together with the device id, a file can be identified uniquely on a device at a given time.

Keep in mind though, that IDs may be re-used at some point.

Example

let file_id = file_id::get_file_id(path).unwrap();

println!("{file_id:?}");

Features

  • serde for serde support, off by default

lib.rs:

Utility for reading inode numbers (Linux, macOS) and file ids (Windows) that uniquely identify a file on a single computer.

Modern file systems assign a unique ID to each file. On Linux and macOS it is called an inode number, on Windows it is called a file id or file index. Together with the device id (Linux, macOS) or the volume serial number (Windows), a file or directory can be uniquely identified on a single computer at a given time.

Keep in mind though, that IDs may be re-used at some point.

Example

let file = tempfile::NamedTempFile::new().unwrap();

let file_id = file_id::get_file_id(file.path()).unwrap();
println!("{file_id:?}");

Example (Windows Only)

let file = tempfile::NamedTempFile::new().unwrap();

let file_id = file_id::get_low_res_file_id(file.path()).unwrap();
println!("{file_id:?}");

let file_id = file_id::get_high_res_file_id(file.path()).unwrap();
println!("{file_id:?}");

Dependencies

~0–8.5MB
~65K SLoC