# HG changeset patch # User Emmanuel Gil Peyrot # Date 1580316325 -3600 # Node ID 5e5e7136ac9257e4a1871c50f51f61201554c92e # Parent eab7dde1164f32a9ee0a75cfd5670bca76f1606e examples: Return a Result for load_file_into_vec() diff --git a/examples/anmrenderer.rs b/examples/anmrenderer.rs --- a/examples/anmrenderer.rs +++ b/examples/anmrenderer.rs @@ -107,7 +107,7 @@ fn main() { let script: u8 = args[2].parse().expect("number"); // Open the ANM file. - let buf = load_file_into_vec(anm_filename); + let buf = load_file_into_vec(anm_filename).unwrap(); let (_, mut anms) = Anm0::from_slice(&buf).unwrap(); let anm0 = anms.pop().unwrap(); diff --git a/examples/common.rs b/examples/common.rs --- a/examples/common.rs +++ b/examples/common.rs @@ -4,15 +4,15 @@ use luminance::texture::{Dim2, Flat, Sam use luminance_glfw::GlfwSurface; use touhou::th06::anm0::Anm0; use std::fs::File; -use std::io::{BufReader, Read}; +use std::io::{self, BufReader, Read}; use std::path::Path; -pub fn load_file_into_vec>(filename: P) -> Vec { - let file = File::open(filename).unwrap(); +pub fn load_file_into_vec>(filename: P) -> io::Result> { + let file = File::open(filename)?; let mut file = BufReader::new(file); let mut buf = vec![]; - file.read_to_end(&mut buf).unwrap(); - buf + file.read_to_end(&mut buf)?; + Ok(buf) } pub enum LoadedTexture { diff --git a/examples/eclrenderer.rs b/examples/eclrenderer.rs --- a/examples/eclrenderer.rs +++ b/examples/eclrenderer.rs @@ -101,11 +101,11 @@ fn main() { let sub: u16 = args[4].parse().expect("number"); // Open the ECL file. - let buf = load_file_into_vec(ecl_filename); + let buf = load_file_into_vec(ecl_filename).unwrap(); let (_, ecl) = Ecl::from_slice(&buf).unwrap(); // Open the ANM file. - let buf = load_file_into_vec(anm_filename); + let buf = load_file_into_vec(anm_filename).unwrap(); let (_, mut anms) = Anm0::from_slice(&buf).unwrap(); let anm0 = anms.pop().unwrap(); let anm0 = Rc::new(RefCell::new([anm0.clone(), anm0])); diff --git a/examples/stagerunner.rs b/examples/stagerunner.rs --- a/examples/stagerunner.rs +++ b/examples/stagerunner.rs @@ -100,20 +100,20 @@ fn main() { let rank: Rank = args[3].parse().expect("rank"); // Open the ECL file. - let buf = load_file_into_vec(directory.join(format!("ecldata{}.ecl", stage_number))); + let buf = load_file_into_vec(directory.join(format!("ecldata{}.ecl", stage_number))).unwrap(); let (_, ecl) = Ecl::from_slice(&buf).unwrap(); assert_eq!(ecl.mains.len(), 1); let main = ecl.mains[0].clone(); // Open the ANM file. let anm_filename = directory.join(format!("stg{}enm.anm", stage_number)); - let buf = load_file_into_vec(&anm_filename); + let buf = load_file_into_vec(&anm_filename).unwrap(); let (_, mut anms) = Anm0::from_slice(&buf).unwrap(); let anm0 = anms.pop().unwrap(); // Open the second ANM file. let anm2_filename = directory.join(format!("stg{}enm2.anm", stage_number)); - let buf = load_file_into_vec(&anm2_filename); + let buf = load_file_into_vec(&anm2_filename).unwrap(); let (_, mut anms) = Anm0::from_slice(&buf).unwrap(); let anm0_bis = anms.pop().unwrap(); diff --git a/examples/stdrenderer.rs b/examples/stdrenderer.rs --- a/examples/stdrenderer.rs +++ b/examples/stdrenderer.rs @@ -118,11 +118,11 @@ fn main() { let anm_filename = Path::new(&args[2]); // Open the STD file. - let buf = load_file_into_vec(std_filename); + let buf = load_file_into_vec(std_filename).unwrap(); let (_, stage) = Stage::from_slice(&buf).unwrap(); // Open the ANM file. - let buf = load_file_into_vec(anm_filename); + let buf = load_file_into_vec(anm_filename).unwrap(); let (_, mut anms) = Anm0::from_slice(&buf).unwrap(); let anm0 = anms.pop().unwrap();