#ntfs #file-copy #volume-shadow-copy #rawcopy

bin+lib rawcopy-rs-next

RawCopy crate provides the capability to use "Volume Shadow Copy technology" for file copying in Rust.Primarily aimed at replicating files that cannot be directly copied due to being in use

1 unstable release

0.1.3 Apr 22, 2024

#297 in Windows APIs

Download history 7/week @ 2024-06-02 6/week @ 2024-06-09 1/week @ 2024-06-16 70/week @ 2024-06-30 32/week @ 2024-07-07 13/week @ 2024-07-14 1/week @ 2024-07-21 11/week @ 2024-07-28 11/week @ 2024-08-04 1/week @ 2024-08-11 2/week @ 2024-08-18 18/week @ 2024-08-25 50/week @ 2024-09-01 18/week @ 2024-09-08 41/week @ 2024-09-15

127 downloads per month
Used in rookie

MIT license

20KB
318 lines

RawCopy-rs

RawCopy crate provides the capability to use "Volume Shadow Copy technology" for file copying in Rust.
Primarily aimed at replicating files that cannot be directly copied due to being in use.

Usage

RawCopy must be run with Administrator privileges on Windows.

Download Prebuilt Binaries

Release download

Usage: rawcopy.exe <file_path> <save_path>

`file_path` is the absolute path of the file must exist.  
`save_path` is the directory where the copied file will be saved.  
        The directory must exist, and the file must not exist.  
        The file name will be the same as the name of the file being copied.  
        If it points to an NTFS filesystem image, then a suffix will be appended.

example:

rawcopy.exe "C:\swapfile.sys" d:\tmp

Use rawcopy-rs crate in Rust

1. Add rawcopy-rs to your Cargo.toml

[dependencies]
rawcopy-rs = "0.1.2"

2. use api to copy file

rawcopy_rs::rawcopy(r"C:\swapfile.sys", ".");

Build from source

cargo build --release

License

MIT

Acknowledgements

The ntfs A low-level NTFS filesystem library implemented in Rust.

Dependencies

~2–10MB
~86K SLoC