1
0
mirror of https://github.com/Llewellynvdm/starship.git synced 2025-01-13 10:25:33 +00:00

refactor(directory/lock): fix clippy, replace str with Path (#1544)

This commit is contained in:
David Knaack 2020-08-02 18:42:38 +02:00 committed by GitHub
parent b14be4dfb1
commit 36ae36282a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 13 additions and 11 deletions

View File

@ -107,7 +107,7 @@ pub fn module<'a>(context: &'a Context) -> Option<Module<'a>> {
.map(|variable| match variable { .map(|variable| match variable {
"path" => Some(Ok(&final_dir_string)), "path" => Some(Ok(&final_dir_string)),
"read_only" => { "read_only" => {
if is_readonly_dir(context.current_dir.to_str()?) { if is_readonly_dir(&context.current_dir) {
Some(Ok(&lock_symbol)) Some(Ok(&lock_symbol))
} else { } else {
None None
@ -129,12 +129,12 @@ pub fn module<'a>(context: &'a Context) -> Option<Module<'a>> {
Some(module) Some(module)
} }
fn is_readonly_dir(path: &str) -> bool { fn is_readonly_dir(path: &Path) -> bool {
match directory_utils::is_write_allowed(path) { match directory_utils::is_write_allowed(path) {
Ok(res) => !res, Ok(res) => !res,
Err(e) => { Err(e) => {
log::debug!( log::debug!(
"Failed to detemine read only status of directory '{}': {}", "Failed to detemine read only status of directory '{:?}': {}",
path, path,
e e
); );

View File

@ -3,6 +3,7 @@ use nix::unistd::{Gid, Uid};
use std::fs; use std::fs;
use std::os::unix::fs::MetadataExt; use std::os::unix::fs::MetadataExt;
use std::os::unix::fs::PermissionsExt; use std::os::unix::fs::PermissionsExt;
use std::path::Path;
/// Checks if the current user can write to the `folder_path`. /// Checks if the current user can write to the `folder_path`.
/// ///
@ -12,7 +13,7 @@ use std::os::unix::fs::PermissionsExt;
/// 2a) (not implemented on macOS) one of the supplementary groups of the current user is the /// 2a) (not implemented on macOS) one of the supplementary groups of the current user is the
/// directory group owner and whether it has write access /// directory group owner and whether it has write access
/// 3) 'others' part of the access mask has the write access /// 3) 'others' part of the access mask has the write access
pub fn is_write_allowed(folder_path: &str) -> Result<bool, &'static str> { pub fn is_write_allowed(folder_path: &Path) -> Result<bool, &'static str> {
let meta = fs::metadata(folder_path).map_err(|_| "Unable to stat() directory")?; let meta = fs::metadata(folder_path).map_err(|_| "Unable to stat() directory")?;
let perms = meta.permissions().mode(); let perms = meta.permissions().mode();
@ -52,9 +53,9 @@ mod tests {
#[test] #[test]
#[ignore] #[ignore]
fn read_only_test() { fn read_only_test() {
assert_eq!(is_write_allowed("/etc"), Ok(false)); assert_eq!(is_write_allowed(Path::new("/etc")), Ok(false));
assert_eq!( assert_eq!(
is_write_allowed("/i_dont_exist"), is_write_allowed(Path::new("/i_dont_exist")),
Err("Unable to stat() directory") Err("Unable to stat() directory")
); );
} }

View File

@ -1,9 +1,9 @@
extern crate winapi; extern crate winapi;
use std::ffi::OsStr;
use std::iter; use std::iter;
use std::mem; use std::mem;
use std::os::windows::ffi::OsStrExt; use std::os::windows::ffi::OsStrExt;
use std::path::Path;
use winapi::ctypes::c_void; use winapi::ctypes::c_void;
use winapi::shared::minwindef::{BOOL, DWORD}; use winapi::shared::minwindef::{BOOL, DWORD};
use winapi::um::handleapi; use winapi::um::handleapi;
@ -21,8 +21,9 @@ use winapi::um::winnt::{
/// First, the function extracts DACL from the given directory and then calls `AccessCheck` against /// First, the function extracts DACL from the given directory and then calls `AccessCheck` against
/// the current process access token and directory's security descriptor. /// the current process access token and directory's security descriptor.
/// Does not work for network drives and always returns true /// Does not work for network drives and always returns true
pub fn is_write_allowed(folder_path: &str) -> std::result::Result<bool, &'static str> { pub fn is_write_allowed(folder_path: &Path) -> std::result::Result<bool, &'static str> {
let folder_name: Vec<u16> = OsStr::new(folder_path) let folder_name: Vec<u16> = folder_path
.as_os_str()
.encode_wide() .encode_wide()
.chain(iter::once(0)) .chain(iter::once(0))
.collect(); .collect();
@ -131,6 +132,6 @@ extern "system" {
fn PathIsNetworkPathW(pszPath: LPCWSTR) -> BOOLEAN; fn PathIsNetworkPathW(pszPath: LPCWSTR) -> BOOLEAN;
} }
fn is_network_path(folder_path: &Vec<u16>) -> bool { fn is_network_path(folder_path: &[u16]) -> bool {
return unsafe { PathIsNetworkPathW(folder_path.as_ptr()) } == 1; unsafe { PathIsNetworkPathW(folder_path.as_ptr()) == 1 }
} }