1
0
mirror of https://github.com/jht5945/buildj.git synced 2025-12-27 17:20:06 +08:00

update use of new_box_error

This commit is contained in:
2019-08-23 01:42:00 +08:00
parent 335f66400d
commit 0245dde9fa
2 changed files with 17 additions and 17 deletions

View File

@@ -8,12 +8,12 @@ use std::{
};
use rust_util::{
new_box_error,
XResult,
new_box_ioerror,
util_msg::{
print_message,
MessageType,
},
XResult,
util_io::*,
};
@@ -42,7 +42,7 @@ pub fn is_buildin_args(args: &Vec<String>) -> bool {
pub fn verify_file_integrity(integrity: &str, file_name: &str) -> XResult<bool> {
match integrity.find('-') {
None => Err(new_box_error(&format!("Not supported integrigty: {}", integrity))),
None => Err(new_box_ioerror(&format!("Not supported integrigty: {}", integrity))),
Some(index) => {
let digest_hex = &integrity[index+1..];
let calc_digest_hex = match &integrity[0..index] {
@@ -50,7 +50,7 @@ pub fn verify_file_integrity(integrity: &str, file_name: &str) -> XResult<bool>
"sha512:hex" => calc_file_digest(&mut Sha512::new(), "SHA512", file_name)?,
"sha1:hex" => calc_file_digest(&mut Sha1::new(), "SHA1", file_name)?,
"md5:hex" => calc_file_digest(&mut Md5::new(), "MD5", file_name)?,
_ => return Err(new_box_error(&format!("Not supported integrigty: {}", integrity))),
_ => return Err(new_box_ioerror(&format!("Not supported integrigty: {}", integrity))),
};
let integrity_verify_result = digest_hex == calc_digest_hex.as_str();
if ! integrity_verify_result {
@@ -92,9 +92,9 @@ pub fn calc_file_digest(digest: &mut Digest, digest_alg: &str, file_name: &str)
pub fn get_user_home() -> XResult<String> {
match dirs::home_dir() {
None => Err(new_box_error("Home dir not found!")),
None => Err(new_box_ioerror("Home dir not found!")),
Some(home_dir_o) => match home_dir_o.to_str() {
None => Err(new_box_error("Home dir not found!")),
None => Err(new_box_ioerror("Home dir not found!")),
Some(home_dir_str) => Ok(home_dir_str.to_string()),
},
}
@@ -122,7 +122,7 @@ pub fn extract_package_and_wait(dir: &str, file_name: &str) -> XResult<()> {
cmd = Command::new("tar");
cmd.arg("-xzvf");
} else {
return Err(new_box_error(&format!("Unknown file type: {}", file_name)));
return Err(new_box_ioerror(&format!("Unknown file type: {}", file_name)));
}
cmd.arg(file_name).current_dir(dir).spawn()?.wait()?;
Ok(())

View File

@@ -6,13 +6,13 @@ use std::{
use super::{
http,
rust_util::{
new_box_error,
XResult,
new_box_ioerror,
util_os::is_macos_or_linux,
util_msg::{
print_message,
MessageType,
},
XResult,
},
local_util::{self, *},
misc::*,
@@ -155,7 +155,7 @@ pub fn get_tool_package_secret() -> XResult<String> {
let build_js_auth_token = &standard_config_object["build.js"]["auth_token"];
if build_js_auth_token.is_null() {
Err(new_box_error("Standard json#build.js#auth_token is null."))
Err(new_box_ioerror("Standard json#build.js#auth_token is null."))
} else {
Ok(build_js_auth_token.to_string())
}
@@ -171,12 +171,12 @@ pub fn set_tool_package_secret(secret: &str) -> XResult<()> {
"auth_token" => secret, }
}, 4)) {
Ok(_) => Ok(()),
Err(err) => Err(new_box_error(&format!("Write config failed: {}, error message: {}", standard_config_file, err))),
Err(err) => Err(new_box_ioerror(&format!("Write config failed: {}, error message: {}", standard_config_file, err))),
}
},
Ok(f) => {
if ! f.is_file() {
return Err(new_box_error(&format!("Config is not a file: {}", standard_config_file)));
return Err(new_box_ioerror(&format!("Config is not a file: {}", standard_config_file)));
}
let standard_config_json = fs::read_to_string(&standard_config_file)?;
let mut standard_config_object = json::parse(&standard_config_json)?;
@@ -189,7 +189,7 @@ pub fn set_tool_package_secret(secret: &str) -> XResult<()> {
}
match fs::write(&standard_config_file, json::stringify_pretty(standard_config_object, 4)) {
Ok(_) => Ok(()),
Err(err) => Err(new_box_error(&format!("Write config failed: {}, error message: {}", &standard_config_file, err))),
Err(err) => Err(new_box_ioerror(&format!("Write config failed: {}, error message: {}", &standard_config_file, err))),
}
}
}
@@ -237,20 +237,20 @@ pub fn get_and_extract_tool_package(base_dir: &str, dir_with_name: bool, name: &
print_message(MessageType::DEBUG, &format!("Get tool {}:{}, result JSON: {}", name, version, json::stringify_pretty(build_json_object.clone(), 4)));
}
if build_json_object["status"] != 200 {
return Err(new_box_error(&format!("Error in get tool package detail: {}", build_json_object["message"])));
return Err(new_box_ioerror(&format!("Error in get tool package detail: {}", build_json_object["message"])));
}
let data = &build_json_object["data"];
let integrity = &data["integrity"];
let url = &data["url"];
let name = &data["name"];
if integrity.is_null() || url.is_null() || name.is_null() {
return Err(new_box_error(&format!("Parse tool package detail failed: {}", tool_package_detail)));
return Err(new_box_ioerror(&format!("Parse tool package detail failed: {}", tool_package_detail)));
}
let n = data["n"].to_string();
let v = data["v"].to_string();
if extract_match && version != &v {
return Err(new_box_error(&format!("Required version not match, {}: {} vs {}", name, version, &v)));
return Err(new_box_ioerror(&format!("Required version not match, {}: {} vs {}", name, version, &v)));
}
let mut target_base_dir = String::new();
@@ -269,7 +269,7 @@ pub fn get_and_extract_tool_package(base_dir: &str, dir_with_name: bool, name: &
if local_util::verify_file_integrity(&integrity.to_string(), &target_file_name)? {
print_message(MessageType::OK, "Verify integrity success.");
} else {
return Err(new_box_error(&format!("Verify integrity failed!")));
return Err(new_box_ioerror(&format!("Verify integrity failed!")));
}
print_message(MessageType::INFO, &format!("Start extract file: {}", &target_file_name));