summaryrefslogtreecommitdiffstats
path: root/libhb
diff options
context:
space:
mode:
authorSean McGovern <[email protected]>2016-07-07 21:19:38 -0400
committerSean McGovern <[email protected]>2016-07-11 23:05:34 -0400
commit7d4e3f9a0263391c3e236ed128268d9de94c4801 (patch)
tree4e4931ba98b1b22fc2d066f4d1de7b72db2a10a1 /libhb
parentb8bf66f0b15842ce240a3320ca4d23aaf8165bf0 (diff)
libhb: make preview reader and writer both more robust
Diffstat (limited to 'libhb')
-rw-r--r--libhb/hb.c46
1 files changed, 42 insertions, 4 deletions
diff --git a/libhb/hb.c b/libhb/hb.c
index eb62d4f45..76325555d 100644
--- a/libhb/hb.c
+++ b/libhb/hb.c
@@ -638,6 +638,7 @@ int hb_save_preview( hb_handle_t * h, int title, int preview, hb_buffer_t *buf )
{
FILE * file;
char filename[1024];
+ char reason[80];
hb_get_tempory_filename( h, filename, "%d_%d_%d",
hb_get_instance_id(h), title, preview );
@@ -645,7 +646,10 @@ int hb_save_preview( hb_handle_t * h, int title, int preview, hb_buffer_t *buf )
file = hb_fopen(filename, "wb");
if( !file )
{
- hb_error( "hb_save_preview: fopen failed (%s)", filename );
+ if (strerror_r(errno, reason, 79) != 0)
+ strcpy(reason, "unknown -- strerror_r() failed");
+
+ hb_error( "hb_save_preview: Failed to open %s (reason: %s)", filename, reason );
return -1;
}
@@ -659,11 +663,25 @@ int hb_save_preview( hb_handle_t * h, int title, int preview, hb_buffer_t *buf )
for( hh = 0; hh < h; hh++ )
{
- fwrite( data, w, 1, file );
+ if (fwrite( data, w, 1, file ) < w)
+ {
+ if (ferror(file))
+ {
+ if (strerror_r(errno, reason, 79) != 0)
+ strcpy(reason, "unknown -- strerror_r() failed");
+
+ hb_error( "hb_save_preview: Failed to write line %d to %s (reason: %s). Preview will be incomplete.",
+ hh, filename, reason );
+ goto done;
+ }
+ }
data += stride;
}
}
+
+done:
fclose( file );
+
return 0;
}
@@ -671,6 +689,7 @@ hb_buffer_t * hb_read_preview(hb_handle_t * h, hb_title_t *title, int preview)
{
FILE * file;
char filename[1024];
+ char reason[80];
hb_get_tempory_filename(h, filename, "%d_%d_%d",
hb_get_instance_id(h), title->index, preview);
@@ -678,7 +697,10 @@ hb_buffer_t * hb_read_preview(hb_handle_t * h, hb_title_t *title, int preview)
file = hb_fopen(filename, "rb");
if (!file)
{
- hb_error( "hb_read_preview: fopen failed (%s)", filename );
+ if (strerror_r(errno, reason, 79) != 0)
+ strcpy(reason, "unknown -- strerror_r() failed");
+
+ hb_error( "hb_read_preview: Failed to open %s (reason: %s)", filename, reason );
return NULL;
}
@@ -686,6 +708,9 @@ hb_buffer_t * hb_read_preview(hb_handle_t * h, hb_title_t *title, int preview)
buf = hb_frame_buffer_init(AV_PIX_FMT_YUV420P,
title->geometry.width, title->geometry.height);
+ if (!buf)
+ goto done;
+
int pp, hh;
for (pp = 0; pp < 3; pp++)
{
@@ -696,10 +721,23 @@ hb_buffer_t * hb_read_preview(hb_handle_t * h, hb_title_t *title, int preview)
for (hh = 0; hh < h; hh++)
{
- fread(data, w, 1, file);
+ if (fread(data, w, 1, file) < w)
+ {
+ if (ferror(file))
+ {
+ if (strerror_r(errno, reason, 79) != 0)
+ strcpy(reason, "unknown -- strerror_r() failed");
+
+ hb_error( "hb_read_preview: Failed to read line %d from %s (reason: %s). Preview will be incomplete.",
+ hh, filename, reason );
+ goto done;
+ }
+ }
data += stride;
}
}
+
+done:
fclose(file);
return buf;