Merge pull request #627 from tcavallari/detect_mp4_subs

Allow the detection of subtitles embedded in mp4 files
This commit is contained in:
echel0n 2014-07-08 09:51:15 -07:00
commit 4683ee41e3
2 changed files with 14 additions and 2 deletions

View file

@ -27,7 +27,7 @@ from exceptions import *
PARSERS = [('asf', ['video/asf'], ['asf', 'wmv', 'wma']), PARSERS = [('asf', ['video/asf'], ['asf', 'wmv', 'wma']),
('flv', ['video/flv'], ['flv']), ('flv', ['video/flv'], ['flv']),
('mkv', ['video/x-matroska', 'application/mkv'], ['mkv', 'mka', 'webm']), ('mkv', ['video/x-matroska', 'application/mkv'], ['mkv', 'mka', 'webm']),
('mp4', ['video/quicktime', 'video/mp4'], ['mov', 'qt', 'mp4', 'mp4a', '3gp', '3gp2', '3g2', 'mk2']), ('mp4', ['video/quicktime', 'video/mp4'], ['mov', 'qt', 'mp4', 'mp4a', 'm4v', '3gp', '3gp2', '3g2', 'mk2']),
('mpeg', ['video/mpeg'], ['mpeg', 'mpg', 'mp4', 'ts']), ('mpeg', ['video/mpeg'], ['mpeg', 'mpg', 'mp4', 'ts']),
('ogm', ['application/ogg'], ['ogm', 'ogg', 'ogv']), ('ogm', ['application/ogg'], ['ogm', 'ogg', 'ogv']),
('real', ['video/real'], ['rm', 'ra', 'ram']), ('real', ['video/real'], ['rm', 'ra', 'ram']),

View file

@ -300,6 +300,13 @@ class MPEG4(core.AVContainer):
trackinfo['length'] = mdhd[4] / mdhd[3] trackinfo['length'] = mdhd[4] / mdhd[3]
if mdhd[5] in QTLANGUAGES: if mdhd[5] in QTLANGUAGES:
trackinfo['language'] = QTLANGUAGES[mdhd[5]] trackinfo['language'] = QTLANGUAGES[mdhd[5]]
elif mdhd[5] == 0x7FF:
trackinfo['language'] = 'und'
elif mdhd[5] >= 0x400:
# language code detected as explained in:
# https://developer.apple.com/library/mac/documentation/QuickTime/qtff/QTFFChap4/qtff4.html#//apple_ref/doc/uid/TP40000939-CH206-35103
language = bytearray([ ((mdhd[5] & 0x7C00) >> 10) + 0x60, ((mdhd[5] & 0x3E0) >> 5) + 0x60, (mdhd[5] & 0x1F) + 0x60])
trackinfo['language'] = str(language)
# mdhd[6] == quality # mdhd[6] == quality
self.length = max(self.length, mdhd[4] / mdhd[3]) self.length = max(self.length, mdhd[4] / mdhd[3])
elif mdia[1] == 'minf': elif mdia[1] == 'minf':
@ -312,11 +319,13 @@ class MPEG4(core.AVContainer):
datasize += (mdia[0] - 8) datasize += (mdia[0] - 8)
elif mdia[1] == 'hdlr': elif mdia[1] == 'hdlr':
hdlr = struct.unpack('>I4s4s', atomdata[pos + 8:pos + 8 + 12]) hdlr = struct.unpack('>I4s4s', atomdata[pos + 8:pos + 8 + 12])
if hdlr[1] == 'mhlr': if hdlr[1] == 'mhlr' or hdlr[1] == '\0\0\0\0':
if hdlr[2] == 'vide': if hdlr[2] == 'vide':
tracktype = 'video' tracktype = 'video'
if hdlr[2] == 'soun': if hdlr[2] == 'soun':
tracktype = 'audio' tracktype = 'audio'
if hdlr[2] == 'subt' or hdlr[2] == 'sbtl' or hdlr[2] == 'subp' or hdlr[2] == 'text':
tracktype = 'subtitle'
elif mdia[1] == 'stsd': elif mdia[1] == 'stsd':
stsd = struct.unpack('>2I', atomdata[pos + 8:pos + 8 + 8]) stsd = struct.unpack('>2I', atomdata[pos + 8:pos + 8 + 8])
if stsd[1] > 0: if stsd[1] > 0:
@ -369,6 +378,9 @@ class MPEG4(core.AVContainer):
if tracktype == 'audio': if tracktype == 'audio':
info = core.AudioStream() info = core.AudioStream()
self.audio.append(info) self.audio.append(info)
if tracktype == 'subtitle':
info = core.Subtitle()
self.subtitles.append(info)
if info: if info:
for key, value in trackinfo.items(): for key, value in trackinfo.items():
setattr(info, key, value) setattr(info, key, value)