diff --git a/lib/dash/dash_parser.js b/lib/dash/dash_parser.js index f1d7d909f64..1887c34d01b 100644 --- a/lib/dash/dash_parser.js +++ b/lib/dash/dash_parser.js @@ -22,7 +22,6 @@ goog.require('shaka.text.TextEngine'); goog.require('shaka.util.CmcdManager'); goog.require('shaka.util.Error'); goog.require('shaka.util.Functional'); -goog.require('shaka.util.Iterables'); goog.require('shaka.util.LanguageUtils'); goog.require('shaka.util.ManifestParserUtils'); goog.require('shaka.util.MimeUtils'); @@ -104,7 +103,7 @@ shaka.dash.DashParser = class { /** * Period IDs seen in previous manifest. - * @private {!Array.} + * @private {!Array.} */ this.lastManifestUpdatePeriodIds_ = []; @@ -556,10 +555,9 @@ shaka.dash.DashParser = class { const periods = []; let prevEnd = 0; const periodNodes = XmlUtils.findChildren(mpd, 'Period'); - // This uses a for-loop rather than a for-of loop because this needs to look - // ahead to the next element. - const enumerate = (it) => shaka.util.Iterables.enumerate(it); - for (const {i, item: elem, next} of enumerate(periodNodes)) { + for (let i = 0; i < periodNodes.length; i++) { + const elem = periodNodes[i]; + const next = periodNodes[i + 1]; const start = /** @type {number} */ ( XmlUtils.parseAttr(elem, 'start', XmlUtils.parseDuration, prevEnd)); const periodId = elem.id; diff --git a/lib/dash/mpd_utils.js b/lib/dash/mpd_utils.js index c18200f338e..806485f672b 100644 --- a/lib/dash/mpd_utils.js +++ b/lib/dash/mpd_utils.js @@ -12,7 +12,6 @@ goog.require('shaka.net.NetworkingEngine'); goog.require('shaka.util.AbortableOperation'); goog.require('shaka.util.Error'); goog.require('shaka.util.Functional'); -goog.require('shaka.util.Iterables'); goog.require('shaka.util.ManifestParserUtils'); goog.require('shaka.util.XmlUtils'); goog.requireType('shaka.dash.DashParser'); @@ -142,8 +141,9 @@ shaka.dash.MpdUtils = class { const timeline = []; let lastEndTime = -unscaledPresentationTimeOffset; - const enumerate = (it) => shaka.util.Iterables.enumerate(it); - for (const {item: timePoint, next} of enumerate(timePoints)) { + for (let i = 0; i < timePoints.length; ++i) { + const timePoint = timePoints[i]; + const next = timePoints[i + 1]; let t = XmlUtils.parseAttr(timePoint, 't', XmlUtils.parseNonNegativeInt); const d = XmlUtils.parseAttr(timePoint, 'd', XmlUtils.parseNonNegativeInt); @@ -225,8 +225,7 @@ shaka.dash.MpdUtils = class { timeline[timeline.length - 1].end = startTime / timescale; } - for (const _ of shaka.util.Iterables.range(repeat + 1)) { - shaka.util.Functional.ignored(_); + for (let j = 0; j <= repeat; ++j) { const endTime = startTime + d; const item = { start: startTime / timescale, diff --git a/lib/dash/segment_template.js b/lib/dash/segment_template.js index f41c1209367..40e8f16ee9f 100644 --- a/lib/dash/segment_template.js +++ b/lib/dash/segment_template.js @@ -14,7 +14,6 @@ goog.require('shaka.media.InitSegmentReference'); goog.require('shaka.media.SegmentIndex'); goog.require('shaka.media.SegmentReference'); goog.require('shaka.util.Error'); -goog.require('shaka.util.Iterables'); goog.require('shaka.util.ManifestParserUtils'); goog.require('shaka.util.ObjectUtils'); goog.requireType('shaka.dash.DashParser'); @@ -504,8 +503,9 @@ shaka.dash.SegmentTemplate = class { /** @type {!Array.} */ const references = []; - const enum_ = (it) => shaka.util.Iterables.enumerate(it); - for (const {i, item: {start, unscaledStart, end}} of enum_(info.timeline)) { + for (let i = 0; i < info.timeline.length; i++) { + const {start, unscaledStart, end} = info.timeline[i]; + // Note: i = k - 1, where k indicates the k'th segment listed in the MPD. // (See section 5.3.9.5.3 of the DASH spec.) const segmentReplacement = i + info.startNumber; diff --git a/lib/util/string_utils.js b/lib/util/string_utils.js index c0539308bfc..76f9f834ee5 100644 --- a/lib/util/string_utils.js +++ b/lib/util/string_utils.js @@ -158,9 +158,8 @@ shaka.util.StringUtils = class { static toUTF16(str, littleEndian) { const result = new ArrayBuffer(str.length * 2); const view = new DataView(result); - const enumerate = (it) => shaka.util.Iterables.enumerate(it); - for (const {i, item} of enumerate(str)) { - const value = item.charCodeAt(0); + for (let i = 0; i < str.length; ++i) { + const value = str.charCodeAt(i); view.setUint16(/* position= */ i * 2, value, littleEndian); } return result; diff --git a/lib/util/uint8array_utils.js b/lib/util/uint8array_utils.js index 903203daae7..0ddcdd1a437 100644 --- a/lib/util/uint8array_utils.js +++ b/lib/util/uint8array_utils.js @@ -74,9 +74,8 @@ shaka.util.Uint8ArrayUtils = class { // byte. const bytes = window.atob(str.replace(/-/g, '+').replace(/_/g, '/')); const result = new Uint8Array(bytes.length); - const enumerate = (it) => shaka.util.Iterables.enumerate(it); - for (const {i, item} of enumerate(bytes)) { - result[i] = item.charCodeAt(0); + for (let i = 0; i < bytes.length; ++i) { + result[i] = bytes.charCodeAt(i); } return result; }