diff options
author | maxd <[email protected]> | 2013-11-05 13:46:42 +0000 |
---|---|---|
committer | maxd <[email protected]> | 2013-11-05 13:46:42 +0000 |
commit | e7fa5d24cdd7275611ed738e3dfc909fe30ad317 (patch) | |
tree | f0478754e3d930d44782e313c3fa21cb465f6b22 /libhb/work.c | |
parent | a89397c1e3358b5f690b046481388ade19316fda (diff) |
RB626: return code support added
git-svn-id: svn://svn.handbrake.fr/HandBrake/trunk@5876 b64f7644-9d1e-0410-96f1-a4d463321fa5
Diffstat (limited to 'libhb/work.c')
-rw-r--r-- | libhb/work.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/libhb/work.c b/libhb/work.c index bdf2191ea..b63925359 100644 --- a/libhb/work.c +++ b/libhb/work.c @@ -91,14 +91,13 @@ static void work_func( void * _work ) { hb_list_rem( work->jobs, job ); job->die = work->die; + job->done_error = work->error; *(work->current_job) = job; InitWorkState( job->h ); do_job( job ); *(work->current_job) = NULL; } - *(work->error) = HB_ERROR_NONE; - free( work ); } @@ -1264,6 +1263,7 @@ static void do_job(hb_job_t *job) if ( ( w = hb_codec_decoder( audio->config.in.codec ) ) == NULL ) { hb_error("Invalid input codec: %d", audio->config.in.codec); + *job->done_error = HB_ERROR_WRONG_INPUT; *job->die = 1; goto cleanup; } @@ -1288,6 +1288,7 @@ static void do_job(hb_job_t *job) { hb_error("Invalid audio codec: %#x", audio->config.out.codec); w = NULL; + *job->done_error = HB_ERROR_WRONG_INPUT; *job->die = 1; goto cleanup; } @@ -1314,6 +1315,7 @@ static void do_job(hb_job_t *job) if ( reader->init( reader, job ) ) { hb_error( "Failure to initialise thread '%s'", reader->name ); + *job->done_error = HB_ERROR_INIT; *job->die = 1; goto cleanup; } @@ -1350,6 +1352,7 @@ static void do_job(hb_job_t *job) if( w->init( w, job ) ) { hb_error( "Failure to initialise thread '%s'", w->name ); + *job->done_error = HB_ERROR_INIT; *job->die = 1; goto cleanup; } @@ -1370,6 +1373,7 @@ static void do_job(hb_job_t *job) if( sync->init( w, job ) ) { hb_error( "Failure to initialise thread '%s'", w->name ); + *job->done_error = HB_ERROR_INIT; *job->die = 1; goto cleanup; } |