mirror of
				https://github.com/kata-containers/kata-containers.git
				synced 2025-10-24 21:51:37 +00:00 
			
		
		
		
	agent: use chain of Result to avoid early return
Use rust `Result`'s `or_else`/`and_then` can write clean codes. And can avoid early return by check wether the `Result` is `Ok` or `Err`. Signed-off-by: bin liu <bin@hyper.sh>
This commit is contained in:
		| @@ -222,23 +222,17 @@ fn get_bool_value(param: &str) -> Result<bool> { | ||||
|  | ||||
|     let v = fields[1]; | ||||
|  | ||||
|     // bool | ||||
|     let t: std::result::Result<bool, std::str::ParseBoolError> = v.parse(); | ||||
|     if t.is_ok() { | ||||
|         return Ok(t.unwrap()); | ||||
|     } | ||||
|  | ||||
|     // integer | ||||
|     let i: std::result::Result<u64, std::num::ParseIntError> = v.parse(); | ||||
|     if i.is_err() { | ||||
|         return Ok(false); | ||||
|     } | ||||
|  | ||||
|     // first try to parse as bool value | ||||
|     v.parse::<bool>().or_else(|_err1| { | ||||
|         // then try to parse as integer value | ||||
|         v.parse::<u64>().or_else(|_err2| Ok(0)).and_then(|v| { | ||||
|             // only `0` returns false, otherwise returns true | ||||
|     Ok(match i.unwrap() { | ||||
|             Ok(match v { | ||||
|                 0 => false, | ||||
|                 _ => true, | ||||
|             }) | ||||
|         }) | ||||
|     }) | ||||
| } | ||||
|  | ||||
| fn get_container_pipe_size(param: &str) -> Result<i32> { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user