From e2730a9990e13803f6fd6f3c7a6942e64b833f5f Mon Sep 17 00:00:00 2001 From: Genny Date: Tue, 23 Nov 2021 00:57:05 -0600 Subject: Collapse extension enum into block --- gifprobe/src/main.rs | 177 ++++++++++++++++++++++++++------------------------- 1 file changed, 89 insertions(+), 88 deletions(-) (limited to 'gifprobe') diff --git a/gifprobe/src/main.rs b/gifprobe/src/main.rs index 3af9a50..35a137f 100644 --- a/gifprobe/src/main.rs +++ b/gifprobe/src/main.rs @@ -1,107 +1,108 @@ use std::{convert::TryInto, fs::File, io::Write, path::Path}; use gifed::{ - block::{ - extension::{Extension, GraphicControl}, - ColorTable, IndexedImage, Version, - }, - reader::GifReader, - writer::{GifBuilder, ImageBuilder}, - Color, + block::{extension::GraphicControl, Block, ColorTable, IndexedImage, Version}, + reader::GifReader, + writer::{GifBuilder, ImageBuilder}, + Color, }; use owo_colors::OwoColorize; fn main() { - let file = if let Some(file) = std::env::args().skip(1).next() { - file - } else { - println!("usage: gifprobe file.gif"); - return; - }; + let file = if let Some(file) = std::env::args().skip(1).next() { + file + } else { + println!("usage: gifprobe file.gif"); + return; + }; - let gif = GifReader::file(&file).unwrap(); + let gif = GifReader::file(&file).unwrap(); - println!("Version {}", gif.header.yellow()); - println!( - "Logical Screen Descriptor\n\tDimensions {}x{}", - gif.screen_descriptor.width.yellow(), - gif.screen_descriptor.height.yellow() - ); + println!("Version {}", gif.header.yellow()); + println!( + "Logical Screen Descriptor\n\tDimensions {}x{}", + gif.screen_descriptor.width.yellow(), + gif.screen_descriptor.height.yellow() + ); - if gif.screen_descriptor.color_table_present() { - println!( - "\tGlobal Color Table Present {}\n\tGlobal Color Table Size {}", - "Yes".green(), - gif.screen_descriptor.color_table_len().green() - ); - } else { - println!( - "\tGlobal Color Table Present {}\n\tGlobal Color Table Size {}", - "No".red(), - gif.screen_descriptor.color_table_len().red() - ); - } + if gif.screen_descriptor.color_table_present() { + println!( + "\tGlobal Color Table Present {}\n\tGlobal Color Table Size {}", + "Yes".green(), + gif.screen_descriptor.color_table_len().green() + ); + } else { + println!( + "\tGlobal Color Table Present {}\n\tGlobal Color Table Size {}", + "No".red(), + gif.screen_descriptor.color_table_len().red() + ); + } - let mut img_count = 0; - let mut hundreths: usize = 0; + let mut img_count = 0; + let mut hundreths: usize = 0; - for block in gif.blocks { - match block { - gifed::block::Block::IndexedImage(img) => { - describe_image(&img); - img_count += 1; - } - gifed::block::Block::Extension(ext) => match ext { - gifed::block::extension::Extension::GraphicControl(gce) => { - hundreths += gce.delay_time() as usize; + for block in gif.blocks { + match block { + Block::IndexedImage(img) => { + describe_image(&img); + img_count += 1; + } + Block::GraphicControlExtension(gce) => { + hundreths += gce.delay_time() as usize; - println!( - "Graphic Control Extension\n\tDelay Time {}\n\tDispose {}", - format!("{}s", gce.delay_time() as f32 / 100.0).yellow(), - gce.disposal_method().unwrap().yellow() - ) - } - gifed::block::extension::Extension::Looping(_) => todo!(), - gifed::block::extension::Extension::Comment(cmt) => { - println!("Comment Extension\n\tLength {}", cmt.len()) - } - gifed::block::extension::Extension::Application(app) => { - let auth = app.authentication_code(); - println!("Application Extension\n\tIdentifier {}\n\tAuthentication {:02X} {:02X} {:02X}",app.identifier().yellow(), auth[0].yellow(), auth[1].yellow(), auth[2].yellow()); - } - }, - } - } + println!( + "Graphic Control Extension\n\tDelay Time {}\n\tDispose {}", + format!("{}s", gce.delay_time() as f32 / 100.0).yellow(), + gce.disposal_method().unwrap().yellow() + ) + } + Block::LoopingExtension(_) => todo!(), + Block::CommentExtension(cmt) => { + println!("Comment Extension\n\tLength {}", cmt.len()) + } + Block::ApplicationExtension(app) => { + let auth = app.authentication_code(); + println!( + "Application Extension\n\tIdentifier {}\n\tAuthentication {:02X} {:02X} {:02X}", + app.identifier().yellow(), + auth[0].yellow(), + auth[1].yellow(), + auth[2].yellow() + ); + } + } + } - println!( - "{} is {}.{}s long and has {} frames", - file, - hundreths / 100, - hundreths % 100, - img_count - ); + println!( + "{} is {}.{}s long and has {} frames", + file, + hundreths / 100, + hundreths % 100, + img_count + ); } fn describe_image(bli: &IndexedImage) { - println!( - "Image\n\tOffset {}x{}\n\tDimensions {}x{}", - bli.image_descriptor.left.yellow(), - bli.image_descriptor.top.yellow(), - bli.image_descriptor.width.yellow(), - bli.image_descriptor.height.yellow(), - ); + println!( + "Image\n\tOffset {}x{}\n\tDimensions {}x{}", + bli.image_descriptor.left.yellow(), + bli.image_descriptor.top.yellow(), + bli.image_descriptor.width.yellow(), + bli.image_descriptor.height.yellow(), + ); - if bli.image_descriptor.color_table_present() { - println!( - "\tLocal Color Table Present {}\n\tLocal Color Table Size {}", - "Yes".green(), - bli.image_descriptor.color_table_size().green() - ); - } else { - println!( - "\tLocal Color Table Present {}\n\tLocal Color Table Size {}", - "No".red(), - bli.image_descriptor.color_table_size().red() - ); - } + if bli.image_descriptor.color_table_present() { + println!( + "\tLocal Color Table Present {}\n\tLocal Color Table Size {}", + "Yes".green(), + bli.image_descriptor.color_table_size().green() + ); + } else { + println!( + "\tLocal Color Table Present {}\n\tLocal Color Table Size {}", + "No".red(), + bli.image_descriptor.color_table_size().red() + ); + } } -- cgit 1.4.1-3-g733a5