* Strip unc if it exists, fix #1110 * Bump pinned version to 1.45.2 * Bump to minimum version required. - https://github.com/getzola/zola/pull/1129#discussion_r480172320 * Add unc comments and a required test * Fix typo in rust pinned version * Fix types not ok
This commit is contained in:
parent
4f5fd63281
commit
5ec3a9ca65
@ -21,7 +21,7 @@ stages:
|
|||||||
rustup_toolchain: stable
|
rustup_toolchain: stable
|
||||||
linux-pinned:
|
linux-pinned:
|
||||||
imageName: 'ubuntu-16.04'
|
imageName: 'ubuntu-16.04'
|
||||||
rustup_toolchain: 1.43.0
|
rustup_toolchain: 1.45.0
|
||||||
pool:
|
pool:
|
||||||
vmImage: $(imageName)
|
vmImage: $(imageName)
|
||||||
steps:
|
steps:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
use std::fs::{canonicalize, create_dir};
|
use std::fs::{canonicalize, create_dir};
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
|
use std::path::PathBuf;
|
||||||
|
|
||||||
use errors::{bail, Result};
|
use errors::{bail, Result};
|
||||||
use utils::fs::create_file;
|
use utils::fs::create_file;
|
||||||
@ -25,6 +26,15 @@ build_search_index = %SEARCH%
|
|||||||
# Put all your custom variables here
|
# Put all your custom variables here
|
||||||
"#;
|
"#;
|
||||||
|
|
||||||
|
// canonicalize(path) function on windows system returns a path with UNC.
|
||||||
|
// Example: \\?\C:\Users\VssAdministrator\AppData\Local\Temp\new_project
|
||||||
|
// More details on Universal Naming Convention (UNC):
|
||||||
|
// https://en.wikipedia.org/wiki/Path_(computing)#Uniform_Naming_Convention
|
||||||
|
// So the following const will be used to remove the network part of the UNC to display users a more common
|
||||||
|
// path on windows systems.
|
||||||
|
// This is a workaround until this issue https://github.com/rust-lang/rust/issues/42869 was fixed.
|
||||||
|
const LOCAL_UNC: &str = "\\\\?\\";
|
||||||
|
|
||||||
// Given a path, return true if it is a directory and it doesn't have any
|
// Given a path, return true if it is a directory and it doesn't have any
|
||||||
// non-hidden files, otherwise return false (path is assumed to exist)
|
// non-hidden files, otherwise return false (path is assumed to exist)
|
||||||
pub fn is_directory_quasi_empty(path: &Path) -> Result<bool> {
|
pub fn is_directory_quasi_empty(path: &Path) -> Result<bool> {
|
||||||
@ -56,6 +66,15 @@ pub fn is_directory_quasi_empty(path: &Path) -> Result<bool> {
|
|||||||
Ok(false)
|
Ok(false)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Remove the unc part of a windows path
|
||||||
|
fn strip_unc(path: &PathBuf) -> String {
|
||||||
|
let path_to_refine = path.to_str().unwrap();
|
||||||
|
match path_to_refine.strip_prefix(LOCAL_UNC) {
|
||||||
|
Some(path_stripped) => path_stripped.to_string(),
|
||||||
|
None => path_to_refine.to_string(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn create_new_project(name: &str, force: bool) -> Result<()> {
|
pub fn create_new_project(name: &str, force: bool) -> Result<()> {
|
||||||
let path = Path::new(name);
|
let path = Path::new(name);
|
||||||
|
|
||||||
@ -90,7 +109,10 @@ pub fn create_new_project(name: &str, force: bool) -> Result<()> {
|
|||||||
populate(&path, compile_sass, &config)?;
|
populate(&path, compile_sass, &config)?;
|
||||||
|
|
||||||
println!();
|
println!();
|
||||||
console::success(&format!("Done! Your site was created in {:?}", canonicalize(path).unwrap()));
|
console::success(&format!(
|
||||||
|
"Done! Your site was created in {}",
|
||||||
|
strip_unc(&canonicalize(path).unwrap())
|
||||||
|
));
|
||||||
println!();
|
println!();
|
||||||
console::info(
|
console::info(
|
||||||
"Get started by moving into the directory and using the built-in server: `zola serve`",
|
"Get started by moving into the directory and using the built-in server: `zola serve`",
|
||||||
@ -120,6 +142,7 @@ mod tests {
|
|||||||
use super::*;
|
use super::*;
|
||||||
use std::env::temp_dir;
|
use std::env::temp_dir;
|
||||||
use std::fs::{create_dir, remove_dir, remove_dir_all};
|
use std::fs::{create_dir, remove_dir, remove_dir_all};
|
||||||
|
use std::path::Path;
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn init_empty_directory() {
|
fn init_empty_directory() {
|
||||||
@ -225,4 +248,47 @@ mod tests {
|
|||||||
|
|
||||||
remove_dir_all(&dir).unwrap();
|
remove_dir_all(&dir).unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn strip_unc_test() {
|
||||||
|
let mut dir = temp_dir();
|
||||||
|
dir.push("new_project");
|
||||||
|
if dir.exists() {
|
||||||
|
remove_dir_all(&dir).expect("Could not free test directory");
|
||||||
|
}
|
||||||
|
create_dir(&dir).expect("Could not create test directory");
|
||||||
|
if cfg!(target_os = "windows") {
|
||||||
|
assert_eq!(
|
||||||
|
strip_unc(&canonicalize(Path::new(&dir)).unwrap()),
|
||||||
|
"C:\\Users\\VssAdministrator\\AppData\\Local\\Temp\\new_project"
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
assert_eq!(
|
||||||
|
strip_unc(&canonicalize(Path::new(&dir)).unwrap()),
|
||||||
|
canonicalize(Path::new(&dir)).unwrap().to_str().unwrap().to_string()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
remove_dir_all(&dir).unwrap();
|
||||||
|
}
|
||||||
|
|
||||||
|
// If the following test fails it means that the canonicalize function is fixed and strip_unc
|
||||||
|
// function/workaround is not anymore required.
|
||||||
|
// See issue https://github.com/rust-lang/rust/issues/42869 as a reference.
|
||||||
|
#[test]
|
||||||
|
#[cfg(target_os = "windows")]
|
||||||
|
fn strip_unc_required_test() {
|
||||||
|
let mut dir = temp_dir();
|
||||||
|
dir.push("new_project");
|
||||||
|
if dir.exists() {
|
||||||
|
remove_dir_all(&dir).expect("Could not free test directory");
|
||||||
|
}
|
||||||
|
create_dir(&dir).expect("Could not create test directory");
|
||||||
|
assert_eq!(
|
||||||
|
canonicalize(Path::new(&dir)).unwrap().to_str().unwrap(),
|
||||||
|
"\\\\?\\C:\\Users\\VssAdministrator\\AppData\\Local\\Temp\\new_project"
|
||||||
|
);
|
||||||
|
|
||||||
|
remove_dir_all(&dir).unwrap();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user