/* * Copyright 2020 Fluence Labs Limited * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ use fluence_sdk_macro::fce; use serde::Serialize; use serde::Deserialize; pub const SUCCESS_CODE: i32 = 0; /// Describes result of calling a CLI service. #[fce] #[derive(Clone, PartialEq, Default, Eq, Debug, Serialize, Deserialize)] pub struct Result { /// Return process exit code or host execution error code, where SUCCESS_CODE means success. pub ret_code: i32, /// Contains the string representation of an error, if ret_code != SUCCESS_CODE. pub error: String, /// The data that the process wrote to stdout. pub stdout: Vec, /// The data that the process wrote to stderr. pub stderr: Vec, } impl Result { /// Create a new failure MountedBinaryResult from the provided ret_code. pub fn from_error(ret_code: i32, error: impl Into) -> Self { Self { ret_code, error: error.into(), stdout: Vec::new(), stderr: Vec::new(), } } /// This function checks ret_code and returns either Ok if it was SUCCESS_CODE or Err otherwise. /// /// SAFETY: /// The function relies on both stdout and stderr to contain valid UTF8 string. pub unsafe fn into_std(self) -> std::result::Result { if self.ret_code == SUCCESS_CODE { Ok(String::from_utf8_unchecked(self.stdout)) } else { Err(String::from_utf8_unchecked(self.stderr)) } } }