summaryrefslogtreecommitdiffstats
path: root/libhb/muxmp4.c
diff options
context:
space:
mode:
authoreddyg <[email protected]>2009-05-07 23:52:25 +0000
committereddyg <[email protected]>2009-05-07 23:52:25 +0000
commitf923df5d7f32362798f2660378b40ea4dd91869e (patch)
tree41f8d6f4b252aa8087c5587e340c746a0bcc6f24 /libhb/muxmp4.c
parent166ebbdc3752de708a72a7c4826713a804b3d507 (diff)
Combine multiple CC lines into one, trimming whitespace, and adding proper language code based on first audio track language.
git-svn-id: svn://svn.handbrake.fr/HandBrake/trunk@2402 b64f7644-9d1e-0410-96f1-a4d463321fa5
Diffstat (limited to 'libhb/muxmp4.c')
-rw-r--r--libhb/muxmp4.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/libhb/muxmp4.c b/libhb/muxmp4.c
index f49ba748f..0f06deb15 100644
--- a/libhb/muxmp4.c
+++ b/libhb/muxmp4.c
@@ -416,6 +416,8 @@ static int MP4Init( hb_mux_object_t * m )
mux_data->sub_format = subtitle->format;
mux_data->track = MP4AddSubtitleTrack( m->file, 1 );
+ MP4SetTrackLanguage(m->file, mux_data->track, subtitle->iso639_2);
+
/* Tune track chunk duration */
MP4TuneTrackDurationPerChunk( m, mux_data->track );
@@ -654,7 +656,8 @@ static int MP4Mux( hb_mux_object_t * m, hb_mux_data_t * mux_data,
{
hb_error("Failed to write to output file, disk full?");
*job->die = 1;
- }
+ }
+ hb_log("Subtitle not due yet, adding delay of %lld", buf->start - m->sum_sub_duration);
m->sum_sub_duration += buf->start - m->sum_sub_duration;
}
@@ -663,7 +666,7 @@ static int MP4Mux( hb_mux_object_t * m, hb_mux_data_t * mux_data,
memcpy( buffer + 2, buf->data, buf->size );
buffer[0] = ( buf->size >> 8 ) & 0xff;
buffer[1] = buf->size & 0xff;
-
+
if( !MP4WriteSample( m->file,
mux_data->track,
buffer,
@@ -676,13 +679,17 @@ static int MP4Mux( hb_mux_object_t * m, hb_mux_data_t * mux_data,
*job->die = 1;
}
- m->sum_sub_duration += buf->stop - buf->start;
- hb_log("MuxMP4:Sub:%lld:%lld: %s", buf->start, buf->stop, buf->data);
+ m->sum_sub_duration += (buf->stop - buf->start);
+ hb_log("MuxMP4:Sub:%lld:%lld:%lld: %s", buf->start, buf->stop,
+ (buf->stop - buf->start), buf->data);
hb_log("MuxMP4:Total time elapsed:%lld", m->sum_sub_duration);
}
}
else
{
+ /*
+ * Audio
+ */
if( !MP4WriteSample( m->file,
mux_data->track,
buf->data,