{
track = track2;
pts = buf->start;
- //hb_log("track: #%d, frame count %ld, fifo size %d", i, track->frames, hb_fifo_size( track->fifo));
}
}
return track;
/* Build list of fifos we're interested in */
list = hb_list_init();
- hb_log( "mux: audio list count %d", hb_list_count( title->list_audio ));
track = calloc( sizeof( hb_track_t ), 1 );
track->fifo = job->fifo_mpeg4;
track->mux_data = job->mux_data;
hb_list_add( list, track );
- hb_log( "mux: 1");
for( i = 0; i < hb_list_count( title->list_audio ); i++ )
{
audio = hb_list_item( title->list_audio, i );
track->mux_data = audio->mux_data;
hb_list_add( list, track );
}
- hb_log( "mux: 2");
while( !*job->die && !job->done )
{
}
hb_buffer_close( &buf );
}
- hb_log( "mux: 3");
if( job->pass != 1 )
{
uint64_t bytes_total, frames_total;
m->end( m );
- hb_log( "mux: 4");
if( !stat( job->file, &sb ) )
{
static int MP4End( hb_mux_object_t * m )
{
- hb_log("MP4End: enter");
av_write_trailer( m->format );
- hb_log("av_write_trailer: complete");
-
url_fclose( &m->format->pb );
- hb_log("url_fclose: complete");
av_free( m->format );
- hb_log("MP4End: exit");
return 0;
}
if( w->work( w, NULL, NULL ) == HB_WORK_DONE )
{
done = 1;
- hb_log("Work is done.");
}
if( done &&
!hb_fifo_size( job->fifo_sync ) &&
!hb_fifo_size( job->fifo_render ) &&
hb_fifo_size( job->fifo_mpeg4 ) < 2 )
{
- hb_log("Work is done and fifos are done.");
break;
}
hb_snooze( 50 );
w->close( w );
}
- hb_log("Closing threads.");
/* Stop read & write threads */
hb_thread_close( &job->reader );
hb_thread_close( &job->muxer );
/* Close fifos */
hb_fifo_close( &job->fifo_mpeg2 );
- hb_log("fifo_mpeg2 closed.");
hb_fifo_close( &job->fifo_raw );
- hb_log("fifo_raw closed.");
hb_fifo_close( &job->fifo_sync );
- hb_log("fifo_sync closed.");
hb_fifo_close( &job->fifo_render );
- hb_log("fifo_render closed.");
hb_fifo_close( &job->fifo_mpeg4 );
- hb_log("fifo_mpeg4 closed.");
if( subtitle )
{
hb_fifo_close( &subtitle->fifo_in );
- hb_log("fifo_in closed.");
hb_fifo_close( &subtitle->fifo_raw );
- hb_log("fifo_raw closed.");
}
for( i = 0; i < hb_list_count( title->list_audio ); i++ )
{
audio = hb_list_item( title->list_audio, i );
hb_fifo_close( &audio->fifo_in );
- hb_log("fifo_in closed.");
hb_fifo_close( &audio->fifo_raw );
- hb_log("fifo_raw closed.");
hb_fifo_close( &audio->fifo_sync );
- hb_log("fifo_sync closed.");
hb_fifo_close( &audio->fifo_out );
- hb_log("fifo_out closed.");
}
- hb_log("do_job complete.");
}
static void work_loop( void * _w )