From a33133ff12313bf415adb7f0432b12d9238ae5b7 Mon Sep 17 00:00:00 2001 From: Dmitry Brant Date: Sat, 30 Jan 2016 15:48:41 -0500 Subject: [PATCH] Improve BPG detection. --- src/Makefile.am | 1 + src/file_bpg.c | 54 ++++++++++++++++++++++++------------------------- src/file_list.c | 2 ++ 3 files changed, 29 insertions(+), 28 deletions(-) diff --git a/src/Makefile.am b/src/Makefile.am index b0ea124b..c5385dcf 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -64,6 +64,7 @@ file_C = filegen.c \ file_bkf.c \ file_bld.c \ file_bmp.c \ + file_bpg.c \ file_bz2.c \ file_cab.c \ file_caf.c \ diff --git a/src/file_bpg.c b/src/file_bpg.c index eb7bd9cb..a74e3033 100644 --- a/src/file_bpg.c +++ b/src/file_bpg.c @@ -3,7 +3,7 @@ File: file_bpg.c Copyright (C) 1998-2007 Christophe GRENIER - Contribution by Dmitry Brant + Copyright (C) 2016 Dmitry Brant This software is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -30,27 +30,18 @@ #include #include "types.h" #include "filegen.h" -#include "common.h" static void register_header_check_bpg(file_stat_t *file_stat); -static int header_check_bpg(const unsigned char *buffer, const unsigned int buffer_size, const unsigned int safe_header_only, const file_recovery_t *file_recovery, file_recovery_t *file_recovery_new); const file_hint_t file_hint_bpg= { .extension="bpg", - .description="Better Portable Graphics (BPG) image", + .description="Better Portable Graphics image", .max_filesize=PHOTOREC_MAX_FILE_SIZE, .recover=1, .enable_by_default=1, .register_header_check=®ister_header_check_bpg }; -static const unsigned char bpg_header[4]= {'B','P','G',0xFB}; - -static void register_header_check_bpg(file_stat_t *file_stat) -{ - register_header_check(0, bpg_header, sizeof(bpg_header), &header_check_bpg, file_stat); -} - static int getue32(const unsigned char *buffer, const unsigned int buffer_size, unsigned int *buf_ptr) { unsigned int value = 0; @@ -58,7 +49,8 @@ static int getue32(const unsigned char *buffer, const unsigned int buffer_size, int bitsRead = 0; while (*buf_ptr < buffer_size) { - b = buffer[*buf_ptr++]; + b = buffer[*buf_ptr]; + *buf_ptr = *buf_ptr + 1; value <<= 7; value |= (b & 0x7F); if ((b & 0x80) == 0) @@ -72,20 +64,26 @@ static int getue32(const unsigned char *buffer, const unsigned int buffer_size, static int header_check_bpg(const unsigned char *buffer, const unsigned int buffer_size, const unsigned int safe_header_only, const file_recovery_t *file_recovery, file_recovery_t *file_recovery_new) { - if(buffer[0]=='B' && buffer[1]=='P' && buffer[2]=='G' && buffer[3]==0xFB) - { - unsigned int buf_ptr = 6; - reset_file_recovery(file_recovery_new); - file_recovery_new->extension=file_hint_bpg.extension; - file_recovery_new->min_filesize=100; - // get image width, and throw it away - getue32(buffer, buffer_size, &buf_ptr); - // get image height, and throw it away - getue32(buffer, buffer_size, &buf_ptr); - file_recovery_new->calculated_file_size=(uint64_t)getue32(buffer, buffer_size, &buf_ptr); - file_recovery_new->data_check=&data_check_size; - file_recovery_new->file_check=&file_check_size; - return 1; - } - return 0; + unsigned int buf_ptr = 6; + // get image width, and throw it away + int width = getue32(buffer, buffer_size, &buf_ptr); + printf(">>>> width...%d\n", width); + // get image height, and throw it away + int height = getue32(buffer, buffer_size, &buf_ptr); + printf(">>>> height...%d\n", height); + int size = getue32(buffer, buffer_size, &buf_ptr); + printf(">>>> size...%d\n", size); + + reset_file_recovery(file_recovery_new); + file_recovery_new->calculated_file_size=size; + file_recovery_new->data_check=&data_check_size; + file_recovery_new->file_check=&file_check_size; + file_recovery_new->extension=file_hint_bpg.extension; + return 1; +} + +static void register_header_check_bpg(file_stat_t *file_stat) +{ + static const unsigned char bpg_header[4]= {'B','P','G',0xFB}; + register_header_check(0, bpg_header,sizeof(bpg_header), &header_check_bpg, file_stat); } diff --git a/src/file_list.c b/src/file_list.c index 13691272..9164a637 100644 --- a/src/file_list.c +++ b/src/file_list.c @@ -65,6 +65,7 @@ extern const file_hint_t file_hint_binvox; extern const file_hint_t file_hint_bkf; extern const file_hint_t file_hint_blend; extern const file_hint_t file_hint_bmp; +extern const file_hint_t file_hint_bpg; extern const file_hint_t file_hint_bz2; extern const file_hint_t file_hint_cab; extern const file_hint_t file_hint_caf; @@ -374,6 +375,7 @@ file_enable_t list_file_enable[]= { .enable=0, .file_hint=&file_hint_bkf }, { .enable=0, .file_hint=&file_hint_blend }, { .enable=0, .file_hint=&file_hint_bmp }, + { .enable=0, .file_hint=&file_hint_bpg }, { .enable=0, .file_hint=&file_hint_bz2 }, { .enable=0, .file_hint=&file_hint_cab }, { .enable=0, .file_hint=&file_hint_caf },