1
0
mirror of https://github.com/jht5945/rust_util.git synced 2026-01-14 00:00:04 +08:00

Compare commits

..

3 Commits

Author SHA1 Message Date
53720edc00 feat: v0.6.34 2021-05-28 01:35:27 +08:00
e89d6be38d feat: cmd 2021-05-28 01:00:43 +08:00
7e752d95b5 feat: cmd 2021-05-28 00:59:07 +08:00
4 changed files with 44 additions and 4 deletions

View File

@@ -1,6 +1,6 @@
[package]
name = "rust_util"
version = "0.6.33"
version = "0.6.35"
authors = ["Hatter Jiang <jht5945@gmail.com>"]
edition = "2018"
description = "Hatter's Rust Util"

View File

@@ -26,7 +26,9 @@ pub mod util_tlv;
($c:expr, $t:expr, $f:expr) => ( if $c { $t } else { $f } )
}
#[macro_export] macro_rules! information {
($($arg:tt)+) => ( rust_util::util_msg::print_info(&format!($($arg)+)); )
($($arg:tt)+) => ( rust_util::util_msg::when(rust_util::util_msg::MessageType::INFO, || {
rust_util::util_msg::print_info(&format!($($arg)+));
}); )
}
#[macro_export] macro_rules! success {
($($arg:tt)+) => ( rust_util::util_msg::print_ok(&format!($($arg)+)); )
@@ -38,7 +40,9 @@ pub mod util_tlv;
($($arg:tt)+) => ( rust_util::util_msg::print_error(&format!($($arg)+)); )
}
#[macro_export] macro_rules! debugging {
($($arg:tt)+) => ( rust_util::util_msg::print_debug(&format!($($arg)+)); )
($($arg:tt)+) => ( rust_util::util_msg::when(rust_util::util_msg::MessageType::DEBUG, || {
rust_util::util_msg::print_debug(&format!($($arg)+))
}); )
}
#[macro_export] macro_rules! failure_and_exit {
($($arg:tt)+) => ( {

View File

@@ -1,5 +1,35 @@
use std::io::{self, Error, ErrorKind};
use std::process::{Command, ExitStatus};
use std::process::{Command, ExitStatus, Output};
use crate::util_msg::{print_debug, print_error, MessageType};
pub fn run_command_or_exit(cmd: &str, args: &[&str]) -> Output {
let mut c = Command::new(cmd);
c.args(args);
crate::util_msg::when(MessageType::DEBUG, || {
print_debug(&format!("Run command: {:?}", c));
});
let output = c.output();
match output {
Err(e) => {
print_error(&format!("Run command: {:?}, failed: {}", c, e));
std::process::exit(-1);
},
Ok(output) => {
if !output.status.success() {
print_error(&format!(r##"Run command failed, code: {:?}
-----std out---------------------------------------------------------------
{}
-----std err---------------------------------------------------------------
{}
---------------------------------------------------------------------------"##,
output.status.code(),
String::from_utf8_lossy(&output.stdout),
String::from_utf8_lossy(&output.stderr)));
}
output
}
}
}
pub fn run_command_and_wait(cmd: &mut Command) -> io::Result<ExitStatus> {
cmd.spawn()?.wait()

View File

@@ -92,6 +92,12 @@ pub fn is_logger_level_enabled(mt: MessageType) -> bool {
mt.get_u8_value() >= logger_level.get_u8_value()
}
pub fn when<F>(mt: MessageType, f: F) where F: Fn() -> () {
if is_logger_level_enabled(mt) {
f();
}
}
pub fn print_message(mt: MessageType, message: &str) {
if is_logger_level_enabled(mt) {
match mt {