mirror of
https://github.com/simon987/libscan.git
synced 2025-04-05 12:23:00 +00:00
Fix for segfault in some comic files
This commit is contained in:
parent
bcf3e4695b
commit
ee9c98b488
@ -12,6 +12,10 @@ void parse_comic(scan_comic_ctx_t *ctx, vfile_t *f, document_t *doc) {
|
|||||||
struct archive_entry *entry = NULL;
|
struct archive_entry *entry = NULL;
|
||||||
arc_data_t arc_data;
|
arc_data_t arc_data;
|
||||||
|
|
||||||
|
if (ctx->tn_size <= 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
int ret = arc_open(&arc_ctx, f, &a, &arc_data, TRUE);
|
int ret = arc_open(&arc_ctx, f, &a, &arc_data, TRUE);
|
||||||
if (ret != ARCHIVE_OK) {
|
if (ret != ARCHIVE_OK) {
|
||||||
CTX_LOG_ERRORF(f->filepath, "(cbr.c) [%d] %s", ret, archive_error_string(a))
|
CTX_LOG_ERRORF(f->filepath, "(cbr.c) [%d] %s", ret, archive_error_string(a))
|
||||||
@ -26,10 +30,10 @@ void parse_comic(scan_comic_ctx_t *ctx, vfile_t *f, document_t *doc) {
|
|||||||
const char *file_path = utf8_name == NULL ? archive_entry_pathname(entry) : utf8_name;
|
const char *file_path = utf8_name == NULL ? archive_entry_pathname(entry) : utf8_name;
|
||||||
|
|
||||||
char *p = strrchr(file_path, '.');
|
char *p = strrchr(file_path, '.');
|
||||||
if (p != NULL && strcmp(p, ".png") == 0 || strcmp(p, ".jpg") == 0 || strcmp(p, ".jpeg") == 0) {
|
if (p != NULL && (strcmp(p, ".png") == 0 || strcmp(p, ".jpg") == 0 || strcmp(p, ".jpeg") == 0)) {
|
||||||
size_t entry_size = archive_entry_size(entry);
|
size_t entry_size = archive_entry_size(entry);
|
||||||
void *buf = malloc(entry_size);
|
void *buf = malloc(entry_size);
|
||||||
int read = archive_read_data(a, buf, entry_size);
|
size_t read = archive_read_data(a, buf, entry_size);
|
||||||
|
|
||||||
if (read != entry_size) {
|
if (read != entry_size) {
|
||||||
const char *err_str = archive_error_string(a);
|
const char *err_str = archive_error_string(a);
|
||||||
|
@ -291,6 +291,19 @@ TEST(Comic, ComicCbr) {
|
|||||||
cleanup(&doc, &f);
|
cleanup(&doc, &f);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(Comic, ComicIssue160) {
|
||||||
|
vfile_t f;
|
||||||
|
document_t doc;
|
||||||
|
load_doc_file("libscan-test-files/test_files/ebook/comic-segfault-issue-160.cbr", &f, &doc);
|
||||||
|
|
||||||
|
int tn_size_saved = comic_ctx.tn_size;
|
||||||
|
comic_ctx.tn_size = 0;
|
||||||
|
parse_comic(&comic_ctx, &f, &doc);
|
||||||
|
comic_ctx.tn_size = tn_size_saved;
|
||||||
|
|
||||||
|
cleanup(&doc, &f);
|
||||||
|
}
|
||||||
|
|
||||||
TEST(Comic, ComicCbrAsIs) {
|
TEST(Comic, ComicCbrAsIs) {
|
||||||
vfile_t f;
|
vfile_t f;
|
||||||
document_t doc;
|
document_t doc;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user