mirror of
https://github.com/rust-lang/rust.git
synced 2025-06-21 12:07:31 +00:00

This also eliminates a use of a `Path` convenience function, in support of #80741, refactoring `std::path` to focus on pure data structures and algorithms.
42 lines
1.1 KiB
Rust
42 lines
1.1 KiB
Rust
#![allow(dead_code)] // not used on all platforms
|
|
|
|
use crate::fs;
|
|
use crate::io::{self, Error, ErrorKind};
|
|
use crate::path::Path;
|
|
|
|
pub fn copy(from: &Path, to: &Path) -> io::Result<u64> {
|
|
let mut reader = fs::File::open(from)?;
|
|
let metadata = reader.metadata()?;
|
|
|
|
if !metadata.is_file() {
|
|
return Err(Error::new(
|
|
ErrorKind::InvalidInput,
|
|
"the source path is not an existing regular file",
|
|
));
|
|
}
|
|
|
|
let mut writer = fs::File::create(to)?;
|
|
let perm = metadata.permissions();
|
|
|
|
let ret = io::copy(&mut reader, &mut writer)?;
|
|
writer.set_permissions(perm)?;
|
|
Ok(ret)
|
|
}
|
|
|
|
pub fn remove_dir_all(path: &Path) -> io::Result<()> {
|
|
let filetype = fs::symlink_metadata(path)?.file_type();
|
|
if filetype.is_symlink() { fs::remove_file(path) } else { remove_dir_all_recursive(path) }
|
|
}
|
|
|
|
fn remove_dir_all_recursive(path: &Path) -> io::Result<()> {
|
|
for child in fs::read_dir(path)? {
|
|
let child = child?;
|
|
if child.file_type()?.is_dir() {
|
|
remove_dir_all_recursive(&child.path())?;
|
|
} else {
|
|
fs::remove_file(&child.path())?;
|
|
}
|
|
}
|
|
fs::remove_dir(path)
|
|
}
|