2019-10-02 11:40:20 +03:00
|
|
|
// Copyright 2019 The Grin Developers
|
2018-08-03 05:16:16 +03:00
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
use std::fs;
|
2018-09-26 23:38:44 +03:00
|
|
|
use std::io::{self, BufRead};
|
2018-08-03 05:16:16 +03:00
|
|
|
use std::path::{Path, PathBuf};
|
|
|
|
use walkdir::WalkDir;
|
|
|
|
|
2018-08-16 03:11:05 +03:00
|
|
|
/// Delete a directory or file
|
|
|
|
pub fn delete(path_buf: PathBuf) -> io::Result<()> {
|
2018-08-03 05:16:16 +03:00
|
|
|
if path_buf.is_dir() {
|
|
|
|
fs::remove_dir_all(path_buf)
|
|
|
|
} else if path_buf.is_file() {
|
|
|
|
fs::remove_file(path_buf)
|
|
|
|
} else {
|
2018-08-16 03:11:05 +03:00
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
}
|
2018-08-03 05:16:16 +03:00
|
|
|
|
2018-08-16 03:11:05 +03:00
|
|
|
/// Copy directory, create destination if needed
|
2018-08-03 05:16:16 +03:00
|
|
|
pub fn copy_dir_to(src: &Path, dst: &Path) -> io::Result<u64> {
|
|
|
|
let mut counter = 0u64;
|
|
|
|
if !dst.is_dir() {
|
|
|
|
fs::create_dir(dst)?
|
|
|
|
}
|
|
|
|
|
|
|
|
for entry_result in src.read_dir()? {
|
|
|
|
let entry = entry_result?;
|
|
|
|
let file_type = entry.file_type()?;
|
|
|
|
let count = copy_to(&entry.path(), &file_type, &dst.join(entry.file_name()))?;
|
2018-08-16 03:11:05 +03:00
|
|
|
counter += count;
|
2018-08-03 05:16:16 +03:00
|
|
|
}
|
|
|
|
Ok(counter)
|
|
|
|
}
|
|
|
|
|
2018-08-16 03:11:05 +03:00
|
|
|
/// List directory
|
2019-07-12 12:50:27 +03:00
|
|
|
pub fn list_files(path: &Path) -> Vec<PathBuf> {
|
|
|
|
WalkDir::new(path)
|
|
|
|
.sort_by(|a, b| a.path().cmp(b.path()))
|
|
|
|
.min_depth(1)
|
2018-08-16 03:11:05 +03:00
|
|
|
.into_iter()
|
2019-07-12 12:50:27 +03:00
|
|
|
.filter_map(|x| x.ok())
|
|
|
|
.filter(|x| x.file_type().is_file())
|
|
|
|
.filter_map(|x| x.path().strip_prefix(path).map(|x| x.to_path_buf()).ok())
|
|
|
|
.collect()
|
2018-08-03 05:16:16 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
fn copy_to(src: &Path, src_type: &fs::FileType, dst: &Path) -> io::Result<u64> {
|
|
|
|
if src_type.is_file() {
|
2018-08-16 03:11:05 +03:00
|
|
|
fs::copy(src, dst)
|
2018-08-03 05:16:16 +03:00
|
|
|
} else if src_type.is_dir() {
|
|
|
|
copy_dir_to(src, dst)
|
|
|
|
} else {
|
2019-09-04 16:53:05 +03:00
|
|
|
Err(io::Error::new(
|
2018-08-16 03:11:05 +03:00
|
|
|
io::ErrorKind::Other,
|
|
|
|
format!("Could not copy: {}", src.display()),
|
2019-09-04 16:53:05 +03:00
|
|
|
))
|
2018-08-03 05:16:16 +03:00
|
|
|
}
|
|
|
|
}
|
2018-09-26 23:38:44 +03:00
|
|
|
|
|
|
|
/// Retrieve first line from file
|
|
|
|
pub fn get_first_line(file_path: Option<String>) -> Option<String> {
|
|
|
|
match file_path {
|
|
|
|
Some(path) => match fs::File::open(path) {
|
|
|
|
Ok(file) => {
|
|
|
|
let buf_reader = io::BufReader::new(file);
|
2018-10-10 12:11:01 +03:00
|
|
|
let mut lines_iter = buf_reader.lines().map(|l| l.unwrap());
|
2018-09-26 23:38:44 +03:00
|
|
|
lines_iter.next()
|
|
|
|
}
|
|
|
|
Err(_) => None,
|
|
|
|
},
|
|
|
|
None => None,
|
|
|
|
}
|
|
|
|
}
|