Skip to content

Commit

Permalink
fix: Fix support for TTAF1 namespace (old version of TTML) (#3864)
Browse files Browse the repository at this point in the history
Fixes #3009
  • Loading branch information
Álvaro Velad Galván authored and joeyparrish committed Jan 28, 2022
1 parent 7f82ff3 commit 4e7c51b
Show file tree
Hide file tree
Showing 3 changed files with 66 additions and 13 deletions.
33 changes: 20 additions & 13 deletions lib/text/ttml_text_parser.js
Original file line number Diff line number Diff line change
Expand Up @@ -86,16 +86,17 @@ shaka.text.TtmlTextParser = class {
}

// Get the framerate, subFrameRate and frameRateMultiplier if applicable.
const frameRate = XmlUtils.getAttributeNS(tt, ttpNs, 'frameRate');
const subFrameRate = XmlUtils.getAttributeNS(tt, ttpNs, 'subFrameRate');
const frameRate = XmlUtils.getAttributeNSList(tt, ttpNs, 'frameRate');
const subFrameRate = XmlUtils.getAttributeNSList(
tt, ttpNs, 'subFrameRate');
const frameRateMultiplier =
XmlUtils.getAttributeNS(tt, ttpNs, 'frameRateMultiplier');
const tickRate = XmlUtils.getAttributeNS(tt, ttpNs, 'tickRate');
XmlUtils.getAttributeNSList(tt, ttpNs, 'frameRateMultiplier');
const tickRate = XmlUtils.getAttributeNSList(tt, ttpNs, 'tickRate');

const cellResolution = XmlUtils.getAttributeNS(
const cellResolution = XmlUtils.getAttributeNSList(
tt, ttpNs, 'cellResolution');
const spaceStyle = tt.getAttribute('xml:space') || 'default';
const extent = XmlUtils.getAttributeNS(tt, ttsNs, 'extent');
const extent = XmlUtils.getAttributeNSList(tt, ttsNs, 'extent');

if (spaceStyle != 'default' && spaceStyle != 'preserve') {
throw new shaka.util.Error(
Expand Down Expand Up @@ -774,7 +775,7 @@ shaka.text.TtmlTextParser = class {
return null;
}

const attr = XmlUtils.getAttributeNS(region, ttsNs, attribute);
const attr = XmlUtils.getAttributeNSList(region, ttsNs, attribute);
if (attr) {
return attr;
}
Expand All @@ -799,7 +800,7 @@ shaka.text.TtmlTextParser = class {

// Styling on elements should take precedence
// over the main styling attributes
const elementAttribute = XmlUtils.getAttributeNS(
const elementAttribute = XmlUtils.getAttributeNSList(
cueElement,
ttsNs,
attribute);
Expand Down Expand Up @@ -842,7 +843,7 @@ shaka.text.TtmlTextParser = class {

if (!styleAttributeValue) {
// Fall back to tts namespace.
styleAttributeValue = XmlUtils.getAttributeNS(
styleAttributeValue = XmlUtils.getAttributeNSList(
inheritedStyles[i],
ttsNs,
attribute);
Expand Down Expand Up @@ -1297,20 +1298,26 @@ shaka.text.TtmlTextParser.textAlignToPositionAlign_ = {
* document, not just "ttp:", so we use this with getAttributeNS() to ensure
* that we support arbitrary namespace names.
*
* @const {string}
* @const {!Array.<string>}
* @private
*/
shaka.text.TtmlTextParser.parameterNs_ = 'http://www.w3.org/ns/ttml#parameter';
shaka.text.TtmlTextParser.parameterNs_ = [
'http://www.w3.org/ns/ttml#parameter',
'http://www.w3.org/2006/10/ttaf1#parameter',
];

/**
* The namespace URL for TTML styles. Can be assigned any name in the TTML
* document, not just "tts:", so we use this with getAttributeNS() to ensure
* that we support arbitrary namespace names.
*
* @const {string}
* @const {!Array.<string>}
* @private
*/
shaka.text.TtmlTextParser.styleNs_ = 'http://www.w3.org/ns/ttml#styling';
shaka.text.TtmlTextParser.styleNs_ = [
'http://www.w3.org/ns/ttml#styling',
'http://www.w3.org/2006/10/ttaf1#styling',
];

/**
* The namespace URL for EBU TTML styles. Can be assigned any name in the TTML
Expand Down
19 changes: 19 additions & 0 deletions lib/util/xml_utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,25 @@ shaka.util.XmlUtils = class {
}


/**
* Gets a namespace-qualified attribute.
* @param {!Element} elem The element to get from.
* @param {!Array.<string>} nsList The lis of namespace URIs.
* @param {string} name The local name of the attribute.
* @return {?string} The attribute's value, or null if not present.
*/
static getAttributeNSList(elem, nsList, name) {
// Some browsers return the empty string when the attribute is missing,
// so check if it exists first. See: https://mzl.la/2L7F0UK
for (const ns of nsList) {
if (elem.hasAttributeNS(ns, name)) {
return elem.getAttributeNS(ns, name);
}
}
return null;
}


/**
* Gets the text contents of a node.
* @param {!Node} elem The XML element.
Expand Down
27 changes: 27 additions & 0 deletions test/text/ttml_text_parser_unit.js
Original file line number Diff line number Diff line change
Expand Up @@ -1358,6 +1358,33 @@ describe('TtmlTextParser', () => {
{startTime: 62.05, endTime: 3723.2});
});

it('allows old-standard namespace', () => {
verifyHelper(
[
{
startTime: 1,
endTime: 2,
payload: 'Test',
cellResolution: {
columns: 60,
rows: 20,
},
fontSize: '67%',
},
],
'<tt ' +
'xmlns:ttp="http://www.w3.org/2006/10/ttaf1#parameter" ' +
'xmlns:tts="http://www.w3.org/2006/10/ttaf1#styling" ' +
'ttp:cellResolution="60 20">' +
'<styling>' +
'<style xml:id="s1" tts:fontSize="67%"/>' +
'</styling>' +
'<body><div>' +
'<p begin="00:01.00" end="00:02.00" style="s1">Test</p>' +
'</div></body></tt>',
{periodStart: 0, segmentStart: 0, segmentEnd: 0});
});

it('parses cue alignment from textAlign attribute', () => {
verifyHelper(
[
Expand Down

0 comments on commit 4e7c51b

Please sign in to comment.