@ -47,7 +47,10 @@ fn get_file_hash(path: &Path) -> Result<String, Error> {
/**
/**
* Put an image buffer in the cache
* Put an image buffer in the cache
* /
* /
pub fn put_image_in_cache ( path : & Path , size : u32 , image : & ImageBuffer < image ::Luma < u8 > , Vec < u8 > > ) {
pub fn put_image_in_cache ( path : & Path ,
size : u32 ,
image : & ImageBuffer < image ::Luma < u8 > , Vec < u8 > > )
-> Result < bool , Error > {
let hash = get_file_hash ( & path ) ;
let hash = get_file_hash ( & path ) ;
match hash {
match hash {
Ok ( sha1 ) = > {
Ok ( sha1 ) = > {
@ -61,11 +64,18 @@ pub fn put_image_in_cache(path: &Path, size: u32, image: &ImageBuffer<image::Lum
// Save the file into the cache
// Save the file into the cache
match image . save ( cached_path ) {
match image . save ( cached_path ) {
Ok ( _ ) = > { }
Ok ( _ ) = > { }
Err ( e ) = > println ! ( "Error: {}" , e ) ,
Err ( e ) = > {
println ! ( "Error: {}" , e ) ;
return Err ( e ) ;
}
}
}
}
Err ( e ) = > println ! ( "Error: {}" , e ) ,
}
}
Err ( e ) = > {
println ! ( "Error: {}" , e ) ;
return Err ( e ) ;
}
}
Ok ( true )
}
}
/**
/**
@ -74,7 +84,8 @@ pub fn put_image_in_cache(path: &Path, size: u32, image: &ImageBuffer<image::Lum
pub fn put_matrix_in_cache ( path : & Path ,
pub fn put_matrix_in_cache ( path : & Path ,
size : u32 ,
size : u32 ,
extension : & str ,
extension : & str ,
file_contents : & Vec < Vec < f64 > > ) {
file_contents : & Vec < Vec < f64 > > )
-> Result < bool , Error > {
let hash = get_file_hash ( & path ) ;
let hash = get_file_hash ( & path ) ;
match hash {
match hash {
Ok ( sha1 ) = > {
Ok ( sha1 ) = > {
@ -91,20 +102,29 @@ pub fn put_matrix_in_cache(path: &Path,
let desire_len = row_str . len ( ) - 1 ;
let desire_len = row_str . len ( ) - 1 ;
row_str . truncate ( desire_len ) ;
row_str . truncate ( desire_len ) ;
row_str . push_str ( "\n" ) ;
row_str . push_str ( "\n" ) ;
compressor . write ( & row_str . into_bytes ( ) ) ;
try ! ( compressor . write ( & row_str . into_bytes ( ) ) ) ;
}
}
let compressed_matrix = match compressor . finish ( ) {
let compressed_matrix = match compressor . finish ( ) {
Ok ( data ) = > data ,
Ok ( data ) = > data ,
Err ( e ) = > { println ! ( "Unable to compress matrix data: {}" , e ) ; return } ,
Err ( e ) = > {
println ! ( "Unable to compress matrix data: {}" , e ) ;
return Err ( e ) ;
}
} ;
} ;
file . write ( & compressed_matrix ) ;
try ! ( file . write ( & compressed_matrix ) ) ;
file . flush ( ) ;
try ! ( file . flush ( ) ) ;
}
Err ( e ) = > {
return Err ( e ) ;
}
}
}
Err ( _ ) = > { }
}
}
Err ( e ) = > {
println ! ( "Error: {}" , e ) ;
return Err ( e ) ;
}
}
Err ( e ) = > println ! ( "Error: {}" , e ) ,
}
}
Ok ( true )
}
}
/**
/**
@ -154,18 +174,26 @@ pub fn get_matrix_from_cache(path: &Path, size: u32, extension: &str) -> Option<
let cached_path = Path ::new ( & cache_path_str ) ;
let cached_path = Path ::new ( & cache_path_str ) ;
// Try to open, if it does, then we can read the image in
// Try to open, if it does, then we can read the image in
match File ::open ( & cached_path ) {
match File ::open ( & cached_path ) {
Ok ( mut file ) = > {
Ok ( file ) = > {
let mut compressed_matrix_data : Vec < u8 > = Vec ::new ( ) ;
let mut decoder = ZlibDecoder ::new ( & file ) ;
let mut decoder = ZlibDecoder ::new ( & file ) ;
let mut matrix_data_str = String ::new ( ) ;
let mut matrix_data_str = String ::new ( ) ;
match decoder . read_to_string ( & mut matrix_data_str ) {
match decoder . read_to_string ( & mut matrix_data_str ) {
Ok ( _ ) = > { } ,
Ok ( _ ) = > { }
Err ( e ) = > { println ! ( "Unable to decompress matrix: {}" , e ) ; return None }
Err ( e ) = > {
println ! ( "Unable to decompress matrix: {}" , e ) ;
return None ;
}
} ;
} ;
// convert the matrix
// convert the matrix
let matrix : Vec < Vec < f64 > > = matrix_data_str . trim ( ) . split ( "\n" )
let matrix : Vec < Vec < f64 > > = matrix_data_str . trim ( )
. map ( | line | line . split ( "," )
. split ( "\n" )
. map ( | f | f64 ::from_str ( f ) . unwrap ( ) ) . collect ( ) )
. map ( | line | {
line . split ( "," )
. map ( | f | {
f64 ::from_str ( f ) . unwrap ( )
} )
. collect ( )
} )
. collect ( ) ;
. collect ( ) ;
Some ( matrix )
Some ( matrix )
xxxxxxxxxx