summaryrefslogtreecommitdiffstats
path: root/libhb/reader.c
diff options
context:
space:
mode:
authorprigaux <[email protected]>2007-02-11 20:00:15 +0000
committerprigaux <[email protected]>2007-02-11 20:00:15 +0000
commita74fd5a1ec37e53fe7008f022639af6ede0e82c9 (patch)
tree0a6a32640a840b72653149aa11efa264674df976 /libhb/reader.c
parentf45dfeb2afb1b0bf46054959e8ea9494f3b7d14f (diff)
Merge the 0.8.0_mpeg4ip branch into the trunk
git-svn-id: svn://svn.handbrake.fr/HandBrake/trunk@285 b64f7644-9d1e-0410-96f1-a4d463321fa5
Diffstat (limited to 'libhb/reader.c')
-rw-r--r--libhb/reader.c156
1 files changed, 0 insertions, 156 deletions
diff --git a/libhb/reader.c b/libhb/reader.c
deleted file mode 100644
index 47ec9d546..000000000
--- a/libhb/reader.c
+++ /dev/null
@@ -1,156 +0,0 @@
-/* $Id: reader.c,v 1.21 2005/11/25 15:05:25 titer Exp $
-
- This file is part of the HandBrake source code.
- Homepage: <http://handbrake.m0k.org/>.
- It may be used under the terms of the GNU General Public License. */
-
-#include "hb.h"
-
-typedef struct
-{
- hb_job_t * job;
- hb_title_t * title;
- volatile int * die;
-
- hb_dvd_t * dvd;
- hb_buffer_t * ps;
-
-} hb_reader_t;
-
-/***********************************************************************
- * Local prototypes
- **********************************************************************/
-static void ReaderFunc( void * );
-static hb_fifo_t * GetFifoForId( hb_job_t * job, int id );
-
-/***********************************************************************
- * hb_reader_init
- ***********************************************************************
- *
- **********************************************************************/
-hb_thread_t * hb_reader_init( hb_job_t * job )
-{
- hb_reader_t * r;
-
- r = calloc( sizeof( hb_reader_t ), 1 );
-
- r->job = job;
- r->title = job->title;
- r->die = job->die;
-
- return hb_thread_init( "reader", ReaderFunc, r,
- HB_NORMAL_PRIORITY );
-}
-
-/***********************************************************************
- * ReaderFunc
- ***********************************************************************
- *
- **********************************************************************/
-static void ReaderFunc( void * _r )
-{
- hb_reader_t * r = _r;
- hb_fifo_t * fifo;
- hb_buffer_t * buf;
- hb_list_t * list;
- int chapter;
-
- if( !( r->dvd = hb_dvd_init( r->title->dvd ) ) )
- {
- return;
- }
-
- if( !hb_dvd_start( r->dvd, r->title->index, r->job->chapter_start ) )
- {
- hb_dvd_close( &r->dvd );
- return;
- }
-
- list = hb_list_init();
- r->ps = hb_buffer_init( 2048 );
-
- while( !*r->die && !r->job->done )
- {
- chapter = hb_dvd_chapter( r->dvd );
- if( chapter < 0 )
- {
- hb_log( "reader: end of the title reached" );
- break;
- }
- if( chapter > r->job->chapter_end )
- {
- hb_log( "reader: end of chapter %d reached (%d)",
- r->job->chapter_end, chapter );
- break;
- }
-
- if( !hb_dvd_read( r->dvd, r->ps ) )
- {
- break;
- }
-
- hb_demux_ps( r->ps, list );
-
- while( ( buf = hb_list_item( list, 0 ) ) )
- {
- hb_list_rem( list, buf );
- fifo = GetFifoForId( r->job, buf->id );
- if( fifo )
- {
- while( !*r->die && !r->job->done &&
- hb_fifo_is_full( fifo ) )
- {
- hb_snooze( 50 );
- }
- hb_fifo_push( fifo, buf );
- }
- else
- {
- hb_buffer_close( &buf );
- }
- }
- }
-
- hb_list_empty( &list );
- hb_buffer_close( &r->ps );
- hb_dvd_stop( r->dvd );
- hb_dvd_close( &r->dvd );
-
- hb_log( "reader: done" );
-}
-
-/***********************************************************************
- * GetFifoForId
- ***********************************************************************
- *
- **********************************************************************/
-static hb_fifo_t * GetFifoForId( hb_job_t * job, int id )
-{
- hb_title_t * title = job->title;
- hb_audio_t * audio;
- hb_subtitle_t * subtitle;
- int i;
-
- if( id == 0xE0 )
- {
- return job->fifo_mpeg2;
- }
-
- if( ( subtitle = hb_list_item( title->list_subtitle, 0 ) ) &&
- id == subtitle->id )
- {
- return subtitle->fifo_in;
- }
-
- for( i = 0; i < hb_list_count( title->list_audio ); i++ )
- {
- audio = hb_list_item( title->list_audio, i );
- if( id == audio->id )
- {
- return audio->fifo_in;
- }
- }
-
- return NULL;
-}
-