From 7cfeb665e0eb0a1c6e0131ca9ebaab43bd5844d2 Mon Sep 17 00:00:00 2001 From: mangui Date: Mon, 21 Sep 2015 14:23:58 +0200 Subject: [PATCH] update dist --- dist/hls.js | 798 ++++++++++++++++++++++++------------------------ dist/hls.min.js | 6 +- 2 files changed, 407 insertions(+), 397 deletions(-) diff --git a/dist/hls.js b/dist/hls.js index ca7f781db1b..c555ec385b0 100644 --- a/dist/hls.js +++ b/dist/hls.js @@ -451,6 +451,7 @@ var BufferController = (function () { this.nextLoadPosition = this.startPosition = this.lastCurrentTime; this.state = this.IDLE; } else { + this.nextLoadPosition = this.startPosition; this.state = this.STARTING; } this.tick(); @@ -527,7 +528,7 @@ var BufferController = (function () { this.fragmentBitrateTest = true; } // set new level to playlist loader : this will trigger start level load - this.hls.nextLoadLevel = this.startLevel; + this.level = this.hls.nextLoadLevel = this.startLevel; this.state = this.WAITING_LEVEL; this.loadedmetadata = false; break; @@ -538,6 +539,11 @@ var BufferController = (function () { break; } + // if video detached or unbound exit loop + if (!this.video) { + break; + } + // seek back to a expected position after video stalling if (this.seekAfterStalling) { this.video.currentTime = this.seekAfterStalling; @@ -731,38 +737,41 @@ var BufferController = (function () { case this.APPENDING: if (this.sourceBuffer) { // if MP4 segment appending in progress nothing to do - if (this.sourceBuffer.audio && this.sourceBuffer.audio.updating || this.sourceBuffer.video && this.sourceBuffer.video.updating) {} else if (this.mp4segments.length) { - var segment = this.mp4segments.shift(); - try { - //logger.log(`appending ${segment.type} SB, size:${segment.data.length}`); - this.sourceBuffer[segment.type].appendBuffer(segment.data); - this.appendError = 0; - } catch (err) { - // in case any error occured while appending, put back segment in mp4segments table - _utilsLogger.logger.error('error while trying to append buffer:' + err.message + ',try appending later'); - this.mp4segments.unshift(segment); - if (this.appendError) { - this.appendError++; - } else { - this.appendError = 1; - } - var event = { type: _errors.ErrorTypes.MEDIA_ERROR, details: _errors.ErrorDetails.FRAG_APPENDING_ERROR, frag: this.frag }; - /* with UHD content, we could get loop of quota exceeded error until - browser is able to evict some data from sourcebuffer. retrying help recovering this - */ - if (this.appendError > this.config.appendErrorMaxRetry) { - _utilsLogger.logger.log('fail ' + this.config.appendErrorMaxRetry + ' times to append segment in sourceBuffer'); - event.fatal = true; - _observer2['default'].trigger(_events2['default'].ERROR, event); - this.state = this.ERROR; - return; - } else { - event.fatal = false; - _observer2['default'].trigger(_events2['default'].ERROR, event); + if (this.sourceBuffer.audio && this.sourceBuffer.audio.updating || this.sourceBuffer.video && this.sourceBuffer.video.updating) { + //logger.log('sb append in progress'); + // check if any MP4 segments left to append + } else if (this.mp4segments.length) { + var segment = this.mp4segments.shift(); + try { + //logger.log(`appending ${segment.type} SB, size:${segment.data.length}`); + this.sourceBuffer[segment.type].appendBuffer(segment.data); + this.appendError = 0; + } catch (err) { + // in case any error occured while appending, put back segment in mp4segments table + _utilsLogger.logger.error('error while trying to append buffer:' + err.message + ',try appending later'); + this.mp4segments.unshift(segment); + if (this.appendError) { + this.appendError++; + } else { + this.appendError = 1; + } + var event = { type: _errors.ErrorTypes.MEDIA_ERROR, details: _errors.ErrorDetails.FRAG_APPENDING_ERROR, frag: this.frag }; + /* with UHD content, we could get loop of quota exceeded error until + browser is able to evict some data from sourcebuffer. retrying help recovering this + */ + if (this.appendError > this.config.appendErrorMaxRetry) { + _utilsLogger.logger.log('fail ' + this.config.appendErrorMaxRetry + ' times to append segment in sourceBuffer'); + event.fatal = true; + _observer2['default'].trigger(_events2['default'].ERROR, event); + this.state = this.ERROR; + return; + } else { + event.fatal = false; + _observer2['default'].trigger(_events2['default'].ERROR, event); + } } + this.state = this.APPENDING; } - this.state = this.APPENDING; - } } else { // sourceBuffer undefined, switch back to IDLE state this.state = this.IDLE; @@ -892,14 +901,14 @@ var BufferController = (function () { if (level && level.details && !level.details.live && this.video.duration - currentTime < 0.2) { if (this.mediaSource && this.mediaSource.readyState === 'open') { _utilsLogger.logger.log('end of VoD stream reached, signal endOfStream() to MediaSource'); + this.lastCurrentTime = this.startPosition; + this.video = null; this.mediaSource.endOfStream(); } } } } } - }, { - key: 'flushBuffer', /* abort any buffer append in progress, and flush all buffered data @@ -908,6 +917,8 @@ var BufferController = (function () { the idea is to call this function from tick() timer and call it again until all resources have been cleaned the timer is rearmed upon sourceBuffer updateend() event, so this should be optimal */ + }, { + key: 'flushBuffer', value: function flushBuffer(startOffset, endOffset) { var sb, i, bufStart, bufEnd, flushStart, flushEnd; //logger.log('flushBuffer,pos/start/end: ' + this.video.currentTime + '/' + startOffset + '/' + endOffset); @@ -965,8 +976,6 @@ var BufferController = (function () { // everything flushed ! return true; } - }, { - key: 'immediateLevelSwitch', /* on immediate level switch : @@ -974,6 +983,8 @@ var BufferController = (function () { - cancel any pending load request - and trigger a buffer flush */ + }, { + key: 'immediateLevelSwitch', value: function immediateLevelSwitch() { _utilsLogger.logger.log('immediateLevelSwitch'); if (!this.immediateSwitch) { @@ -995,14 +1006,14 @@ var BufferController = (function () { // speed up switching, trigger timer function this.tick(); } - }, { - key: 'immediateLevelSwitchEnd', /* on immediate level switch end, after new fragment has been buffered : - nudge video decoder by slightly adjusting video currentTime - resume the playback if needed */ + }, { + key: 'immediateLevelSwitchEnd', value: function immediateLevelSwitchEnd() { this.immediateSwitch = false; this.video.currentTime -= 0.0001; @@ -1370,7 +1381,7 @@ var BufferController = (function () { } }, { key: 'currentLevel', - get: function () { + get: function get() { if (this.video) { var range = this.getBufferRange(this.video.currentTime); if (range) { @@ -1381,7 +1392,7 @@ var BufferController = (function () { } }, { key: 'nextBufferRange', - get: function () { + get: function get() { if (this.video) { // first get end range of current fragment return this.followingBufferRange(this.getBufferRange(this.video.currentTime)); @@ -1391,7 +1402,7 @@ var BufferController = (function () { } }, { key: 'nextLevel', - get: function () { + get: function get() { var range = this.nextBufferRange; if (range) { return range.frag.level; @@ -1407,9 +1418,6 @@ var BufferController = (function () { exports['default'] = BufferController; module.exports = exports['default']; -//logger.log('sb append in progress'); -// check if any MP4 segments left to append - },{"../demux/demuxer":5,"../errors":9,"../events":10,"../observer":14,"../utils/logger":17}],4:[function(require,module,exports){ /* * level controller @@ -1659,60 +1667,60 @@ var LevelController = (function () { } }, { key: 'levels', - get: function () { + get: function get() { return this._levels; } }, { key: 'level', - get: function () { + get: function get() { return this._level; }, - set: function (newLevel) { + set: function set(newLevel) { if (this._level !== newLevel || this._levels[newLevel].details === undefined) { this.setLevelInternal(newLevel); } } }, { key: 'manualLevel', - get: function () { + get: function get() { return this._manualLevel; }, - set: function (newLevel) { + set: function set(newLevel) { this._manualLevel = newLevel; if (newLevel !== -1) { this.level = newLevel; } } - }, { - key: 'autoLevelCapping', /** Return the capping/max level value that could be used by automatic level selection algorithm **/ - get: function () { + }, { + key: 'autoLevelCapping', + get: function get() { return this._autoLevelCapping; }, /** set the capping/max level value that could be used by automatic level selection algorithm **/ - set: function (newLevel) { + set: function set(newLevel) { this._autoLevelCapping = newLevel; } }, { key: 'firstLevel', - get: function () { + get: function get() { return this._firstLevel; }, - set: function (newLevel) { + set: function set(newLevel) { this._firstLevel = newLevel; } }, { key: 'startLevel', - get: function () { + get: function get() { if (this._startLevel === undefined) { return this._firstLevel; } else { return this._startLevel; } }, - set: function (newLevel) { + set: function set(newLevel) { this._startLevel = newLevel; } }]); @@ -1874,10 +1882,10 @@ var ExpGolomb = (function () { this.bitsAvailable = 0; // :uint } + // ():void + _createClass(ExpGolomb, [{ key: 'loadWord', - - // ():void value: function loadWord() { var position = this.data.byteLength - this.bytesAvailable, workingBytes = new Uint8Array(4), @@ -1894,10 +1902,10 @@ var ExpGolomb = (function () { this.bitsAvailable = availableBytes * 8; this.bytesAvailable -= availableBytes; } - }, { - key: 'skipBits', // (count:int):void + }, { + key: 'skipBits', value: function skipBits(count) { var skipBytes; // :int if (this.bitsAvailable > count) { @@ -1916,10 +1924,10 @@ var ExpGolomb = (function () { this.bitsAvailable -= count; } } - }, { - key: 'readBits', // (size:int):uint + }, { + key: 'readBits', value: function readBits(size) { var bits = Math.min(this.bitsAvailable, size), // :uint @@ -1943,14 +1951,14 @@ var ExpGolomb = (function () { return valu; } } - }, { - key: 'skipLZ', // ():uint + }, { + key: 'skipLZ', value: function skipLZ() { var leadingZeroCount; // :uint for (leadingZeroCount = 0; leadingZeroCount < this.bitsAvailable; ++leadingZeroCount) { - if (0 !== (this.word & 2147483648 >>> leadingZeroCount)) { + if (0 !== (this.word & 0x80000000 >>> leadingZeroCount)) { // the first bit of working word is 1 this.word <<= leadingZeroCount; this.bitsAvailable -= leadingZeroCount; @@ -1962,58 +1970,56 @@ var ExpGolomb = (function () { this.loadWord(); return leadingZeroCount + this.skipLZ(); } - }, { - key: 'skipUEG', // ():void + }, { + key: 'skipUEG', value: function skipUEG() { this.skipBits(1 + this.skipLZ()); } - }, { - key: 'skipEG', // ():void + }, { + key: 'skipEG', value: function skipEG() { this.skipBits(1 + this.skipLZ()); } - }, { - key: 'readUEG', // ():uint + }, { + key: 'readUEG', value: function readUEG() { var clz = this.skipLZ(); // :uint return this.readBits(clz + 1) - 1; } - }, { - key: 'readEG', // ():int + }, { + key: 'readEG', value: function readEG() { var valu = this.readUEG(); // :int - if (1 & valu) { + if (0x01 & valu) { // the number is odd if the low order bit is set return 1 + valu >>> 1; // add 1 to make it even, and divide by 2 } else { - return -1 * (valu >>> 1); // divide by two then make it negative - } + return -1 * (valu >>> 1); // divide by two then make it negative + } } - }, { - key: 'readBoolean', // Some convenience functions // :Boolean + }, { + key: 'readBoolean', value: function readBoolean() { return 1 === this.readBits(1); } - }, { - key: 'readUByte', // ():int + }, { + key: 'readUByte', value: function readUByte() { return this.readBits(8); } - }, { - key: 'skipScalingList', /** * Advance the ExpGolomb decoder past a scaling list. The scaling @@ -2022,6 +2028,8 @@ var ExpGolomb = (function () { * @param count {number} the number of entries in this scaling list * @see Recommendation ITU-T H.264, Section 7.3.2.1.1.1 */ + }, { + key: 'skipScalingList', value: function skipScalingList(count) { var lastScale = 8, nextScale = 8, @@ -2037,8 +2045,6 @@ var ExpGolomb = (function () { lastScale = nextScale === 0 ? lastScale : nextScale; } } - }, { - key: 'readSPS', /** * Read a sequence parameter set and return some interesting video @@ -2049,6 +2055,8 @@ var ExpGolomb = (function () { * sequence parameter set, including the dimensions of the * associated video frames. */ + }, { + key: 'readSPS', value: function readSPS() { var frameCropLeftOffset = 0, frameCropRightOffset = 0, @@ -2102,14 +2110,14 @@ var ExpGolomb = (function () { if (picOrderCntType === 0) { this.readUEG(); //log2_max_pic_order_cnt_lsb_minus4 } else if (picOrderCntType === 1) { - this.skipBits(1); // delta_pic_order_always_zero_flag - this.skipEG(); // offset_for_non_ref_pic - this.skipEG(); // offset_for_top_to_bottom_field - numRefFramesInPicOrderCntCycle = this.readUEG(); - for (i = 0; i < numRefFramesInPicOrderCntCycle; i++) { - this.skipEG(); // offset_for_ref_frame[ i ] + this.skipBits(1); // delta_pic_order_always_zero_flag + this.skipEG(); // offset_for_non_ref_pic + this.skipEG(); // offset_for_top_to_bottom_field + numRefFramesInPicOrderCntCycle = this.readUEG(); + for (i = 0; i < numRefFramesInPicOrderCntCycle; i++) { + this.skipEG(); // offset_for_ref_frame[ i ] + } } - } this.skipUEG(); // max_num_ref_frames this.skipBits(1); // gaps_in_frame_num_value_allowed_flag @@ -2218,10 +2226,10 @@ var TSDemuxer = (function () { this.switchLevel(); this._initPTS = this._initDTS = undefined; } - }, { - key: 'push', // feed incoming data to the front of the parsing pipeline + }, { + key: 'push', value: function push(data, audioCodec, videoCodec, timeOffset, cc, level, duration) { var avcData, aacData, @@ -2250,11 +2258,11 @@ var TSDemuxer = (function () { // loop through TS packets for (start = 0; start < len; start += 188) { - if (data[start] === 71) { - stt = !!(data[start + 1] & 64); + if (data[start] === 0x47) { + stt = !!(data[start + 1] & 0x40); // pid is a 13-bit field starting at the last bit of TS[1] - pid = ((data[start + 1] & 31) << 8) + data[start + 2]; - atf = (data[start + 3] & 48) >> 4; + pid = ((data[start + 1] & 0x1f) << 8) + data[start + 2]; + atf = (data[start + 3] & 0x30) >> 4; // if an adaption field is present, its length is specified by the fifth byte of the TS packet header. if (atf > 1) { offset = start + 5 + data[start + 4]; @@ -2343,32 +2351,32 @@ var TSDemuxer = (function () { key: '_parsePAT', value: function _parsePAT(data, offset) { // skip the PSI header and parse the first PMT entry - this._pmtId = (data[offset + 10] & 31) << 8 | data[offset + 11]; + this._pmtId = (data[offset + 10] & 0x1F) << 8 | data[offset + 11]; //logger.log('PMT PID:' + this._pmtId); } }, { key: '_parsePMT', value: function _parsePMT(data, offset) { var sectionLength, tableEnd, programInfoLength, pid; - sectionLength = (data[offset + 1] & 15) << 8 | data[offset + 2]; + sectionLength = (data[offset + 1] & 0x0f) << 8 | data[offset + 2]; tableEnd = offset + 3 + sectionLength - 4; // to determine where the table is, we have to figure out how // long the program info descriptors are - programInfoLength = (data[offset + 10] & 15) << 8 | data[offset + 11]; + programInfoLength = (data[offset + 10] & 0x0f) << 8 | data[offset + 11]; // advance the offset to the first entry in the mapping table offset += 12 + programInfoLength; while (offset < tableEnd) { - pid = (data[offset + 1] & 31) << 8 | data[offset + 2]; + pid = (data[offset + 1] & 0x1F) << 8 | data[offset + 2]; switch (data[offset]) { // ISO/IEC 13818-7 ADTS AAC (MPEG-2 lower bit-rate audio) - case 15: + case 0x0f: //logger.log('AAC PID:' + pid); this._aacId = pid; this._aacTrack.id = pid; break; // ITU-T Rec. H.264 and ISO/IEC 14496-10 (lower bit-rate video) - case 27: + case 0x1b: //logger.log('AVC PID:' + pid); this._avcId = pid; this._avcTrack.id = pid; @@ -2379,7 +2387,7 @@ var TSDemuxer = (function () { } // move to the next table entry // skip past the elementary stream descriptors, if present - offset += ((data[offset + 3] & 15) << 8 | data[offset + 4]) + 5; + offset += ((data[offset + 3] & 0x0F) << 8 | data[offset + 4]) + 5; } } }, { @@ -2401,26 +2409,26 @@ var TSDemuxer = (function () { if (pesPrefix === 1) { pesLen = (frag[4] << 8) + frag[5]; pesFlags = frag[7]; - if (pesFlags & 192) { + if (pesFlags & 0xC0) { /* PES header described here : http://dvd.sourceforge.net/dvdinfo/pes-hdr.html as PTS / DTS is 33 bit we cannot use bitwise operator in JS, as Bitwise operators treat their operands as a sequence of 32 bits */ - pesPts = (frag[9] & 14) * 536870912 + // 1 << 29 - (frag[10] & 255) * 4194304 + // 1 << 22 - (frag[11] & 254) * 16384 + // 1 << 14 - (frag[12] & 255) * 128 + // 1 << 7 - (frag[13] & 254) / 2; + pesPts = (frag[9] & 0x0E) * 536870912 + // 1 << 29 + (frag[10] & 0xFF) * 4194304 + // 1 << 22 + (frag[11] & 0xFE) * 16384 + // 1 << 14 + (frag[12] & 0xFF) * 128 + // 1 << 7 + (frag[13] & 0xFE) / 2; // check if greater than 2^32 -1 if (pesPts > 4294967295) { // decrement 2^33 pesPts -= 8589934592; } - if (pesFlags & 64) { - pesDts = (frag[14] & 14) * 536870912 + // 1 << 29 - (frag[15] & 255) * 4194304 + // 1 << 22 - (frag[16] & 254) * 16384 + // 1 << 14 - (frag[17] & 255) * 128 + // 1 << 7 - (frag[18] & 254) / 2; + if (pesFlags & 0x40) { + pesDts = (frag[14] & 0x0E) * 536870912 + // 1 << 29 + (frag[15] & 0xFF) * 4194304 + // 1 << 22 + (frag[16] & 0xFE) * 16384 + // 1 << 14 + (frag[17] & 0xFF) * 128 + // 1 << 7 + (frag[18] & 0xFE) / 2; // check if greater than 2^32 -1 if (pesDts > 4294967295) { // decrement 2^33 @@ -2583,20 +2591,20 @@ var TSDemuxer = (function () { dtsnorm = Math.max(dtsnorm - delta, this.lastAvcDts); // logger.log('Video/PTS/DTS adjusted:' + avcSample.pts + '/' + avcSample.dts); } else { - // not contiguous timestamp, check if PTS is within acceptable range - var expectedPTS = this.PES_TIMESCALE * this.timeOffset; - // check if there is any unexpected drift between expected timestamp and real one - if (Math.abs(expectedPTS - ptsnorm) > this.PES_TIMESCALE * 3600) { - //logger.log(`PTS looping ??? AVC PTS delta:${expectedPTS-ptsnorm}`); - var ptsOffset = expectedPTS - ptsnorm; - // set PTS to next expected PTS; - ptsnorm = expectedPTS; - dtsnorm = ptsnorm; - // offset initPTS/initDTS to fix computation for following samples - this._initPTS -= ptsOffset; - this._initDTS -= ptsOffset; + // not contiguous timestamp, check if PTS is within acceptable range + var expectedPTS = this.PES_TIMESCALE * this.timeOffset; + // check if there is any unexpected drift between expected timestamp and real one + if (Math.abs(expectedPTS - ptsnorm) > this.PES_TIMESCALE * 3600) { + //logger.log(`PTS looping ??? AVC PTS delta:${expectedPTS-ptsnorm}`); + var ptsOffset = expectedPTS - ptsnorm; + // set PTS to next expected PTS; + ptsnorm = expectedPTS; + dtsnorm = ptsnorm; + // offset initPTS/initDTS to fix computation for following samples + this._initPTS -= ptsOffset; + this._initDTS -= ptsOffset; + } } - } } // remember first PTS of our avcSamples, ensure value is positive firstPTS = Math.max(0, ptsnorm); @@ -2689,7 +2697,7 @@ var TSDemuxer = (function () { if (value === 0) { state = 3; } else if (value === 1) { - unitType = array[i] & 31; + unitType = array[i] & 0x1f; //logger.log('find NALU @ offset:' + i + ',type:' + unitType); if (lastUnitStart) { unit = { data: array.subarray(lastUnitStart, i - state - 1), type: lastUnitType }; @@ -2779,7 +2787,7 @@ var TSDemuxer = (function () { } // look for ADTS header (0xFFFx) for (adtsStartOffset = 0, len = data.length; adtsStartOffset < len - 1; adtsStartOffset++) { - if (data[adtsStartOffset] === 255 && (data[adtsStartOffset + 1] & 240) === 240) { + if (data[adtsStartOffset] === 0xff && (data[adtsStartOffset + 1] & 0xf0) === 0xf0) { break; } } @@ -2812,12 +2820,12 @@ var TSDemuxer = (function () { nbSamples = 0; while (adtsStartOffset + 5 < len) { // retrieve frame size - adtsFrameSize = (data[adtsStartOffset + 3] & 3) << 11; + adtsFrameSize = (data[adtsStartOffset + 3] & 0x03) << 11; // byte 4 adtsFrameSize |= data[adtsStartOffset + 4] << 3; // byte 5 - adtsFrameSize |= (data[adtsStartOffset + 5] & 224) >>> 5; - adtsHeaderLen = !!(data[adtsStartOffset + 1] & 1) ? 7 : 9; + adtsFrameSize |= (data[adtsStartOffset + 5] & 0xE0) >>> 5; + adtsHeaderLen = !!(data[adtsStartOffset + 1] & 0x01) ? 7 : 9; adtsFrameSize -= adtsHeaderLen; stamp = Math.round(pes.pts + nbSamples * 1024 * this.PES_TIMESCALE / track.audiosamplerate); //stamp = pes.pts; @@ -2900,8 +2908,8 @@ var TSDemuxer = (function () { dtsnorm = ptsnorm; //logger.log('Audio/PTS/DTS adjusted:' + aacSample.pts + '/' + aacSample.dts); } else { - _utilsLogger.logger.log('AAC:' + -delta + ' ms overlapping between fragments detected'); - } + _utilsLogger.logger.log('AAC:' + -delta + ' ms overlapping between fragments detected'); + } } else if (absdelta) { // not contiguous timestamp, check if PTS is within acceptable range var expectedPTS = this.PES_TIMESCALE * this.timeOffset; @@ -2979,11 +2987,11 @@ var TSDemuxer = (function () { adtsSampleingRates = [96000, 88200, 64000, 48000, 44100, 32000, 24000, 22050, 16000, 12000]; // byte 2 - adtsObjectType = ((data[offset + 2] & 192) >>> 6) + 1; - adtsSampleingIndex = (data[offset + 2] & 60) >>> 2; - adtsChanelConfig = (data[offset + 2] & 1) << 2; + adtsObjectType = ((data[offset + 2] & 0xC0) >>> 6) + 1; + adtsSampleingIndex = (data[offset + 2] & 0x3C) >>> 2; + adtsChanelConfig = (data[offset + 2] & 0x01) << 2; // byte 3 - adtsChanelConfig |= (data[offset + 3] & 192) >>> 6; + adtsChanelConfig |= (data[offset + 3] & 0xC0) >>> 6; _utilsLogger.logger.log('manifest codec:' + audioCodec + ',ADTS data:type:' + adtsObjectType + ',sampleingIndex:' + adtsSampleingIndex + '[' + adtsSampleingRates[adtsSampleingIndex] + 'kHz],channelConfig:' + adtsChanelConfig); @@ -3003,30 +3011,30 @@ var TSDemuxer = (function () { } // Android : always use AAC } else if (userAgent.indexOf('android') !== -1) { - adtsObjectType = 2; - config = new Array(2); - adtsExtensionSampleingIndex = adtsSampleingIndex; - } else { - /* for other browsers (chrome ...) - always force audio type to be HE-AAC SBR, as some browsers do not support audio codec switch properly (like Chrome ...) - */ - adtsObjectType = 5; - config = new Array(4); - // if (manifest codec is HE-AAC) OR (manifest codec not specified AND frequency less than 24kHz) - if (audioCodec && audioCodec.indexOf('mp4a.40.5') !== -1 || !audioCodec && adtsSampleingIndex >= 6) { - // HE-AAC uses SBR (Spectral Band Replication) , high frequencies are constructed from low frequencies - // there is a factor 2 between frame sample rate and output sample rate - // multiply frequency by 2 (see table below, equivalent to substract 3) - adtsExtensionSampleingIndex = adtsSampleingIndex - 3; + adtsObjectType = 2; + config = new Array(2); + adtsExtensionSampleingIndex = adtsSampleingIndex; } else { - // if (manifest codec is AAC) AND (frequency less than 24kHz OR nb channel is 1) - if (audioCodec && audioCodec.indexOf('mp4a.40.2') !== -1 && (adtsSampleingIndex >= 6 || adtsChanelConfig === 1)) { - adtsObjectType = 2; - config = new Array(2); + /* for other browsers (chrome ...) + always force audio type to be HE-AAC SBR, as some browsers do not support audio codec switch properly (like Chrome ...) + */ + adtsObjectType = 5; + config = new Array(4); + // if (manifest codec is HE-AAC) OR (manifest codec not specified AND frequency less than 24kHz) + if (audioCodec && audioCodec.indexOf('mp4a.40.5') !== -1 || !audioCodec && adtsSampleingIndex >= 6) { + // HE-AAC uses SBR (Spectral Band Replication) , high frequencies are constructed from low frequencies + // there is a factor 2 between frame sample rate and output sample rate + // multiply frequency by 2 (see table below, equivalent to substract 3) + adtsExtensionSampleingIndex = adtsSampleingIndex - 3; + } else { + // if (manifest codec is AAC) AND (frequency less than 24kHz OR nb channel is 1) + if (audioCodec && audioCodec.indexOf('mp4a.40.2') !== -1 && (adtsSampleingIndex >= 6 || adtsChanelConfig === 1)) { + adtsObjectType = 2; + config = new Array(2); + } + adtsExtensionSampleingIndex = adtsSampleingIndex; } - adtsExtensionSampleingIndex = adtsSampleingIndex; } - } /* refer to http://wiki.multimedia.cx/index.php?title=MPEG-4_Audio#Audio_Specific_Config ISO 14496-3 (AAC).pdf - Table 1.13 — Syntax of AudioSpecificConfig() Audio Profile / Audio Object Type @@ -3063,14 +3071,14 @@ var TSDemuxer = (function () { // audioObjectType = profile => profile, the MPEG-4 Audio Object Type minus 1 config[0] = adtsObjectType << 3; // samplingFrequencyIndex - config[0] |= (adtsSampleingIndex & 14) >> 1; - config[1] |= (adtsSampleingIndex & 1) << 7; + config[0] |= (adtsSampleingIndex & 0x0E) >> 1; + config[1] |= (adtsSampleingIndex & 0x01) << 7; // channelConfiguration config[1] |= adtsChanelConfig << 3; if (adtsObjectType === 5) { // adtsExtensionSampleingIndex - config[1] |= (adtsExtensionSampleingIndex & 14) >> 1; - config[2] = (adtsExtensionSampleingIndex & 1) << 7; + config[1] |= (adtsExtensionSampleingIndex & 0x0E) >> 1; + config[2] = (adtsExtensionSampleingIndex & 0x01) << 7; // adtsObjectType (force to 2, chrome is checking that object type is less than 5 ??? // https://chromium.googlesource.com/chromium/src.git/+/master/media/formats/mp4/aac.cc config[2] |= 2 << 2; @@ -3359,8 +3367,30 @@ var _utilsXhrLoader = require('./utils/xhr-loader'); var _utilsXhrLoader2 = _interopRequireDefault(_utilsXhrLoader); var Hls = (function () { + _createClass(Hls, null, [{ + key: 'isSupported', + value: function isSupported() { + return window.MediaSource && MediaSource.isTypeSupported('video/mp4; codecs="avc1.42E01E,mp4a.40.2"'); + } + }, { + key: 'Events', + get: function get() { + return _events2['default']; + } + }, { + key: 'ErrorTypes', + get: function get() { + return _errors.ErrorTypes; + } + }, { + key: 'ErrorDetails', + get: function get() { + return _errors.ErrorDetails; + } + }]); + function Hls() { - var config = arguments[0] === undefined ? {} : arguments[0]; + var config = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; _classCallCheck(this, Hls); @@ -3482,6 +3512,8 @@ var Hls = (function () { this.detachVideo(); this.attachVideo(video); } + + /** Return all quality levels **/ }, { key: 'onMediaSourceOpen', value: function onMediaSourceOpen() { @@ -3502,87 +3534,85 @@ var Hls = (function () { } }, { key: 'levels', - - /** Return all quality levels **/ - get: function () { + get: function get() { return this.levelController.levels; } - }, { - key: 'currentLevel', /** Return current playback quality level **/ - get: function () { + }, { + key: 'currentLevel', + get: function get() { return this.bufferController.currentLevel; }, /* set quality level immediately (-1 for automatic level selection) */ - set: function (newLevel) { + set: function set(newLevel) { _utilsLogger.logger.log('set currentLevel:' + newLevel); this.loadLevel = newLevel; this.bufferController.immediateLevelSwitch(); } - }, { - key: 'nextLevel', /** Return next playback quality level (quality level of next fragment) **/ - get: function () { + }, { + key: 'nextLevel', + get: function get() { return this.bufferController.nextLevel; }, /* set quality level for next fragment (-1 for automatic level selection) */ - set: function (newLevel) { + set: function set(newLevel) { _utilsLogger.logger.log('set nextLevel:' + newLevel); this.levelController.manualLevel = newLevel; this.bufferController.nextLevelSwitch(); } - }, { - key: 'loadLevel', /** Return the quality level of current/last loaded fragment **/ - get: function () { + }, { + key: 'loadLevel', + get: function get() { return this.levelController.level; }, /* set quality level for current/next loaded fragment (-1 for automatic level selection) */ - set: function (newLevel) { + set: function set(newLevel) { _utilsLogger.logger.log('set loadLevel:' + newLevel); this.levelController.manualLevel = newLevel; } - }, { - key: 'nextLoadLevel', /** Return the quality level of next loaded fragment **/ - get: function () { + }, { + key: 'nextLoadLevel', + get: function get() { return this.levelController.nextLoadLevel(); }, /** set quality level of next loaded fragment **/ - set: function (level) { + set: function set(level) { this.levelController.level = level; } - }, { - key: 'firstLevel', /** Return first level (index of first level referenced in manifest) **/ - get: function () { + }, { + key: 'firstLevel', + get: function get() { return this.levelController.firstLevel; }, /** set first level (index of first level referenced in manifest) **/ - set: function (newLevel) { + set: function set(newLevel) { _utilsLogger.logger.log('set firstLevel:' + newLevel); this.levelController.firstLevel = newLevel; } - }, { - key: 'startLevel', /** Return start level (level of first fragment that will be played back) if not overrided by user, first level appearing in manifest will be used as start level if -1 : automatic start level selection, playback will start from level matching download bandwidth (determined from download of first segment) **/ - get: function () { + }, { + key: 'startLevel', + get: function get() { return this.levelController.startLevel; }, @@ -3590,63 +3620,43 @@ var Hls = (function () { if not overrided by user, first level appearing in manifest will be used as start level if -1 : automatic start level selection, playback will start from level matching download bandwidth (determined from download of first segment) **/ - set: function (newLevel) { + set: function set(newLevel) { _utilsLogger.logger.log('set startLevel:' + newLevel); this.levelController.startLevel = newLevel; } - }, { - key: 'autoLevelCapping', /** Return the capping/max level value that could be used by automatic level selection algorithm **/ - get: function () { + }, { + key: 'autoLevelCapping', + get: function get() { return this.levelController.autoLevelCapping; }, /** set the capping/max level value that could be used by automatic level selection algorithm **/ - set: function (newLevel) { + set: function set(newLevel) { _utilsLogger.logger.log('set autoLevelCapping:' + newLevel); this.levelController.autoLevelCapping = newLevel; } - }, { - key: 'autoLevelEnabled', /* check if we are in automatic level selection mode */ - get: function () { + }, { + key: 'autoLevelEnabled', + get: function get() { return this.levelController.manualLevel === -1; } - }, { - key: 'manualLevel', /* return manual level */ - get: function () { + }, { + key: 'manualLevel', + get: function get() { return this.levelController.manualLevel; } - }, { - key: 'stats', /* return playback session stats */ - get: function () { - return this.statsHandler.stats; - } - }], [{ - key: 'isSupported', - value: function isSupported() { - return window.MediaSource && MediaSource.isTypeSupported('video/mp4; codecs="avc1.42E01E,mp4a.40.2"'); - } - }, { - key: 'Events', - get: function () { - return _events2['default']; - } - }, { - key: 'ErrorTypes', - get: function () { - return _errors.ErrorTypes; - } }, { - key: 'ErrorDetails', - get: function () { - return _errors.ErrorDetails; + key: 'stats', + get: function get() { + return this.statsHandler.stats; } }]); @@ -4132,60 +4142,61 @@ var MP4 = (function () { MP4.MAJOR_BRAND = new Uint8Array(['i'.charCodeAt(0), 's'.charCodeAt(0), 'o'.charCodeAt(0), 'm'.charCodeAt(0)]); MP4.AVC1_BRAND = new Uint8Array(['a'.charCodeAt(0), 'v'.charCodeAt(0), 'c'.charCodeAt(0), '1'.charCodeAt(0)]); MP4.MINOR_VERSION = new Uint8Array([0, 0, 0, 1]); - MP4.VIDEO_HDLR = new Uint8Array([0, // version 0 - 0, 0, 0, // flags - 0, 0, 0, 0, // pre_defined - 118, 105, 100, 101, // handler_type: 'vide' - 0, 0, 0, 0, // reserved - 0, 0, 0, 0, // reserved - 0, 0, 0, 0, // reserved - 86, 105, 100, 101, 111, 72, 97, 110, 100, 108, 101, 114, 0 // name: 'VideoHandler' + MP4.VIDEO_HDLR = new Uint8Array([0x00, // version 0 + 0x00, 0x00, 0x00, // flags + 0x00, 0x00, 0x00, 0x00, // pre_defined + 0x76, 0x69, 0x64, 0x65, // handler_type: 'vide' + 0x00, 0x00, 0x00, 0x00, // reserved + 0x00, 0x00, 0x00, 0x00, // reserved + 0x00, 0x00, 0x00, 0x00, // reserved + 0x56, 0x69, 0x64, 0x65, 0x6f, 0x48, 0x61, 0x6e, 0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'VideoHandler' ]); - MP4.AUDIO_HDLR = new Uint8Array([0, // version 0 - 0, 0, 0, // flags - 0, 0, 0, 0, // pre_defined - 115, 111, 117, 110, // handler_type: 'soun' - 0, 0, 0, 0, // reserved - 0, 0, 0, 0, // reserved - 0, 0, 0, 0, // reserved - 83, 111, 117, 110, 100, 72, 97, 110, 100, 108, 101, 114, 0 // name: 'SoundHandler' + MP4.AUDIO_HDLR = new Uint8Array([0x00, // version 0 + 0x00, 0x00, 0x00, // flags + 0x00, 0x00, 0x00, 0x00, // pre_defined + 0x73, 0x6f, 0x75, 0x6e, // handler_type: 'soun' + 0x00, 0x00, 0x00, 0x00, // reserved + 0x00, 0x00, 0x00, 0x00, // reserved + 0x00, 0x00, 0x00, 0x00, // reserved + 0x53, 0x6f, 0x75, 0x6e, 0x64, 0x48, 0x61, 0x6e, 0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'SoundHandler' ]); MP4.HDLR_TYPES = { 'video': MP4.VIDEO_HDLR, 'audio': MP4.AUDIO_HDLR }; - MP4.DREF = new Uint8Array([0, // version 0 - 0, 0, 0, // flags - 0, 0, 0, 1, // entry_count - 0, 0, 0, 12, // entry_size - 117, 114, 108, 32, // 'url' type - 0, // version 0 - 0, 0, 1 // entry_flags + MP4.DREF = new Uint8Array([0x00, // version 0 + 0x00, 0x00, 0x00, // flags + 0x00, 0x00, 0x00, 0x01, // entry_count + 0x00, 0x00, 0x00, 0x0c, // entry_size + 0x75, 0x72, 0x6c, 0x20, // 'url' type + 0x00, // version 0 + 0x00, 0x00, 0x01 // entry_flags ]); - MP4.STCO = new Uint8Array([0, // version - 0, 0, 0, // flags - 0, 0, 0, 0 // entry_count + MP4.STCO = new Uint8Array([0x00, // version + 0x00, 0x00, 0x00, // flags + 0x00, 0x00, 0x00, 0x00 // entry_count ]); MP4.STSC = MP4.STCO; MP4.STTS = MP4.STCO; - MP4.STSZ = new Uint8Array([0, // version - 0, 0, 0, // flags - 0, 0, 0, 0, // sample_size - 0, 0, 0, 0]); - MP4.VMHD = new Uint8Array([0, // version - 0, 0, 1, // flags - 0, 0, // graphicsmode - 0, 0, 0, 0, 0, 0 // opcolor + MP4.STSZ = new Uint8Array([0x00, // version + 0x00, 0x00, 0x00, // flags + 0x00, 0x00, 0x00, 0x00, // sample_size + 0x00, 0x00, 0x00, 0x00]); + // sample_count + MP4.VMHD = new Uint8Array([0x00, // version + 0x00, 0x00, 0x01, // flags + 0x00, 0x00, // graphicsmode + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 // opcolor ]); - MP4.SMHD = new Uint8Array([0, // version - 0, 0, 0, // flags - 0, 0, // balance - 0, 0 // reserved + MP4.SMHD = new Uint8Array([0x00, // version + 0x00, 0x00, 0x00, // flags + 0x00, 0x00, // balance + 0x00, 0x00 // reserved ]); - MP4.STSD = new Uint8Array([0, // version 0 - 0, 0, 0, // flags - 0, 0, 0, 1]); // entry_count + MP4.STSD = new Uint8Array([0x00, // version 0 + 0x00, 0x00, 0x00, // flags + 0x00, 0x00, 0x00, 0x01]); // entry_count MP4.FTYP = MP4.box(MP4.types.ftyp, MP4.MAJOR_BRAND, MP4.MINOR_VERSION, MP4.MAJOR_BRAND, MP4.AVC1_BRAND); MP4.DINF = MP4.box(MP4.types.dinf, MP4.box(MP4.types.dref, MP4.DREF)); @@ -4228,13 +4239,14 @@ var MP4 = (function () { }, { key: 'mdhd', value: function mdhd(timescale, duration) { - return MP4.box(MP4.types.mdhd, new Uint8Array([0, // version 0 - 0, 0, 0, // flags - 0, 0, 0, 2, // creation_time - 0, 0, 0, 3, // modification_time - timescale >> 24 & 255, timescale >> 16 & 255, timescale >> 8 & 255, timescale & 255, duration >> 24, duration >> 16 & 255, duration >> 8 & 255, duration & 255, // duration - 85, 196, // 'und' language (undetermined) - 0, 0])); + return MP4.box(MP4.types.mdhd, new Uint8Array([0x00, // version 0 + 0x00, 0x00, 0x00, // flags + 0x00, 0x00, 0x00, 0x02, // creation_time + 0x00, 0x00, 0x00, 0x03, // modification_time + timescale >> 24 & 0xFF, timescale >> 16 & 0xFF, timescale >> 8 & 0xFF, timescale & 0xFF, // timescale + duration >> 24, duration >> 16 & 0xFF, duration >> 8 & 0xFF, duration & 0xFF, // duration + 0x55, 0xc4, // 'und' language (undetermined) + 0x00, 0x00])); } }, { key: 'mdia', @@ -4244,10 +4256,12 @@ var MP4 = (function () { }, { key: 'mfhd', value: function mfhd(sequenceNumber) { - return MP4.box(MP4.types.mfhd, new Uint8Array([0, 0, 0, 0, sequenceNumber >> 24, sequenceNumber >> 16 & 255, sequenceNumber >> 8 & 255, sequenceNumber & 255])); + return MP4.box(MP4.types.mfhd, new Uint8Array([0x00, 0x00, 0x00, 0x00, // flags + sequenceNumber >> 24, sequenceNumber >> 16 & 0xFF, sequenceNumber >> 8 & 0xFF, sequenceNumber & 0xFF])); } }, { key: 'minf', + // sequence_number value: function minf(track) { if (track.type === 'audio') { return MP4.box(MP4.types.minf, MP4.box(MP4.types.smhd, MP4.SMHD), MP4.DINF, MP4.stbl(track)); @@ -4260,12 +4274,12 @@ var MP4 = (function () { value: function moof(sn, baseMediaDecodeTime, track) { return MP4.box(MP4.types.moof, MP4.mfhd(sn), MP4.traf(track, baseMediaDecodeTime)); } - }, { - key: 'moov', /** * @param tracks... (optional) {array} the tracks associated with this movie */ + }, { + key: 'moov', value: function moov(tracks) { var i = tracks.length, boxes = []; @@ -4290,20 +4304,20 @@ var MP4 = (function () { }, { key: 'mvhd', value: function mvhd(timescale, duration) { - var bytes = new Uint8Array([0, // version 0 - 0, 0, 0, // flags - 0, 0, 0, 1, // creation_time - 0, 0, 0, 2, // modification_time - timescale >> 24 & 255, timescale >> 16 & 255, timescale >> 8 & 255, timescale & 255, // timescale - duration >> 24 & 255, duration >> 16 & 255, duration >> 8 & 255, duration & 255, // duration - 0, 1, 0, 0, // 1.0 rate - 1, 0, // 1.0 volume - 0, 0, // reserved - 0, 0, 0, 0, // reserved - 0, 0, 0, 0, // reserved - 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 64, 0, 0, 0, // transformation: unity matrix - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // pre_defined - 255, 255, 255, 255 // next_track_ID + var bytes = new Uint8Array([0x00, // version 0 + 0x00, 0x00, 0x00, // flags + 0x00, 0x00, 0x00, 0x01, // creation_time + 0x00, 0x00, 0x00, 0x02, // modification_time + timescale >> 24 & 0xFF, timescale >> 16 & 0xFF, timescale >> 8 & 0xFF, timescale & 0xFF, // timescale + duration >> 24 & 0xFF, duration >> 16 & 0xFF, duration >> 8 & 0xFF, duration & 0xFF, // duration + 0x00, 0x01, 0x00, 0x00, // 1.0 rate + 0x01, 0x00, // 1.0 volume + 0x00, 0x00, // reserved + 0x00, 0x00, 0x00, 0x00, // reserved + 0x00, 0x00, 0x00, 0x00, // reserved + 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x40, 0x00, 0x00, 0x00, // transformation: unity matrix + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // pre_defined + 0xff, 0xff, 0xff, 0xff // next_track_ID ]); return MP4.box(MP4.types.mvhd, bytes); } @@ -4338,80 +4352,80 @@ var MP4 = (function () { i; // assemble the SPSs for (i = 0; i < track.sps.length; i++) { - sps.push(track.sps[i].byteLength >>> 8 & 255); - sps.push(track.sps[i].byteLength & 255); // sequenceParameterSetLength + sps.push(track.sps[i].byteLength >>> 8 & 0xFF); + sps.push(track.sps[i].byteLength & 0xFF); // sequenceParameterSetLength sps = sps.concat(Array.prototype.slice.call(track.sps[i])); // SPS } // assemble the PPSs for (i = 0; i < track.pps.length; i++) { - pps.push(track.pps[i].byteLength >>> 8 & 255); - pps.push(track.pps[i].byteLength & 255); + pps.push(track.pps[i].byteLength >>> 8 & 0xFF); + pps.push(track.pps[i].byteLength & 0xFF); pps = pps.concat(Array.prototype.slice.call(track.pps[i])); } - return MP4.box(MP4.types.avc1, new Uint8Array([0, 0, 0, // reserved - 0, 0, 0, // reserved - 0, 1, // data_reference_index - 0, 0, // pre_defined - 0, 0, // reserved - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // pre_defined - track.width >> 8 & 255, track.width & 255, // width - track.height >> 8 & 255, track.height & 255, // height - 0, 72, 0, 0, // horizresolution - 0, 72, 0, 0, // vertresolution - 0, 0, 0, 0, // reserved - 0, 1, // frame_count - 19, 118, 105, 100, 101, 111, 106, 115, 45, 99, 111, 110, 116, 114, 105, 98, 45, 104, 108, 115, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // compressorname - 0, 24, // depth = 24 - 17, 17]), // pre_defined = -1 - MP4.box(MP4.types.avcC, new Uint8Array([1, // configurationVersion + return MP4.box(MP4.types.avc1, new Uint8Array([0x00, 0x00, 0x00, // reserved + 0x00, 0x00, 0x00, // reserved + 0x00, 0x01, // data_reference_index + 0x00, 0x00, // pre_defined + 0x00, 0x00, // reserved + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // pre_defined + track.width >> 8 & 0xFF, track.width & 0xff, // width + track.height >> 8 & 0xFF, track.height & 0xff, // height + 0x00, 0x48, 0x00, 0x00, // horizresolution + 0x00, 0x48, 0x00, 0x00, // vertresolution + 0x00, 0x00, 0x00, 0x00, // reserved + 0x00, 0x01, // frame_count + 0x13, 0x76, 0x69, 0x64, 0x65, 0x6f, 0x6a, 0x73, 0x2d, 0x63, 0x6f, 0x6e, 0x74, 0x72, 0x69, 0x62, 0x2d, 0x68, 0x6c, 0x73, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // compressorname + 0x00, 0x18, // depth = 24 + 0x11, 0x11]), // pre_defined = -1 + MP4.box(MP4.types.avcC, new Uint8Array([0x01, // configurationVersion track.profileIdc, // AVCProfileIndication track.profileCompat, // profile_compatibility track.levelIdc, // AVCLevelIndication - 255 // lengthSizeMinusOne, hard-coded to 4 bytes + 0xff // lengthSizeMinusOne, hard-coded to 4 bytes ].concat([track.sps.length // numOfSequenceParameterSets ]).concat(sps).concat([track.pps.length // numOfPictureParameterSets ]).concat(pps))), // "PPS" - MP4.box(MP4.types.btrt, new Uint8Array([0, 28, 156, 128, // bufferSizeDB - 0, 45, 198, 192, // maxBitrate - 0, 45, 198, 192])) // avgBitrate + MP4.box(MP4.types.btrt, new Uint8Array([0x00, 0x1c, 0x9c, 0x80, // bufferSizeDB + 0x00, 0x2d, 0xc6, 0xc0, // maxBitrate + 0x00, 0x2d, 0xc6, 0xc0])) // avgBitrate ); } }, { key: 'esds', value: function esds(track) { - return new Uint8Array([0, // version 0 - 0, 0, 0, // flags + return new Uint8Array([0x00, // version 0 + 0x00, 0x00, 0x00, // flags - 3, // descriptor_type - 23 + track.config.length, // length - 0, 1, //es_id - 0, // stream_priority + 0x03, // descriptor_type + 0x17 + track.config.length, // length + 0x00, 0x01, //es_id + 0x00, // stream_priority - 4, // descriptor_type - 15 + track.config.length, // length - 64, //codec : mpeg4_audio - 21, // stream_type - 0, 0, 0, // buffer_size - 0, 0, 0, 0, // maxBitrate - 0, 0, 0, 0, // avgBitrate + 0x04, // descriptor_type + 0x0f + track.config.length, // length + 0x40, //codec : mpeg4_audio + 0x15, // stream_type + 0x00, 0x00, 0x00, // buffer_size + 0x00, 0x00, 0x00, 0x00, // maxBitrate + 0x00, 0x00, 0x00, 0x00, // avgBitrate - 5 // descriptor_type - ].concat([track.config.length]).concat(track.config).concat([6, 1, 2])); // GASpecificConfig)); // length + audio config descriptor + 0x05 // descriptor_type + ].concat([track.config.length]).concat(track.config).concat([0x06, 0x01, 0x02])); // GASpecificConfig)); // length + audio config descriptor } }, { key: 'mp4a', value: function mp4a(track) { - return MP4.box(MP4.types.mp4a, new Uint8Array([0, 0, 0, // reserved - 0, 0, 0, // reserved - 0, 1, // data_reference_index - 0, 0, 0, 0, 0, 0, 0, 0, // reserved - 0, track.channelCount, // channelcount - 0, 16, // sampleSize:16bits - 0, 0, 0, 0, // reserved2 - track.audiosamplerate >> 8 & 255, track.audiosamplerate & 255, // - 0, 0]), MP4.box(MP4.types.esds, MP4.esds(track))); + return MP4.box(MP4.types.mp4a, new Uint8Array([0x00, 0x00, 0x00, // reserved + 0x00, 0x00, 0x00, // reserved + 0x00, 0x01, // data_reference_index + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // reserved + 0x00, track.channelCount, // channelcount + 0x00, 0x10, // sampleSize:16bits + 0x00, 0x00, 0x00, 0x00, // reserved2 + track.audiosamplerate >> 8 & 0xFF, track.audiosamplerate & 0xff, // + 0x00, 0x00]), MP4.box(MP4.types.esds, MP4.esds(track))); } }, { key: 'stsd', @@ -4425,29 +4439,34 @@ var MP4 = (function () { }, { key: 'tkhd', value: function tkhd(track) { - return MP4.box(MP4.types.tkhd, new Uint8Array([0, // version 0 - 0, 0, 7, // flags - 0, 0, 0, 0, // creation_time - 0, 0, 0, 0, // modification_time - track.id >> 24 & 255, track.id >> 16 & 255, track.id >> 8 & 255, track.id & 255, // track_ID - 0, 0, 0, 0, track.duration >> 24, track.duration >> 16 & 255, track.duration >> 8 & 255, track.duration & 255, // duration - 0, 0, 0, 0, 0, 0, 0, 0, // reserved - 0, 0, // layer - 0, 0, // alternate_group - 0, 0, // non-audio track volume - 0, 0, // reserved - 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 64, 0, 0, 0, // transformation: unity matrix - track.width >> 8 & 255, track.width & 255, 0, 0, // width - track.height >> 8 & 255, track.height & 255, 0, 0 // height + return MP4.box(MP4.types.tkhd, new Uint8Array([0x00, // version 0 + 0x00, 0x00, 0x07, // flags + 0x00, 0x00, 0x00, 0x00, // creation_time + 0x00, 0x00, 0x00, 0x00, // modification_time + track.id >> 24 & 0xFF, track.id >> 16 & 0xFF, track.id >> 8 & 0xFF, track.id & 0xFF, // track_ID + 0x00, 0x00, 0x00, 0x00, // reserved + track.duration >> 24, track.duration >> 16 & 0xFF, track.duration >> 8 & 0xFF, track.duration & 0xFF, // duration + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // reserved + 0x00, 0x00, // layer + 0x00, 0x00, // alternate_group + 0x00, 0x00, // non-audio track volume + 0x00, 0x00, // reserved + 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x40, 0x00, 0x00, 0x00, // transformation: unity matrix + track.width >> 8 & 0xFF, track.width & 0xFF, 0x00, 0x00, // width + track.height >> 8 & 0xFF, track.height & 0xFF, 0x00, 0x00 // height ])); } }, { key: 'traf', value: function traf(track, baseMediaDecodeTime) { var sampleDependencyTable = MP4.sdtp(track); - return MP4.box(MP4.types.traf, MP4.box(MP4.types.tfhd, new Uint8Array([0, // version 0 - 0, 0, 0, track.id >> 24, track.id >> 16 & 255, track.id >> 8 & 255, track.id & 255])), MP4.box(MP4.types.tfdt, new Uint8Array([0, // version 0 - 0, 0, 0, baseMediaDecodeTime >> 24, baseMediaDecodeTime >> 16 & 255, baseMediaDecodeTime >> 8 & 255, baseMediaDecodeTime & 255])), MP4.trun(track, sampleDependencyTable.length + 16 + // tfhd + return MP4.box(MP4.types.traf, MP4.box(MP4.types.tfhd, new Uint8Array([0x00, // version 0 + 0x00, 0x00, 0x00, // flags + track.id >> 24, track.id >> 16 & 0XFF, track.id >> 8 & 0XFF, track.id & 0xFF])), // track_ID + MP4.box(MP4.types.tfdt, new Uint8Array([0x00, // version 0 + 0x00, 0x00, 0x00, // flags + baseMediaDecodeTime >> 24, baseMediaDecodeTime >> 16 & 0XFF, baseMediaDecodeTime >> 8 & 0XFF, baseMediaDecodeTime & 0xFF])), // baseMediaDecodeTime + MP4.trun(track, sampleDependencyTable.length + 16 + // tfhd 16 + // tfdt 8 + // traf header 16 + // mfhd @@ -4455,27 +4474,28 @@ var MP4 = (function () { 8), // mdat header sampleDependencyTable); } - }, { - key: 'trak', /** * Generate a track box. * @param track {object} a track definition * @return {Uint8Array} the track box */ + }, { + key: 'trak', value: function trak(track) { - track.duration = track.duration || 4294967295; + track.duration = track.duration || 0xffffffff; return MP4.box(MP4.types.trak, MP4.tkhd(track), MP4.mdia(track)); } }, { key: 'trex', value: function trex(track) { - return MP4.box(MP4.types.trex, new Uint8Array([0, // version 0 - 0, 0, 0, track.id >> 24, track.id >> 16 & 255, track.id >> 8 & 255, track.id & 255, // track_ID - 0, 0, 0, 1, // default_sample_description_index - 0, 0, 0, 0, // default_sample_duration - 0, 0, 0, 0, // default_sample_size - 0, 1, 0, 1 // default_sample_flags + return MP4.box(MP4.types.trex, new Uint8Array([0x00, // version 0 + 0x00, 0x00, 0x00, // flags + track.id >> 24, track.id >> 16 & 0XFF, track.id >> 8 & 0XFF, track.id & 0xFF, // track_ID + 0x00, 0x00, 0x00, 0x01, // default_sample_description_index + 0x00, 0x00, 0x00, 0x00, // default_sample_duration + 0x00, 0x00, 0x00, 0x00, // default_sample_size + 0x00, 0x01, 0x00, 0x01 // default_sample_flags ])); } }, { @@ -4487,18 +4507,18 @@ var MP4 = (function () { array = new Uint8Array(12 + 16 * samples.length); offset += 8 + array.byteLength; - array.set([0, // version 0 - 0, 15, 1, // flags - samples.length >>> 24 & 255, samples.length >>> 16 & 255, samples.length >>> 8 & 255, samples.length & 255, // sample_count - offset >>> 24 & 255, offset >>> 16 & 255, offset >>> 8 & 255, offset & 255 // data_offset + array.set([0x00, // version 0 + 0x00, 0x0f, 0x01, // flags + samples.length >>> 24 & 0xFF, samples.length >>> 16 & 0xFF, samples.length >>> 8 & 0xFF, samples.length & 0xFF, // sample_count + offset >>> 24 & 0xFF, offset >>> 16 & 0xFF, offset >>> 8 & 0xFF, offset & 0xFF // data_offset ], 0); for (i = 0; i < samples.length; i++) { sample = samples[i]; - array.set([sample.duration >>> 24 & 255, sample.duration >>> 16 & 255, sample.duration >>> 8 & 255, sample.duration & 255, // sample_duration - sample.size >>> 24 & 255, sample.size >>> 16 & 255, sample.size >>> 8 & 255, sample.size & 255, // sample_size - sample.flags.isLeading << 2 | sample.flags.dependsOn, sample.flags.isDependedOn << 6 | sample.flags.hasRedundancy << 4 | sample.flags.paddingValue << 1 | sample.flags.isNonSync, sample.flags.degradPrio & 240 << 8, sample.flags.degradPrio & 15, // sample_flags - sample.cts >>> 24 & 255, sample.cts >>> 16 & 255, sample.cts >>> 8 & 255, sample.cts & 255 // sample_composition_time_offset + array.set([sample.duration >>> 24 & 0xFF, sample.duration >>> 16 & 0xFF, sample.duration >>> 8 & 0xFF, sample.duration & 0xFF, // sample_duration + sample.size >>> 24 & 0xFF, sample.size >>> 16 & 0xFF, sample.size >>> 8 & 0xFF, sample.size & 0xFF, // sample_size + sample.flags.isLeading << 2 | sample.flags.dependsOn, sample.flags.isDependedOn << 6 | sample.flags.hasRedundancy << 4 | sample.flags.paddingValue << 1 | sample.flags.isNonSync, sample.flags.degradPrio & 0xF0 << 8, sample.flags.degradPrio & 0x0F, // sample_flags + sample.cts >>> 24 & 0xFF, sample.cts >>> 16 & 0xFF, sample.cts >>> 8 & 0xFF, sample.cts & 0xFF // sample_composition_time_offset ], 12 + 16 * i); } return MP4.box(MP4.types.trun, array); @@ -4525,16 +4545,6 @@ var MP4 = (function () { exports['default'] = MP4; module.exports = exports['default']; -// sample_count -// timescale -// flags -// sequence_number -// reserved -// flags -// track_ID -// flags -// baseMediaDecodeTime -// flags },{}],16:[function(require,module,exports){ /* @@ -4601,17 +4611,17 @@ var StatsHandler = (function () { value: function detachVideo() { this.video = null; } - }, { - key: 'onManifestParsed', // reset stats on manifest parsed + }, { + key: 'onManifestParsed', value: function onManifestParsed(event, data) { this._stats = { tech: 'hls.js', levelNb: data.levels.length }; } - }, { - key: 'onFragmentChanged', // on fragment changed is triggered whenever playback of a new fragment is starting ... + }, { + key: 'onFragmentChanged', value: function onFragmentChanged(event, data) { var stats = this._stats, level = data.frag.level, @@ -4655,10 +4665,10 @@ var StatsHandler = (function () { this.levelLastAuto = autoLevel; } } - }, { - key: 'onFragmentBuffered', // triggered each time a new fragment is buffered + }, { + key: 'onFragmentBuffered', value: function onFragmentBuffered(event, data) { var stats = this._stats, latency = data.stats.tfirst - data.stats.trequest, @@ -4745,7 +4755,7 @@ var StatsHandler = (function () { } }, { key: 'stats', - get: function () { + get: function get() { if (this.video) { this._stats.lastPos = this.video.currentTime.toFixed(3); } @@ -4842,7 +4852,7 @@ var XhrLoader = (function () { }, { key: 'load', value: function load(url, responseType, onSuccess, onError, onTimeout, timeout, maxRetry, retryDelay) { - var onProgress = arguments[8] === undefined ? null : arguments[8]; + var onProgress = arguments.length <= 8 || arguments[8] === undefined ? null : arguments[8]; this.url = url; this.responseType = responseType; @@ -4881,7 +4891,7 @@ var XhrLoader = (function () { key: 'loaderror', value: function loaderror(event) { if (this.stats.retry < this.maxRetry) { - _utilsLogger.logger.warn('' + event.type + ' while loading ' + this.url + ', retrying in ' + this.retryDelay + '...'); + _utilsLogger.logger.warn(event.type + ' while loading ' + this.url + ', retrying in ' + this.retryDelay + '...'); this.destroy(); window.setTimeout(this.loadInternal.bind(this), this.retryDelay); // exponential backoff @@ -4889,7 +4899,7 @@ var XhrLoader = (function () { this.stats.retry++; } else { window.clearTimeout(this.timeoutHandle); - _utilsLogger.logger.error('' + event.type + ' while loading ' + this.url); + _utilsLogger.logger.error(event.type + ' while loading ' + this.url); this.onError(event); } } @@ -4921,4 +4931,4 @@ module.exports = exports['default']; },{"../utils/logger":17}]},{},[11])(11) }); -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/watchify/node_modules/browserify/node_modules/browser-pack/_prelude.js","node_modules/watchify/node_modules/browserify/node_modules/events/events.js","node_modules/webworkify/index.js","/Users/g.dupontavice/workdir/github/hls.js/src/controller/buffer-controller.js","/Users/g.dupontavice/workdir/github/hls.js/src/controller/level-controller.js","/Users/g.dupontavice/workdir/github/hls.js/src/demux/demuxer.js","/Users/g.dupontavice/workdir/github/hls.js/src/demux/exp-golomb.js","/Users/g.dupontavice/workdir/github/hls.js/src/demux/tsdemuxer.js","/Users/g.dupontavice/workdir/github/hls.js/src/demux/tsdemuxerworker.js","/Users/g.dupontavice/workdir/github/hls.js/src/errors.js","/Users/g.dupontavice/workdir/github/hls.js/src/events.js","/Users/g.dupontavice/workdir/github/hls.js/src/hls.js","/Users/g.dupontavice/workdir/github/hls.js/src/loader/fragment-loader.js","/Users/g.dupontavice/workdir/github/hls.js/src/loader/playlist-loader.js","/Users/g.dupontavice/workdir/github/hls.js/src/observer.js","/Users/g.dupontavice/workdir/github/hls.js/src/remux/mp4-generator.js","/Users/g.dupontavice/workdir/github/hls.js/src/stats.js","/Users/g.dupontavice/workdir/github/hls.js/src/utils/logger.js","/Users/g.dupontavice/workdir/github/hls.js/src/utils/xhr-loader.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7SA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;sBClDkC,WAAW;;;;wBACX,aAAa;;;;2BACb,iBAAiB;;4BACjB,kBAAkB;;;;sBACb,WAAW;;IAE3C,gBAAgB;AAEV,WAFN,gBAAgB,CAET,GAAG,EAAE;0BAFZ,gBAAgB;;AAGnB,QAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;AAChB,QAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;AACnB,QAAI,CAAC,IAAI,GAAG,CAAC,CAAC;AACd,QAAI,CAAC,OAAO,GAAI,CAAC,CAAC;AAClB,QAAI,CAAC,aAAa,GAAG,CAAC,CAAC;AACvB,QAAI,CAAC,OAAO,GAAG,CAAC,CAAC;AACjB,QAAI,CAAC,MAAM,GAAG,CAAC,CAAC;AAChB,QAAI,CAAC,SAAS,GAAG,CAAC,CAAC;AACnB,QAAI,CAAC,eAAe,GAAG,CAAC,CAAC;AACzB,QAAI,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC;AACzB,QAAI,CAAC,aAAa,GAAG,CAAC,CAAC;AACvB,QAAI,CAAC,GAAG,GAAG,GAAG,CAAC;;A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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nfunction EventEmitter() {\n  this._events = this._events || {};\n  this._maxListeners = this._maxListeners || undefined;\n}\nmodule.exports = EventEmitter;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nEventEmitter.defaultMaxListeners = 10;\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function(n) {\n  if (!isNumber(n) || n < 0 || isNaN(n))\n    throw TypeError('n must be a positive number');\n  this._maxListeners = n;\n  return this;\n};\n\nEventEmitter.prototype.emit = function(type) {\n  var er, handler, len, args, i, listeners;\n\n  if (!this._events)\n    this._events = {};\n\n  // If there is no 'error' event listener then throw.\n  if (type === 'error') {\n    if (!this._events.error ||\n        (isObject(this._events.error) && !this._events.error.length)) {\n      er = arguments[1];\n      if (er instanceof Error) {\n        throw er; // Unhandled 'error' event\n      }\n      throw TypeError('Uncaught, unspecified \"error\" event.');\n    }\n  }\n\n  handler = this._events[type];\n\n  if (isUndefined(handler))\n    return false;\n\n  if (isFunction(handler)) {\n    switch (arguments.length) {\n      // fast cases\n      case 1:\n        handler.call(this);\n        break;\n      case 2:\n        handler.call(this, arguments[1]);\n        break;\n      case 3:\n        handler.call(this, arguments[1], arguments[2]);\n        break;\n      // slower\n      default:\n        len = arguments.length;\n        args = new Array(len - 1);\n        for (i = 1; i < len; i++)\n          args[i - 1] = arguments[i];\n        handler.apply(this, args);\n    }\n  } else if (isObject(handler)) {\n    len = arguments.length;\n    args = new Array(len - 1);\n    for (i = 1; i < len; i++)\n      args[i - 1] = arguments[i];\n\n    listeners = handler.slice();\n    len = listeners.length;\n    for (i = 0; i < len; i++)\n      listeners[i].apply(this, args);\n  }\n\n  return true;\n};\n\nEventEmitter.prototype.addListener = function(type, listener) {\n  var m;\n\n  if (!isFunction(listener))\n    throw TypeError('listener must be a function');\n\n  if (!this._events)\n    this._events = {};\n\n  // To avoid recursion in the case that type === \"newListener\"! Before\n  // adding it to the listeners, first emit \"newListener\".\n  if (this._events.newListener)\n    this.emit('newListener', type,\n              isFunction(listener.listener) ?\n              listener.listener : listener);\n\n  if (!this._events[type])\n    // Optimize the case of one listener. Don't need the extra array object.\n    this._events[type] = listener;\n  else if (isObject(this._events[type]))\n    // If we've already got an array, just append.\n    this._events[type].push(listener);\n  else\n    // Adding the second element, need to change to array.\n    this._events[type] = [this._events[type], listener];\n\n  // Check for listener leak\n  if (isObject(this._events[type]) && !this._events[type].warned) {\n    var m;\n    if (!isUndefined(this._maxListeners)) {\n      m = this._maxListeners;\n    } else {\n      m = EventEmitter.defaultMaxListeners;\n    }\n\n    if (m && m > 0 && this._events[type].length > m) {\n      this._events[type].warned = true;\n      console.error('(node) warning: possible EventEmitter memory ' +\n                    'leak detected. %d listeners added. ' +\n                    'Use emitter.setMaxListeners() to increase limit.',\n                    this._events[type].length);\n      if (typeof console.trace === 'function') {\n        // not supported in IE 10\n        console.trace();\n      }\n    }\n  }\n\n  return this;\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.once = function(type, listener) {\n  if (!isFunction(listener))\n    throw TypeError('listener must be a function');\n\n  var fired = false;\n\n  function g() {\n    this.removeListener(type, g);\n\n    if (!fired) {\n      fired = true;\n      listener.apply(this, arguments);\n    }\n  }\n\n  g.listener = listener;\n  this.on(type, g);\n\n  return this;\n};\n\n// emits a 'removeListener' event iff the listener was removed\nEventEmitter.prototype.removeListener = function(type, listener) {\n  var list, position, length, i;\n\n  if (!isFunction(listener))\n    throw TypeError('listener must be a function');\n\n  if (!this._events || !this._events[type])\n    return this;\n\n  list = this._events[type];\n  length = list.length;\n  position = -1;\n\n  if (list === listener ||\n      (isFunction(list.listener) && list.listener === listener)) {\n    delete this._events[type];\n    if (this._events.removeListener)\n      this.emit('removeListener', type, listener);\n\n  } else if (isObject(list)) {\n    for (i = length; i-- > 0;) {\n      if (list[i] === listener ||\n          (list[i].listener && list[i].listener === listener)) {\n        position = i;\n        break;\n      }\n    }\n\n    if (position < 0)\n      return this;\n\n    if (list.length === 1) {\n      list.length = 0;\n      delete this._events[type];\n    } else {\n      list.splice(position, 1);\n    }\n\n    if (this._events.removeListener)\n      this.emit('removeListener', type, listener);\n  }\n\n  return this;\n};\n\nEventEmitter.prototype.removeAllListeners = function(type) {\n  var key, listeners;\n\n  if (!this._events)\n    return this;\n\n  // not listening for removeListener, no need to emit\n  if (!this._events.removeListener) {\n    if (arguments.length === 0)\n      this._events = {};\n    else if (this._events[type])\n      delete this._events[type];\n    return this;\n  }\n\n  // emit removeListener for all listeners on all events\n  if (arguments.length === 0) {\n    for (key in this._events) {\n      if (key === 'removeListener') continue;\n      this.removeAllListeners(key);\n    }\n    this.removeAllListeners('removeListener');\n    this._events = {};\n    return this;\n  }\n\n  listeners = this._events[type];\n\n  if (isFunction(listeners)) {\n    this.removeListener(type, listeners);\n  } else {\n    // LIFO order\n    while (listeners.length)\n      this.removeListener(type, listeners[listeners.length - 1]);\n  }\n  delete this._events[type];\n\n  return this;\n};\n\nEventEmitter.prototype.listeners = function(type) {\n  var ret;\n  if (!this._events || !this._events[type])\n    ret = [];\n  else if (isFunction(this._events[type]))\n    ret = [this._events[type]];\n  else\n    ret = this._events[type].slice();\n  return ret;\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n  var ret;\n  if (!emitter._events || !emitter._events[type])\n    ret = 0;\n  else if (isFunction(emitter._events[type]))\n    ret = 1;\n  else\n    ret = emitter._events[type].length;\n  return ret;\n};\n\nfunction isFunction(arg) {\n  return typeof arg === 'function';\n}\n\nfunction isNumber(arg) {\n  return typeof arg === 'number';\n}\n\nfunction isObject(arg) {\n  return typeof arg === 'object' && arg !== null;\n}\n\nfunction isUndefined(arg) {\n  return arg === void 0;\n}\n","var bundleFn = arguments[3];\nvar sources = arguments[4];\nvar cache = arguments[5];\n\nvar stringify = JSON.stringify;\n\nmodule.exports = function (fn) {\n    var keys = [];\n    var wkey;\n    var cacheKeys = Object.keys(cache);\n    \n    for (var i = 0, l = cacheKeys.length; i < l; i++) {\n        var key = cacheKeys[i];\n        if (cache[key].exports === fn) {\n            wkey = key;\n            break;\n        }\n    }\n    \n    if (!wkey) {\n        wkey = Math.floor(Math.pow(16, 8) * Math.random()).toString(16);\n        var wcache = {};\n        for (var i = 0, l = cacheKeys.length; i < l; i++) {\n            var key = cacheKeys[i];\n            wcache[key] = key;\n        }\n        sources[wkey] = [\n            Function(['require','module','exports'], '(' + fn + ')(self)'),\n            wcache\n        ];\n    }\n    var skey = Math.floor(Math.pow(16, 8) * Math.random()).toString(16);\n    \n    var scache = {}; scache[wkey] = wkey;\n    sources[skey] = [\n        Function(['require'],'require(' + stringify(wkey) + ')(self)'),\n        scache\n    ];\n    \n    var src = '(' + bundleFn + ')({'\n        + Object.keys(sources).map(function (key) {\n            return stringify(key) + ':['\n                + sources[key][0]\n                + ',' + stringify(sources[key][1]) + ']'\n            ;\n        }).join(',')\n        + '},{},[' + stringify(skey) + '])'\n    ;\n    \n    var URL = window.URL || window.webkitURL || window.mozURL || window.msURL;\n    \n    return new Worker(URL.createObjectURL(\n        new Blob([src], { type: 'text/javascript' })\n    ));\n};\n","/*\n * buffer controller\n *\n */\n\n import Event                from '../events';\n import observer             from '../observer';\n import {logger}             from '../utils/logger';\n import Demuxer              from '../demux/demuxer';\n import {ErrorTypes,ErrorDetails} from '../errors';\n\n class BufferController {\n\n  constructor(hls) {\n    this.ERROR = -2;\n    this.STARTING = -1;\n    this.IDLE = 0;\n    this.LOADING =  1;\n    this.WAITING_LEVEL = 2;\n    this.PARSING = 3;\n    this.PARSED = 4;\n    this.APPENDING = 5;\n    this.BUFFER_FLUSHING = 6;\n    this.config = hls.config;\n    this.startPosition = 0;\n    this.hls = hls;\n    // Source Buffer listeners\n    this.onsbue = this.onSourceBufferUpdateEnd.bind(this);\n    this.onsbe  = this.onSourceBufferError.bind(this);\n    // internal listeners\n    this.onmse = this.onMSEAttached.bind(this);\n    this.onmsed = this.onMSEDetached.bind(this);\n    this.onmp = this.onManifestParsed.bind(this);\n    this.onll = this.onLevelLoaded.bind(this);\n    this.onfl = this.onFragmentLoaded.bind(this);\n    this.onis = this.onInitSegment.bind(this);\n    this.onfpg = this.onFragmentParsing.bind(this);\n    this.onfp = this.onFragmentParsed.bind(this);\n    this.onerr = this.onError.bind(this);\n    this.ontick = this.tick.bind(this);\n    observer.on(Event.MSE_ATTACHED, this.onmse);\n    observer.on(Event.MSE_DETACHED, this.onmsed);\n    observer.on(Event.MANIFEST_PARSED, this.onmp);\n  }\n  destroy() {\n    this.stop();\n    observer.off(Event.MANIFEST_PARSED, this.onmp);\n    // remove video listener\n    if(this.video) {\n      this.video.removeEventListener('seeking',this.onvseeking);\n      this.video.removeEventListener('seeked',this.onvseeked);\n      this.video.removeEventListener('loadedmetadata',this.onvmetadata);\n      this.onvseeking = this.onvseeked = this.onvmetadata = null;\n    }\n    this.state = this.IDLE;\n  }\n\n  startLoad() {\n    if(this.levels && this.video) {\n      this.startInternal();\n      if(this.lastCurrentTime) {\n        logger.log(`resuming video @ ${this.lastCurrentTime}`);\n        this.nextLoadPosition = this.startPosition = this.lastCurrentTime;\n        this.state = this.IDLE;\n      } else {\n        this.state = this.STARTING;\n      }\n      this.tick();\n    } else {\n      logger.warn(`cannot start loading as either manifest not parsed or video not attached`);\n    }\n  }\n\n  startInternal() {\n    this.stop();\n    this.demuxer = new Demuxer(this.config);\n    this.timer = setInterval(this.ontick, 100);\n    this.level = -1;\n    observer.on(Event.FRAG_LOADED, this.onfl);\n    observer.on(Event.FRAG_PARSING_INIT_SEGMENT, this.onis);\n    observer.on(Event.FRAG_PARSING_DATA, this.onfpg);\n    observer.on(Event.FRAG_PARSED, this.onfp);\n    observer.on(Event.ERROR, this.onerr);\n    observer.on(Event.LEVEL_LOADED, this.onll);\n  }\n\n\n  stop() {\n    this.mp4segments = [];\n    this.flushRange = [];\n    this.bufferRange = [];\n    if(this.frag) {\n      if(this.frag.loader) {\n        this.frag.loader.abort();\n      }\n      this.frag = null;\n    }\n    if(this.sourceBuffer) {\n      for(var type in this.sourceBuffer) {\n        var sb = this.sourceBuffer[type];\n        try {\n          this.mediaSource.removeSourceBuffer(sb);\n          sb.removeEventListener('updateend', this.onsbue);\n          sb.removeEventListener('error', this.onsbe);\n        } catch(err) {\n\n        }\n      }\n      this.sourceBuffer = null;\n    }\n    if(this.timer) {\n      clearInterval(this.timer);\n      this.timer = null;\n    }\n    if(this.demuxer) {\n      this.demuxer.destroy();\n      this.demuxer = null;\n    }\n    observer.off(Event.FRAG_LOADED, this.onfl);\n    observer.off(Event.FRAG_PARSED, this.onfp);\n    observer.off(Event.FRAG_PARSING_DATA, this.onfpg);\n    observer.off(Event.LEVEL_LOADED, this.onll);\n    observer.off(Event.FRAG_PARSING_INIT_SEGMENT, this.onis);\n    observer.off(Event.ERROR, this.onerr);\n  }\n\n  tick() {\n    var pos,level,levelDetails,fragIdx;\n    switch(this.state) {\n      case this.ERROR:\n        //don't do anything in error state to avoid breaking further ...\n        break;\n      case this.STARTING:\n        // determine load level\n        this.startLevel = this.hls.startLevel;\n        if (this.startLevel === -1) {\n          // -1 : guess start Level by doing a bitrate test by loading first fragment of lowest quality level\n          this.startLevel = 0;\n          this.fragmentBitrateTest = true;\n        }\n        // set new level to playlist loader : this will trigger start level load\n        this.hls.nextLoadLevel = this.startLevel;\n        this.state = this.WAITING_LEVEL;\n        this.loadedmetadata = false;\n        break;\n      case this.IDLE:\n        // handle end of immediate switching if needed\n        if(this.immediateSwitch) {\n          this.immediateLevelSwitchEnd();\n          break;\n        }\n\n        // seek back to a expected position after video stalling\n        if(this.seekAfterStalling) {\n          this.video.currentTime=this.seekAfterStalling;\n          this.seekAfterStalling = undefined;\n        }\n\n        // determine next candidate fragment to be loaded, based on current position and\n        //  end of buffer position\n        //  ensure 60s of buffer upfront\n        // if we have not yet loaded any fragment, start loading from start position\n        if(this.loadedmetadata) {\n          pos = this.video.currentTime;\n        } else {\n          pos = this.nextLoadPosition;\n        }\n        // determine next load level\n        if(this.startFragmentRequested === false) {\n          level = this.startLevel;\n        } else {\n          // we are not at playback start, get next load level from level Controller\n          level = this.hls.nextLoadLevel;\n        }\n        var bufferInfo = this.bufferInfo(pos), bufferLen = bufferInfo.len, bufferEnd = bufferInfo.end, maxBufLen;\n        // compute max Buffer Length that we could get from this load level, based on level bitrate. don't buffer more than 60 MB and more than 30s\n        if((this.levels[level]).hasOwnProperty('bitrate')) {\n          maxBufLen = Math.max(8*this.config.maxBufferSize/this.levels[level].bitrate,this.config.maxBufferLength);\n          maxBufLen = Math.min(maxBufLen,this.config.maxMaxBufferLength);\n        } else {\n          maxBufLen = this.config.maxBufferLength;\n        }\n        // if buffer length is less than maxBufLen try to load a new fragment\n        if(bufferLen < maxBufLen) {\n          // set next load level : this will trigger a playlist load if needed\n          this.hls.nextLoadLevel = level;\n          this.level = level;\n          levelDetails = this.levels[level].details;\n          // if level info not retrieved yet, switch state and wait for level retrieval\n          if(typeof levelDetails === 'undefined') {\n            this.state = this.WAITING_LEVEL;\n            break;\n          }\n          // find fragment index, contiguous with end of buffer position\n          let fragments = levelDetails.fragments, frag, sliding = levelDetails.sliding, start = fragments[0].start + sliding, drift =0;\n          // check if requested position is within seekable boundaries :\n          // in case of live playlist we need to ensure that requested position is not located before playlist start\n          //logger.log(`start/pos/bufEnd/seeking:${start.toFixed(3)}/${pos.toFixed(3)}/${bufferEnd.toFixed(3)}/${this.video.seeking}`);\n          if(bufferEnd < start) {\n              this.seekAfterStalling = this.startPosition + sliding;\n              logger.log(`buffer end: ${bufferEnd} is located before start of live sliding playlist, media position will be reseted to: ${this.seekAfterStalling.toFixed(3)}`);\n              bufferEnd = this.seekAfterStalling;\n          }\n\n          if(levelDetails.live && levelDetails.sliding === undefined) {\n            /* we are switching level on live playlist, but we don't have any sliding info ...\n               try to load frag matching with next SN.\n               even if SN are not synchronized between playlists, loading this frag will help us\n               compute playlist sliding and find the right one after in case it was not the right consecutive one */\n            if(this.frag) {\n              var targetSN = this.frag.sn+1;\n              if(targetSN >= levelDetails.startSN && targetSN <= levelDetails.endSN) {\n                frag = fragments[targetSN-levelDetails.startSN];\n                logger.log(`live playlist, switching playlist, load frag with next SN: ${frag.sn}`);\n              }\n            }\n            if(!frag) {\n              /* we have no idea about which fragment should be loaded.\n                 so let's load mid fragment. it will help computing playlist sliding and find the right one\n              */\n              frag = fragments[Math.round(fragments.length/2)];\n              logger.log(`live playlist, switching playlist, unknown, load middle frag : ${frag.sn}`);\n            }\n          } else {\n          //look for fragments matching with current play position\n            for (fragIdx = 0; fragIdx < fragments.length ; fragIdx++) {\n              frag = fragments[fragIdx];\n              start = frag.start+sliding;\n              if(frag.drift) {\n                drift = frag.drift;\n              }\n              start+=drift;\n              //logger.log(`level/sn/sliding/drift/start/end/bufEnd:${level}/${frag.sn}/${sliding.toFixed(3)}/${drift.toFixed(3)}/${start.toFixed(3)}/${(start+frag.duration).toFixed(3)}/${bufferEnd.toFixed(3)}`);\n              // offset should be within fragment boundary\n              if(start <= bufferEnd && (start + frag.duration) > bufferEnd) {\n                break;\n              }\n            }\n            if(fragIdx === fragments.length) {\n              // reach end of playlist\n              break;\n            }\n            //logger.log('find SN matching with pos:' +  bufferEnd + ':' + frag.sn);\n            if(this.frag && frag.sn === this.frag.sn) {\n              if(fragIdx === (fragments.length -1)) {\n                // we are at the end of the playlist and we already loaded last fragment, don't do anything\n                break;\n              } else {\n                frag = fragments[fragIdx+1];\n                logger.log(`SN just loaded, load next one: ${frag.sn}`);\n              }\n            }\n          }\n          logger.log(`Loading       ${frag.sn} of [${levelDetails.startSN} ,${levelDetails.endSN}],level ${level}, currentTime:${pos},bufferEnd:${bufferEnd.toFixed(3)}`);\n          //logger.log('      loading frag ' + i +',pos/bufEnd:' + pos.toFixed(3) + '/' + bufferEnd.toFixed(3));\n          frag.drift = drift;\n          frag.autoLevel = this.hls.autoLevelEnabled;\n          if(this.levels.length>1) {\n            frag.expectedLen = Math.round(frag.duration*this.levels[level].bitrate/8);\n            frag.trequest = new Date();\n          }\n\n          // ensure that we are not reloading the same fragments in loop ...\n          if(this.fragLoadIdx !== undefined) {\n            this.fragLoadIdx++;\n          } else {\n            this.fragLoadIdx = 0;\n          }\n          if(frag.loadCounter) {\n            frag.loadCounter++;\n            let maxThreshold = this.config.fragLoadingLoopThreshold;\n            // if this frag has already been loaded 3 times, and if it has been reloaded recently\n            if(frag.loadCounter > maxThreshold && (Math.abs(this.fragLoadIdx - frag.loadIdx) < maxThreshold)) {\n              observer.trigger(Event.ERROR, {type : ErrorTypes.MEDIA_ERROR, details : ErrorDetails.FRAG_LOOP_LOADING_ERROR, fatal:false, frag : frag});\n              return;\n            }\n          } else {\n            frag.loadCounter=1;\n          }\n          frag.loadIdx = this.fragLoadIdx;\n          this.frag = frag;\n          this.startFragmentRequested = true;\n          observer.trigger(Event.FRAG_LOADING, { frag: frag });\n          this.state = this.LOADING;\n        }\n        break;\n      case this.WAITING_LEVEL:\n        level = this.levels[this.level];\n        // check if playlist is already loaded\n        if(level && level.details) {\n          this.state = this.IDLE;\n        }\n        break;\n      case this.LOADING:\n        /*\n          monitor fragment retrieval time...\n          we compute expected time of arrival of the complete fragment.\n          we compare it to expected time of buffer starvation\n        */\n        let v = this.video,frag = this.frag;\n        /* only monitor frag retrieval time if\n        (video not paused OR first fragment being loaded) AND autoswitching enabled AND not lowest level AND multiple levels */\n        if(v && (!v.paused || this.loadedmetadata === false) && frag.autoLevel && this.level && this.levels.length>1 ) {\n          var requestDelay=new Date()-frag.trequest;\n          // monitor fragment load progress after half of expected fragment duration,to stabilize bitrate\n          if(requestDelay > 500*frag.duration) {\n            var loadRate = frag.loaded*1000/requestDelay; // byte/s\n            if(frag.expectedLen < frag.loaded) {\n              frag.expectedLen = frag.loaded;\n            }\n            pos = v.currentTime;\n            var fragLoadedDelay =(frag.expectedLen-frag.loaded)/loadRate;\n            var bufferStarvationDelay=this.bufferInfo(pos).end-pos;\n            var fragLevelNextLoadedDelay = frag.duration*this.levels[this.hls.nextLoadLevel].bitrate/(8*loadRate); //bps/Bps\n            /* if we have less than 2 frag duration in buffer and if frag loaded delay is greater than buffer starvation delay\n              ... and also bigger than duration needed to load fragment at next level ...*/\n            if(bufferStarvationDelay < 2*frag.duration && fragLoadedDelay > bufferStarvationDelay && fragLoadedDelay > fragLevelNextLoadedDelay) {\n              // abort fragment loading ...\n              logger.warn('loading too slow, abort fragment loading');\n              logger.log(`fragLoadedDelay/bufferStarvationDelay/fragLevelNextLoadedDelay :${fragLoadedDelay.toFixed(1)}/${bufferStarvationDelay.toFixed(1)}/${fragLevelNextLoadedDelay.toFixed(1)}`);\n              //abort fragment loading\n              frag.loader.abort();\n              this.frag = null;\n              observer.trigger(Event.FRAG_LOAD_EMERGENCY_ABORTED, { frag: frag });\n              // switch back to IDLE state to request new fragment at lowest level\n              this.state = this.IDLE;\n            }\n          }\n        }\n        break;\n      case this.PARSING:\n        // nothing to do, wait for fragment being parsed\n        break;\n      case this.PARSED:\n      case this.APPENDING:\n        if (this.sourceBuffer) {\n          // if MP4 segment appending in progress nothing to do\n          if((this.sourceBuffer.audio && this.sourceBuffer.audio.updating) ||\n             (this.sourceBuffer.video && this.sourceBuffer.video.updating)) {\n            //logger.log('sb append in progress');\n        // check if any MP4 segments left to append\n          } else if(this.mp4segments.length) {\n            var segment = this.mp4segments.shift();\n            try {\n              //logger.log(`appending ${segment.type} SB, size:${segment.data.length}`);\n              this.sourceBuffer[segment.type].appendBuffer(segment.data);\n              this.appendError=0;\n            } catch(err) {\n              // in case any error occured while appending, put back segment in mp4segments table\n              logger.error(`error while trying to append buffer:${err.message},try appending later`);\n              this.mp4segments.unshift(segment);\n              if(this.appendError) {\n                this.appendError++;\n              } else {\n                this.appendError=1;\n              }\n              var event = {type : ErrorTypes.MEDIA_ERROR, details : ErrorDetails.FRAG_APPENDING_ERROR, frag : this.frag};\n              /* with UHD content, we could get loop of quota exceeded error until\n                browser is able to evict some data from sourcebuffer. retrying help recovering this\n              */\n              if(this.appendError > this.config.appendErrorMaxRetry) {\n                logger.log(`fail ${this.config.appendErrorMaxRetry} times to append segment in sourceBuffer`);\n                event.fatal = true;\n                observer.trigger(Event.ERROR, event);\n                this.state = this.ERROR;\n                return;\n              } else {\n                event.fatal = false;\n                observer.trigger(Event.ERROR, event);\n              }\n            }\n            this.state = this.APPENDING;\n          }\n        } else {\n          // sourceBuffer undefined, switch back to IDLE state\n          this.state = this.IDLE;\n        }\n        break;\n      case this.BUFFER_FLUSHING:\n        // loop through all buffer ranges to flush\n        while(this.flushRange.length) {\n          var range = this.flushRange[0];\n          // flushBuffer will abort any buffer append in progress and flush Audio/Video Buffer\n          if(this.flushBuffer(range.start,range.end)) {\n            // range flushed, remove from flush array\n            this.flushRange.shift();\n          } else {\n            // flush in progress, come back later\n            break;\n          }\n        }\n\n        if(this.flushRange.length === 0) {\n          // move to IDLE once flush complete. this should trigger new fragment loading\n          this.state = this.IDLE;\n          // reset reference to frag\n          this.frag = null;\n        }\n         /* if not everything flushed, stay in BUFFER_FLUSHING state. we will come back here\n            each time sourceBuffer updateend() callback will be triggered\n            */\n        break;\n      default:\n        break;\n    }\n    // check/update current fragment\n    this._checkFragmentChanged();\n  }\n\n   bufferInfo(pos) {\n    var v = this.video,\n        buffered = v.buffered,\n        bufferLen,\n        // bufferStart and bufferEnd are buffer boundaries around current video position\n        bufferStart,bufferEnd,\n        i;\n    var buffered2 = [];\n    // there might be some small holes between buffer time range\n    // consider that holes smaller than 300 ms are irrelevant and build another\n    // buffer time range representations that discards those holes\n    for(i = 0 ; i < buffered.length ; i++) {\n      //logger.log('buf start/end:' + buffered.start(i) + '/' + buffered.end(i));\n      if((buffered2.length) && (buffered.start(i) - buffered2[buffered2.length-1].end ) < 0.3) {\n        buffered2[buffered2.length-1].end = buffered.end(i);\n      } else {\n        buffered2.push({start : buffered.start(i),end : buffered.end(i)});\n      }\n    }\n\n    for(i = 0, bufferLen = 0, bufferStart = bufferEnd = pos ; i < buffered2.length ; i++) {\n      //logger.log('buf start/end:' + buffered.start(i) + '/' + buffered.end(i));\n      if((pos+0.3) >= buffered2[i].start && pos < buffered2[i].end) {\n        // play position is inside this buffer TimeRange, retrieve end of buffer position and buffer length\n        bufferStart = buffered2[i].start;\n        bufferEnd = buffered2[i].end + 0.3;\n        bufferLen = bufferEnd - pos;\n      }\n    }\n    return {len : bufferLen, start : bufferStart, end : bufferEnd};\n  }\n\n\n  getBufferRange(position) {\n    var i,range;\n    for (i = this.bufferRange.length-1; i >=0 ; i--) {\n      range = this.bufferRange[i];\n      if(position >= range.start && position <= range.end) {\n        return range;\n      }\n    }\n    return null;\n  }\n\n\n  get currentLevel() {\n    if(this.video) {\n      var range = this.getBufferRange(this.video.currentTime);\n      if(range) {\n        return range.frag.level;\n      }\n    }\n    return -1;\n  }\n\n  get nextBufferRange() {\n    if(this.video) {\n      // first get end range of current fragment\n      return this.followingBufferRange(this.getBufferRange(this.video.currentTime));\n    } else {\n      return null;\n    }\n  }\n\n  followingBufferRange(range) {\n    if(range) {\n      // try to get range of next fragment (500ms after this range)\n      return this.getBufferRange(range.end+0.5);\n    }\n    return null;\n  }\n\n\n  get nextLevel() {\n    var range = this.nextBufferRange;\n    if(range) {\n      return range.frag.level;\n    } else {\n      return -1;\n    }\n  }\n\n  isBuffered(position) {\n    var v = this.video,buffered = v.buffered;\n    for(var i = 0 ; i < buffered.length ; i++) {\n      if(position >= buffered.start(i) && position <= buffered.end(i)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  _checkFragmentChanged() {\n    var rangeCurrent, currentTime;\n    if(this.video && this.video.seeking === false) {\n      this.lastCurrentTime = currentTime = this.video.currentTime;\n      if(this.isBuffered(currentTime)) {\n        rangeCurrent = this.getBufferRange(currentTime);\n      } else if(this.isBuffered(currentTime+0.1)) {\n        /* ensure that FRAG_CHANGED event is triggered at startup,\n          when first video frame is displayed and playback is paused.\n          add a tolerance of 100ms, in case current position is not buffered,\n          check if current pos+100ms is buffered and use that buffer range\n          for FRAG_CHANGED event reporting */\n        rangeCurrent = this.getBufferRange(currentTime+0.1);\n      }\n      if(rangeCurrent) {\n        if(rangeCurrent.frag !== this.fragCurrent) {\n          this.fragCurrent = rangeCurrent.frag;\n          observer.trigger(Event.FRAG_CHANGED, { frag : this.fragCurrent });\n        }\n        // if stream is VOD (not live) and we reach End of Stream\n        var level = this.levels[this.level];\n        if(level && level.details && !level.details.live && (this.video.duration - currentTime) < 0.2) {\n          if(this.mediaSource && this.mediaSource.readyState === 'open') {\n            logger.log(`end of VoD stream reached, signal endOfStream() to MediaSource`);\n            this.mediaSource.endOfStream();\n          }\n        }\n      }\n    }\n  }\n\n/*\n  abort any buffer append in progress, and flush all buffered data\n  return true once everything has been flushed.\n  sourceBuffer.abort() and sourceBuffer.remove() are asynchronous operations\n  the idea is to call this function from tick() timer and call it again until all resources have been cleaned\n  the timer is rearmed upon sourceBuffer updateend() event, so this should be optimal\n*/\n  flushBuffer(startOffset, endOffset) {\n    var sb,i,bufStart,bufEnd, flushStart, flushEnd;\n    //logger.log('flushBuffer,pos/start/end: ' + this.video.currentTime + '/' + startOffset + '/' + endOffset);\n    // safeguard to avoid infinite looping\n    if(this.flushBufferCounter++ < 2*this.bufferRange.length && this.sourceBuffer) {\n      for(var type in this.sourceBuffer) {\n        sb = this.sourceBuffer[type];\n        if(!sb.updating) {\n          for(i = 0 ; i < sb.buffered.length ; i++) {\n            bufStart = sb.buffered.start(i);\n            bufEnd = sb.buffered.end(i);\n            // workaround firefox not able to properly flush multiple buffered range.\n            if(navigator.userAgent.toLowerCase().indexOf('firefox') !== -1 &&  endOffset === Number.POSITIVE_INFINITY) {\n              flushStart = startOffset;\n              flushEnd = endOffset;\n            } else {\n              flushStart = Math.max(bufStart,startOffset);\n              flushEnd = Math.min(bufEnd,endOffset);\n            }\n            /* sometimes sourcebuffer.remove() does not flush\n               the exact expected time range.\n               to avoid rounding issues/infinite loop,\n               only flush buffer range of length greater than 500ms.\n            */\n            if(flushEnd - flushStart > 0.5) {\n              logger.log(`flush ${type} [${flushStart},${flushEnd}], of [${bufStart},${bufEnd}], pos:${this.video.currentTime}`);\n              sb.remove(flushStart,flushEnd);\n              return false;\n            }\n          }\n        } else {\n          //logger.log('abort ' + type + ' append in progress');\n          // this will abort any appending in progress\n          //sb.abort();\n          return false;\n        }\n      }\n    }\n\n    /* after successful buffer flushing, rebuild buffer Range array\n      loop through existing buffer range and check if\n      corresponding range is still buffered. only push to new array already buffered range\n    */\n    var newRange = [],range;\n    for (i = 0 ; i < this.bufferRange.length ; i++) {\n      range = this.bufferRange[i];\n      if(this.isBuffered((range.start + range.end)/2)) {\n        newRange.push(range);\n      }\n    }\n    this.bufferRange = newRange;\n\n    logger.log('buffer flushed');\n    // everything flushed !\n    return true;\n  }\n\n    /*\n      on immediate level switch :\n       - pause playback if playing\n       - cancel any pending load request\n       - and trigger a buffer flush\n    */\n  immediateLevelSwitch() {\n    logger.log('immediateLevelSwitch');\n    if(!this.immediateSwitch) {\n      this.immediateSwitch = true;\n      this.previouslyPaused = this.video.paused;\n      this.video.pause();\n    }\n    if(this.frag && this.frag.loader) {\n      this.frag.loader.abort();\n    }\n    this.frag=null;\n    // flush everything\n    this.flushBufferCounter = 0;\n    this.flushRange.push({ start : 0, end : Number.POSITIVE_INFINITY});\n    // trigger a sourceBuffer flush\n    this.state = this.BUFFER_FLUSHING;\n    // increase fragment load Index to avoid frag loop loading error after buffer flush\n    this.fragLoadIdx+=2*this.config.fragLoadingLoopThreshold;\n    // speed up switching, trigger timer function\n    this.tick();\n  }\n\n/*\n   on immediate level switch end, after new fragment has been buffered :\n    - nudge video decoder by slightly adjusting video currentTime\n    - resume the playback if needed\n*/\n  immediateLevelSwitchEnd() {\n    this.immediateSwitch = false;\n    this.video.currentTime-=0.0001;\n    if(!this.previouslyPaused) {\n      this.video.play();\n    }\n  }\n\n  nextLevelSwitch() {\n    /* try to switch ASAP without breaking video playback :\n       in order to ensure smooth but quick level switching,\n      we need to find the next flushable buffer range\n      we should take into account new segment fetch time\n    */\n    var fetchdelay,currentRange,nextRange;\n\n    currentRange = this.getBufferRange(this.video.currentTime);\n    if(currentRange) {\n    // flush buffer preceding current fragment (flush until current fragment start offset)\n    // minus 1s to avoid video freezing, that could happen if we flush keyframe of current video ...\n      this.flushRange.push({ start : 0, end : currentRange.start-1});\n    }\n\n    if(!this.video.paused) {\n      // add a safety delay of 1s\n      var nextLevelId = this.hls.nextLoadLevel,nextLevel = this.levels[nextLevelId];\n      if(this.hls.stats.fragLastKbps && this.frag) {\n        fetchdelay = this.frag.duration*nextLevel.bitrate/(1000*this.hls.stats.fragLastKbps)+1;\n      } else {\n        fetchdelay = 0;\n      }\n    } else {\n      fetchdelay = 0;\n    }\n    //logger.log('fetchdelay:'+fetchdelay);\n    // find buffer range that will be reached once new fragment will be fetched\n    nextRange = this.getBufferRange(this.video.currentTime + fetchdelay);\n    if(nextRange) {\n      // we can flush buffer range following this one without stalling playback\n      nextRange = this.followingBufferRange(nextRange);\n      if(nextRange) {\n        // flush position is the start position of this new buffer\n        this.flushRange.push({ start : nextRange.start, end : Number.POSITIVE_INFINITY});\n      }\n    }\n    if(this.flushRange.length) {\n      this.flushBufferCounter = 0;\n      // trigger a sourceBuffer flush\n      this.state = this.BUFFER_FLUSHING;\n      // increase fragment load Index to avoid frag loop loading error after buffer flush\n      this.fragLoadIdx+=2*this.config.fragLoadingLoopThreshold;\n      // speed up switching, trigger timer function\n      this.tick();\n    }\n  }\n\n  onMSEAttached(event,data) {\n    this.video = data.video;\n    this.mediaSource = data.mediaSource;\n    this.onvseeking = this.onVideoSeeking.bind(this);\n    this.onvseeked = this.onVideoSeeked.bind(this);\n    this.onvmetadata = this.onVideoMetadata.bind(this);\n    this.video.addEventListener('seeking',this.onvseeking);\n    this.video.addEventListener('seeked',this.onvseeked);\n    this.video.addEventListener('loadedmetadata',this.onvmetadata);\n    if(this.levels && this.config.autoStartLoad) {\n      this.startLoad();\n    }\n  }\n\n  onMSEDetached() {\n    this.video = null;\n    this.loadedmetadata = false;\n    this.stop();\n  }\n\n\n  onVideoSeeking() {\n    if(this.state === this.LOADING) {\n      // check if currently loaded fragment is inside buffer.\n      //if outside, cancel fragment loading, otherwise do nothing\n      if(this.bufferInfo(this.video.currentTime).len === 0) {\n        logger.log('seeking outside of buffer while fragment load in progress, cancel fragment load');\n        this.frag.loader.abort();\n        this.frag = null;\n        // switch to IDLE state to load new fragment\n        this.state = this.IDLE;\n      }\n    }\n    if(this.video) {\n      this.lastCurrentTime = this.video.currentTime;\n    }\n    // avoid reporting fragment loop loading error in case user is seeking several times on same position\n    if(this.fragLoadIdx !== undefined) {\n      this.fragLoadIdx+= 2*this.config.fragLoadingLoopThreshold;\n    }\n    // tick to speed up processing\n    this.tick();\n  }\n\n  onVideoSeeked() {\n    // tick to speed up FRAGMENT_PLAYING triggering\n    this.tick();\n  }\n\n  onVideoMetadata() {\n      if(this.video.currentTime !== this.startPosition) {\n        this.video.currentTime = this.startPosition;\n    }\n    this.loadedmetadata = true;\n    this.tick();\n  }\n\n  onManifestParsed(event,data) {\n    var aac=false, heaac=false,codecs;\n    data.levels.forEach(level => {\n      // detect if we have different kind of audio codecs used amongst playlists\n      codecs = level.codecs;\n      if(codecs) {\n        if(codecs.indexOf('mp4a.40.2') !== -1) {\n          aac = true;\n        }\n        if(codecs.indexOf('mp4a.40.5') !== -1) {\n          heaac = true;\n        }\n      }\n    });\n    this.audiocodecswitch = (aac && heaac);\n    if(this.audiocodecswitch) {\n      logger.log('both AAC/HE-AAC audio found in levels; declaring audio codec as HE-AAC');\n    }\n    this.levels = data.levels;\n    this.startLevelLoaded = false;\n    this.startFragmentRequested = false;\n    if(this.video && this.config.autoStartLoad) {\n      this.startLoad();\n    }\n  }\n\n  onLevelLoaded(event,data) {\n    var newLevelDetails = data.details,\n        duration = newLevelDetails.totalduration,\n        newLevelId = data.level,\n        newLevel = this.levels[newLevelId],\n        curLevel = this.levels[this.level],\n        sliding = 0;\n    logger.log(`level ${newLevelId} loaded [${newLevelDetails.startSN},${newLevelDetails.endSN}],duration:${duration}`);\n    // check if playlist is already loaded (if yes, it should be a live playlist)\n    if(curLevel && curLevel.details && curLevel.details.live) {\n      var curLevelDetails = curLevel.details;\n      //  playlist sliding is the sum of : current playlist sliding + sliding of new playlist compared to current one\n      // check sliding of updated playlist against current one :\n      // and find its position in current playlist\n      //logger.log(\"fragments[0].sn/this.level/curLevel.details.fragments[0].sn:\" + fragments[0].sn + \"/\" + this.level + \"/\" + curLevel.details.fragments[0].sn);\n      var SNdiff = newLevelDetails.startSN - curLevelDetails.startSN;\n      if(SNdiff >=0) {\n        // positive sliding : new playlist sliding window is after previous one\n        var oldfragments = curLevelDetails.fragments;\n        if( SNdiff < oldfragments.length) {\n          sliding = curLevelDetails.sliding + oldfragments[SNdiff].start;\n        } else {\n          logger.log(`cannot compute sliding, no SN in common between old/new level:[${curLevelDetails.startSN},${curLevelDetails.endSN}]/[${newLevelDetails.startSN},${newLevelDetails.endSN}]`);\n          sliding = undefined;\n        }\n      } else {\n        // negative sliding: new playlist sliding window is before previous one\n        sliding = curLevelDetails.sliding - newLevelDetails.fragments[-SNdiff].start;\n      }\n      if(sliding) {\n        logger.log(`live playlist sliding:${sliding.toFixed(3)}`);\n      }\n    }\n    // override level info\n    newLevel.details = newLevelDetails;\n    newLevel.details.sliding = sliding;\n    if(this.startLevelLoaded === false) {\n      // if live playlist, set start position to be fragment N-3\n      if(newLevelDetails.live) {\n        this.startPosition = Math.max(0,duration - 3 * newLevelDetails.targetduration);\n      }\n      this.nextLoadPosition = this.startPosition;\n      this.startLevelLoaded = true;\n    }\n    // only switch batck to IDLE state if we were waiting for level to start downloading a new fragment\n    if(this.state === this.WAITING_LEVEL) {\n      this.state = this.IDLE;\n    }\n    //trigger handler right now\n    this.tick();\n  }\n\n  onFragmentLoaded(event,data) {\n    if(this.state === this.LOADING) {\n      if(this.fragmentBitrateTest === true) {\n        // switch back to IDLE state ... we just loaded a fragment to determine adequate start bitrate and initialize autoswitch algo\n        this.state = this.IDLE;\n        this.fragmentBitrateTest = false;\n        data.stats.tparsed = data.stats.tbuffered = new Date();\n        observer.trigger(Event.FRAG_BUFFERED, { stats : data.stats, frag : this.frag});\n        this.frag = null;\n      } else {\n        this.state = this.PARSING;\n        // transmux the MPEG-TS data to ISO-BMFF segments\n        this.stats = data.stats;\n        var currentLevel = this.levels[this.level], details = currentLevel.details,  duration =  details.totalduration, start = this.frag.start;\n        if(details.live) {\n          duration+=details.sliding;\n          start+=details.sliding;\n        }\n        if(this.frag.drift) {\n          start+= this.frag.drift;\n        }\n        logger.log(`Demuxing      ${this.frag.sn} of [${details.startSN} ,${details.endSN}],level ${this.level}`);\n        this.demuxer.push(data.payload,currentLevel.audioCodec,currentLevel.videoCodec,start,this.frag.cc, this.level, duration);\n      }\n    }\n  }\n\n  onInitSegment(event,data) {\n    if(this.state === this.PARSING) {\n      // check if codecs have been explicitely defined in the master playlist for this level;\n      // if yes use these ones instead of the ones parsed from the demux\n      var audioCodec = this.levels[this.level].audioCodec, videoCodec = this.levels[this.level].videoCodec,sb;\n      //logger.log('playlist level A/V codecs:' + audioCodec + ',' + videoCodec);\n      //logger.log('playlist codecs:' + codec);\n      // if playlist does not specify codecs, use codecs found while parsing fragment\n      if(audioCodec === undefined || data.audiocodec === undefined) {\n        audioCodec = data.audioCodec;\n      }\n      if(videoCodec === undefined  || data.videocodec === undefined) {\n        videoCodec = data.videoCodec;\n      }\n      // in case several audio codecs might be used, force HE-AAC for audio (some browsers don't support audio codec switch)\n      //don't do it for mono streams ...\n      if(this.audiocodecswitch && data.audioChannelCount === 2 && navigator.userAgent.toLowerCase().indexOf('android') === -1 && navigator.userAgent.toLowerCase().indexOf('firefox') === -1) {\n        audioCodec = 'mp4a.40.5';\n      }\n      if(!this.sourceBuffer) {\n        this.sourceBuffer = {};\n        logger.log(`selected A/V codecs for sourceBuffers:${audioCodec},${videoCodec}`);\n        // create source Buffer and link them to MediaSource\n        if(audioCodec) {\n          sb = this.sourceBuffer.audio = this.mediaSource.addSourceBuffer(`video/mp4;codecs=${audioCodec}`);\n          sb.addEventListener('updateend', this.onsbue);\n          sb.addEventListener('error', this.onsbe);\n        }\n        if(videoCodec) {\n          sb = this.sourceBuffer.video = this.mediaSource.addSourceBuffer(`video/mp4;codecs=${videoCodec}`);\n          sb.addEventListener('updateend', this.onsbue);\n          sb.addEventListener('error', this.onsbe);\n        }\n      }\n      if(audioCodec) {\n        this.mp4segments.push({ type : 'audio', data : data.audioMoov});\n      }\n      if(videoCodec) {\n        this.mp4segments.push({ type : 'video', data : data.videoMoov});\n      }\n      //trigger handler right now\n      this.tick();\n    }\n  }\n\n  onFragmentParsing(event,data) {\n    if(this.state === this.PARSING) {\n      this.tparse2 = Date.now();\n      var level = this.levels[this.level];\n      if(level.details.live) {\n        var fragments = this.levels[this.level].details.fragments;\n        var sn0 = fragments[0].sn,sn1 = fragments[fragments.length-1].sn, sn = this.frag.sn;\n        //retrieve this.frag.sn in this.levels[this.level]\n        if(sn >= sn0 && sn <= sn1) {\n          level.details.sliding = data.startPTS - fragments[sn-sn0].start;\n          //logger.log(`live playlist sliding:${level.details.sliding.toFixed(3)}`);\n        }\n      }\n      logger.log(`      parsed data, type/startPTS/endPTS/startDTS/endDTS/nb:${data.type}/${data.startPTS.toFixed(3)}/${data.endPTS.toFixed(3)}/${data.startDTS.toFixed(3)}/${data.endDTS.toFixed(3)}/${data.nb}`);\n      //this.frag.drift=data.startPTS-this.frag.start;\n      this.frag.drift=0;\n      // if(level.details.sliding) {\n      //   this.frag.drift-=level.details.sliding;\n      // }\n      //logger.log(`      drift:${this.frag.drift.toFixed(3)}`);\n      this.mp4segments.push({ type : data.type, data : data.moof});\n      this.mp4segments.push({ type : data.type, data : data.mdat});\n      this.nextLoadPosition = data.endPTS;\n      this.bufferRange.push({type : data.type, start : data.startPTS, end : data.endPTS, frag : this.frag});\n      // if(data.type === 'video') {\n      //   this.frag.fpsExpected = (data.nb-1) / (data.endPTS - data.startPTS);\n      // }\n      //trigger handler right now\n      this.tick();\n    } else {\n      logger.warn(`not in PARSING state, discarding ${event}`);\n    }\n  }\n\n  onFragmentParsed() {\n    if(this.state === this.PARSING) {\n      this.state = this.PARSED;\n      this.stats.tparsed = new Date();\n      //trigger handler right now\n      this.tick();\n    }\n  }\n\n  onError(event,data) {\n    switch(data.details) {\n      // abort fragment loading on errors\n      case ErrorDetails.FRAG_LOAD_ERROR:\n      case ErrorDetails.FRAG_LOAD_TIMEOUT:\n      case ErrorDetails.FRAG_LOOP_LOADING_ERROR:\n      case ErrorDetails.LEVEL_LOAD_ERROR:\n      case ErrorDetails.LEVEL_LOAD_TIMEOUT:\n        // if fatal error, stop processing, otherwise move to IDLE to retry loading\n        logger.warn(`buffer controller: ${data.details} while loading frag,switch to ${data.fatal ? 'ERROR' : 'IDLE'} state ...`);\n        this.state = data.fatal ? this.ERROR : this.IDLE;\n        this.frag = null;\n        break;\n      default:\n        break;\n    }\n  }\n\n  onSourceBufferUpdateEnd() {\n    //trigger handler right now\n    if(this.state === this.APPENDING && this.mp4segments.length === 0)  {\n      if(this.frag) {\n        this.stats.tbuffered = new Date();\n        observer.trigger(Event.FRAG_BUFFERED, { stats : this.stats, frag : this.frag});\n        this.state = this.IDLE;\n      }\n    }\n    this.tick();\n  }\n\n  onSourceBufferError(event) {\n      logger.error(`sourceBuffer error:${event}`);\n      this.state = this.ERROR;\n      observer.trigger(Event.ERROR, {type : ErrorTypes.MEDIA_ERROR, details : ErrorDetails.FRAG_APPENDING_ERROR, fatal:true, frag : this.frag});\n  }\n}\n\nexport default BufferController;\n","/*\n * level controller\n *\n */\n\n import Event                from '../events';\n import observer             from '../observer';\n import {logger}             from '../utils/logger';\n import {ErrorTypes,ErrorDetails} from '../errors';\n\n class LevelController {\n\n  constructor(hls) {\n    this.hls = hls;\n    this.onml = this.onManifestLoaded.bind(this);\n    this.onll = this.onLevelLoaded.bind(this);\n    this.onflp = this.onFragmentLoadProgress.bind(this);\n    this.onerr = this.onError.bind(this);\n    this.ontick = this.tick.bind(this);\n    observer.on(Event.MANIFEST_LOADED, this.onml);\n    observer.on(Event.FRAG_LOAD_PROGRESS, this.onflp);\n    observer.on(Event.LEVEL_LOADED, this.onll);\n    observer.on(Event.ERROR, this.onerr);\n    this._manualLevel = this._autoLevelCapping = -1;\n  }\n\n  destroy() {\n    observer.off(Event.MANIFEST_LOADED, this.onml);\n    observer.off(Event.FRAG_LOAD_PROGRESS, this.onflp);\n    observer.off(Event.LEVEL_LOADED, this.onll);\n    observer.off(Event.ERROR, this.onerr);\n    if(this.timer) {\n     clearInterval(this.timer);\n    }\n    this._manualLevel = -1;\n  }\n\n  onManifestLoaded(event,data) {\n    var levels = [],bitrateStart,i,bitrateSet={};\n    data.levels.forEach(level => {\n      var redundantLevelId = bitrateSet[level.bitrate];\n      if(redundantLevelId === undefined) {\n        bitrateSet[level.bitrate] = levels.length;\n        level.url = [level.url];\n        level.urlId = 0;\n        levels.push(level);\n      } else {\n        levels[redundantLevelId].url.push(level.url);\n      }\n    });\n    // start bitrate is the first bitrate of the manifest\n    bitrateStart = levels[0].bitrate;\n    // sort level on bitrate\n    levels.sort(function (a, b) {\n      return a.bitrate-b.bitrate;\n    });\n    this._levels = levels;\n\n    // find index of first level in sorted levels\n    for(i=0; i < levels.length ; i++) {\n      if(levels[i].bitrate === bitrateStart) {\n        this._firstLevel = i;\n        logger.log(`manifest loaded,${levels.length} level(s) found, first bitrate:${bitrateStart}`);\n        break;\n      }\n    }\n    observer.trigger(Event.MANIFEST_PARSED,\n                    { levels : this._levels,\n                      firstLevel : this._firstLevel,\n                      stats : data.stats\n                    });\n    return;\n  }\n\n  get levels() {\n    return this._levels;\n  }\n\n  get level() {\n    return this._level;\n  }\n\n  set level(newLevel) {\n    if(this._level !== newLevel || this._levels[newLevel].details === undefined) {\n      this.setLevelInternal(newLevel);\n    }\n  }\n\n setLevelInternal(newLevel) {\n    // check if level idx is valid\n    if(newLevel >= 0 && newLevel < this._levels.length) {\n      // stopping live reloading timer if any\n      if(this.timer) {\n       clearInterval(this.timer);\n       this.timer = null;\n      }\n      this._level = newLevel;\n      logger.log(`switching to level ${newLevel}`);\n      observer.trigger(Event.LEVEL_SWITCH, { level : newLevel});\n      var level = this._levels[newLevel];\n       // check if we need to load playlist for this level\n      if(level.details === undefined || level.details.live === true) {\n        // level not retrieved yet, or live playlist we need to (re)load it\n        logger.log(`(re)loading playlist for level ${newLevel}`);\n        var urlId = level.urlId;\n        observer.trigger(Event.LEVEL_LOADING, { url : level.url[urlId], level : newLevel, id : urlId});\n      }\n    } else {\n      // invalid level id given, trigger error\n      observer.trigger(Event.ERROR, { type : ErrorTypes.OTHER_ERROR, details: ErrorDetails.LEVEL_SWITCH_ERROR, level : newLevel, fatal:false, reason: 'invalid level idx'});\n    }\n }\n\n\n  get manualLevel() {\n    return this._manualLevel;\n  }\n\n  set manualLevel(newLevel) {\n    this._manualLevel = newLevel;\n    if(newLevel !==-1) {\n      this.level = newLevel;\n    }\n  }\n\n  /** Return the capping/max level value that could be used by automatic level selection algorithm **/\n  get autoLevelCapping() {\n    return this._autoLevelCapping;\n  }\n\n  /** set the capping/max level value that could be used by automatic level selection algorithm **/\n  set autoLevelCapping(newLevel) {\n    this._autoLevelCapping = newLevel;\n  }\n\n  get firstLevel() {\n    return this._firstLevel;\n  }\n\n  set firstLevel(newLevel) {\n    this._firstLevel = newLevel;\n  }\n\n  get startLevel() {\n    if(this._startLevel === undefined) {\n      return this._firstLevel;\n    } else {\n      return this._startLevel;\n    }\n  }\n\n  set startLevel(newLevel) {\n    this._startLevel = newLevel;\n  }\n\n  onFragmentLoadProgress(event,data) {\n    var stats = data.stats;\n    if(stats.aborted === undefined) {\n      this.lastfetchduration = (new Date() - stats.trequest)/1000;\n      this.lastfetchlevel = data.frag.level;\n      this.lastbw = stats.loaded*8/this.lastfetchduration;\n      //console.log(`fetchDuration:${this.lastfetchduration},bw:${(this.lastbw/1000).toFixed(0)}/${stats.aborted}`);\n    }\n  }\n\n  onError(event,data) {\n    var details = data.details,levelId,level;\n    // try to recover not fatal errors\n    switch(details) {\n      case ErrorDetails.FRAG_LOAD_ERROR:\n      case ErrorDetails.FRAG_LOAD_TIMEOUT:\n      case ErrorDetails.FRAG_LOOP_LOADING_ERROR:\n         levelId = data.frag.level;\n         break;\n      case ErrorDetails.LEVEL_LOAD_ERROR:\n      case ErrorDetails.LEVEL_LOAD_TIMEOUT:\n        levelId = data.level;\n        break;\n      default:\n        break;\n    }\n    /* try to switch to a redundant stream if any available.\n     * if no redundant stream available, emergency switch down (if in auto mode and current level not 0)\n     * otherwise, we cannot recover this network error ....\n     */\n    if(levelId !== undefined) {\n      level = this._levels[levelId];\n      if(level.urlId < level.url.length-1) {\n        level.urlId++;\n        level.details = undefined;\n        logger.warn(`level controller,${details} for level ${levelId}: switching to redundant stream id ${level.urlId}`);\n      } else {\n        // we could try to recover if in auto mode and current level not lowest level (0)\n        let recoverable = ((this._manualLevel === -1) && levelId);\n        if(recoverable) {\n          logger.warn(`level controller,${details}: emergency switch-down for next fragment`);\n          this.lastbw = 0;\n          this.lastfetchduration = 0;\n        } else {\n          logger.error(`cannot recover ${details} error`);\n          this._level = undefined;\n          // stopping live reloading timer if any\n          if(this.timer) {\n            clearInterval(this.timer);\n            this.timer = null;\n            // redispatch same error but with fatal set to true\n            data.fatal = true;\n            observer.trigger(event,data);\n          }\n        }\n      }\n    }\n  }\n\n  onLevelLoaded(event,data) {\n    // check if current playlist is a live playlist\n    if(data.details.live && !this.timer) {\n      // if live playlist we will have to reload it periodically\n      // set reload period to playlist target duration\n      this.timer = setInterval(this.ontick, 1000*data.details.targetduration);\n    }\n  }\n\n  tick() {\n    var levelId = this._level;\n    if(levelId !== undefined) {\n      var level = this._levels[levelId], urlId = level.urlId;\n      observer.trigger(Event.LEVEL_LOADING, { url: level.url[urlId], level : levelId, id : urlId });\n    }\n  }\n\n  nextLoadLevel() {\n    if(this._manualLevel !== -1) {\n      return this._manualLevel;\n    } else {\n     return this.nextAutoLevel();\n    }\n  }\n\n  nextAutoLevel() {\n    var lastbw = this.lastbw,adjustedbw,i,maxAutoLevel;\n    if(this._autoLevelCapping === -1) {\n      maxAutoLevel = this._levels.length-1;\n    } else {\n      maxAutoLevel = this._autoLevelCapping;\n    }\n    // follow algorithm captured from stagefright :\n    // https://android.googlesource.com/platform/frameworks/av/+/master/media/libstagefright/httplive/LiveSession.cpp\n    // Pick the highest bandwidth stream below or equal to estimated bandwidth.\n    for(i =0; i <= maxAutoLevel ; i++) {\n    // consider only 80% of the available bandwidth, but if we are switching up,\n    // be even more conservative (70%) to avoid overestimating and immediately\n    // switching back.\n      if(i <= this._level) {\n        adjustedbw = 0.8*lastbw;\n      } else {\n        adjustedbw = 0.7*lastbw;\n      }\n      if(adjustedbw < this._levels[i].bitrate) {\n        return Math.max(0,i-1);\n      }\n    }\n    return i-1;\n  }\n}\n\nexport default LevelController;\n"," import Event                from '../events';\n import TSDemuxer            from './tsdemuxer';\n import TSDemuxerWorker      from './tsdemuxerworker';\n import observer             from '../observer';\n import {logger}             from '../utils/logger';\n\n\nclass Demuxer {\n\n  constructor(config) {\n    if(config.enableWorker && (typeof(Worker) !== 'undefined')) {\n        logger.log('TS demuxing in webworker');\n        try {\n          var work = require('webworkify');\n          this.w = work(TSDemuxerWorker);\n          this.onwmsg = this.onWorkerMessage.bind(this);\n          this.w.addEventListener('message', this.onwmsg);\n          this.w.postMessage({ cmd : 'init'});\n        } catch(err) {\n          logger.error('error while initializing TSDemuxerWorker, fallback on regular TSDemuxer');\n          this.demuxer = new TSDemuxer();\n        }\n      } else {\n        this.demuxer = new TSDemuxer();\n      }\n      this.demuxInitialized = true;\n  }\n\n  destroy() {\n    if(this.w) {\n      this.w.removeEventListener('message',this.onwmsg);\n      this.w.terminate();\n      this.w = null;\n    } else {\n      this.demuxer.destroy();\n    }\n  }\n\n  push(data, audioCodec, videoCodec, timeOffset, cc, level, duration) {\n    if(this.w) {\n      // post fragment payload as transferable objects (no copy)\n      this.w.postMessage({ cmd : 'demux' , data : data, audioCodec : audioCodec, videoCodec: videoCodec, timeOffset : timeOffset, cc: cc, level : level, duration : duration},[data]);\n    } else {\n      this.demuxer.push(new Uint8Array(data), audioCodec, videoCodec, timeOffset, cc, level, duration);\n      this.demuxer.end();\n    }\n  }\n\n  onWorkerMessage(ev) {\n    //console.log('onWorkerMessage:' + ev.data.event);\n    switch(ev.data.event) {\n      case Event.FRAG_PARSING_INIT_SEGMENT:\n        var obj = {};\n        if(ev.data.audioMoov) {\n          obj.audioMoov = new Uint8Array(ev.data.audioMoov);\n          obj.audioCodec = ev.data.audioCodec;\n          obj.audioChannelCount = ev.data.audioChannelCount;\n        }\n        if(ev.data.videoMoov) {\n          obj.videoMoov = new Uint8Array(ev.data.videoMoov);\n          obj.videoCodec = ev.data.videoCodec;\n          obj.videoWidth = ev.data.videoWidth;\n          obj.videoHeight = ev.data.videoHeight;\n        }\n        observer.trigger(Event.FRAG_PARSING_INIT_SEGMENT, obj);\n        break;\n      case Event.FRAG_PARSING_DATA:\n        observer.trigger(Event.FRAG_PARSING_DATA,{\n          moof : new Uint8Array(ev.data.moof),\n          mdat : new Uint8Array(ev.data.mdat),\n          startPTS : ev.data.startPTS,\n          endPTS : ev.data.endPTS,\n          startDTS : ev.data.startDTS,\n          endDTS : ev.data.endDTS,\n          type : ev.data.type,\n          nb : ev.data.nb\n        });\n        break;\n      default:\n        observer.trigger(ev.data.event,ev.data.data);\n        break;\n    }\n  }\n}\nexport default Demuxer;\n","/**\n * Parser for exponential Golomb codes, a variable-bitwidth number encoding\n * scheme used by h264.\n */\n\nimport {logger}        from '../utils/logger';\n\nclass ExpGolomb {\n\n  constructor(data) {\n    this.data = data;\n    // the number of bytes left to examine in this.data\n    this.bytesAvailable = this.data.byteLength;\n    // the current word being examined\n    this.word = 0; // :uint\n    // the number of bits left to examine in the current word\n    this.bitsAvailable = 0; // :uint\n  }\n\n  // ():void\n  loadWord() {\n    var\n      position = this.data.byteLength - this.bytesAvailable,\n      workingBytes = new Uint8Array(4),\n      availableBytes = Math.min(4, this.bytesAvailable);\n\n    if (availableBytes === 0) {\n      throw new Error('no bytes available');\n    }\n\n    workingBytes.set(this.data.subarray(position,\n                                          position + availableBytes));\n    this.word = new DataView(workingBytes.buffer).getUint32(0);\n\n    // track the amount of this.data that has been processed\n    this.bitsAvailable = availableBytes * 8;\n    this.bytesAvailable -= availableBytes;\n  }\n\n  // (count:int):void\n  skipBits(count) {\n    var skipBytes; // :int\n    if (this.bitsAvailable > count) {\n      this.word          <<= count;\n      this.bitsAvailable -= count;\n    } else {\n      count -= this.bitsAvailable;\n      skipBytes = count >> 3;\n\n      count -= (skipBytes >> 3);\n      this.bytesAvailable -= skipBytes;\n\n      this.loadWord();\n\n      this.word <<= count;\n      this.bitsAvailable -= count;\n    }\n  }\n\n  // (size:int):uint\n  readBits(size) {\n    var\n      bits = Math.min(this.bitsAvailable, size), // :uint\n      valu = this.word >>> (32 - bits); // :uint\n\n    if(size >32) {\n      logger.error('Cannot read more than 32 bits at a time');\n    }\n\n    this.bitsAvailable -= bits;\n    if (this.bitsAvailable > 0) {\n      this.word <<= bits;\n    } else if (this.bytesAvailable > 0) {\n      this.loadWord();\n    }\n\n    bits = size - bits;\n    if (bits > 0) {\n      return valu << bits | this.readBits(bits);\n    } else {\n      return valu;\n    }\n  }\n\n  // ():uint\n  skipLZ() {\n    var leadingZeroCount; // :uint\n    for (leadingZeroCount = 0 ; leadingZeroCount < this.bitsAvailable ; ++leadingZeroCount) {\n      if (0 !== (this.word & (0x80000000 >>> leadingZeroCount))) {\n        // the first bit of working word is 1\n        this.word <<= leadingZeroCount;\n        this.bitsAvailable -= leadingZeroCount;\n        return leadingZeroCount;\n      }\n    }\n\n    // we exhausted word and still have not found a 1\n    this.loadWord();\n    return leadingZeroCount + this.skipLZ();\n  }\n\n  // ():void\n  skipUEG() {\n    this.skipBits(1 + this.skipLZ());\n  }\n\n  // ():void\n  skipEG() {\n    this.skipBits(1 + this.skipLZ());\n  }\n\n  // ():uint\n  readUEG() {\n    var clz = this.skipLZ(); // :uint\n    return this.readBits(clz + 1) - 1;\n  }\n\n  // ():int\n  readEG() {\n    var valu = this.readUEG(); // :int\n    if (0x01 & valu) {\n      // the number is odd if the low order bit is set\n      return (1 + valu) >>> 1; // add 1 to make it even, and divide by 2\n    } else {\n      return -1 * (valu >>> 1); // divide by two then make it negative\n    }\n  }\n\n  // Some convenience functions\n  // :Boolean\n  readBoolean() {\n    return 1 === this.readBits(1);\n  }\n\n  // ():int\n  readUByte() {\n    return this.readBits(8);\n  }\n\n  /**\n   * Advance the ExpGolomb decoder past a scaling list. The scaling\n   * list is optionally transmitted as part of a sequence parameter\n   * set and is not relevant to transmuxing.\n   * @param count {number} the number of entries in this scaling list\n   * @see Recommendation ITU-T H.264, Section 7.3.2.1.1.1\n   */\n  skipScalingList(count) {\n    var\n      lastScale = 8,\n      nextScale = 8,\n      j,\n      deltaScale;\n\n    for (j = 0; j < count; j++) {\n      if (nextScale !== 0) {\n        deltaScale = this.readEG();\n        nextScale = (lastScale + deltaScale + 256) % 256;\n      }\n\n      lastScale = (nextScale === 0) ? lastScale : nextScale;\n    }\n  }\n\n  /**\n   * Read a sequence parameter set and return some interesting video\n   * properties. A sequence parameter set is the H264 metadata that\n   * describes the properties of upcoming video frames.\n   * @param data {Uint8Array} the bytes of a sequence parameter set\n   * @return {object} an object with configuration parsed from the\n   * sequence parameter set, including the dimensions of the\n   * associated video frames.\n   */\n  readSPS() {\n    var\n      frameCropLeftOffset = 0,\n      frameCropRightOffset = 0,\n      frameCropTopOffset = 0,\n      frameCropBottomOffset = 0,\n      profileIdc,profileCompat,levelIdc,\n      numRefFramesInPicOrderCntCycle, picWidthInMbsMinus1,\n      picHeightInMapUnitsMinus1,\n      frameMbsOnlyFlag,\n      scalingListCount,\n      i;\n\n    this.readUByte();\n    profileIdc = this.readUByte(); // profile_idc\n    profileCompat = this.readBits(5); // constraint_set[0-4]_flag, u(5)\n    this.skipBits(3); // reserved_zero_3bits u(3),\n    levelIdc = this.readUByte(); //level_idc u(8)\n    this.skipUEG(); // seq_parameter_set_id\n\n    // some profiles have more optional data we don't need\n    if (profileIdc === 100 ||\n        profileIdc === 110 ||\n        profileIdc === 122 ||\n        profileIdc === 144) {\n      var chromaFormatIdc = this.readUEG();\n      if (chromaFormatIdc === 3) {\n        this.skipBits(1); // separate_colour_plane_flag\n      }\n      this.skipUEG(); // bit_depth_luma_minus8\n      this.skipUEG(); // bit_depth_chroma_minus8\n      this.skipBits(1); // qpprime_y_zero_transform_bypass_flag\n      if (this.readBoolean()) { // seq_scaling_matrix_present_flag\n        scalingListCount = (chromaFormatIdc !== 3) ? 8 : 12;\n        for (i = 0; i < scalingListCount; i++) {\n          if (this.readBoolean()) { // seq_scaling_list_present_flag[ i ]\n            if (i < 6) {\n              this.skipScalingList(16);\n            } else {\n              this.skipScalingList(64);\n            }\n          }\n        }\n      }\n    }\n\n    this.skipUEG(); // log2_max_frame_num_minus4\n    var picOrderCntType = this.readUEG();\n\n    if (picOrderCntType === 0) {\n      this.readUEG(); //log2_max_pic_order_cnt_lsb_minus4\n    } else if (picOrderCntType === 1) {\n      this.skipBits(1); // delta_pic_order_always_zero_flag\n      this.skipEG(); // offset_for_non_ref_pic\n      this.skipEG(); // offset_for_top_to_bottom_field\n      numRefFramesInPicOrderCntCycle = this.readUEG();\n      for(i = 0; i < numRefFramesInPicOrderCntCycle; i++) {\n        this.skipEG(); // offset_for_ref_frame[ i ]\n      }\n    }\n\n    this.skipUEG(); // max_num_ref_frames\n    this.skipBits(1); // gaps_in_frame_num_value_allowed_flag\n\n    picWidthInMbsMinus1 = this.readUEG();\n    picHeightInMapUnitsMinus1 = this.readUEG();\n\n    frameMbsOnlyFlag = this.readBits(1);\n    if (frameMbsOnlyFlag === 0) {\n      this.skipBits(1); // mb_adaptive_frame_field_flag\n    }\n\n    this.skipBits(1); // direct_8x8_inference_flag\n    if (this.readBoolean()) { // frame_cropping_flag\n      frameCropLeftOffset = this.readUEG();\n      frameCropRightOffset = this.readUEG();\n      frameCropTopOffset = this.readUEG();\n      frameCropBottomOffset = this.readUEG();\n    }\n\n    return {\n      profileIdc : profileIdc,\n      profileCompat : profileCompat,\n      levelIdc : levelIdc,\n      width: ((picWidthInMbsMinus1 + 1) * 16) - frameCropLeftOffset * 2 - frameCropRightOffset * 2,\n      height: ((2 - frameMbsOnlyFlag) * (picHeightInMapUnitsMinus1 + 1) * 16) - (frameCropTopOffset * 2) - (frameCropBottomOffset * 2)\n    };\n  }\n}\n\nexport default ExpGolomb;\n","/**\n * A stream-based mp2ts to mp4 converter. This utility is used to\n * deliver mp4s to a SourceBuffer on platforms that support native\n * Media Source Extensions.\n */\n\n import Event           from '../events';\n import ExpGolomb       from './exp-golomb';\n// import Hex             from '../utils/hex';\n import MP4             from '../remux/mp4-generator';\n import observer        from '../observer';\n import {logger}        from '../utils/logger';\n import {ErrorTypes,ErrorDetails} from '../errors';\n\n class TSDemuxer {\n\n  constructor() {\n    this.lastCC = 0;\n    this.PES_TIMESCALE=90000;\n    this.PES2MP4SCALEFACTOR=4;\n    this.MP4_TIMESCALE=this.PES_TIMESCALE/this.PES2MP4SCALEFACTOR;\n  }\n\n  switchLevel() {\n    this.pmtParsed = false;\n    this._pmtId = this._avcId = this._aacId = -1;\n    this._avcTrack = {type : 'video', sequenceNumber : 0};\n    this._aacTrack = {type : 'audio', sequenceNumber : 0};\n    this._avcSamples = [];\n    this._avcSamplesLength = 0;\n    this._avcSamplesNbNalu = 0;\n    this._aacSamples = [];\n    this._aacSamplesLength = 0;\n    this._initSegGenerated = false;\n  }\n\n  insertDiscontinuity() {\n    this.switchLevel();\n    this._initPTS = this._initDTS = undefined;\n  }\n\n  // feed incoming data to the front of the parsing pipeline\n  push(data,audioCodec, videoCodec,timeOffset,cc,level,duration) {\n    var avcData,aacData,start,len = data.length,stt,pid,atf,offset;\n    this.audioCodec = audioCodec;\n    this.videoCodec = videoCodec;\n    this.timeOffset = timeOffset;\n    this._duration = duration;\n    if(cc !== this.lastCC) {\n      logger.log(`discontinuity detected`);\n      this.insertDiscontinuity();\n      this.lastCC = cc;\n    } else if(level !== this.lastLevel) {\n      logger.log(`level switch detected`);\n      this.switchLevel();\n      this.lastLevel = level;\n    }\n    var pmtParsed=this.pmtParsed,avcId=this._avcId,aacId=this._aacId;\n\n    // loop through TS packets\n    for(start = 0; start < len ; start += 188) {\n      if(data[start] === 0x47) {\n        stt = !!(data[start+1] & 0x40);\n        // pid is a 13-bit field starting at the last bit of TS[1]\n        pid = ((data[start+1] & 0x1f) << 8) + data[start+2];\n        atf = (data[start+3] & 0x30) >> 4;\n        // if an adaption field is present, its length is specified by the fifth byte of the TS packet header.\n        if(atf > 1) {\n          offset = start+5+data[start+4];\n          // continue if there is only adaptation field\n          if(offset === (start+188)) {\n            continue;\n          }\n        } else {\n          offset = start+4;\n        }\n        if(pmtParsed) {\n          if(pid === avcId) {\n            if(stt) {\n              if(avcData) {\n                this._parseAVCPES(this._parsePES(avcData));\n              }\n              avcData = {data: [],size: 0};\n            }\n            if(avcData) {\n              avcData.data.push(data.subarray(offset,start+188));\n              avcData.size+=start+188-offset;\n            }\n          } else if(pid === aacId) {\n            if(stt) {\n              if(aacData) {\n                this._parseAACPES(this._parsePES(aacData));\n              }\n              aacData = {data: [],size: 0};\n            }\n            if(aacData) {\n              aacData.data.push(data.subarray(offset,start+188));\n              aacData.size+=start+188-offset;\n            }\n          }\n        } else {\n          if(stt) {\n            offset += data[offset] + 1;\n          }\n          if(pid === 0) {\n            this._parsePAT(data,offset);\n          } else if(pid === this._pmtId) {\n            this._parsePMT(data,offset);\n            pmtParsed = this.pmtParsed = true;\n            avcId = this._avcId;\n            aacId = this._aacId;\n          }\n        }\n      } else {\n        observer.trigger(Event.ERROR, { type : ErrorTypes.MEDIA_ERROR, details : ErrorDetails.FRAG_PARSING_ERROR, fatal:false, reason : 'TS packet did not start with 0x47'});\n      }\n    }\n  // parse last PES packet\n    if(avcData) {\n      this._parseAVCPES(this._parsePES(avcData));\n    }\n    if(aacData) {\n      this._parseAACPES(this._parsePES(aacData));\n    }\n  }\n\n  end() {\n    // generate Init Segment if needed\n    if(!this._initSegGenerated) {\n      this._generateInitSegment();\n    }\n    //logger.log('nb AVC samples:' + this._avcSamples.length);\n    if(this._avcSamples.length) {\n      this._flushAVCSamples();\n    }\n    //logger.log('nb AAC samples:' + this._aacSamples.length);\n    if(this._aacSamples.length) {\n      this._flushAACSamples();\n    }\n    //notify end of parsing\n    observer.trigger(Event.FRAG_PARSED);\n  }\n\n  destroy() {\n    this.switchLevel();\n    this._initPTS = this._initDTS = undefined;\n    this._duration = 0;\n  }\n\n  _parsePAT(data,offset) {\n    // skip the PSI header and parse the first PMT entry\n    this._pmtId  = (data[offset+10] & 0x1F) << 8 | data[offset+11];\n    //logger.log('PMT PID:'  + this._pmtId);\n  }\n\n  _parsePMT(data,offset) {\n    var sectionLength,tableEnd,programInfoLength,pid;\n    sectionLength = (data[offset+1] & 0x0f) << 8 | data[offset+2];\n    tableEnd = offset + 3 + sectionLength - 4;\n    // to determine where the table is, we have to figure out how\n    // long the program info descriptors are\n    programInfoLength = (data[offset+10] & 0x0f) << 8 | data[offset+11];\n\n    // advance the offset to the first entry in the mapping table\n    offset += 12 + programInfoLength;\n    while (offset < tableEnd) {\n      pid = (data[offset + 1] & 0x1F) << 8 | data[offset + 2];\n      switch(data[offset]) {\n        // ISO/IEC 13818-7 ADTS AAC (MPEG-2 lower bit-rate audio)\n        case 0x0f:\n        //logger.log('AAC PID:'  + pid);\n          this._aacId = pid;\n          this._aacTrack.id = pid;\n        break;\n        // ITU-T Rec. H.264 and ISO/IEC 14496-10 (lower bit-rate video)\n        case 0x1b:\n        //logger.log('AVC PID:'  + pid);\n        this._avcId = pid;\n        this._avcTrack.id = pid;\n        break;\n        default:\n        logger.log('unkown stream type:'  + data[offset]);\n        break;\n      }\n      // move to the next table entry\n      // skip past the elementary stream descriptors, if present\n      offset += ((data[offset + 3] & 0x0F) << 8 | data[offset + 4]) + 5;\n    }\n  }\n\n  _parsePES(stream) {\n    var i = 0,frag,pesFlags,pesPrefix,pesLen,pesHdrLen,pesData,pesPts,pesDts,payloadStartOffset;\n    //retrieve PTS/DTS from first fragment\n    frag = stream.data[0];\n    pesPrefix = (frag[0] << 16) + (frag[1] << 8) + frag[2];\n    if(pesPrefix === 1) {\n      pesLen = (frag[4] << 8) + frag[5];\n      pesFlags = frag[7];\n      if (pesFlags & 0xC0) {\n        /* PES header described here : http://dvd.sourceforge.net/dvdinfo/pes-hdr.html\n            as PTS / DTS is 33 bit we cannot use bitwise operator in JS,\n            as Bitwise operators treat their operands as a sequence of 32 bits */\n        pesPts = (frag[9] & 0x0E)*536870912 +// 1 << 29\n          (frag[10] & 0xFF)*4194304 +// 1 << 22\n          (frag[11] & 0xFE)*16384 +// 1 << 14\n          (frag[12] & 0xFF)*128 +// 1 << 7\n          (frag[13] & 0xFE)/2;\n          // check if greater than 2^32 -1\n          if (pesPts > 4294967295) {\n              // decrement 2^33\n              pesPts -= 8589934592;\n          }\n        if (pesFlags & 0x40) {\n          pesDts = (frag[14] & 0x0E )*536870912 +// 1 << 29\n            (frag[15] & 0xFF )*4194304 +// 1 << 22\n            (frag[16] & 0xFE )*16384 +// 1 << 14\n            (frag[17] & 0xFF )*128 +// 1 << 7\n            (frag[18] & 0xFE )/2;\n          // check if greater than 2^32 -1\n          if (pesDts > 4294967295) {\n              // decrement 2^33\n              pesDts -= 8589934592;\n          }\n        } else {\n          pesDts = pesPts;\n        }\n      }\n      pesHdrLen = frag[8];\n      payloadStartOffset = pesHdrLen+9;\n      // trim PES header\n      stream.data[0] = stream.data[0].subarray(payloadStartOffset);\n      stream.size -= payloadStartOffset;\n      //reassemble PES packet\n      pesData = new Uint8Array(stream.size);\n      // reassemble the packet\n      while (stream.data.length) {\n        frag = stream.data.shift();\n        pesData.set(frag, i);\n        i += frag.byteLength;\n      }\n      return { data : pesData, pts : pesPts, dts : pesDts, len : pesLen};\n    } else {\n      return null;\n    }\n  }\n\n  _parseAVCPES(pes) {\n    var units,track = this._avcTrack,avcSample,key = false;\n    units = this._parseAVCNALu(pes.data);\n    //free pes.data to save up some memory\n    pes.data = null;\n    units.units.forEach(unit => {\n      switch(unit.type) {\n        //IDR\n        case 5:\n          key = true;\n          break;\n        //SPS\n        case 7:\n          if(!track.sps) {\n            var expGolombDecoder = new ExpGolomb(unit.data);\n            var config = expGolombDecoder.readSPS();\n            track.width = config.width;\n            track.height = config.height;\n            track.profileIdc = config.profileIdc;\n            track.profileCompat = config.profileCompat;\n            track.levelIdc = config.levelIdc;\n            track.sps = [unit.data];\n            track.timescale = this.MP4_TIMESCALE;\n            track.duration = this.MP4_TIMESCALE*this._duration;\n            var codecarray = unit.data.subarray(1,4);\n            var codecstring  = 'avc1.';\n            for(var i = 0; i < 3; i++) {\n                var h = codecarray[i].toString(16);\n                if (h.length < 2) {\n                    h = '0' + h;\n                }\n                codecstring += h;\n            }\n            track.codec = codecstring;\n          }\n          break;\n        //PPS\n        case 8:\n          if(!track.pps) {\n            track.pps = [unit.data];\n          }\n          break;\n        default:\n          break;\n      }\n    });\n    //build sample from PES\n    // Annex B to MP4 conversion to be done\n    avcSample = { units : units, pts : pes.pts, dts : pes.dts , key : key};\n    this._avcSamples.push(avcSample);\n    this._avcSamplesLength += units.length;\n    this._avcSamplesNbNalu += units.units.length;\n  }\n\n\n  _flushAVCSamples() {\n    var view,i=8,avcSample,mp4Sample,mp4SampleLength,unit,track = this._avcTrack,\n        lastSampleDTS,mdat,moof,firstPTS,firstDTS,pts,dts,ptsnorm,dtsnorm,samples = [];\n\n    /* concatenate the video data and construct the mdat in place\n      (need 8 more bytes to fill length and mpdat type) */\n    mdat = new Uint8Array(this._avcSamplesLength + (4 * this._avcSamplesNbNalu)+8);\n    view = new DataView(mdat.buffer);\n    view.setUint32(0,mdat.byteLength);\n    mdat.set(MP4.types.mdat,4);\n    while(this._avcSamples.length) {\n      avcSample = this._avcSamples.shift();\n      mp4SampleLength = 0;\n\n      // convert NALU bitstream to MP4 format (prepend NALU with size field)\n      while(avcSample.units.units.length) {\n        unit = avcSample.units.units.shift();\n        view.setUint32(i, unit.data.byteLength);\n        i += 4;\n        mdat.set(unit.data, i);\n        i += unit.data.byteLength;\n        mp4SampleLength+=4+unit.data.byteLength;\n      }\n      pts = avcSample.pts - this._initDTS;\n      dts = avcSample.dts - this._initDTS;\n      //logger.log('Video/PTS/DTS:' + avcSample.pts + '/' + avcSample.dts);\n\n      if(lastSampleDTS !== undefined) {\n        ptsnorm = this._PTSNormalize(pts,lastSampleDTS);\n        dtsnorm = this._PTSNormalize(dts,lastSampleDTS);\n\n        mp4Sample.duration = (dtsnorm - lastSampleDTS)/this.PES2MP4SCALEFACTOR;\n        if(mp4Sample.duration < 0) {\n          //logger.log('invalid sample duration at PTS/DTS::' + avcSample.pts + '/' + avcSample.dts + ':' + mp4Sample.duration);\n          mp4Sample.duration = 0;\n        }\n      } else {\n        ptsnorm = this._PTSNormalize(pts,this.nextAvcPts);\n        dtsnorm = this._PTSNormalize(dts,this.nextAvcPts);\n        // check if fragments are contiguous (i.e. no missing frames between fragment)\n        if(this.nextAvcPts) {\n          var delta = Math.round((ptsnorm - this.nextAvcPts)/90),absdelta=Math.abs(delta);\n          //logger.log('absdelta/avcSample.pts:' + absdelta + '/' + avcSample.pts);\n          // if delta is less than 300 ms, next loaded fragment is assumed to be contiguous with last one\n          if(absdelta < 300) {\n            //logger.log('Video next PTS:' + this.nextAvcPts);\n            if(delta > 1) {\n              logger.log(`AVC:${delta} ms hole between fragments detected,filling it`);\n            } else if (delta < -1) {\n              logger.log(`AVC:${(-delta)} ms overlapping between fragments detected`);\n            }\n            // set PTS to next PTS\n            ptsnorm = this.nextAvcPts;\n            // offset DTS as well, ensure that DTS is smaller or equal than new PTS\n            dtsnorm = Math.max(dtsnorm-delta, this.lastAvcDts);\n           // logger.log('Video/PTS/DTS adjusted:' + avcSample.pts + '/' + avcSample.dts);\n          }\n          else {\n            // not contiguous timestamp, check if PTS is within acceptable range\n            var expectedPTS = this.PES_TIMESCALE*this.timeOffset;\n            // check if there is any unexpected drift between expected timestamp and real one\n            if(Math.abs(expectedPTS - ptsnorm) > this.PES_TIMESCALE*3600 ) {\n              //logger.log(`PTS looping ??? AVC PTS delta:${expectedPTS-ptsnorm}`);\n              var ptsOffset = expectedPTS-ptsnorm;\n              // set PTS to next expected PTS;\n              ptsnorm = expectedPTS;\n              dtsnorm = ptsnorm;\n              // offset initPTS/initDTS to fix computation for following samples\n              this._initPTS-=ptsOffset;\n              this._initDTS-=ptsOffset;\n            }\n          }\n        }\n        // remember first PTS of our avcSamples, ensure value is positive\n        firstPTS = Math.max(0,ptsnorm);\n        firstDTS = Math.max(0,dtsnorm);\n      }\n      //console.log(`PTS/DTS/initDTS/normPTS/normDTS/relative PTS : ${avcSample.pts}/${avcSample.dts}/${this._initDTS}/${ptsnorm}/${dtsnorm}/${(avcSample.pts/4294967296).toFixed(3)}`);\n\n      mp4Sample = {\n        size: mp4SampleLength,\n        duration : 0,\n        cts: (ptsnorm - dtsnorm)/this.PES2MP4SCALEFACTOR,\n        flags: {\n          isLeading: 0,\n          isDependedOn: 0,\n          hasRedundancy: 0,\n          degradPrio: 0\n        }\n      };\n\n      if(avcSample.key === true) {\n        // the current sample is a key frame\n        mp4Sample.flags.dependsOn = 2;\n        mp4Sample.flags.isNonSync = 0;\n      } else {\n        mp4Sample.flags.dependsOn = 1;\n        mp4Sample.flags.isNonSync = 1;\n      }\n      samples.push(mp4Sample);\n      lastSampleDTS = dtsnorm;\n    }\n    if(samples.length >=2) {\n      mp4Sample.duration = samples[samples.length-2].duration;\n    }\n    this.lastAvcDts = dtsnorm;\n    // next AVC sample PTS should be equal to last sample PTS + duration\n    this.nextAvcPts = ptsnorm + mp4Sample.duration*this.PES2MP4SCALEFACTOR;\n    //logger.log('Video/lastAvcDts/nextAvcPts:' + this.lastAvcDts + '/' + this.nextAvcPts);\n\n    this._avcSamplesLength = 0;\n    this._avcSamplesNbNalu = 0;\n\n    track.samples = samples;\n    moof = MP4.moof(track.sequenceNumber++,firstDTS/this.PES2MP4SCALEFACTOR,track);\n    track.samples = [];\n    observer.trigger(Event.FRAG_PARSING_DATA,{\n      moof: moof,\n      mdat: mdat,\n      startPTS : firstPTS/this.PES_TIMESCALE,\n      endPTS : this.nextAvcPts/this.PES_TIMESCALE,\n      startDTS : firstDTS/this.PES_TIMESCALE,\n      endDTS : (dtsnorm + this.PES2MP4SCALEFACTOR*mp4Sample.duration)/this.PES_TIMESCALE,\n      type : 'video',\n      nb : samples.length\n    });\n  }\n\n  _parseAVCNALu(array) {\n    var i = 0,len = array.byteLength,value,overflow,state = 0;\n    var units = [], unit, unitType, lastUnitStart,lastUnitType,length = 0;\n    //logger.log('PES:' + Hex.hexDump(array));\n\n    while(i< len) {\n      value = array[i++];\n      // finding 3 or 4-byte start codes (00 00 01 OR 00 00 00 01)\n      switch(state) {\n        case 0:\n          if(value === 0) {\n            state = 1;\n          }\n          break;\n        case 1:\n          if(value === 0) {\n            state = 2;\n          } else {\n            state = 0;\n          }\n          break;\n        case 2:\n        case 3:\n          if(value === 0) {\n            state = 3;\n          } else if(value === 1) {\n            unitType = array[i] & 0x1f;\n            //logger.log('find NALU @ offset:' + i + ',type:' + unitType);\n            if(lastUnitStart) {\n              unit = { data : array.subarray(lastUnitStart,i-state-1), type : lastUnitType};\n              length+=i-state-1-lastUnitStart;\n              //logger.log('pushing NALU, type/size:' + unit.type + '/' + unit.data.byteLength);\n              units.push(unit);\n            } else {\n              // If NAL units are not starting right at the beginning of the PES packet, push preceding data into previous NAL unit.\n              overflow  = i - state - 1;\n              if (overflow) {\n                  //logger.log('first NALU found with overflow:' + overflow);\n                  if(this._avcSamples.length) {\n                    var lastavcSample = this._avcSamples[this._avcSamples.length-1];\n                    var lastUnit = lastavcSample.units.units[lastavcSample.units.units.length-1];\n                    var tmp = new Uint8Array(lastUnit.data.byteLength+overflow);\n                    tmp.set(lastUnit.data,0);\n                    tmp.set(array.subarray(0,overflow),lastUnit.data.byteLength);\n                    lastUnit.data = tmp;\n                    lastavcSample.units.length+=overflow;\n                    this._avcSamplesLength+=overflow;\n                  }\n              }\n            }\n            lastUnitStart = i;\n            lastUnitType = unitType;\n            if(unitType === 1 || unitType === 5) {\n              // OPTI !!! if IDR/NDR unit, consider it is last NALu\n              i = len;\n            }\n            state = 0;\n          } else {\n            state = 0;\n          }\n          break;\n        default:\n          break;\n      }\n    }\n    if(lastUnitStart) {\n      unit = { data : array.subarray(lastUnitStart,len), type : lastUnitType};\n      length+=len-lastUnitStart;\n      units.push(unit);\n      //logger.log('pushing NALU, type/size:' + unit.type + '/' + unit.data.byteLength);\n    }\n    return { units : units , length : length};\n  }\n\n  _PTSNormalize(value,reference) {\n    var offset;\n    if (reference === undefined) {\n      return value;\n    }\n    if (reference < value) {\n        // - 2^33\n        offset = -8589934592;\n    } else {\n        // + 2^33\n        offset = 8589934592;\n    }\n    /* PTS is 33bit (from 0 to 2^33 -1)\n      if diff between value and reference is bigger than half of the amplitude (2^32) then it means that\n      PTS looping occured. fill the gap */\n    while (Math.abs(value - reference) > 4294967296) {\n        value += offset;\n    }\n    return value;\n  }\n\n  _parseAACPES(pes) {\n    var track = this._aacTrack,aacSample,data = pes.data,config,adtsFrameSize,adtsStartOffset,adtsHeaderLen,stamp,nbSamples,len;\n    if(this.aacOverFlow) {\n      var tmp = new Uint8Array(this.aacOverFlow.byteLength+data.byteLength);\n      tmp.set(this.aacOverFlow,0);\n      tmp.set(data,this.aacOverFlow.byteLength);\n      data = tmp;\n    }\n    // look for ADTS header (0xFFFx)\n    for(adtsStartOffset = 0, len = data.length; adtsStartOffset<len-1; adtsStartOffset++) {\n      if((data[adtsStartOffset] === 0xff) && (data[adtsStartOffset+1] & 0xf0) === 0xf0) {\n        break;\n      }\n    }\n    // if ADTS header does not start straight from the beginning of the PES payload, raise an error\n    if(adtsStartOffset) {\n      var reason,fatal;\n      if(adtsStartOffset < len - 1) {\n        reason = `AAC PES did not start with ADTS header,offset:${adtsStartOffset}`;\n        fatal = false;\n      } else {\n        reason = `no ADTS header found in AAC PES`;\n        fatal = true;\n      }\n      observer.trigger(Event.ERROR, { type : ErrorTypes.MEDIA_ERROR, details : ErrorDetails.FRAG_PARSING_ERROR, fatal:fatal, reason : reason});\n      if(fatal) {\n        return;\n      }\n    }\n\n    if(!track.audiosamplerate) {\n      config = this._ADTStoAudioConfig(data,adtsStartOffset,this.audioCodec);\n      track.config = config.config;\n      track.audiosamplerate = config.samplerate;\n      track.channelCount = config.channelCount;\n      track.codec = config.codec;\n      track.timescale = this.MP4_TIMESCALE;\n      track.duration = this.MP4_TIMESCALE*this._duration;\n      logger.log(`parsed   codec:${track.codec},rate:${config.samplerate},nb channel:${config.channelCount}`);\n    }\n    nbSamples = 0;\n    while((adtsStartOffset + 5) < len) {\n      // retrieve frame size\n      adtsFrameSize = ((data[adtsStartOffset+3] & 0x03) << 11);\n      // byte 4\n      adtsFrameSize |= (data[adtsStartOffset+4] << 3);\n      // byte 5\n      adtsFrameSize |= ((data[adtsStartOffset+5] & 0xE0) >>> 5);\n      adtsHeaderLen = (!!(data[adtsStartOffset+1] & 0x01) ? 7 : 9);\n      adtsFrameSize -= adtsHeaderLen;\n      stamp = Math.round(pes.pts + nbSamples*1024*this.PES_TIMESCALE/track.audiosamplerate);\n      //stamp = pes.pts;\n      //console.log('AAC frame, offset/length/pts:' + (adtsStartOffset+7) + '/' + adtsFrameSize + '/' + stamp.toFixed(0));\n      if(adtsStartOffset+adtsHeaderLen+adtsFrameSize <= len) {\n        aacSample = { unit : data.subarray(adtsStartOffset+adtsHeaderLen,adtsStartOffset+adtsHeaderLen+adtsFrameSize) , pts : stamp, dts : stamp};\n        this._aacSamples.push(aacSample);\n        this._aacSamplesLength += adtsFrameSize;\n        adtsStartOffset+=adtsFrameSize+adtsHeaderLen;\n        nbSamples++;\n      } else {\n        break;\n      }\n    }\n    if(adtsStartOffset < len) {\n      this.aacOverFlow = data.subarray(adtsStartOffset,len);\n    } else {\n      this.aacOverFlow = null;\n    }\n  }\n\n  _flushAACSamples() {\n    var view,i=8,aacSample,mp4Sample,unit,track = this._aacTrack,\n        lastSampleDTS,mdat,moof,firstPTS,firstDTS,pts,dts,ptsnorm,dtsnorm,samples = [];\n\n    /* concatenate the audio data and construct the mdat in place\n      (need 8 more bytes to fill length and mpdat type) */\n    mdat = new Uint8Array(this._aacSamplesLength+8);\n    view = new DataView(mdat.buffer);\n    view.setUint32(0,mdat.byteLength);\n    mdat.set(MP4.types.mdat,4);\n    while(this._aacSamples.length) {\n      aacSample = this._aacSamples.shift();\n      unit = aacSample.unit;\n      mdat.set(unit, i);\n      i += unit.byteLength;\n\n      pts = aacSample.pts - this._initDTS;\n      dts = aacSample.dts - this._initDTS;\n\n      //logger.log('Audio/PTS:' + aacSample.pts.toFixed(0));\n      if(lastSampleDTS !== undefined) {\n        ptsnorm = this._PTSNormalize(pts,lastSampleDTS);\n        dtsnorm = this._PTSNormalize(dts,lastSampleDTS);\n        // we use DTS to compute sample duration, but we use PTS to compute initPTS which is used to sync audio and video\n        mp4Sample.duration = (dtsnorm - lastSampleDTS)/this.PES2MP4SCALEFACTOR;\n        if(mp4Sample.duration < 0) {\n          //logger.log('invalid sample duration at PTS/DTS::' + avcSample.pts + '/' + avcSample.dts + ':' + mp4Sample.duration);\n          mp4Sample.duration = 0;\n        }\n      } else {\n        ptsnorm = this._PTSNormalize(pts,this.nextAacPts);\n        dtsnorm = this._PTSNormalize(dts,this.nextAacPts);\n        // check if fragments are contiguous (i.e. no missing frames between fragment)\n        if(this.nextAacPts && this.nextAacPts !== ptsnorm) {\n          //logger.log('Audio next PTS:' + this.nextAacPts);\n          var delta = Math.round(1000*(ptsnorm - this.nextAacPts)/this.PES_TIMESCALE),absdelta=Math.abs(delta);\n          // if delta is less than 300 ms, next loaded fragment is assumed to be contiguous with last one\n          if(absdelta > 1 && absdelta < 300) {\n            if(delta > 0) {\n              logger.log(`AAC:${delta} ms hole between fragments detected,filling it`);\n              // set PTS to next PTS, and ensure PTS is greater or equal than last DTS\n              ptsnorm = Math.max(this.nextAacPts, this.lastAacDts);\n              dtsnorm = ptsnorm;\n              //logger.log('Audio/PTS/DTS adjusted:' + aacSample.pts + '/' + aacSample.dts);\n            } else {\n              logger.log(`AAC:${(-delta)} ms overlapping between fragments detected`);\n            }\n          }\n          else if (absdelta) {\n            // not contiguous timestamp, check if PTS is within acceptable range\n            var expectedPTS = this.PES_TIMESCALE*this.timeOffset;\n            //logger.log(`expectedPTS/PTSnorm:${expectedPTS}/${ptsnorm}/${expectedPTS-ptsnorm}`);\n            // check if there is any unexpected drift between expected timestamp and real one\n            if(Math.abs(expectedPTS - ptsnorm) > this.PES_TIMESCALE*3600 ) {\n              //logger.log(`PTS looping ??? AAC PTS delta:${expectedPTS-ptsnorm}`);\n              var ptsOffset = expectedPTS-ptsnorm;\n              // set PTS to next expected PTS;\n              ptsnorm = expectedPTS;\n              dtsnorm = ptsnorm;\n              // offset initPTS/initDTS to fix computation for following samples\n              this._initPTS-=ptsOffset;\n              this._initDTS-=ptsOffset;\n            }\n          }\n        }\n        // remember first PTS of our aacSamples, ensure value is positive\n        firstPTS = Math.max(0,ptsnorm);\n        firstDTS = Math.max(0,dtsnorm);\n      }\n      //console.log(`PTS/DTS/initDTS/normPTS/normDTS/relative PTS : ${aacSample.pts}/${aacSample.dts}/${this._initDTS}/${ptsnorm}/${dtsnorm}/${(aacSample.pts/4294967296).toFixed(3)}`);\n      mp4Sample = {\n        size: unit.byteLength,\n        cts: 0,\n        duration:0,\n        flags: {\n          isLeading: 0,\n          isDependedOn: 0,\n          hasRedundancy: 0,\n          degradPrio: 0,\n          dependsOn : 1,\n        }\n      };\n      samples.push(mp4Sample);\n      lastSampleDTS = dtsnorm;\n    }\n    //set last sample duration as being identical to previous sample\n    if(samples.length >=2) {\n      mp4Sample.duration = samples[samples.length-2].duration;\n    }\n    this.lastAacDts = dtsnorm;\n    // next aac sample PTS should be equal to last sample PTS + duration\n    this.nextAacPts = ptsnorm + this.PES2MP4SCALEFACTOR*mp4Sample.duration;\n    //logger.log('Audio/PTS/PTSend:' + aacSample.pts.toFixed(0) + '/' + this.nextAacDts.toFixed(0));\n\n    this._aacSamplesLength = 0;\n    track.samples = samples;\n    moof = MP4.moof(track.sequenceNumber++,firstDTS/this.PES2MP4SCALEFACTOR,track);\n    track.samples = [];\n    observer.trigger(Event.FRAG_PARSING_DATA,{\n      moof: moof,\n      mdat: mdat,\n      startPTS : firstPTS/this.PES_TIMESCALE,\n      endPTS : this.nextAacPts/this.PES_TIMESCALE,\n      startDTS : firstDTS/this.PES_TIMESCALE,\n      endDTS : (dtsnorm + this.PES2MP4SCALEFACTOR*mp4Sample.duration)/this.PES_TIMESCALE,\n      type : 'audio',\n      nb : samples.length\n    });\n  }\n\n  _ADTStoAudioConfig(data,offset,audioCodec) {\n    var adtsObjectType, // :int\n        adtsSampleingIndex, // :int\n        adtsExtensionSampleingIndex, // :int\n        adtsChanelConfig, // :int\n        config,\n        userAgent = navigator.userAgent.toLowerCase(),\n        adtsSampleingRates = [\n            96000, 88200,\n            64000, 48000,\n            44100, 32000,\n            24000, 22050,\n            16000, 12000\n          ];\n\n    // byte 2\n    adtsObjectType = ((data[offset+2] & 0xC0) >>> 6) + 1;\n    adtsSampleingIndex = ((data[offset+2] & 0x3C) >>> 2);\n    adtsChanelConfig = ((data[offset+2] & 0x01) << 2);\n    // byte 3\n    adtsChanelConfig |= ((data[offset+3] & 0xC0) >>> 6);\n\n    logger.log(`manifest codec:${audioCodec},ADTS data:type:${adtsObjectType},sampleingIndex:${adtsSampleingIndex}[${adtsSampleingRates[adtsSampleingIndex]}kHz],channelConfig:${adtsChanelConfig}`);\n\n\n    // firefox: freq less than 24kHz = AAC SBR (HE-AAC)\n    if(userAgent.indexOf('firefox') !== -1) {\n      if(adtsSampleingIndex >=6) {\n        adtsObjectType = 5;\n        config = new Array(4);\n        // HE-AAC uses SBR (Spectral Band Replication) , high frequencies are constructed from low frequencies\n        // there is a factor 2 between frame sample rate and output sample rate\n        // multiply frequency by 2 (see table below, equivalent to substract 3)\n        adtsExtensionSampleingIndex = adtsSampleingIndex-3;\n      } else {\n        adtsObjectType = 2;\n        config = new Array(2);\n        adtsExtensionSampleingIndex = adtsSampleingIndex;\n      }\n      // Android : always use AAC\n    } else if(userAgent.indexOf('android') !== -1) {\n      adtsObjectType = 2;\n      config = new Array(2);\n      adtsExtensionSampleingIndex = adtsSampleingIndex;\n    } else {\n      /*  for other browsers (chrome ...)\n          always force audio type to be HE-AAC SBR, as some browsers do not support audio codec switch properly (like Chrome ...)\n      */\n        adtsObjectType = 5;\n        config = new Array(4);\n       // if (manifest codec is HE-AAC) OR (manifest codec not specified AND frequency less than 24kHz)\n      if((audioCodec && audioCodec.indexOf('mp4a.40.5') !==-1) || (!audioCodec && adtsSampleingIndex >=6))  {\n        // HE-AAC uses SBR (Spectral Band Replication) , high frequencies are constructed from low frequencies\n        // there is a factor 2 between frame sample rate and output sample rate\n        // multiply frequency by 2 (see table below, equivalent to substract 3)\n        adtsExtensionSampleingIndex = adtsSampleingIndex - 3;\n      } else {\n      // if (manifest codec is AAC) AND (frequency less than 24kHz OR nb channel is 1)\n        if(audioCodec && audioCodec.indexOf('mp4a.40.2') !==-1 && (adtsSampleingIndex >= 6 || adtsChanelConfig ===1)) {\n          adtsObjectType = 2;\n          config = new Array(2);\n        }\n        adtsExtensionSampleingIndex = adtsSampleingIndex;\n      }\n    }\n  /* refer to http://wiki.multimedia.cx/index.php?title=MPEG-4_Audio#Audio_Specific_Config\n      ISO 14496-3 (AAC).pdf - Table 1.13 — Syntax of AudioSpecificConfig()\n    Audio Profile / Audio Object Type\n    0: Null\n    1: AAC Main\n    2: AAC LC (Low Complexity)\n    3: AAC SSR (Scalable Sample Rate)\n    4: AAC LTP (Long Term Prediction)\n    5: SBR (Spectral Band Replication)\n    6: AAC Scalable\n   sampling freq\n    0: 96000 Hz\n    1: 88200 Hz\n    2: 64000 Hz\n    3: 48000 Hz\n    4: 44100 Hz\n    5: 32000 Hz\n    6: 24000 Hz\n    7: 22050 Hz\n    8: 16000 Hz\n    9: 12000 Hz\n    10: 11025 Hz\n    11: 8000 Hz\n    12: 7350 Hz\n    13: Reserved\n    14: Reserved\n    15: frequency is written explictly\n    Channel Configurations\n    These are the channel configurations:\n    0: Defined in AOT Specifc Config\n    1: 1 channel: front-center\n    2: 2 channels: front-left, front-right\n  */\n    // audioObjectType = profile => profile, the MPEG-4 Audio Object Type minus 1\n    config[0] = adtsObjectType << 3;\n    // samplingFrequencyIndex\n    config[0] |= (adtsSampleingIndex & 0x0E) >> 1;\n    config[1] |= (adtsSampleingIndex & 0x01) << 7;\n    // channelConfiguration\n    config[1] |= adtsChanelConfig << 3;\n    if(adtsObjectType === 5) {\n      // adtsExtensionSampleingIndex\n      config[1] |= (adtsExtensionSampleingIndex & 0x0E) >> 1;\n      config[2] = (adtsExtensionSampleingIndex & 0x01) << 7;\n      // adtsObjectType (force to 2, chrome is checking that object type is less than 5 ???\n      //    https://chromium.googlesource.com/chromium/src.git/+/master/media/formats/mp4/aac.cc\n      config[2] |= 2 << 2;\n      config[3] = 0;\n    }\n    return { config : config, samplerate : adtsSampleingRates[adtsSampleingIndex], channelCount : adtsChanelConfig, codec : ('mp4a.40.' + adtsObjectType)};\n  }\n\n  _generateInitSegment() {\n    if(this._avcId === -1) {\n      //audio only\n      if(this._aacTrack.config) {\n         observer.trigger(Event.FRAG_PARSING_INIT_SEGMENT,{\n          audioMoov: MP4.initSegment([this._aacTrack]),\n          audioCodec : this._aacTrack.codec,\n          audioChannelCount : this._aacTrack.channelCount\n        });\n        this._initSegGenerated = true;\n      }\n      if(this._initPTS === undefined) {\n        // remember first PTS of this demuxing context\n        this._initPTS = this._aacSamples[0].pts - this.PES_TIMESCALE*this.timeOffset;\n        this._initDTS = this._aacSamples[0].dts - this.PES_TIMESCALE*this.timeOffset;\n      }\n    } else\n    if(this._aacId === -1) {\n      //video only\n      if(this._avcTrack.sps && this._avcTrack.pps) {\n         observer.trigger(Event.FRAG_PARSING_INIT_SEGMENT,{\n          videoMoov: MP4.initSegment([this._avcTrack]),\n          videoCodec : this._avcTrack.codec,\n          videoWidth : this._avcTrack.width,\n          videoHeight : this._avcTrack.height\n        });\n        this._initSegGenerated = true;\n        if(this._initPTS === undefined) {\n          // remember first PTS of this demuxing context\n          this._initPTS = this._avcSamples[0].pts - this.PES_TIMESCALE*this.timeOffset;\n          this._initDTS = this._avcSamples[0].dts - this.PES_TIMESCALE*this.timeOffset;\n        }\n      }\n    } else {\n      //audio and video\n      if(this._aacTrack.config && this._avcTrack.sps && this._avcTrack.pps) {\n         observer.trigger(Event.FRAG_PARSING_INIT_SEGMENT,{\n          audioMoov: MP4.initSegment([this._aacTrack]),\n          audioCodec : this._aacTrack.codec,\n          audioChannelCount : this._aacTrack.channelCount,\n          videoMoov: MP4.initSegment([this._avcTrack]),\n          videoCodec : this._avcTrack.codec,\n          videoWidth : this._avcTrack.width,\n          videoHeight : this._avcTrack.height\n        });\n        this._initSegGenerated = true;\n        if(this._initPTS === undefined) {\n          // remember first PTS of this demuxing context\n          this._initPTS = Math.min(this._avcSamples[0].pts,this._aacSamples[0].pts) - this.PES_TIMESCALE*this.timeOffset;\n          this._initDTS = Math.min(this._avcSamples[0].dts,this._aacSamples[0].dts) - this.PES_TIMESCALE*this.timeOffset;\n        }\n      }\n    }\n  }\n}\n\nexport default TSDemuxer;\n"," import Event                from '../events';\n import TSDemuxer            from '../demux/tsdemuxer';\n import observer             from '../observer';\n\nvar TSDemuxerWorker = function (self) {\n    self.addEventListener('message',function (ev) {\n      //console.log('demuxer cmd:' + ev.data.cmd);\n      switch(ev.data.cmd) {\n        case 'init':\n          self.demuxer = new TSDemuxer();\n          break;\n        case 'demux':\n          self.demuxer.push(new Uint8Array(ev.data.data), ev.data.audioCodec,ev.data.videoCodec, ev.data.timeOffset, ev.data.cc, ev.data.level, ev.data.duration);\n          self.demuxer.end();\n          break;\n        default:\n          break;\n      }\n    });\n\n    // listen to events triggered by TS Demuxer\n    observer.on(Event.FRAG_PARSING_INIT_SEGMENT, function(ev,data) {\n      var objData = { event : ev };\n      var objTransferable = [];\n      if(data.audioCodec) {\n        objData.audioCodec = data.audioCodec;\n        objData.audioMoov = data.audioMoov.buffer;\n        objData.audioChannelCount = data.audioChannelCount;\n        objTransferable.push(objData.audioMoov);\n      }\n      if(data.videoCodec) {\n        objData.videoCodec = data.videoCodec;\n        objData.videoMoov = data.videoMoov.buffer;\n        objData.videoWidth = data.videoWidth;\n        objData.videoHeight = data.videoHeight;\n        objTransferable.push(objData.videoMoov);\n      }\n      // pass moov as transferable object (no copy)\n      self.postMessage(objData,objTransferable);\n    });\n    observer.on(Event.FRAG_PARSING_DATA, function(ev,data) {\n      var objData = { event : ev , type : data.type, startPTS : data.startPTS, endPTS : data.endPTS , startDTS : data.startDTS, endDTS : data.endDTS ,moof : data.moof.buffer, mdat : data.mdat.buffer, nb : data.nb};\n      // pass moof/mdat data as transferable object (no copy)\n      self.postMessage(objData,[objData.moof,objData.mdat]);\n    });\n    observer.on(Event.FRAG_PARSED, function(event) {\n      self.postMessage({event:event});\n    });\n    observer.on(Event.ERROR, function(event,data) {\n      self.postMessage({event:event,data:data});\n    });\n  };\n\nexport default TSDemuxerWorker;\n\n","\nexport var ErrorTypes = {\n  // Identifier for a network error (loading error / timeout ...)\n  NETWORK_ERROR :  'hlsNetworkError',\n  // Identifier for a media Error (video/parsing/mediasource error)\n  MEDIA_ERROR :  'hlsMediaError',\n  // Identifier for all other errors\n  OTHER_ERROR :  'hlsOtherError'\n};\n\nexport var ErrorDetails = {\n  // Identifier for a manifest load error - data: { url : faulty URL, response : XHR response}\n  MANIFEST_LOAD_ERROR :  'manifestLoadError',\n  // Identifier for a manifest load timeout - data: { url : faulty URL, response : XHR response}\n  MANIFEST_LOAD_TIMEOUT :  'manifestLoadTimeOut',\n  // Identifier for a manifest parsing error - data: { url : faulty URL, reason : error reason}\n  MANIFEST_PARSING_ERROR :  'manifestParsingError',\n  // Identifier for playlist load error - data: { url : faulty URL, response : XHR response}\n  LEVEL_LOAD_ERROR :  'levelLoadError',\n  // Identifier for playlist load timeout - data: { url : faulty URL, response : XHR response}\n  LEVEL_LOAD_TIMEOUT :  'levelLoadTimeOut',\n  // Identifier for a level switch error - data: { level : faulty level Id, event : error description}\n  LEVEL_SWITCH_ERROR :  'levelSwitchError',\n  // Identifier for fragment load error - data: { frag : fragment object, response : XHR response}\n  FRAG_LOAD_ERROR :  'fragLoadError',\n  // Identifier for fragment loop loading error - data: { frag : fragment object}\n  FRAG_LOOP_LOADING_ERROR :  'fragLoopLoadingError',\n  // Identifier for fragment load timeout error - data: { frag : fragment object}\n  FRAG_LOAD_TIMEOUT :  'fragLoadTimeOut',\n  // Identifier for a fragment parsing error event - data: parsing error description\n  FRAG_PARSING_ERROR :  'fragParsingError',\n    // Identifier for a fragment appending error event - data: appending error description\n  FRAG_APPENDING_ERROR :  'fragAppendingError'\n};\n","export default {\n  // fired when MediaSource has been succesfully attached to video element - data: { mediaSource }\n  MSE_ATTACHED : 'hlsMediaSourceAttached',\n  // fired when MediaSource has been detached from video element - data: { }\n  MSE_DETACHED : 'hlsMediaSourceDetached',\n  // fired to signal that a manifest loading starts - data: { url : manifestURL}\n  MANIFEST_LOADING  : 'hlsManifestLoading',\n  // fired after manifest has been loaded - data: { levels : [available quality levels] , url : manifestURL, stats : { trequest, tfirst, tload, mtime}}\n  MANIFEST_LOADED  : 'hlsManifestLoaded',\n  // fired after manifest has been parsed - data: { levels : [available quality levels] , firstLevel : index of first quality level appearing in Manifest}\n  MANIFEST_PARSED  : 'hlsManifestParsed',\n  // fired when a level playlist loading starts - data: { url : level URL  level : id of level being loaded}\n  LEVEL_LOADING    : 'hlsLevelLoading',\n  // fired when a level playlist loading finishes - data: { details : levelDetails object, level : id of loaded level, stats : { trequest, tfirst, tload, mtime} }\n  LEVEL_LOADED :  'hlsLevelLoaded',\n  // fired when a level switch is requested - data: { level : id of new level }\n  LEVEL_SWITCH :  'hlsLevelSwitch',\n  // fired when a fragment loading starts - data: { frag : fragment object}\n  FRAG_LOADING :  'hlsFragLoading',\n  // fired when a fragment loading is progressing - data: { frag : fragment object, { trequest, tfirst, loaded}}\n  FRAG_LOAD_PROGRESS :  'hlsFragLoadProgress',\n  // Identifier for fragment load aborting for emergency switch down - data: {frag : fragment object}\n  FRAG_LOAD_EMERGENCY_ABORTED :  'hlsFragLoadEmergencyAborted',\n  // fired when a fragment loading is completed - data: { frag : fragment object, payload : fragment payload, stats : { trequest, tfirst, tload, length}}\n  FRAG_LOADED :  'hlsFragLoaded',\n  // fired when Init Segment has been extracted from fragment - data: { moov : moov MP4 box, codecs : codecs found while parsing fragment}\n  FRAG_PARSING_INIT_SEGMENT :  'hlsFragParsingInitSegment',\n  // fired when moof/mdat have been extracted from fragment - data: { moof : moof MP4 box, mdat : mdat MP4 box}\n  FRAG_PARSING_DATA :  'hlsFragParsingData',\n  // fired when fragment parsing is completed - data: undefined\n  FRAG_PARSED :  'hlsFragParsed',\n  // fired when fragment remuxed MP4 boxes have all been appended into SourceBuffer - data: { frag : fragment object, stats : { trequest, tfirst, tload, tparsed, tbuffered, length} }\n  FRAG_BUFFERED :  'hlsFragBuffered',\n  // fired when fragment matching with current video position is changing - data : { frag : fragment object }\n  FRAG_CHANGED :  'hlsFragChanged',\n    // Identifier for a FPS drop event - data: {curentDropped, currentDecoded, totalDroppedFrames}\n  FPS_DROP :  'hlsFPSDrop',\n  // Identifier for an error event - data: { type : error type, details : error details, fatal : if true, hls.js cannot/will not try to recover, if false, hls.js will try to recover,other error specific data}\n  ERROR : 'hlsError'\n};\n","/**\n * HLS interface\n */\n'use strict';\n\nimport Event                      from './events';\nimport {ErrorTypes,ErrorDetails}  from './errors';\nimport StatsHandler               from './stats';\nimport observer                   from './observer';\nimport PlaylistLoader             from './loader/playlist-loader';\nimport FragmentLoader             from './loader/fragment-loader';\nimport BufferController           from './controller/buffer-controller';\nimport LevelController            from './controller/level-controller';\n//import FPSController              from './controller/fps-controller';\nimport {logger,enableLogs}        from './utils/logger';\nimport XhrLoader                  from './utils/xhr-loader';\n\nclass Hls {\n\n  static isSupported() {\n    return (window.MediaSource && MediaSource.isTypeSupported('video/mp4; codecs=\"avc1.42E01E,mp4a.40.2\"'));\n  }\n\n  static get Events() {\n    return Event;\n  }\n\n  static get ErrorTypes() {\n    return ErrorTypes;\n  }\n\n  static get ErrorDetails() {\n    return ErrorDetails;\n  }\n\n  constructor(config = {}) {\n   var configDefault = {\n      autoStartLoad : true,\n      debug : false,\n      maxBufferLength : 30,\n      maxBufferSize : 60*1000*1000,\n      maxMaxBufferLength : 600,\n      enableWorker : true,\n      fragLoadingTimeOut : 20000,\n      fragLoadingMaxRetry : 1,\n      fragLoadingRetryDelay : 1000,\n      fragLoadingLoopThreshold : 3,\n      manifestLoadingTimeOut : 10000,\n      manifestLoadingMaxRetry : 1,\n      manifestLoadingRetryDelay : 1000,\n      fpsDroppedMonitoringPeriod : 5000,\n      fpsDroppedMonitoringThreshold : 0.2,\n      appendErrorMaxRetry : 200,\n      loader : XhrLoader\n    };\n    for (var prop in configDefault) {\n        if (prop in config) { continue; }\n        config[prop] = configDefault[prop];\n    }\n    enableLogs(config.debug);\n    this.config = config;\n    this.playlistLoader = new PlaylistLoader(this);\n    this.fragmentLoader = new FragmentLoader(this);\n    this.levelController = new LevelController(this);\n    this.bufferController = new BufferController(this);\n    //this.fpsController = new FPSController(this);\n    this.statsHandler = new StatsHandler(this);\n    // observer setup\n    this.on = observer.on.bind(observer);\n    this.off = observer.off.bind(observer);\n  }\n\n  destroy() {\n    logger.log(`destroy`);\n    this.playlistLoader.destroy();\n    this.fragmentLoader.destroy();\n    this.levelController.destroy();\n    this.bufferController.destroy();\n    //this.fpsController.destroy();\n    this.statsHandler.destroy();\n    this.url = null;\n    this.detachVideo();\n    observer.removeAllListeners();\n  }\n\n  attachVideo(video) {\n    logger.log(`attachVideo`);\n    this.video = video;\n    this.statsHandler.attachVideo(video);\n    // setup the media source\n    var ms = this.mediaSource = new MediaSource();\n    //Media Source listeners\n    this.onmso = this.onMediaSourceOpen.bind(this);\n    this.onmse = this.onMediaSourceEnded.bind(this);\n    this.onmsc = this.onMediaSourceClose.bind(this);\n    ms.addEventListener('sourceopen',  this.onmso);\n    ms.addEventListener('sourceended', this.onmse);\n    ms.addEventListener('sourceclose', this.onmsc);\n    // link video and media Source\n    video.src = URL.createObjectURL(ms);\n    video.addEventListener('error',this.onverror);\n  }\n\n  detachVideo() {\n    logger.log(`detachVideo`);\n    var video = this.video;\n    this.statsHandler.detachVideo(video);\n    var ms = this.mediaSource;\n    if(ms) {\n      if(ms.readyState !== 'ended') {\n        ms.endOfStream();\n      }\n      ms.removeEventListener('sourceopen',  this.onmso);\n      ms.removeEventListener('sourceended', this.onmse);\n      ms.removeEventListener('sourceclose', this.onmsc);\n      // unlink MediaSource from video tag\n      video.src = '';\n      this.mediaSource = null;\n      logger.log(`trigger MSE_DETACHED`);\n      observer.trigger(Event.MSE_DETACHED);\n    }\n    this.onmso = this.onmse = this.onmsc = null;\n    if(video) {\n      this.video = null;\n    }\n  }\n\n  loadSource(url) {\n    logger.log(`loadSource:${url}`);\n    this.url = url;\n    // when attaching to a source URL, trigger a playlist load\n    observer.trigger(Event.MANIFEST_LOADING, { url: url });\n  }\n\n  startLoad() {\n    logger.log(`startLoad`);\n    this.bufferController.startLoad();\n  }\n\n  recoverMediaError() {\n    logger.log('recoverMediaError');\n    var video = this.video;\n    this.detachVideo();\n    this.attachVideo(video);\n  }\n\n  /** Return all quality levels **/\n  get levels() {\n    return this.levelController.levels;\n  }\n\n  /** Return current playback quality level **/\n  get currentLevel() {\n    return this.bufferController.currentLevel;\n  }\n\n  /* set quality level immediately (-1 for automatic level selection) */\n  set currentLevel(newLevel) {\n    logger.log(`set currentLevel:${newLevel}`);\n    this.loadLevel = newLevel;\n    this.bufferController.immediateLevelSwitch();\n  }\n\n  /** Return next playback quality level (quality level of next fragment) **/\n  get nextLevel() {\n    return this.bufferController.nextLevel;\n  }\n\n  /* set quality level for next fragment (-1 for automatic level selection) */\n  set nextLevel(newLevel) {\n    logger.log(`set nextLevel:${newLevel}`);\n    this.levelController.manualLevel = newLevel;\n    this.bufferController.nextLevelSwitch();\n  }\n\n  /** Return the quality level of current/last loaded fragment **/\n  get loadLevel() {\n    return this.levelController.level;\n  }\n\n  /* set quality level for current/next loaded fragment (-1 for automatic level selection) */\n  set loadLevel(newLevel) {\n    logger.log(`set loadLevel:${newLevel}`);\n    this.levelController.manualLevel = newLevel;\n  }\n\n  /** Return the quality level of next loaded fragment **/\n  get nextLoadLevel() {\n    return this.levelController.nextLoadLevel();\n  }\n\n  /** set quality level of next loaded fragment **/\n  set nextLoadLevel(level) {\n    this.levelController.level = level;\n  }\n\n  /** Return first level (index of first level referenced in manifest)\n  **/\n  get firstLevel() {\n    return this.levelController.firstLevel;\n  }\n\n  /** set first level (index of first level referenced in manifest)\n  **/\n  set firstLevel(newLevel) {\n    logger.log(`set firstLevel:${newLevel}`);\n    this.levelController.firstLevel = newLevel;\n  }\n\n  /** Return start level (level of first fragment that will be played back)\n      if not overrided by user, first level appearing in manifest will be used as start level\n      if -1 : automatic start level selection, playback will start from level matching download bandwidth (determined from download of first segment)\n  **/\n  get startLevel() {\n    return this.levelController.startLevel;\n  }\n\n  /** set  start level (level of first fragment that will be played back)\n      if not overrided by user, first level appearing in manifest will be used as start level\n      if -1 : automatic start level selection, playback will start from level matching download bandwidth (determined from download of first segment)\n  **/\n  set startLevel(newLevel) {\n    logger.log(`set startLevel:${newLevel}`);\n    this.levelController.startLevel = newLevel;\n  }\n\n  /** Return the capping/max level value that could be used by automatic level selection algorithm **/\n  get autoLevelCapping() {\n    return this.levelController.autoLevelCapping;\n  }\n\n  /** set the capping/max level value that could be used by automatic level selection algorithm **/\n  set autoLevelCapping(newLevel) {\n    logger.log(`set autoLevelCapping:${newLevel}`);\n    this.levelController.autoLevelCapping = newLevel;\n  }\n\n  /* check if we are in automatic level selection mode */\n  get autoLevelEnabled() {\n    return (this.levelController.manualLevel  === -1);\n  }\n\n  /* return manual level */\n  get manualLevel() {\n    return this.levelController.manualLevel;\n  }\n\n\n  /* return playback session stats */\n  get stats() {\n    return this.statsHandler.stats;\n  }\n\n  onMediaSourceOpen() {\n    logger.log('media source opened');\n    observer.trigger(Event.MSE_ATTACHED, { video: this.video, mediaSource : this.mediaSource });\n    // once received, don't listen anymore to sourceopen event\n    this.mediaSource.removeEventListener('sourceopen',  this.onmso);\n  }\n\n  onMediaSourceClose() {\n    logger.log('media source closed');\n  }\n\n  onMediaSourceEnded() {\n    logger.log('media source ended');\n  }\n}\n\nexport default Hls;\n"," /*\n * fragment loader\n *\n */\n\nimport Event                from '../events';\nimport observer             from '../observer';\nimport {ErrorTypes,ErrorDetails} from '../errors';\n\n class FragmentLoader {\n\n  constructor(hls) {\n    this.hls=hls;\n    this.onfl = this.onFragLoading.bind(this);\n    observer.on(Event.FRAG_LOADING, this.onfl);\n  }\n\n  destroy() {\n    if(this.loader) {\n      this.loader.destroy();\n      this.loader = null;\n    }\n    observer.off(Event.FRAG_LOADING, this.onfl);\n  }\n\n  onFragLoading(event,data) {\n    var frag = data.frag;\n    this.frag = frag;\n    this.frag.loaded = 0;\n    var config = this.hls.config;\n    frag.loader = this.loader = new config.loader();\n    this.loader.load(frag.url,'arraybuffer',this.loadsuccess.bind(this), this.loaderror.bind(this), this.loadtimeout.bind(this), config.fragLoadingTimeOut, config.fragLoadingMaxRetry,config.fragLoadingRetryDelay,this.loadprogress.bind(this));\n  }\n\n  loadsuccess(event, stats) {\n    var payload = event.currentTarget.response;\n    stats.length = payload.byteLength;\n    // detach fragment loader on load success\n    this.frag.loader = undefined;\n    observer.trigger(Event.FRAG_LOADED,\n                    { payload : payload,\n                      frag : this.frag ,\n                      stats : stats});\n  }\n\n  loaderror(event) {\n    this.loader.abort();\n    observer.trigger(Event.ERROR, { type : ErrorTypes.NETWORK_ERROR, details : ErrorDetails.FRAG_LOAD_ERROR, fatal:false,frag : this.frag, response:event});\n  }\n\n  loadtimeout() {\n    this.loader.abort();\n    observer.trigger(Event.ERROR, { type : ErrorTypes.NETWORK_ERROR, details : ErrorDetails.FRAG_LOAD_TIMEOUT, fatal:false,frag : this.frag});\n  }\n\n  loadprogress(event, stats) {\n    this.frag.loaded = stats.loaded;\n   observer.trigger(Event.FRAG_LOAD_PROGRESS, { frag : this.frag, stats : stats});\n  }\n}\n\nexport default FragmentLoader;\n","/*\n * playlist loader\n *\n */\n\nimport Event                from '../events';\nimport observer             from '../observer';\nimport {ErrorTypes,ErrorDetails} from '../errors';\n//import {logger}             from '../utils/logger';\n\n class PlaylistLoader {\n\n  constructor(hls) {\n    this.hls = hls;\n    this.onml = this.onManifestLoading.bind(this);\n    this.onll = this.onLevelLoading.bind(this);\n    observer.on(Event.MANIFEST_LOADING, this.onml);\n    observer.on(Event.LEVEL_LOADING, this.onll);\n  }\n\n  destroy() {\n    if(this.loader) {\n      this.loader.destroy();\n      this.loader = null;\n    }\n    this.url = this.id = null;\n    observer.off(Event.MANIFEST_LOADING, this.onml);\n    observer.off(Event.LEVEL_LOADING, this.onll);\n  }\n\n  onManifestLoading(event,data) {\n    this.load(data.url,null);\n  }\n\n  onLevelLoading(event,data) {\n    this.load(data.url,data.level,data.id);\n  }\n\n  load(url,id1,id2) {\n    var config=this.hls.config;\n    this.url = url;\n    this.id = id1;\n    this.id2 = id2;\n    this.loader = new config.loader();\n    this.loader.load(url,'',this.loadsuccess.bind(this), this.loaderror.bind(this), this.loadtimeout.bind(this), config.manifestLoadingTimeOut, config.manifestLoadingMaxRetry,config.manifestLoadingRetryDelay);\n  }\n\n  resolve(url, baseUrl) {\n    var doc      = document,\n        oldBase = doc.getElementsByTagName('base')[0],\n        oldHref = oldBase && oldBase.href,\n        docHead = doc.head || doc.getElementsByTagName('head')[0],\n        ourBase = oldBase || docHead.appendChild(doc.createElement('base')),\n        resolver = doc.createElement('a'),\n        resolvedUrl;\n\n    ourBase.href = baseUrl;\n    resolver.href = url;\n    resolvedUrl  = resolver.href; // browser magic at work here\n\n    if (oldBase) {oldBase.href = oldHref;}\n    else {docHead.removeChild(ourBase);}\n    return resolvedUrl;\n  }\n\n  parseMasterPlaylist(string,baseurl) {\n    var levels = [],level =  {},result,codecs,codec;\n    var re = /#EXT-X-STREAM-INF:([^\\n\\r]*(BAND)WIDTH=(\\d+))?([^\\n\\r]*(CODECS)=\\\"(.*)\\\",)?([^\\n\\r]*(RES)OLUTION=(\\d+)x(\\d+))?([^\\n\\r]*(NAME)=\\\"(.*)\\\")?[^\\n\\r]*[\\r\\n]+([^\\r\\n]+)/g;\n    while((result = re.exec(string)) != null){\n      result.shift();\n      result = result.filter(function(n){ return (n !== undefined);});\n      level.url = this.resolve(result.pop(),baseurl);\n      while(result.length > 0) {\n        switch(result.shift()) {\n          case 'RES':\n            level.width = parseInt(result.shift());\n            level.height = parseInt(result.shift());\n            break;\n          case 'BAND':\n            level.bitrate = parseInt(result.shift());\n            break;\n          case 'NAME':\n            level.name = result.shift();\n            break;\n          case 'CODECS':\n            codecs = result.shift().split(',');\n            while(codecs.length > 0) {\n              codec = codecs.shift();\n              if(codec.indexOf('avc1') !== -1) {\n                level.videoCodec = this.avc1toavcoti(codec);\n              } else {\n                level.audioCodec = codec;\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n      levels.push(level);\n      level = {};\n    }\n    return levels;\n  }\n\n  avc1toavcoti(codec) {\n    var result,avcdata = codec.split('.');\n    if(avcdata.length > 2) {\n      result = avcdata.shift() + '.';\n      result += parseInt(avcdata.shift()).toString(16);\n      result += ('00' + parseInt(avcdata.shift()).toString(16)).substr(-4);\n    } else {\n      result = codec;\n    }\n    return result;\n  }\n\n  parseLevelPlaylist(string, baseurl, id) {\n    var currentSN = 0,totalduration = 0, level = { url : baseurl, fragments : [], live : true, startSN : 0}, result, regexp, cc = 0;\n    regexp = /(?:#EXT-X-(MEDIA-SEQUENCE):(\\d+))|(?:#EXT-X-(TARGETDURATION):(\\d+))|(?:#EXT(INF):([\\d\\.]+)[^\\r\\n]*[\\r\\n]+([^\\r\\n]+)|(?:#EXT-X-(ENDLIST))|(?:#EXT-X-(DIS)CONTINUITY))/g;\n    while((result = regexp.exec(string)) !== null){\n      result.shift();\n      result = result.filter(function(n){ return (n !== undefined);});\n      switch(result[0]) {\n        case 'MEDIA-SEQUENCE':\n          currentSN = level.startSN = parseInt(result[1]);\n          break;\n        case 'TARGETDURATION':\n          level.targetduration = parseFloat(result[1]);\n          break;\n        case 'ENDLIST':\n          level.live = false;\n          break;\n        case 'DIS':\n          cc++;\n          break;\n        case 'INF':\n          var duration = parseFloat(result[1]);\n          level.fragments.push({url : this.resolve(result[2],baseurl), duration : duration, start : totalduration, sn : currentSN++, level:id, cc : cc});\n          totalduration+=duration;\n          break;\n        default:\n          break;\n      }\n    }\n    //logger.log('found ' + level.fragments.length + ' fragments');\n    level.totalduration = totalduration;\n    level.endSN = currentSN - 1;\n    return level;\n  }\n\n  loadsuccess(event, stats) {\n    var string = event.currentTarget.responseText, url = event.currentTarget.responseURL, id = this.id,id2= this.id2, levels;\n    // responseURL not supported on some browsers (it is used to detect URL redirection)\n    if(url === undefined) {\n      // fallback to initial URL\n      url = this.url;\n    }\n    stats.tload = new Date();\n    stats.mtime = new Date(event.currentTarget.getResponseHeader('Last-Modified'));\n\n    if(string.indexOf('#EXTM3U') === 0) {\n      if (string.indexOf('#EXTINF:') > 0) {\n        // 1 level playlist\n        // if first request, fire manifest loaded event, level will be reloaded afterwards\n        // (this is to have a uniform logic for 1 level/multilevel playlists)\n        if(this.id === null) {\n          observer.trigger(Event.MANIFEST_LOADED,\n                          { levels : [{url : url}],\n                            url : url,\n                            stats : stats});\n        } else {\n          observer.trigger(Event.LEVEL_LOADED,\n                          { details : this.parseLevelPlaylist(string,url,id),\n                            level : id,\n                            id : id2,\n                            stats : stats});\n        }\n      } else {\n        levels = this.parseMasterPlaylist(string,url);\n        // multi level playlist, parse level info\n        if(levels.length) {\n          observer.trigger(Event.MANIFEST_LOADED,\n                          { levels : levels,\n                            url : url,\n                            stats : stats});\n        } else {\n          observer.trigger(Event.ERROR, { type : ErrorTypes.NETWORK_ERROR, details : ErrorDetails.MANIFEST_PARSING_ERROR, fatal:true, url : url, reason : 'no level found in manifest'});\n        }\n      }\n    } else {\n      observer.trigger(Event.ERROR, { type : ErrorTypes.NETWORK_ERROR, details : ErrorDetails.MANIFEST_PARSING_ERROR, fatal:true, url : url, reason : 'no EXTM3U delimiter'});\n    }\n  }\n\n  loaderror(event) {\n    var details,fatal;\n    if(this.id === null) {\n      details = ErrorDetails.MANIFEST_LOAD_ERROR;\n      fatal = true;\n    } else {\n      details = ErrorDetails.LEVEL_LOAD_ERROR;\n      fatal = false;\n    }\n    this.loader.abort();\n    observer.trigger(Event.ERROR, {type : ErrorTypes.NETWORK_ERROR, details:details, fatal:fatal, url:this.url, loader : this.loader, response:event.currentTarget, level: this.id, id : this.id2});\n  }\n\n  loadtimeout() {\n    var details,fatal;\n    if(this.id === null) {\n      details = ErrorDetails.MANIFEST_LOAD_TIMEOUT;\n      fatal = true;\n    } else {\n      details = ErrorDetails.LEVEL_LOAD_TIMEOUT;\n      fatal = false;\n    }\n   this.loader.abort();\n   observer.trigger(Event.ERROR, { type : ErrorTypes.NETWORK_ERROR, details:details, fatal:fatal, url : this.url, loader: this.loader, level: this.id, id : this.id2});\n  }\n}\n\nexport default PlaylistLoader;\n","import EventEmitter from 'events';\n\nlet observer = new EventEmitter();\n\nobserver.trigger = function trigger (event, ...data) {\n  observer.emit(event, event, ...data);\n};\n\nobserver.off = function off (event, ...data) {\n  observer.removeListener(event, ...data);\n};\n\n\nexport default observer;\n","/**\n * generate MP4 Box\n */\n\nclass MP4 {\n  static init() {\n    MP4.types = {\n      avc1: [], // codingname\n      avcC: [],\n      btrt: [],\n      dinf: [],\n      dref: [],\n      esds: [],\n      ftyp: [],\n      hdlr: [],\n      mdat: [],\n      mdhd: [],\n      mdia: [],\n      mfhd: [],\n      minf: [],\n      moof: [],\n      moov: [],\n      mp4a: [],\n      mvex: [],\n      mvhd: [],\n      sdtp: [],\n      stbl: [],\n      stco: [],\n      stsc: [],\n      stsd: [],\n      stsz: [],\n      stts: [],\n      tfdt: [],\n      tfhd: [],\n      traf: [],\n      trak: [],\n      trun: [],\n      trex: [],\n      tkhd: [],\n      vmhd: [],\n      smhd: []\n    };\n\n    var i;\n    for (i in MP4.types) {\n      if (MP4.types.hasOwnProperty(i)) {\n        MP4.types[i] = [\n          i.charCodeAt(0),\n          i.charCodeAt(1),\n          i.charCodeAt(2),\n          i.charCodeAt(3)\n        ];\n      }\n    }\n\n    MP4.MAJOR_BRAND = new Uint8Array([\n      'i'.charCodeAt(0),\n      's'.charCodeAt(0),\n      'o'.charCodeAt(0),\n      'm'.charCodeAt(0)\n    ]);\n    MP4.AVC1_BRAND = new Uint8Array([\n      'a'.charCodeAt(0),\n      'v'.charCodeAt(0),\n      'c'.charCodeAt(0),\n      '1'.charCodeAt(0)\n    ]);\n    MP4.MINOR_VERSION = new Uint8Array([0, 0, 0, 1]);\n    MP4.VIDEO_HDLR = new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x00, // pre_defined\n      0x76, 0x69, 0x64, 0x65, // handler_type: 'vide'\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x56, 0x69, 0x64, 0x65,\n      0x6f, 0x48, 0x61, 0x6e,\n      0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'VideoHandler'\n    ]);\n    MP4.AUDIO_HDLR = new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x00, // pre_defined\n      0x73, 0x6f, 0x75, 0x6e, // handler_type: 'soun'\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x53, 0x6f, 0x75, 0x6e,\n      0x64, 0x48, 0x61, 0x6e,\n      0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'SoundHandler'\n    ]);\n    MP4.HDLR_TYPES = {\n      'video':MP4.VIDEO_HDLR,\n      'audio':MP4.AUDIO_HDLR\n    };\n    MP4.DREF = new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x01, // entry_count\n      0x00, 0x00, 0x00, 0x0c, // entry_size\n      0x75, 0x72, 0x6c, 0x20, // 'url' type\n      0x00, // version 0\n      0x00, 0x00, 0x01 // entry_flags\n    ]);\n    MP4.STCO = new Uint8Array([\n      0x00, // version\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x00 // entry_count\n    ]);\n    MP4.STSC = MP4.STCO;\n    MP4.STTS = MP4.STCO;\n    MP4.STSZ = new Uint8Array([\n      0x00, // version\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x00, // sample_size\n      0x00, 0x00, 0x00, 0x00, // sample_count\n    ]);\n    MP4.VMHD = new Uint8Array([\n      0x00, // version\n      0x00, 0x00, 0x01, // flags\n      0x00, 0x00, // graphicsmode\n      0x00, 0x00,\n      0x00, 0x00,\n      0x00, 0x00 // opcolor\n    ]);\n    MP4.SMHD = new Uint8Array([\n      0x00, // version\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, // balance\n      0x00, 0x00 // reserved\n    ]);\n\n    MP4.STSD = new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x01]);// entry_count\n\n    MP4.FTYP = MP4.box(MP4.types.ftyp, MP4.MAJOR_BRAND, MP4.MINOR_VERSION, MP4.MAJOR_BRAND, MP4.AVC1_BRAND);\n    MP4.DINF = MP4.box(MP4.types.dinf, MP4.box(MP4.types.dref, MP4.DREF));\n  }\n\n  static box(type) {\n  var\n    payload = Array.prototype.slice.call(arguments, 1),\n    size = 0,\n    i = payload.length,\n    result,\n    view;\n\n    // calculate the total size we need to allocate\n    while (i--) {\n      size += payload[i].byteLength;\n    }\n    result = new Uint8Array(size + 8);\n    view = new DataView(result.buffer);\n    view.setUint32(0, result.byteLength);\n    result.set(type, 4);\n\n    // copy the payload into the result\n    for (i = 0, size = 8; i < payload.length; i++) {\n      result.set(payload[i], size);\n      size += payload[i].byteLength;\n    }\n    return result;\n  }\n\n  static hdlr(type) {\n    return MP4.box(MP4.types.hdlr, MP4.HDLR_TYPES[type]);\n  }\n\n  static mdat(data) {\n    return MP4.box(MP4.types.mdat, data);\n  }\n\n  static mdhd(timescale,duration) {\n    return MP4.box(MP4.types.mdhd, new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x02, // creation_time\n      0x00, 0x00, 0x00, 0x03, // modification_time\n      (timescale >> 24) & 0xFF,\n      (timescale >> 16) & 0xFF,\n      (timescale >>  8) & 0xFF,\n      timescale & 0xFF, // timescale\n      (duration >> 24),\n      (duration >> 16) & 0xFF,\n      (duration >>  8) & 0xFF,\n      duration & 0xFF, // duration\n      0x55, 0xc4, // 'und' language (undetermined)\n      0x00, 0x00\n    ]));\n  }\n\n  static mdia(track) {\n    return MP4.box(MP4.types.mdia, MP4.mdhd(track.timescale,track.duration), MP4.hdlr(track.type), MP4.minf(track));\n  }\n\n  static mfhd(sequenceNumber) {\n    return MP4.box(MP4.types.mfhd, new Uint8Array([\n      0x00,\n      0x00, 0x00, 0x00, // flags\n      (sequenceNumber >> 24),\n      (sequenceNumber >> 16) & 0xFF,\n      (sequenceNumber >>  8) & 0xFF,\n      sequenceNumber & 0xFF, // sequence_number\n    ]));\n  }\n\n  static minf(track) {\n    if (track.type === 'audio') {\n      return MP4.box(MP4.types.minf, MP4.box(MP4.types.smhd, MP4.SMHD), MP4.DINF, MP4.stbl(track));\n    } else {\n      return MP4.box(MP4.types.minf, MP4.box(MP4.types.vmhd, MP4.VMHD), MP4.DINF, MP4.stbl(track));\n    }\n  }\n\n  static moof(sn, baseMediaDecodeTime, track) {\n    return MP4.box(MP4.types.moof,\n                   MP4.mfhd(sn),\n                   MP4.traf(track,baseMediaDecodeTime));\n  }\n/**\n * @param tracks... (optional) {array} the tracks associated with this movie\n */\n  static moov(tracks) {\n    var\n      i = tracks.length,\n      boxes = [];\n\n    while (i--) {\n      boxes[i] = MP4.trak(tracks[i]);\n    }\n\n    return MP4.box.apply(null, [MP4.types.moov, MP4.mvhd(tracks[0].timescale,tracks[0].duration)].concat(boxes).concat(MP4.mvex(tracks)));\n  }\n\n  static mvex(tracks) {\n    var\n      i = tracks.length,\n      boxes = [];\n\n    while (i--) {\n      boxes[i] = MP4.trex(tracks[i]);\n    }\n    return MP4.box.apply(null, [MP4.types.mvex].concat(boxes));\n  }\n\n  static mvhd(timescale,duration) {\n    var\n      bytes = new Uint8Array([\n        0x00, // version 0\n        0x00, 0x00, 0x00, // flags\n        0x00, 0x00, 0x00, 0x01, // creation_time\n        0x00, 0x00, 0x00, 0x02, // modification_time\n        (timescale >> 24) & 0xFF,\n        (timescale >> 16) & 0xFF,\n        (timescale >>  8) & 0xFF,\n        timescale & 0xFF, // timescale\n        (duration >> 24) & 0xFF,\n        (duration >> 16) & 0xFF,\n        (duration >>  8) & 0xFF,\n        duration & 0xFF, // duration\n        0x00, 0x01, 0x00, 0x00, // 1.0 rate\n        0x01, 0x00, // 1.0 volume\n        0x00, 0x00, // reserved\n        0x00, 0x00, 0x00, 0x00, // reserved\n        0x00, 0x00, 0x00, 0x00, // reserved\n        0x00, 0x01, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x01, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00, // pre_defined\n        0xff, 0xff, 0xff, 0xff // next_track_ID\n      ]);\n    return MP4.box(MP4.types.mvhd, bytes);\n  }\n\n  static sdtp(track) {\n    var\n      samples = track.samples || [],\n      bytes = new Uint8Array(4 + samples.length),\n      flags,\n      i;\n\n    // leave the full box header (4 bytes) all zero\n\n    // write the sample table\n    for (i = 0; i < samples.length; i++) {\n      flags = samples[i].flags;\n      bytes[i + 4] = (flags.dependsOn << 4) |\n        (flags.isDependedOn << 2) |\n        (flags.hasRedundancy);\n    }\n\n    return MP4.box(MP4.types.sdtp,\n               bytes);\n  }\n\n  static stbl(track) {\n    return MP4.box(MP4.types.stbl,\n               MP4.stsd(track),\n               MP4.box(MP4.types.stts, MP4.STTS),\n               MP4.box(MP4.types.stsc, MP4.STSC),\n               MP4.box(MP4.types.stsz, MP4.STSZ),\n               MP4.box(MP4.types.stco, MP4.STCO));\n  }\n\n  static avc1(track) {\n    var sps = [], pps = [], i;\n    // assemble the SPSs\n    for (i = 0; i < track.sps.length; i++) {\n      sps.push((track.sps[i].byteLength >>> 8) & 0xFF);\n      sps.push((track.sps[i].byteLength & 0xFF)); // sequenceParameterSetLength\n      sps = sps.concat(Array.prototype.slice.call(track.sps[i])); // SPS\n    }\n\n    // assemble the PPSs\n    for (i = 0; i < track.pps.length; i++) {\n      pps.push((track.pps[i].byteLength >>> 8) & 0xFF);\n      pps.push((track.pps[i].byteLength & 0xFF));\n      pps = pps.concat(Array.prototype.slice.call(track.pps[i]));\n    }\n\n    return MP4.box(MP4.types.avc1, new Uint8Array([\n        0x00, 0x00, 0x00, // reserved\n        0x00, 0x00, 0x00, // reserved\n        0x00, 0x01, // data_reference_index\n        0x00, 0x00, // pre_defined\n        0x00, 0x00, // reserved\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00, // pre_defined\n        (track.width >> 8) & 0xFF,\n        track.width & 0xff, // width\n        (track.height >> 8) & 0xFF,\n        track.height & 0xff, // height\n        0x00, 0x48, 0x00, 0x00, // horizresolution\n        0x00, 0x48, 0x00, 0x00, // vertresolution\n        0x00, 0x00, 0x00, 0x00, // reserved\n        0x00, 0x01, // frame_count\n        0x13,\n        0x76, 0x69, 0x64, 0x65,\n        0x6f, 0x6a, 0x73, 0x2d,\n        0x63, 0x6f, 0x6e, 0x74,\n        0x72, 0x69, 0x62, 0x2d,\n        0x68, 0x6c, 0x73, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, // compressorname\n        0x00, 0x18, // depth = 24\n        0x11, 0x11]), // pre_defined = -1\n          MP4.box(MP4.types.avcC, new Uint8Array([\n            0x01, // configurationVersion\n            track.profileIdc, // AVCProfileIndication\n            track.profileCompat, // profile_compatibility\n            track.levelIdc, // AVCLevelIndication\n            0xff // lengthSizeMinusOne, hard-coded to 4 bytes\n          ].concat([\n            track.sps.length // numOfSequenceParameterSets\n          ]).concat(sps).concat([\n            track.pps.length // numOfPictureParameterSets\n          ]).concat(pps))), // \"PPS\"\n          MP4.box(MP4.types.btrt, new Uint8Array([\n            0x00, 0x1c, 0x9c, 0x80, // bufferSizeDB\n            0x00, 0x2d, 0xc6, 0xc0, // maxBitrate\n            0x00, 0x2d, 0xc6, 0xc0])) // avgBitrate\n          );\n  }\n\n  static esds(track) {\n    return new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n\n      0x03, // descriptor_type\n      0x17+track.config.length, // length\n      0x00, 0x01, //es_id\n      0x00, // stream_priority\n\n      0x04, // descriptor_type\n      0x0f+track.config.length, // length\n      0x40, //codec : mpeg4_audio\n      0x15, // stream_type\n      0x00, 0x00, 0x00, // buffer_size\n      0x00, 0x00, 0x00, 0x00, // maxBitrate\n      0x00, 0x00, 0x00, 0x00, // avgBitrate\n\n      0x05 // descriptor_type\n      ].concat([track.config.length]).concat(track.config).concat([0x06, 0x01, 0x02])); // GASpecificConfig)); // length + audio config descriptor\n  }\n\n  static mp4a(track) {\n        return MP4.box(MP4.types.mp4a, new Uint8Array([\n        0x00, 0x00, 0x00, // reserved\n        0x00, 0x00, 0x00, // reserved\n        0x00, 0x01, // data_reference_index\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00, // reserved\n        0x00, track.channelCount, // channelcount\n        0x00, 0x10, // sampleSize:16bits\n        0x00, 0x00, 0x00, 0x00, // reserved2\n        (track.audiosamplerate >> 8) & 0xFF,\n        track.audiosamplerate & 0xff, //\n        0x00, 0x00]),\n        MP4.box(MP4.types.esds, MP4.esds(track)));\n  }\n\n  static stsd(track) {\n    if (track.type === 'audio') {\n      return MP4.box(MP4.types.stsd, MP4.STSD , MP4.mp4a(track));\n    } else {\n      return MP4.box(MP4.types.stsd, MP4.STSD , MP4.avc1(track));\n    }\n  }\n\n  static tkhd(track) {\n    return MP4.box(MP4.types.tkhd, new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x07, // flags\n      0x00, 0x00, 0x00, 0x00, // creation_time\n      0x00, 0x00, 0x00, 0x00, // modification_time\n      (track.id >> 24) & 0xFF,\n      (track.id >> 16) & 0xFF,\n      (track.id >> 8) & 0xFF,\n      track.id & 0xFF, // track_ID\n      0x00, 0x00, 0x00, 0x00, // reserved\n      (track.duration >> 24),\n      (track.duration >> 16) & 0xFF,\n      (track.duration >>  8) & 0xFF,\n      track.duration & 0xFF, // duration\n      0x00, 0x00, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x00, 0x00, // layer\n      0x00, 0x00, // alternate_group\n      0x00, 0x00, // non-audio track volume\n      0x00, 0x00, // reserved\n      0x00, 0x01, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00,\n      0x00, 0x01, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00,\n      0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n      (track.width >> 8) & 0xFF,\n      track.width & 0xFF,\n      0x00, 0x00, // width\n      (track.height >> 8) & 0xFF,\n      track.height & 0xFF,\n      0x00, 0x00 // height\n    ]));\n  }\n\n  static traf(track,baseMediaDecodeTime) {\n    var sampleDependencyTable = MP4.sdtp(track);\n    return MP4.box(MP4.types.traf,\n               MP4.box(MP4.types.tfhd, new Uint8Array([\n                 0x00, // version 0\n                 0x00, 0x00, 0x00, // flags\n                 (track.id >> 24),\n                 (track.id >> 16) & 0XFF,\n                 (track.id >> 8) & 0XFF,\n                 (track.id & 0xFF) // track_ID\n               ])),\n               MP4.box(MP4.types.tfdt, new Uint8Array([\n                 0x00, // version 0\n                 0x00, 0x00, 0x00, // flags\n                 (baseMediaDecodeTime >>24),\n                 (baseMediaDecodeTime >> 16) & 0XFF,\n                 (baseMediaDecodeTime >> 8) & 0XFF,\n                 (baseMediaDecodeTime & 0xFF) // baseMediaDecodeTime\n               ])),\n               MP4.trun(track,\n                    sampleDependencyTable.length +\n                    16 + // tfhd\n                    16 + // tfdt\n                    8 +  // traf header\n                    16 + // mfhd\n                    8 +  // moof header\n                    8),  // mdat header\n               sampleDependencyTable);\n  }\n\n  /**\n   * Generate a track box.\n   * @param track {object} a track definition\n   * @return {Uint8Array} the track box\n   */\n  static trak(track) {\n    track.duration = track.duration || 0xffffffff;\n    return MP4.box(MP4.types.trak,\n               MP4.tkhd(track),\n               MP4.mdia(track));\n  }\n\n  static trex(track) {\n    return MP4.box(MP4.types.trex, new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n     (track.id >> 24),\n     (track.id >> 16) & 0XFF,\n     (track.id >> 8) & 0XFF,\n     (track.id & 0xFF), // track_ID\n      0x00, 0x00, 0x00, 0x01, // default_sample_description_index\n      0x00, 0x00, 0x00, 0x00, // default_sample_duration\n      0x00, 0x00, 0x00, 0x00, // default_sample_size\n      0x00, 0x01, 0x00, 0x01 // default_sample_flags\n    ]));\n  }\n\n  static trun(track, offset) {\n    var samples, sample, i, array;\n\n    samples = track.samples || [];\n    array = new Uint8Array(12 + (16 * samples.length));\n    offset += 8 + array.byteLength;\n\n    array.set([\n      0x00, // version 0\n      0x00, 0x0f, 0x01, // flags\n      (samples.length >>> 24) & 0xFF,\n      (samples.length >>> 16) & 0xFF,\n      (samples.length >>> 8) & 0xFF,\n      samples.length & 0xFF, // sample_count\n      (offset >>> 24) & 0xFF,\n      (offset >>> 16) & 0xFF,\n      (offset >>> 8) & 0xFF,\n      offset & 0xFF // data_offset\n    ],0);\n\n    for (i = 0; i < samples.length; i++) {\n      sample = samples[i];\n      array.set([\n        (sample.duration >>> 24) & 0xFF,\n        (sample.duration >>> 16) & 0xFF,\n        (sample.duration >>> 8) & 0xFF,\n        sample.duration & 0xFF, // sample_duration\n        (sample.size >>> 24) & 0xFF,\n        (sample.size >>> 16) & 0xFF,\n        (sample.size >>> 8) & 0xFF,\n        sample.size & 0xFF, // sample_size\n        (sample.flags.isLeading << 2) | sample.flags.dependsOn,\n        (sample.flags.isDependedOn << 6) |\n          (sample.flags.hasRedundancy << 4) |\n          (sample.flags.paddingValue << 1) |\n          sample.flags.isNonSync,\n        sample.flags.degradPrio & 0xF0 << 8,\n        sample.flags.degradPrio & 0x0F, // sample_flags\n        (sample.cts >>> 24) & 0xFF,\n        (sample.cts >>> 16) & 0xFF,\n        (sample.cts >>> 8) & 0xFF,\n        sample.cts & 0xFF // sample_composition_time_offset\n      ],12+16*i);\n    }\n    return MP4.box(MP4.types.trun, array);\n  }\n\n  static initSegment(tracks) {\n\n    if(!MP4.types) {\n      MP4.init();\n    }\n    var\n      movie = MP4.moov(tracks),\n      result;\n\n    result = new Uint8Array(MP4.FTYP.byteLength + movie.byteLength);\n    result.set(MP4.FTYP);\n    result.set(movie, MP4.FTYP.byteLength);\n    return result;\n  }\n}\n\nexport default MP4;\n\n\n"," /*\n * Stats Handler\n *\n */\n\nimport Event                from './events';\nimport observer             from './observer';\n\n class StatsHandler {\n\n  constructor(hls) {\n    this.hls=hls;\n    this.onmp = this.onManifestParsed.bind(this);\n    this.onfc = this.onFragmentChanged.bind(this);\n    this.onfb = this.onFragmentBuffered.bind(this);\n    this.onflea = this.onFragmentLoadEmergencyAborted.bind(this);\n    this.onerr = this.onError.bind(this);\n    this.onfpsd = this.onFPSDrop.bind(this);\n    observer.on(Event.MANIFEST_PARSED, this.onmp);\n    observer.on(Event.FRAG_BUFFERED, this.onfb);\n    observer.on(Event.FRAG_CHANGED, this.onfc);\n    observer.on(Event.ERROR, this.onerr);\n    observer.on(Event.FRAG_LOAD_EMERGENCY_ABORTED, this.onflea);\n    observer.on(Event.FPS_DROP, this.onfpsd);\n  }\n\n  destroy() {\n    observer.off(Event.MANIFEST_PARSED, this.onmp);\n    observer.off(Event.FRAG_BUFFERED, this.onfb);\n    observer.off(Event.FRAG_CHANGED, this.onfc);\n    observer.off(Event.ERROR, this.onerr);\n    observer.off(Event.FRAG_LOAD_EMERGENCY_ABORTED, this.onflea);\n    observer.off(Event.FPS_DROP, this.onfpsd);\n  }\n\n  attachVideo(video) {\n    this.video = video;\n  }\n\n  detachVideo() {\n    this.video = null;\n  }\n\n  // reset stats on manifest parsed\n  onManifestParsed(event,data) {\n    this._stats = { tech : 'hls.js', levelNb : data.levels.length};\n  }\n\n  // on fragment changed is triggered whenever playback of a new fragment is starting ...\n  onFragmentChanged(event,data) {\n    var stats = this._stats,level = data.frag.level,autoLevel = data.frag.autoLevel;\n    if(stats) {\n      if(stats.levelStart === undefined) {\n        stats.levelStart = level;\n      }\n      if(autoLevel) {\n        if(stats.fragChangedAuto) {\n          stats.autoLevelMin = Math.min(stats.autoLevelMin,level);\n          stats.autoLevelMax = Math.max(stats.autoLevelMax,level);\n          stats.fragChangedAuto++;\n          if(this.levelLastAuto && level !== stats.autoLevelLast) {\n            stats.autoLevelSwitch++;\n          }\n        } else {\n          stats.autoLevelMin = stats.autoLevelMax = level;\n          stats.autoLevelSwitch = 0;\n          stats.fragChangedAuto = 1;\n          this.sumAutoLevel = 0;\n        }\n        this.sumAutoLevel+=level;\n        stats.autoLevelAvg = Math.round(1000*this.sumAutoLevel/stats.fragChangedAuto)/1000;\n        stats.autoLevelLast = level;\n      } else {\n        if(stats.fragChangedManual) {\n          stats.manualLevelMin = Math.min(stats.manualLevelMin,level);\n          stats.manualLevelMax = Math.max(stats.manualLevelMax,level);\n          stats.fragChangedManual++;\n          if(!this.levelLastAuto && level !== stats.manualLevelLast) {\n            stats.manualLevelSwitch++;\n          }\n        } else {\n          stats.manualLevelMin = stats.manualLevelMax = level;\n          stats.manualLevelSwitch = 0;\n          stats.fragChangedManual = 1;\n        }\n        stats.manualLevelLast = level;\n      }\n      this.levelLastAuto = autoLevel;\n    }\n  }\n\n  // triggered each time a new fragment is buffered\n  onFragmentBuffered(event,data) {\n    var stats = this._stats,latency = data.stats.tfirst - data.stats.trequest, process = data.stats.tbuffered - data.stats.trequest, bitrate = Math.round(8*data.stats.length/(data.stats.tbuffered - data.stats.tfirst));\n    if(stats.fragBuffered) {\n      stats.fragMinLatency = Math.min(stats.fragMinLatency,latency);\n      stats.fragMaxLatency = Math.max(stats.fragMaxLatency,latency);\n      stats.fragMinProcess = Math.min(stats.fragMinProcess,process);\n      stats.fragMaxProcess = Math.max(stats.fragMaxProcess,process);\n      stats.fragMinKbps = Math.min(stats.fragMinKbps,bitrate);\n      stats.fragMaxKbps = Math.max(stats.fragMaxKbps,bitrate);\n      stats.autoLevelCappingMin = Math.min(stats.autoLevelCappingMin,this.hls.autoLevelCapping);\n      stats.autoLevelCappingMax = Math.max(stats.autoLevelCappingMax,this.hls.autoLevelCapping);\n      stats.fragBuffered++;\n    } else {\n      stats.fragMinLatency = stats.fragMaxLatency = latency;\n      stats.fragMinProcess = stats.fragMaxProcess = process;\n      stats.fragMinKbps = stats.fragMaxKbps = bitrate;\n      stats.fragBuffered = 1;\n      stats.fragBufferedBytes = 0;\n      stats.autoLevelCappingMin = stats.autoLevelCappingMax = this.hls.autoLevelCapping;\n      this.sumLatency=0;\n      this.sumKbps=0;\n      this.sumProcess=0;\n    }\n    stats.fraglastLatency=latency;\n    this.sumLatency+=latency;\n    stats.fragAvgLatency = Math.round(this.sumLatency/stats.fragBuffered);\n    stats.fragLastProcess=process;\n    this.sumProcess+=process;\n    stats.fragAvgProcess = Math.round(this.sumProcess/stats.fragBuffered);\n    stats.fragLastKbps=bitrate;\n    this.sumKbps+=bitrate;\n    stats.fragAvgKbps = Math.round(this.sumKbps/stats.fragBuffered);\n    stats.fragBufferedBytes+=data.stats.length;\n    stats.autoLevelCappingLast = this.hls.autoLevelCapping;\n  }\n\n  onFragmentLoadEmergencyAborted() {\n    var stats = this._stats;\n    if(stats) {\n      if(stats.fragLoadEmergencyAborted === undefined) {\n        stats.fragLoadEmergencyAborted =1;\n      } else {\n        stats.fragLoadEmergencyAborted++;\n      }\n    }\n  }\n\n  onError(event,data) {\n    var stats = this._stats;\n    if(stats) {\n      // track all errors independently\n      if(stats[data.details] === undefined) {\n        stats[data.details] =1;\n      } else {\n        stats[data.details]+=1;\n      }\n      // track fatal error\n      if(data.fatal) {\n        if(stats.fatalError === undefined) {\n            stats.fatalError=1;\n        } else {\n            stats.fatalError+=1;\n        }\n      }\n    }\n  }\n\n  onFPSDrop(event,data) {\n    var stats = this._stats;\n    if(stats) {\n     if(stats.fpsDropEvent === undefined) {\n        stats.fpsDropEvent =1;\n      } else {\n        stats.fpsDropEvent++;\n      }\n      stats.fpsTotalDroppedFrames = data.totalDroppedFrames;\n    }\n  }\n\n  get stats() {\n    if(this.video) {\n      this._stats.lastPos = this.video.currentTime.toFixed(3);\n    }\n    return this._stats;\n  }\n}\n\nexport default StatsHandler;\n","'use strict';\n\nfunction noop(){}\nlet fakeLogger = {\n  log: noop,\n  warn: noop,\n  info: noop,\n  error: noop\n};\nlet exportedLogger = fakeLogger;\n\nexport var enableLogs = function(debug) {\n  if (debug === true || typeof debug       === 'object') {\n    exportedLogger.log   = debug.log   ? debug.log.bind(debug)   : console.log.bind(console);\n    exportedLogger.info  = debug.info  ? debug.info.bind(debug)  : console.info.bind(console);\n    exportedLogger.error = debug.error ? debug.error.bind(debug) : console.error.bind(console);\n    exportedLogger.warn  = debug.warn  ? debug.warn.bind(debug)  : console.warn.bind(console);\n\n    // Some browsers don't allow to use bind on console object anyway\n    // fallback to default if needed\n    try {\n     exportedLogger.log();\n    }\n    catch (e) {\n      exportedLogger.log   = noop;\n      exportedLogger.info  = noop;\n      exportedLogger.error = noop;\n      exportedLogger.warn  = noop;\n    }\n  }\n  else {\n    exportedLogger = fakeLogger;\n  }\n};\nexport var logger = exportedLogger;\n"," /*\n  * Xhr based Loader\n  *\n  */\n\nimport {logger}             from '../utils/logger';\n\n class XhrLoader {\n\n  constructor() {\n  }\n\n  destroy() {\n    this.abort();\n    this.loader = null;\n  }\n\n  abort() {\n    if(this.loader &&this.loader.readyState !== 4) {\n      this.stats.aborted = true;\n      this.loader.abort();\n    }\n    if(this.timeoutHandle) {\n      window.clearTimeout(this.timeoutHandle);\n    }\n  }\n\n  load(url,responseType,onSuccess,onError,onTimeout,timeout,maxRetry,retryDelay,onProgress=null) {\n    this.url = url;\n    this.responseType = responseType;\n    this.onSuccess = onSuccess;\n    this.onProgress = onProgress;\n    this.onTimeout = onTimeout;\n    this.onError = onError;\n    this.stats = { trequest:new Date(), retry:0};\n    this.timeout = timeout;\n    this.maxRetry = maxRetry;\n    this.retryDelay = retryDelay;\n    this.timeoutHandle = window.setTimeout(this.loadtimeout.bind(this),timeout);\n    this.loadInternal();\n  }\n\n  loadInternal() {\n    var xhr = this.loader = new XMLHttpRequest();\n    xhr.onload =  this.loadsuccess.bind(this);\n    xhr.onerror = this.loaderror.bind(this);\n    xhr.onprogress = this.loadprogress.bind(this);\n    xhr.open('GET', this.url , true);\n    xhr.responseType = this.responseType;\n    this.stats.tfirst = null;\n    this.stats.loaded = 0;\n    xhr.send();\n  }\n\n  loadsuccess(event) {\n    window.clearTimeout(this.timeoutHandle);\n    this.stats.tload = new Date();\n    this.onSuccess(event,this.stats);\n  }\n\n  loaderror(event) {\n    if(this.stats.retry < this.maxRetry) {\n      logger.warn(`${event.type} while loading ${this.url}, retrying in ${this.retryDelay}...`);\n      this.destroy();\n      window.setTimeout(this.loadInternal.bind(this),this.retryDelay);\n      // exponential backoff\n      this.retryDelay=Math.min(2*this.retryDelay,64000);\n      this.stats.retry++;\n    } else {\n      window.clearTimeout(this.timeoutHandle);\n      logger.error(`${event.type} while loading ${this.url}` );\n      this.onError(event);\n    }\n  }\n\n  loadtimeout(event) {\n    logger.warn(`timeout while loading ${this.url}` );\n    this.onTimeout(event,this.stats);\n  }\n\n  loadprogress(event) {\n    var stats = this.stats;\n    if(stats.tfirst === null) {\n      stats.tfirst = new Date();\n    }\n    stats.loaded = event.loaded;\n    if(this.onProgress) {\n      this.onProgress(event, stats);\n    }\n  }\n}\n\nexport default XhrLoader;\n"]} +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/watchify/node_modules/browserify/node_modules/browser-pack/_prelude.js","node_modules/watchify/node_modules/browserify/node_modules/events/events.js","node_modules/webworkify/index.js","/Users/g.dupontavice/workdir/github/hls.js/src/controller/buffer-controller.js","/Users/g.dupontavice/workdir/github/hls.js/src/controller/level-controller.js","/Users/g.dupontavice/workdir/github/hls.js/src/demux/demuxer.js","/Users/g.dupontavice/workdir/github/hls.js/src/demux/exp-golomb.js","/Users/g.dupontavice/workdir/github/hls.js/src/demux/tsdemuxer.js","/Users/g.dupontavice/workdir/github/hls.js/src/demux/tsdemuxerworker.js","/Users/g.dupontavice/workdir/github/hls.js/src/errors.js","/Users/g.dupontavice/workdir/github/hls.js/src/events.js","/Users/g.dupontavice/workdir/github/hls.js/src/hls.js","/Users/g.dupontavice/workdir/github/hls.js/src/loader/fragment-loader.js","/Users/g.dupontavice/workdir/github/hls.js/src/loader/playlist-loader.js","/Users/g.dupontavice/workdir/github/hls.js/src/observer.js","/Users/g.dupontavice/workdir/github/hls.js/src/remux/mp4-generator.js","/Users/g.dupontavice/workdir/github/hls.js/src/stats.js","/Users/g.dupontavice/workdir/github/hls.js/src/utils/logger.js","/Users/g.dupontavice/workdir/github/hls.js/src/utils/xhr-loader.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7SA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;sBClDkC,WAAW;;;;wBACX,aAAa;;;;2BACb,iBAAiB;;4BACjB,kBAAkB;;;;sBACb,WAAW;;IAE3C,gBAAgB;AAEV,WAFN,gBAAgB,CAET,GAAG,EAAE;0BAFZ,gBAAgB;;AAGnB,QAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;AAChB,QAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;AACnB,QAAI,CAAC,IAAI,GAAG,CAAC,CAAC;AACd,QAAI,CAAC,OAAO,GAAI,CAAC,CAAC;AAClB,QAAI,CAAC,aAAa,GAAG,CAAC,CAAC;AACvB,QAAI,CAAC,OAAO,GAAG,CAAC,CAAC;AACjB,QAAI,CAAC,MAAM,GAAG,CAAC,CAAC;AAChB,QAAI,CAAC,SAAS,GAAG,CAAC,CAAC;AACnB,QAAI,CAAC,eAAe,GAAG,CAAC,CAAC;AACzB,QAAI,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC;AACzB,QAAI,CAAC,aAAa,GAAG,CAAC,CAAC;AACvB,QAAI,CAAC,GAAG,GAAG,GAAG,CAAC;;A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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nfunction EventEmitter() {\n  this._events = this._events || {};\n  this._maxListeners = this._maxListeners || undefined;\n}\nmodule.exports = EventEmitter;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nEventEmitter.defaultMaxListeners = 10;\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function(n) {\n  if (!isNumber(n) || n < 0 || isNaN(n))\n    throw TypeError('n must be a positive number');\n  this._maxListeners = n;\n  return this;\n};\n\nEventEmitter.prototype.emit = function(type) {\n  var er, handler, len, args, i, listeners;\n\n  if (!this._events)\n    this._events = {};\n\n  // If there is no 'error' event listener then throw.\n  if (type === 'error') {\n    if (!this._events.error ||\n        (isObject(this._events.error) && !this._events.error.length)) {\n      er = arguments[1];\n      if (er instanceof Error) {\n        throw er; // Unhandled 'error' event\n      }\n      throw TypeError('Uncaught, unspecified \"error\" event.');\n    }\n  }\n\n  handler = this._events[type];\n\n  if (isUndefined(handler))\n    return false;\n\n  if (isFunction(handler)) {\n    switch (arguments.length) {\n      // fast cases\n      case 1:\n        handler.call(this);\n        break;\n      case 2:\n        handler.call(this, arguments[1]);\n        break;\n      case 3:\n        handler.call(this, arguments[1], arguments[2]);\n        break;\n      // slower\n      default:\n        len = arguments.length;\n        args = new Array(len - 1);\n        for (i = 1; i < len; i++)\n          args[i - 1] = arguments[i];\n        handler.apply(this, args);\n    }\n  } else if (isObject(handler)) {\n    len = arguments.length;\n    args = new Array(len - 1);\n    for (i = 1; i < len; i++)\n      args[i - 1] = arguments[i];\n\n    listeners = handler.slice();\n    len = listeners.length;\n    for (i = 0; i < len; i++)\n      listeners[i].apply(this, args);\n  }\n\n  return true;\n};\n\nEventEmitter.prototype.addListener = function(type, listener) {\n  var m;\n\n  if (!isFunction(listener))\n    throw TypeError('listener must be a function');\n\n  if (!this._events)\n    this._events = {};\n\n  // To avoid recursion in the case that type === \"newListener\"! Before\n  // adding it to the listeners, first emit \"newListener\".\n  if (this._events.newListener)\n    this.emit('newListener', type,\n              isFunction(listener.listener) ?\n              listener.listener : listener);\n\n  if (!this._events[type])\n    // Optimize the case of one listener. Don't need the extra array object.\n    this._events[type] = listener;\n  else if (isObject(this._events[type]))\n    // If we've already got an array, just append.\n    this._events[type].push(listener);\n  else\n    // Adding the second element, need to change to array.\n    this._events[type] = [this._events[type], listener];\n\n  // Check for listener leak\n  if (isObject(this._events[type]) && !this._events[type].warned) {\n    var m;\n    if (!isUndefined(this._maxListeners)) {\n      m = this._maxListeners;\n    } else {\n      m = EventEmitter.defaultMaxListeners;\n    }\n\n    if (m && m > 0 && this._events[type].length > m) {\n      this._events[type].warned = true;\n      console.error('(node) warning: possible EventEmitter memory ' +\n                    'leak detected. %d listeners added. ' +\n                    'Use emitter.setMaxListeners() to increase limit.',\n                    this._events[type].length);\n      if (typeof console.trace === 'function') {\n        // not supported in IE 10\n        console.trace();\n      }\n    }\n  }\n\n  return this;\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.once = function(type, listener) {\n  if (!isFunction(listener))\n    throw TypeError('listener must be a function');\n\n  var fired = false;\n\n  function g() {\n    this.removeListener(type, g);\n\n    if (!fired) {\n      fired = true;\n      listener.apply(this, arguments);\n    }\n  }\n\n  g.listener = listener;\n  this.on(type, g);\n\n  return this;\n};\n\n// emits a 'removeListener' event iff the listener was removed\nEventEmitter.prototype.removeListener = function(type, listener) {\n  var list, position, length, i;\n\n  if (!isFunction(listener))\n    throw TypeError('listener must be a function');\n\n  if (!this._events || !this._events[type])\n    return this;\n\n  list = this._events[type];\n  length = list.length;\n  position = -1;\n\n  if (list === listener ||\n      (isFunction(list.listener) && list.listener === listener)) {\n    delete this._events[type];\n    if (this._events.removeListener)\n      this.emit('removeListener', type, listener);\n\n  } else if (isObject(list)) {\n    for (i = length; i-- > 0;) {\n      if (list[i] === listener ||\n          (list[i].listener && list[i].listener === listener)) {\n        position = i;\n        break;\n      }\n    }\n\n    if (position < 0)\n      return this;\n\n    if (list.length === 1) {\n      list.length = 0;\n      delete this._events[type];\n    } else {\n      list.splice(position, 1);\n    }\n\n    if (this._events.removeListener)\n      this.emit('removeListener', type, listener);\n  }\n\n  return this;\n};\n\nEventEmitter.prototype.removeAllListeners = function(type) {\n  var key, listeners;\n\n  if (!this._events)\n    return this;\n\n  // not listening for removeListener, no need to emit\n  if (!this._events.removeListener) {\n    if (arguments.length === 0)\n      this._events = {};\n    else if (this._events[type])\n      delete this._events[type];\n    return this;\n  }\n\n  // emit removeListener for all listeners on all events\n  if (arguments.length === 0) {\n    for (key in this._events) {\n      if (key === 'removeListener') continue;\n      this.removeAllListeners(key);\n    }\n    this.removeAllListeners('removeListener');\n    this._events = {};\n    return this;\n  }\n\n  listeners = this._events[type];\n\n  if (isFunction(listeners)) {\n    this.removeListener(type, listeners);\n  } else {\n    // LIFO order\n    while (listeners.length)\n      this.removeListener(type, listeners[listeners.length - 1]);\n  }\n  delete this._events[type];\n\n  return this;\n};\n\nEventEmitter.prototype.listeners = function(type) {\n  var ret;\n  if (!this._events || !this._events[type])\n    ret = [];\n  else if (isFunction(this._events[type]))\n    ret = [this._events[type]];\n  else\n    ret = this._events[type].slice();\n  return ret;\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n  var ret;\n  if (!emitter._events || !emitter._events[type])\n    ret = 0;\n  else if (isFunction(emitter._events[type]))\n    ret = 1;\n  else\n    ret = emitter._events[type].length;\n  return ret;\n};\n\nfunction isFunction(arg) {\n  return typeof arg === 'function';\n}\n\nfunction isNumber(arg) {\n  return typeof arg === 'number';\n}\n\nfunction isObject(arg) {\n  return typeof arg === 'object' && arg !== null;\n}\n\nfunction isUndefined(arg) {\n  return arg === void 0;\n}\n","var bundleFn = arguments[3];\nvar sources = arguments[4];\nvar cache = arguments[5];\n\nvar stringify = JSON.stringify;\n\nmodule.exports = function (fn) {\n    var keys = [];\n    var wkey;\n    var cacheKeys = Object.keys(cache);\n    \n    for (var i = 0, l = cacheKeys.length; i < l; i++) {\n        var key = cacheKeys[i];\n        if (cache[key].exports === fn) {\n            wkey = key;\n            break;\n        }\n    }\n    \n    if (!wkey) {\n        wkey = Math.floor(Math.pow(16, 8) * Math.random()).toString(16);\n        var wcache = {};\n        for (var i = 0, l = cacheKeys.length; i < l; i++) {\n            var key = cacheKeys[i];\n            wcache[key] = key;\n        }\n        sources[wkey] = [\n            Function(['require','module','exports'], '(' + fn + ')(self)'),\n            wcache\n        ];\n    }\n    var skey = Math.floor(Math.pow(16, 8) * Math.random()).toString(16);\n    \n    var scache = {}; scache[wkey] = wkey;\n    sources[skey] = [\n        Function(['require'],'require(' + stringify(wkey) + ')(self)'),\n        scache\n    ];\n    \n    var src = '(' + bundleFn + ')({'\n        + Object.keys(sources).map(function (key) {\n            return stringify(key) + ':['\n                + sources[key][0]\n                + ',' + stringify(sources[key][1]) + ']'\n            ;\n        }).join(',')\n        + '},{},[' + stringify(skey) + '])'\n    ;\n    \n    var URL = window.URL || window.webkitURL || window.mozURL || window.msURL;\n    \n    return new Worker(URL.createObjectURL(\n        new Blob([src], { type: 'text/javascript' })\n    ));\n};\n","/*\n * buffer controller\n *\n */\n\n import Event                from '../events';\n import observer             from '../observer';\n import {logger}             from '../utils/logger';\n import Demuxer              from '../demux/demuxer';\n import {ErrorTypes,ErrorDetails} from '../errors';\n\n class BufferController {\n\n  constructor(hls) {\n    this.ERROR = -2;\n    this.STARTING = -1;\n    this.IDLE = 0;\n    this.LOADING =  1;\n    this.WAITING_LEVEL = 2;\n    this.PARSING = 3;\n    this.PARSED = 4;\n    this.APPENDING = 5;\n    this.BUFFER_FLUSHING = 6;\n    this.config = hls.config;\n    this.startPosition = 0;\n    this.hls = hls;\n    // Source Buffer listeners\n    this.onsbue = this.onSourceBufferUpdateEnd.bind(this);\n    this.onsbe  = this.onSourceBufferError.bind(this);\n    // internal listeners\n    this.onmse = this.onMSEAttached.bind(this);\n    this.onmsed = this.onMSEDetached.bind(this);\n    this.onmp = this.onManifestParsed.bind(this);\n    this.onll = this.onLevelLoaded.bind(this);\n    this.onfl = this.onFragmentLoaded.bind(this);\n    this.onis = this.onInitSegment.bind(this);\n    this.onfpg = this.onFragmentParsing.bind(this);\n    this.onfp = this.onFragmentParsed.bind(this);\n    this.onerr = this.onError.bind(this);\n    this.ontick = this.tick.bind(this);\n    observer.on(Event.MSE_ATTACHED, this.onmse);\n    observer.on(Event.MSE_DETACHED, this.onmsed);\n    observer.on(Event.MANIFEST_PARSED, this.onmp);\n  }\n  destroy() {\n    this.stop();\n    observer.off(Event.MANIFEST_PARSED, this.onmp);\n    // remove video listener\n    if(this.video) {\n      this.video.removeEventListener('seeking',this.onvseeking);\n      this.video.removeEventListener('seeked',this.onvseeked);\n      this.video.removeEventListener('loadedmetadata',this.onvmetadata);\n      this.onvseeking = this.onvseeked = this.onvmetadata = null;\n    }\n    this.state = this.IDLE;\n  }\n\n  startLoad() {\n    if(this.levels && this.video) {\n      this.startInternal();\n      if(this.lastCurrentTime) {\n        logger.log(`resuming video @ ${this.lastCurrentTime}`);\n        this.nextLoadPosition = this.startPosition = this.lastCurrentTime;\n        this.state = this.IDLE;\n      } else {\n        this.nextLoadPosition = this.startPosition;\n        this.state = this.STARTING;\n      }\n      this.tick();\n    } else {\n      logger.warn(`cannot start loading as either manifest not parsed or video not attached`);\n    }\n  }\n\n  startInternal() {\n    this.stop();\n    this.demuxer = new Demuxer(this.config);\n    this.timer = setInterval(this.ontick, 100);\n    this.level = -1;\n    observer.on(Event.FRAG_LOADED, this.onfl);\n    observer.on(Event.FRAG_PARSING_INIT_SEGMENT, this.onis);\n    observer.on(Event.FRAG_PARSING_DATA, this.onfpg);\n    observer.on(Event.FRAG_PARSED, this.onfp);\n    observer.on(Event.ERROR, this.onerr);\n    observer.on(Event.LEVEL_LOADED, this.onll);\n  }\n\n\n  stop() {\n    this.mp4segments = [];\n    this.flushRange = [];\n    this.bufferRange = [];\n    if(this.frag) {\n      if(this.frag.loader) {\n        this.frag.loader.abort();\n      }\n      this.frag = null;\n    }\n    if(this.sourceBuffer) {\n      for(var type in this.sourceBuffer) {\n        var sb = this.sourceBuffer[type];\n        try {\n          this.mediaSource.removeSourceBuffer(sb);\n          sb.removeEventListener('updateend', this.onsbue);\n          sb.removeEventListener('error', this.onsbe);\n        } catch(err) {\n\n        }\n      }\n      this.sourceBuffer = null;\n    }\n    if(this.timer) {\n      clearInterval(this.timer);\n      this.timer = null;\n    }\n    if(this.demuxer) {\n      this.demuxer.destroy();\n      this.demuxer = null;\n    }\n    observer.off(Event.FRAG_LOADED, this.onfl);\n    observer.off(Event.FRAG_PARSED, this.onfp);\n    observer.off(Event.FRAG_PARSING_DATA, this.onfpg);\n    observer.off(Event.LEVEL_LOADED, this.onll);\n    observer.off(Event.FRAG_PARSING_INIT_SEGMENT, this.onis);\n    observer.off(Event.ERROR, this.onerr);\n  }\n\n  tick() {\n    var pos,level,levelDetails,fragIdx;\n    switch(this.state) {\n      case this.ERROR:\n        //don't do anything in error state to avoid breaking further ...\n        break;\n      case this.STARTING:\n        // determine load level\n        this.startLevel = this.hls.startLevel;\n        if (this.startLevel === -1) {\n          // -1 : guess start Level by doing a bitrate test by loading first fragment of lowest quality level\n          this.startLevel = 0;\n          this.fragmentBitrateTest = true;\n        }\n        // set new level to playlist loader : this will trigger start level load\n        this.level = this.hls.nextLoadLevel = this.startLevel;\n        this.state = this.WAITING_LEVEL;\n        this.loadedmetadata = false;\n        break;\n      case this.IDLE:\n        // handle end of immediate switching if needed\n        if(this.immediateSwitch) {\n          this.immediateLevelSwitchEnd();\n          break;\n        }\n\n        // if video detached or unbound exit loop\n        if(!this.video) {\n          break;\n        }\n\n        // seek back to a expected position after video stalling\n        if(this.seekAfterStalling) {\n          this.video.currentTime=this.seekAfterStalling;\n          this.seekAfterStalling = undefined;\n        }\n\n        // determine next candidate fragment to be loaded, based on current position and\n        //  end of buffer position\n        //  ensure 60s of buffer upfront\n        // if we have not yet loaded any fragment, start loading from start position\n        if(this.loadedmetadata) {\n          pos = this.video.currentTime;\n        } else {\n          pos = this.nextLoadPosition;\n        }\n        // determine next load level\n        if(this.startFragmentRequested === false) {\n          level = this.startLevel;\n        } else {\n          // we are not at playback start, get next load level from level Controller\n          level = this.hls.nextLoadLevel;\n        }\n        var bufferInfo = this.bufferInfo(pos), bufferLen = bufferInfo.len, bufferEnd = bufferInfo.end, maxBufLen;\n        // compute max Buffer Length that we could get from this load level, based on level bitrate. don't buffer more than 60 MB and more than 30s\n        if((this.levels[level]).hasOwnProperty('bitrate')) {\n          maxBufLen = Math.max(8*this.config.maxBufferSize/this.levels[level].bitrate,this.config.maxBufferLength);\n          maxBufLen = Math.min(maxBufLen,this.config.maxMaxBufferLength);\n        } else {\n          maxBufLen = this.config.maxBufferLength;\n        }\n        // if buffer length is less than maxBufLen try to load a new fragment\n        if(bufferLen < maxBufLen) {\n          // set next load level : this will trigger a playlist load if needed\n          this.hls.nextLoadLevel = level;\n          this.level = level;\n          levelDetails = this.levels[level].details;\n          // if level info not retrieved yet, switch state and wait for level retrieval\n          if(typeof levelDetails === 'undefined') {\n            this.state = this.WAITING_LEVEL;\n            break;\n          }\n          // find fragment index, contiguous with end of buffer position\n          let fragments = levelDetails.fragments, frag, sliding = levelDetails.sliding, start = fragments[0].start + sliding, drift =0;\n          // check if requested position is within seekable boundaries :\n          // in case of live playlist we need to ensure that requested position is not located before playlist start\n          //logger.log(`start/pos/bufEnd/seeking:${start.toFixed(3)}/${pos.toFixed(3)}/${bufferEnd.toFixed(3)}/${this.video.seeking}`);\n          if(bufferEnd < start) {\n              this.seekAfterStalling = this.startPosition + sliding;\n              logger.log(`buffer end: ${bufferEnd} is located before start of live sliding playlist, media position will be reseted to: ${this.seekAfterStalling.toFixed(3)}`);\n              bufferEnd = this.seekAfterStalling;\n          }\n\n          if(levelDetails.live && levelDetails.sliding === undefined) {\n            /* we are switching level on live playlist, but we don't have any sliding info ...\n               try to load frag matching with next SN.\n               even if SN are not synchronized between playlists, loading this frag will help us\n               compute playlist sliding and find the right one after in case it was not the right consecutive one */\n            if(this.frag) {\n              var targetSN = this.frag.sn+1;\n              if(targetSN >= levelDetails.startSN && targetSN <= levelDetails.endSN) {\n                frag = fragments[targetSN-levelDetails.startSN];\n                logger.log(`live playlist, switching playlist, load frag with next SN: ${frag.sn}`);\n              }\n            }\n            if(!frag) {\n              /* we have no idea about which fragment should be loaded.\n                 so let's load mid fragment. it will help computing playlist sliding and find the right one\n              */\n              frag = fragments[Math.round(fragments.length/2)];\n              logger.log(`live playlist, switching playlist, unknown, load middle frag : ${frag.sn}`);\n            }\n          } else {\n          //look for fragments matching with current play position\n            for (fragIdx = 0; fragIdx < fragments.length ; fragIdx++) {\n              frag = fragments[fragIdx];\n              start = frag.start+sliding;\n              if(frag.drift) {\n                drift = frag.drift;\n              }\n              start+=drift;\n              //logger.log(`level/sn/sliding/drift/start/end/bufEnd:${level}/${frag.sn}/${sliding.toFixed(3)}/${drift.toFixed(3)}/${start.toFixed(3)}/${(start+frag.duration).toFixed(3)}/${bufferEnd.toFixed(3)}`);\n              // offset should be within fragment boundary\n              if(start <= bufferEnd && (start + frag.duration) > bufferEnd) {\n                break;\n              }\n            }\n            if(fragIdx === fragments.length) {\n              // reach end of playlist\n              break;\n            }\n            //logger.log('find SN matching with pos:' +  bufferEnd + ':' + frag.sn);\n            if(this.frag && frag.sn === this.frag.sn) {\n              if(fragIdx === (fragments.length -1)) {\n                // we are at the end of the playlist and we already loaded last fragment, don't do anything\n                break;\n              } else {\n                frag = fragments[fragIdx+1];\n                logger.log(`SN just loaded, load next one: ${frag.sn}`);\n              }\n            }\n          }\n          logger.log(`Loading       ${frag.sn} of [${levelDetails.startSN} ,${levelDetails.endSN}],level ${level}, currentTime:${pos},bufferEnd:${bufferEnd.toFixed(3)}`);\n          //logger.log('      loading frag ' + i +',pos/bufEnd:' + pos.toFixed(3) + '/' + bufferEnd.toFixed(3));\n          frag.drift = drift;\n          frag.autoLevel = this.hls.autoLevelEnabled;\n          if(this.levels.length>1) {\n            frag.expectedLen = Math.round(frag.duration*this.levels[level].bitrate/8);\n            frag.trequest = new Date();\n          }\n\n          // ensure that we are not reloading the same fragments in loop ...\n          if(this.fragLoadIdx !== undefined) {\n            this.fragLoadIdx++;\n          } else {\n            this.fragLoadIdx = 0;\n          }\n          if(frag.loadCounter) {\n            frag.loadCounter++;\n            let maxThreshold = this.config.fragLoadingLoopThreshold;\n            // if this frag has already been loaded 3 times, and if it has been reloaded recently\n            if(frag.loadCounter > maxThreshold && (Math.abs(this.fragLoadIdx - frag.loadIdx) < maxThreshold)) {\n              observer.trigger(Event.ERROR, {type : ErrorTypes.MEDIA_ERROR, details : ErrorDetails.FRAG_LOOP_LOADING_ERROR, fatal:false, frag : frag});\n              return;\n            }\n          } else {\n            frag.loadCounter=1;\n          }\n          frag.loadIdx = this.fragLoadIdx;\n          this.frag = frag;\n          this.startFragmentRequested = true;\n          observer.trigger(Event.FRAG_LOADING, { frag: frag });\n          this.state = this.LOADING;\n        }\n        break;\n      case this.WAITING_LEVEL:\n        level = this.levels[this.level];\n        // check if playlist is already loaded\n        if(level && level.details) {\n          this.state = this.IDLE;\n        }\n        break;\n      case this.LOADING:\n        /*\n          monitor fragment retrieval time...\n          we compute expected time of arrival of the complete fragment.\n          we compare it to expected time of buffer starvation\n        */\n        let v = this.video,frag = this.frag;\n        /* only monitor frag retrieval time if\n        (video not paused OR first fragment being loaded) AND autoswitching enabled AND not lowest level AND multiple levels */\n        if(v && (!v.paused || this.loadedmetadata === false) && frag.autoLevel && this.level && this.levels.length>1 ) {\n          var requestDelay=new Date()-frag.trequest;\n          // monitor fragment load progress after half of expected fragment duration,to stabilize bitrate\n          if(requestDelay > 500*frag.duration) {\n            var loadRate = frag.loaded*1000/requestDelay; // byte/s\n            if(frag.expectedLen < frag.loaded) {\n              frag.expectedLen = frag.loaded;\n            }\n            pos = v.currentTime;\n            var fragLoadedDelay =(frag.expectedLen-frag.loaded)/loadRate;\n            var bufferStarvationDelay=this.bufferInfo(pos).end-pos;\n            var fragLevelNextLoadedDelay = frag.duration*this.levels[this.hls.nextLoadLevel].bitrate/(8*loadRate); //bps/Bps\n            /* if we have less than 2 frag duration in buffer and if frag loaded delay is greater than buffer starvation delay\n              ... and also bigger than duration needed to load fragment at next level ...*/\n            if(bufferStarvationDelay < 2*frag.duration && fragLoadedDelay > bufferStarvationDelay && fragLoadedDelay > fragLevelNextLoadedDelay) {\n              // abort fragment loading ...\n              logger.warn('loading too slow, abort fragment loading');\n              logger.log(`fragLoadedDelay/bufferStarvationDelay/fragLevelNextLoadedDelay :${fragLoadedDelay.toFixed(1)}/${bufferStarvationDelay.toFixed(1)}/${fragLevelNextLoadedDelay.toFixed(1)}`);\n              //abort fragment loading\n              frag.loader.abort();\n              this.frag = null;\n              observer.trigger(Event.FRAG_LOAD_EMERGENCY_ABORTED, { frag: frag });\n              // switch back to IDLE state to request new fragment at lowest level\n              this.state = this.IDLE;\n            }\n          }\n        }\n        break;\n      case this.PARSING:\n        // nothing to do, wait for fragment being parsed\n        break;\n      case this.PARSED:\n      case this.APPENDING:\n        if (this.sourceBuffer) {\n          // if MP4 segment appending in progress nothing to do\n          if((this.sourceBuffer.audio && this.sourceBuffer.audio.updating) ||\n             (this.sourceBuffer.video && this.sourceBuffer.video.updating)) {\n            //logger.log('sb append in progress');\n        // check if any MP4 segments left to append\n          } else if(this.mp4segments.length) {\n            var segment = this.mp4segments.shift();\n            try {\n              //logger.log(`appending ${segment.type} SB, size:${segment.data.length}`);\n              this.sourceBuffer[segment.type].appendBuffer(segment.data);\n              this.appendError=0;\n            } catch(err) {\n              // in case any error occured while appending, put back segment in mp4segments table\n              logger.error(`error while trying to append buffer:${err.message},try appending later`);\n              this.mp4segments.unshift(segment);\n              if(this.appendError) {\n                this.appendError++;\n              } else {\n                this.appendError=1;\n              }\n              var event = {type : ErrorTypes.MEDIA_ERROR, details : ErrorDetails.FRAG_APPENDING_ERROR, frag : this.frag};\n              /* with UHD content, we could get loop of quota exceeded error until\n                browser is able to evict some data from sourcebuffer. retrying help recovering this\n              */\n              if(this.appendError > this.config.appendErrorMaxRetry) {\n                logger.log(`fail ${this.config.appendErrorMaxRetry} times to append segment in sourceBuffer`);\n                event.fatal = true;\n                observer.trigger(Event.ERROR, event);\n                this.state = this.ERROR;\n                return;\n              } else {\n                event.fatal = false;\n                observer.trigger(Event.ERROR, event);\n              }\n            }\n            this.state = this.APPENDING;\n          }\n        } else {\n          // sourceBuffer undefined, switch back to IDLE state\n          this.state = this.IDLE;\n        }\n        break;\n      case this.BUFFER_FLUSHING:\n        // loop through all buffer ranges to flush\n        while(this.flushRange.length) {\n          var range = this.flushRange[0];\n          // flushBuffer will abort any buffer append in progress and flush Audio/Video Buffer\n          if(this.flushBuffer(range.start,range.end)) {\n            // range flushed, remove from flush array\n            this.flushRange.shift();\n          } else {\n            // flush in progress, come back later\n            break;\n          }\n        }\n\n        if(this.flushRange.length === 0) {\n          // move to IDLE once flush complete. this should trigger new fragment loading\n          this.state = this.IDLE;\n          // reset reference to frag\n          this.frag = null;\n        }\n         /* if not everything flushed, stay in BUFFER_FLUSHING state. we will come back here\n            each time sourceBuffer updateend() callback will be triggered\n            */\n        break;\n      default:\n        break;\n    }\n    // check/update current fragment\n    this._checkFragmentChanged();\n  }\n\n   bufferInfo(pos) {\n    var v = this.video,\n        buffered = v.buffered,\n        bufferLen,\n        // bufferStart and bufferEnd are buffer boundaries around current video position\n        bufferStart,bufferEnd,\n        i;\n    var buffered2 = [];\n    // there might be some small holes between buffer time range\n    // consider that holes smaller than 300 ms are irrelevant and build another\n    // buffer time range representations that discards those holes\n    for(i = 0 ; i < buffered.length ; i++) {\n      //logger.log('buf start/end:' + buffered.start(i) + '/' + buffered.end(i));\n      if((buffered2.length) && (buffered.start(i) - buffered2[buffered2.length-1].end ) < 0.3) {\n        buffered2[buffered2.length-1].end = buffered.end(i);\n      } else {\n        buffered2.push({start : buffered.start(i),end : buffered.end(i)});\n      }\n    }\n\n    for(i = 0, bufferLen = 0, bufferStart = bufferEnd = pos ; i < buffered2.length ; i++) {\n      //logger.log('buf start/end:' + buffered.start(i) + '/' + buffered.end(i));\n      if((pos+0.3) >= buffered2[i].start && pos < buffered2[i].end) {\n        // play position is inside this buffer TimeRange, retrieve end of buffer position and buffer length\n        bufferStart = buffered2[i].start;\n        bufferEnd = buffered2[i].end + 0.3;\n        bufferLen = bufferEnd - pos;\n      }\n    }\n    return {len : bufferLen, start : bufferStart, end : bufferEnd};\n  }\n\n\n  getBufferRange(position) {\n    var i,range;\n    for (i = this.bufferRange.length-1; i >=0 ; i--) {\n      range = this.bufferRange[i];\n      if(position >= range.start && position <= range.end) {\n        return range;\n      }\n    }\n    return null;\n  }\n\n\n  get currentLevel() {\n    if(this.video) {\n      var range = this.getBufferRange(this.video.currentTime);\n      if(range) {\n        return range.frag.level;\n      }\n    }\n    return -1;\n  }\n\n  get nextBufferRange() {\n    if(this.video) {\n      // first get end range of current fragment\n      return this.followingBufferRange(this.getBufferRange(this.video.currentTime));\n    } else {\n      return null;\n    }\n  }\n\n  followingBufferRange(range) {\n    if(range) {\n      // try to get range of next fragment (500ms after this range)\n      return this.getBufferRange(range.end+0.5);\n    }\n    return null;\n  }\n\n\n  get nextLevel() {\n    var range = this.nextBufferRange;\n    if(range) {\n      return range.frag.level;\n    } else {\n      return -1;\n    }\n  }\n\n  isBuffered(position) {\n    var v = this.video,buffered = v.buffered;\n    for(var i = 0 ; i < buffered.length ; i++) {\n      if(position >= buffered.start(i) && position <= buffered.end(i)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  _checkFragmentChanged() {\n    var rangeCurrent, currentTime;\n    if(this.video && this.video.seeking === false) {\n      this.lastCurrentTime = currentTime = this.video.currentTime;\n      if(this.isBuffered(currentTime)) {\n        rangeCurrent = this.getBufferRange(currentTime);\n      } else if(this.isBuffered(currentTime+0.1)) {\n        /* ensure that FRAG_CHANGED event is triggered at startup,\n          when first video frame is displayed and playback is paused.\n          add a tolerance of 100ms, in case current position is not buffered,\n          check if current pos+100ms is buffered and use that buffer range\n          for FRAG_CHANGED event reporting */\n        rangeCurrent = this.getBufferRange(currentTime+0.1);\n      }\n      if(rangeCurrent) {\n        if(rangeCurrent.frag !== this.fragCurrent) {\n          this.fragCurrent = rangeCurrent.frag;\n          observer.trigger(Event.FRAG_CHANGED, { frag : this.fragCurrent });\n        }\n        // if stream is VOD (not live) and we reach End of Stream\n        var level = this.levels[this.level];\n        if(level && level.details && !level.details.live && (this.video.duration - currentTime) < 0.2) {\n          if(this.mediaSource && this.mediaSource.readyState === 'open') {\n            logger.log(`end of VoD stream reached, signal endOfStream() to MediaSource`);\n            this.lastCurrentTime = this.startPosition;\n            this.video = null;\n            this.mediaSource.endOfStream();\n          }\n        }\n      }\n    }\n  }\n\n/*\n  abort any buffer append in progress, and flush all buffered data\n  return true once everything has been flushed.\n  sourceBuffer.abort() and sourceBuffer.remove() are asynchronous operations\n  the idea is to call this function from tick() timer and call it again until all resources have been cleaned\n  the timer is rearmed upon sourceBuffer updateend() event, so this should be optimal\n*/\n  flushBuffer(startOffset, endOffset) {\n    var sb,i,bufStart,bufEnd, flushStart, flushEnd;\n    //logger.log('flushBuffer,pos/start/end: ' + this.video.currentTime + '/' + startOffset + '/' + endOffset);\n    // safeguard to avoid infinite looping\n    if(this.flushBufferCounter++ < 2*this.bufferRange.length && this.sourceBuffer) {\n      for(var type in this.sourceBuffer) {\n        sb = this.sourceBuffer[type];\n        if(!sb.updating) {\n          for(i = 0 ; i < sb.buffered.length ; i++) {\n            bufStart = sb.buffered.start(i);\n            bufEnd = sb.buffered.end(i);\n            // workaround firefox not able to properly flush multiple buffered range.\n            if(navigator.userAgent.toLowerCase().indexOf('firefox') !== -1 &&  endOffset === Number.POSITIVE_INFINITY) {\n              flushStart = startOffset;\n              flushEnd = endOffset;\n            } else {\n              flushStart = Math.max(bufStart,startOffset);\n              flushEnd = Math.min(bufEnd,endOffset);\n            }\n            /* sometimes sourcebuffer.remove() does not flush\n               the exact expected time range.\n               to avoid rounding issues/infinite loop,\n               only flush buffer range of length greater than 500ms.\n            */\n            if(flushEnd - flushStart > 0.5) {\n              logger.log(`flush ${type} [${flushStart},${flushEnd}], of [${bufStart},${bufEnd}], pos:${this.video.currentTime}`);\n              sb.remove(flushStart,flushEnd);\n              return false;\n            }\n          }\n        } else {\n          //logger.log('abort ' + type + ' append in progress');\n          // this will abort any appending in progress\n          //sb.abort();\n          return false;\n        }\n      }\n    }\n\n    /* after successful buffer flushing, rebuild buffer Range array\n      loop through existing buffer range and check if\n      corresponding range is still buffered. only push to new array already buffered range\n    */\n    var newRange = [],range;\n    for (i = 0 ; i < this.bufferRange.length ; i++) {\n      range = this.bufferRange[i];\n      if(this.isBuffered((range.start + range.end)/2)) {\n        newRange.push(range);\n      }\n    }\n    this.bufferRange = newRange;\n\n    logger.log('buffer flushed');\n    // everything flushed !\n    return true;\n  }\n\n    /*\n      on immediate level switch :\n       - pause playback if playing\n       - cancel any pending load request\n       - and trigger a buffer flush\n    */\n  immediateLevelSwitch() {\n    logger.log('immediateLevelSwitch');\n    if(!this.immediateSwitch) {\n      this.immediateSwitch = true;\n      this.previouslyPaused = this.video.paused;\n      this.video.pause();\n    }\n    if(this.frag && this.frag.loader) {\n      this.frag.loader.abort();\n    }\n    this.frag=null;\n    // flush everything\n    this.flushBufferCounter = 0;\n    this.flushRange.push({ start : 0, end : Number.POSITIVE_INFINITY});\n    // trigger a sourceBuffer flush\n    this.state = this.BUFFER_FLUSHING;\n    // increase fragment load Index to avoid frag loop loading error after buffer flush\n    this.fragLoadIdx+=2*this.config.fragLoadingLoopThreshold;\n    // speed up switching, trigger timer function\n    this.tick();\n  }\n\n/*\n   on immediate level switch end, after new fragment has been buffered :\n    - nudge video decoder by slightly adjusting video currentTime\n    - resume the playback if needed\n*/\n  immediateLevelSwitchEnd() {\n    this.immediateSwitch = false;\n    this.video.currentTime-=0.0001;\n    if(!this.previouslyPaused) {\n      this.video.play();\n    }\n  }\n\n  nextLevelSwitch() {\n    /* try to switch ASAP without breaking video playback :\n       in order to ensure smooth but quick level switching,\n      we need to find the next flushable buffer range\n      we should take into account new segment fetch time\n    */\n    var fetchdelay,currentRange,nextRange;\n\n    currentRange = this.getBufferRange(this.video.currentTime);\n    if(currentRange) {\n    // flush buffer preceding current fragment (flush until current fragment start offset)\n    // minus 1s to avoid video freezing, that could happen if we flush keyframe of current video ...\n      this.flushRange.push({ start : 0, end : currentRange.start-1});\n    }\n\n    if(!this.video.paused) {\n      // add a safety delay of 1s\n      var nextLevelId = this.hls.nextLoadLevel,nextLevel = this.levels[nextLevelId];\n      if(this.hls.stats.fragLastKbps && this.frag) {\n        fetchdelay = this.frag.duration*nextLevel.bitrate/(1000*this.hls.stats.fragLastKbps)+1;\n      } else {\n        fetchdelay = 0;\n      }\n    } else {\n      fetchdelay = 0;\n    }\n    //logger.log('fetchdelay:'+fetchdelay);\n    // find buffer range that will be reached once new fragment will be fetched\n    nextRange = this.getBufferRange(this.video.currentTime + fetchdelay);\n    if(nextRange) {\n      // we can flush buffer range following this one without stalling playback\n      nextRange = this.followingBufferRange(nextRange);\n      if(nextRange) {\n        // flush position is the start position of this new buffer\n        this.flushRange.push({ start : nextRange.start, end : Number.POSITIVE_INFINITY});\n      }\n    }\n    if(this.flushRange.length) {\n      this.flushBufferCounter = 0;\n      // trigger a sourceBuffer flush\n      this.state = this.BUFFER_FLUSHING;\n      // increase fragment load Index to avoid frag loop loading error after buffer flush\n      this.fragLoadIdx+=2*this.config.fragLoadingLoopThreshold;\n      // speed up switching, trigger timer function\n      this.tick();\n    }\n  }\n\n  onMSEAttached(event,data) {\n    this.video = data.video;\n    this.mediaSource = data.mediaSource;\n    this.onvseeking = this.onVideoSeeking.bind(this);\n    this.onvseeked = this.onVideoSeeked.bind(this);\n    this.onvmetadata = this.onVideoMetadata.bind(this);\n    this.video.addEventListener('seeking',this.onvseeking);\n    this.video.addEventListener('seeked',this.onvseeked);\n    this.video.addEventListener('loadedmetadata',this.onvmetadata);\n    if(this.levels && this.config.autoStartLoad) {\n      this.startLoad();\n    }\n  }\n\n  onMSEDetached() {\n    this.video = null;\n    this.loadedmetadata = false;\n    this.stop();\n  }\n\n\n  onVideoSeeking() {\n    if(this.state === this.LOADING) {\n      // check if currently loaded fragment is inside buffer.\n      //if outside, cancel fragment loading, otherwise do nothing\n      if(this.bufferInfo(this.video.currentTime).len === 0) {\n        logger.log('seeking outside of buffer while fragment load in progress, cancel fragment load');\n        this.frag.loader.abort();\n        this.frag = null;\n        // switch to IDLE state to load new fragment\n        this.state = this.IDLE;\n      }\n    }\n    if(this.video) {\n      this.lastCurrentTime = this.video.currentTime;\n    }\n    // avoid reporting fragment loop loading error in case user is seeking several times on same position\n    if(this.fragLoadIdx !== undefined) {\n      this.fragLoadIdx+= 2*this.config.fragLoadingLoopThreshold;\n    }\n    // tick to speed up processing\n    this.tick();\n  }\n\n  onVideoSeeked() {\n    // tick to speed up FRAGMENT_PLAYING triggering\n    this.tick();\n  }\n\n  onVideoMetadata() {\n      if(this.video.currentTime !== this.startPosition) {\n        this.video.currentTime = this.startPosition;\n    }\n    this.loadedmetadata = true;\n    this.tick();\n  }\n\n  onManifestParsed(event,data) {\n    var aac=false, heaac=false,codecs;\n    data.levels.forEach(level => {\n      // detect if we have different kind of audio codecs used amongst playlists\n      codecs = level.codecs;\n      if(codecs) {\n        if(codecs.indexOf('mp4a.40.2') !== -1) {\n          aac = true;\n        }\n        if(codecs.indexOf('mp4a.40.5') !== -1) {\n          heaac = true;\n        }\n      }\n    });\n    this.audiocodecswitch = (aac && heaac);\n    if(this.audiocodecswitch) {\n      logger.log('both AAC/HE-AAC audio found in levels; declaring audio codec as HE-AAC');\n    }\n    this.levels = data.levels;\n    this.startLevelLoaded = false;\n    this.startFragmentRequested = false;\n    if(this.video && this.config.autoStartLoad) {\n      this.startLoad();\n    }\n  }\n\n  onLevelLoaded(event,data) {\n    var newLevelDetails = data.details,\n        duration = newLevelDetails.totalduration,\n        newLevelId = data.level,\n        newLevel = this.levels[newLevelId],\n        curLevel = this.levels[this.level],\n        sliding = 0;\n    logger.log(`level ${newLevelId} loaded [${newLevelDetails.startSN},${newLevelDetails.endSN}],duration:${duration}`);\n    // check if playlist is already loaded (if yes, it should be a live playlist)\n    if(curLevel && curLevel.details && curLevel.details.live) {\n      var curLevelDetails = curLevel.details;\n      //  playlist sliding is the sum of : current playlist sliding + sliding of new playlist compared to current one\n      // check sliding of updated playlist against current one :\n      // and find its position in current playlist\n      //logger.log(\"fragments[0].sn/this.level/curLevel.details.fragments[0].sn:\" + fragments[0].sn + \"/\" + this.level + \"/\" + curLevel.details.fragments[0].sn);\n      var SNdiff = newLevelDetails.startSN - curLevelDetails.startSN;\n      if(SNdiff >=0) {\n        // positive sliding : new playlist sliding window is after previous one\n        var oldfragments = curLevelDetails.fragments;\n        if( SNdiff < oldfragments.length) {\n          sliding = curLevelDetails.sliding + oldfragments[SNdiff].start;\n        } else {\n          logger.log(`cannot compute sliding, no SN in common between old/new level:[${curLevelDetails.startSN},${curLevelDetails.endSN}]/[${newLevelDetails.startSN},${newLevelDetails.endSN}]`);\n          sliding = undefined;\n        }\n      } else {\n        // negative sliding: new playlist sliding window is before previous one\n        sliding = curLevelDetails.sliding - newLevelDetails.fragments[-SNdiff].start;\n      }\n      if(sliding) {\n        logger.log(`live playlist sliding:${sliding.toFixed(3)}`);\n      }\n    }\n    // override level info\n    newLevel.details = newLevelDetails;\n    newLevel.details.sliding = sliding;\n    if(this.startLevelLoaded === false) {\n      // if live playlist, set start position to be fragment N-3\n      if(newLevelDetails.live) {\n        this.startPosition = Math.max(0,duration - 3 * newLevelDetails.targetduration);\n      }\n      this.nextLoadPosition = this.startPosition;\n      this.startLevelLoaded = true;\n    }\n    // only switch batck to IDLE state if we were waiting for level to start downloading a new fragment\n    if(this.state === this.WAITING_LEVEL) {\n      this.state = this.IDLE;\n    }\n    //trigger handler right now\n    this.tick();\n  }\n\n  onFragmentLoaded(event,data) {\n    if(this.state === this.LOADING) {\n      if(this.fragmentBitrateTest === true) {\n        // switch back to IDLE state ... we just loaded a fragment to determine adequate start bitrate and initialize autoswitch algo\n        this.state = this.IDLE;\n        this.fragmentBitrateTest = false;\n        data.stats.tparsed = data.stats.tbuffered = new Date();\n        observer.trigger(Event.FRAG_BUFFERED, { stats : data.stats, frag : this.frag});\n        this.frag = null;\n      } else {\n        this.state = this.PARSING;\n        // transmux the MPEG-TS data to ISO-BMFF segments\n        this.stats = data.stats;\n        var currentLevel = this.levels[this.level], details = currentLevel.details,  duration =  details.totalduration, start = this.frag.start;\n        if(details.live) {\n          duration+=details.sliding;\n          start+=details.sliding;\n        }\n        if(this.frag.drift) {\n          start+= this.frag.drift;\n        }\n        logger.log(`Demuxing      ${this.frag.sn} of [${details.startSN} ,${details.endSN}],level ${this.level}`);\n        this.demuxer.push(data.payload,currentLevel.audioCodec,currentLevel.videoCodec,start,this.frag.cc, this.level, duration);\n      }\n    }\n  }\n\n  onInitSegment(event,data) {\n    if(this.state === this.PARSING) {\n      // check if codecs have been explicitely defined in the master playlist for this level;\n      // if yes use these ones instead of the ones parsed from the demux\n      var audioCodec = this.levels[this.level].audioCodec, videoCodec = this.levels[this.level].videoCodec,sb;\n      //logger.log('playlist level A/V codecs:' + audioCodec + ',' + videoCodec);\n      //logger.log('playlist codecs:' + codec);\n      // if playlist does not specify codecs, use codecs found while parsing fragment\n      if(audioCodec === undefined || data.audiocodec === undefined) {\n        audioCodec = data.audioCodec;\n      }\n      if(videoCodec === undefined  || data.videocodec === undefined) {\n        videoCodec = data.videoCodec;\n      }\n      // in case several audio codecs might be used, force HE-AAC for audio (some browsers don't support audio codec switch)\n      //don't do it for mono streams ...\n      if(this.audiocodecswitch && data.audioChannelCount === 2 && navigator.userAgent.toLowerCase().indexOf('android') === -1 && navigator.userAgent.toLowerCase().indexOf('firefox') === -1) {\n        audioCodec = 'mp4a.40.5';\n      }\n      if(!this.sourceBuffer) {\n        this.sourceBuffer = {};\n        logger.log(`selected A/V codecs for sourceBuffers:${audioCodec},${videoCodec}`);\n        // create source Buffer and link them to MediaSource\n        if(audioCodec) {\n          sb = this.sourceBuffer.audio = this.mediaSource.addSourceBuffer(`video/mp4;codecs=${audioCodec}`);\n          sb.addEventListener('updateend', this.onsbue);\n          sb.addEventListener('error', this.onsbe);\n        }\n        if(videoCodec) {\n          sb = this.sourceBuffer.video = this.mediaSource.addSourceBuffer(`video/mp4;codecs=${videoCodec}`);\n          sb.addEventListener('updateend', this.onsbue);\n          sb.addEventListener('error', this.onsbe);\n        }\n      }\n      if(audioCodec) {\n        this.mp4segments.push({ type : 'audio', data : data.audioMoov});\n      }\n      if(videoCodec) {\n        this.mp4segments.push({ type : 'video', data : data.videoMoov});\n      }\n      //trigger handler right now\n      this.tick();\n    }\n  }\n\n  onFragmentParsing(event,data) {\n    if(this.state === this.PARSING) {\n      this.tparse2 = Date.now();\n      var level = this.levels[this.level];\n      if(level.details.live) {\n        var fragments = this.levels[this.level].details.fragments;\n        var sn0 = fragments[0].sn,sn1 = fragments[fragments.length-1].sn, sn = this.frag.sn;\n        //retrieve this.frag.sn in this.levels[this.level]\n        if(sn >= sn0 && sn <= sn1) {\n          level.details.sliding = data.startPTS - fragments[sn-sn0].start;\n          //logger.log(`live playlist sliding:${level.details.sliding.toFixed(3)}`);\n        }\n      }\n      logger.log(`      parsed data, type/startPTS/endPTS/startDTS/endDTS/nb:${data.type}/${data.startPTS.toFixed(3)}/${data.endPTS.toFixed(3)}/${data.startDTS.toFixed(3)}/${data.endDTS.toFixed(3)}/${data.nb}`);\n      //this.frag.drift=data.startPTS-this.frag.start;\n      this.frag.drift=0;\n      // if(level.details.sliding) {\n      //   this.frag.drift-=level.details.sliding;\n      // }\n      //logger.log(`      drift:${this.frag.drift.toFixed(3)}`);\n      this.mp4segments.push({ type : data.type, data : data.moof});\n      this.mp4segments.push({ type : data.type, data : data.mdat});\n      this.nextLoadPosition = data.endPTS;\n      this.bufferRange.push({type : data.type, start : data.startPTS, end : data.endPTS, frag : this.frag});\n      // if(data.type === 'video') {\n      //   this.frag.fpsExpected = (data.nb-1) / (data.endPTS - data.startPTS);\n      // }\n      //trigger handler right now\n      this.tick();\n    } else {\n      logger.warn(`not in PARSING state, discarding ${event}`);\n    }\n  }\n\n  onFragmentParsed() {\n    if(this.state === this.PARSING) {\n      this.state = this.PARSED;\n      this.stats.tparsed = new Date();\n      //trigger handler right now\n      this.tick();\n    }\n  }\n\n  onError(event,data) {\n    switch(data.details) {\n      // abort fragment loading on errors\n      case ErrorDetails.FRAG_LOAD_ERROR:\n      case ErrorDetails.FRAG_LOAD_TIMEOUT:\n      case ErrorDetails.FRAG_LOOP_LOADING_ERROR:\n      case ErrorDetails.LEVEL_LOAD_ERROR:\n      case ErrorDetails.LEVEL_LOAD_TIMEOUT:\n        // if fatal error, stop processing, otherwise move to IDLE to retry loading\n        logger.warn(`buffer controller: ${data.details} while loading frag,switch to ${data.fatal ? 'ERROR' : 'IDLE'} state ...`);\n        this.state = data.fatal ? this.ERROR : this.IDLE;\n        this.frag = null;\n        break;\n      default:\n        break;\n    }\n  }\n\n  onSourceBufferUpdateEnd() {\n    //trigger handler right now\n    if(this.state === this.APPENDING && this.mp4segments.length === 0)  {\n      if(this.frag) {\n        this.stats.tbuffered = new Date();\n        observer.trigger(Event.FRAG_BUFFERED, { stats : this.stats, frag : this.frag});\n        this.state = this.IDLE;\n      }\n    }\n    this.tick();\n  }\n\n  onSourceBufferError(event) {\n      logger.error(`sourceBuffer error:${event}`);\n      this.state = this.ERROR;\n      observer.trigger(Event.ERROR, {type : ErrorTypes.MEDIA_ERROR, details : ErrorDetails.FRAG_APPENDING_ERROR, fatal:true, frag : this.frag});\n  }\n}\n\nexport default BufferController;\n","/*\n * level controller\n *\n */\n\n import Event                from '../events';\n import observer             from '../observer';\n import {logger}             from '../utils/logger';\n import {ErrorTypes,ErrorDetails} from '../errors';\n\n class LevelController {\n\n  constructor(hls) {\n    this.hls = hls;\n    this.onml = this.onManifestLoaded.bind(this);\n    this.onll = this.onLevelLoaded.bind(this);\n    this.onflp = this.onFragmentLoadProgress.bind(this);\n    this.onerr = this.onError.bind(this);\n    this.ontick = this.tick.bind(this);\n    observer.on(Event.MANIFEST_LOADED, this.onml);\n    observer.on(Event.FRAG_LOAD_PROGRESS, this.onflp);\n    observer.on(Event.LEVEL_LOADED, this.onll);\n    observer.on(Event.ERROR, this.onerr);\n    this._manualLevel = this._autoLevelCapping = -1;\n  }\n\n  destroy() {\n    observer.off(Event.MANIFEST_LOADED, this.onml);\n    observer.off(Event.FRAG_LOAD_PROGRESS, this.onflp);\n    observer.off(Event.LEVEL_LOADED, this.onll);\n    observer.off(Event.ERROR, this.onerr);\n    if(this.timer) {\n     clearInterval(this.timer);\n    }\n    this._manualLevel = -1;\n  }\n\n  onManifestLoaded(event,data) {\n    var levels = [],bitrateStart,i,bitrateSet={};\n    data.levels.forEach(level => {\n      var redundantLevelId = bitrateSet[level.bitrate];\n      if(redundantLevelId === undefined) {\n        bitrateSet[level.bitrate] = levels.length;\n        level.url = [level.url];\n        level.urlId = 0;\n        levels.push(level);\n      } else {\n        levels[redundantLevelId].url.push(level.url);\n      }\n    });\n    // start bitrate is the first bitrate of the manifest\n    bitrateStart = levels[0].bitrate;\n    // sort level on bitrate\n    levels.sort(function (a, b) {\n      return a.bitrate-b.bitrate;\n    });\n    this._levels = levels;\n\n    // find index of first level in sorted levels\n    for(i=0; i < levels.length ; i++) {\n      if(levels[i].bitrate === bitrateStart) {\n        this._firstLevel = i;\n        logger.log(`manifest loaded,${levels.length} level(s) found, first bitrate:${bitrateStart}`);\n        break;\n      }\n    }\n    observer.trigger(Event.MANIFEST_PARSED,\n                    { levels : this._levels,\n                      firstLevel : this._firstLevel,\n                      stats : data.stats\n                    });\n    return;\n  }\n\n  get levels() {\n    return this._levels;\n  }\n\n  get level() {\n    return this._level;\n  }\n\n  set level(newLevel) {\n    if(this._level !== newLevel || this._levels[newLevel].details === undefined) {\n      this.setLevelInternal(newLevel);\n    }\n  }\n\n setLevelInternal(newLevel) {\n    // check if level idx is valid\n    if(newLevel >= 0 && newLevel < this._levels.length) {\n      // stopping live reloading timer if any\n      if(this.timer) {\n       clearInterval(this.timer);\n       this.timer = null;\n      }\n      this._level = newLevel;\n      logger.log(`switching to level ${newLevel}`);\n      observer.trigger(Event.LEVEL_SWITCH, { level : newLevel});\n      var level = this._levels[newLevel];\n       // check if we need to load playlist for this level\n      if(level.details === undefined || level.details.live === true) {\n        // level not retrieved yet, or live playlist we need to (re)load it\n        logger.log(`(re)loading playlist for level ${newLevel}`);\n        var urlId = level.urlId;\n        observer.trigger(Event.LEVEL_LOADING, { url : level.url[urlId], level : newLevel, id : urlId});\n      }\n    } else {\n      // invalid level id given, trigger error\n      observer.trigger(Event.ERROR, { type : ErrorTypes.OTHER_ERROR, details: ErrorDetails.LEVEL_SWITCH_ERROR, level : newLevel, fatal:false, reason: 'invalid level idx'});\n    }\n }\n\n\n  get manualLevel() {\n    return this._manualLevel;\n  }\n\n  set manualLevel(newLevel) {\n    this._manualLevel = newLevel;\n    if(newLevel !==-1) {\n      this.level = newLevel;\n    }\n  }\n\n  /** Return the capping/max level value that could be used by automatic level selection algorithm **/\n  get autoLevelCapping() {\n    return this._autoLevelCapping;\n  }\n\n  /** set the capping/max level value that could be used by automatic level selection algorithm **/\n  set autoLevelCapping(newLevel) {\n    this._autoLevelCapping = newLevel;\n  }\n\n  get firstLevel() {\n    return this._firstLevel;\n  }\n\n  set firstLevel(newLevel) {\n    this._firstLevel = newLevel;\n  }\n\n  get startLevel() {\n    if(this._startLevel === undefined) {\n      return this._firstLevel;\n    } else {\n      return this._startLevel;\n    }\n  }\n\n  set startLevel(newLevel) {\n    this._startLevel = newLevel;\n  }\n\n  onFragmentLoadProgress(event,data) {\n    var stats = data.stats;\n    if(stats.aborted === undefined) {\n      this.lastfetchduration = (new Date() - stats.trequest)/1000;\n      this.lastfetchlevel = data.frag.level;\n      this.lastbw = stats.loaded*8/this.lastfetchduration;\n      //console.log(`fetchDuration:${this.lastfetchduration},bw:${(this.lastbw/1000).toFixed(0)}/${stats.aborted}`);\n    }\n  }\n\n  onError(event,data) {\n    var details = data.details,levelId,level;\n    // try to recover not fatal errors\n    switch(details) {\n      case ErrorDetails.FRAG_LOAD_ERROR:\n      case ErrorDetails.FRAG_LOAD_TIMEOUT:\n      case ErrorDetails.FRAG_LOOP_LOADING_ERROR:\n         levelId = data.frag.level;\n         break;\n      case ErrorDetails.LEVEL_LOAD_ERROR:\n      case ErrorDetails.LEVEL_LOAD_TIMEOUT:\n        levelId = data.level;\n        break;\n      default:\n        break;\n    }\n    /* try to switch to a redundant stream if any available.\n     * if no redundant stream available, emergency switch down (if in auto mode and current level not 0)\n     * otherwise, we cannot recover this network error ....\n     */\n    if(levelId !== undefined) {\n      level = this._levels[levelId];\n      if(level.urlId < level.url.length-1) {\n        level.urlId++;\n        level.details = undefined;\n        logger.warn(`level controller,${details} for level ${levelId}: switching to redundant stream id ${level.urlId}`);\n      } else {\n        // we could try to recover if in auto mode and current level not lowest level (0)\n        let recoverable = ((this._manualLevel === -1) && levelId);\n        if(recoverable) {\n          logger.warn(`level controller,${details}: emergency switch-down for next fragment`);\n          this.lastbw = 0;\n          this.lastfetchduration = 0;\n        } else {\n          logger.error(`cannot recover ${details} error`);\n          this._level = undefined;\n          // stopping live reloading timer if any\n          if(this.timer) {\n            clearInterval(this.timer);\n            this.timer = null;\n            // redispatch same error but with fatal set to true\n            data.fatal = true;\n            observer.trigger(event,data);\n          }\n        }\n      }\n    }\n  }\n\n  onLevelLoaded(event,data) {\n    // check if current playlist is a live playlist\n    if(data.details.live && !this.timer) {\n      // if live playlist we will have to reload it periodically\n      // set reload period to playlist target duration\n      this.timer = setInterval(this.ontick, 1000*data.details.targetduration);\n    }\n  }\n\n  tick() {\n    var levelId = this._level;\n    if(levelId !== undefined) {\n      var level = this._levels[levelId], urlId = level.urlId;\n      observer.trigger(Event.LEVEL_LOADING, { url: level.url[urlId], level : levelId, id : urlId });\n    }\n  }\n\n  nextLoadLevel() {\n    if(this._manualLevel !== -1) {\n      return this._manualLevel;\n    } else {\n     return this.nextAutoLevel();\n    }\n  }\n\n  nextAutoLevel() {\n    var lastbw = this.lastbw,adjustedbw,i,maxAutoLevel;\n    if(this._autoLevelCapping === -1) {\n      maxAutoLevel = this._levels.length-1;\n    } else {\n      maxAutoLevel = this._autoLevelCapping;\n    }\n    // follow algorithm captured from stagefright :\n    // https://android.googlesource.com/platform/frameworks/av/+/master/media/libstagefright/httplive/LiveSession.cpp\n    // Pick the highest bandwidth stream below or equal to estimated bandwidth.\n    for(i =0; i <= maxAutoLevel ; i++) {\n    // consider only 80% of the available bandwidth, but if we are switching up,\n    // be even more conservative (70%) to avoid overestimating and immediately\n    // switching back.\n      if(i <= this._level) {\n        adjustedbw = 0.8*lastbw;\n      } else {\n        adjustedbw = 0.7*lastbw;\n      }\n      if(adjustedbw < this._levels[i].bitrate) {\n        return Math.max(0,i-1);\n      }\n    }\n    return i-1;\n  }\n}\n\nexport default LevelController;\n"," import Event                from '../events';\n import TSDemuxer            from './tsdemuxer';\n import TSDemuxerWorker      from './tsdemuxerworker';\n import observer             from '../observer';\n import {logger}             from '../utils/logger';\n\n\nclass Demuxer {\n\n  constructor(config) {\n    if(config.enableWorker && (typeof(Worker) !== 'undefined')) {\n        logger.log('TS demuxing in webworker');\n        try {\n          var work = require('webworkify');\n          this.w = work(TSDemuxerWorker);\n          this.onwmsg = this.onWorkerMessage.bind(this);\n          this.w.addEventListener('message', this.onwmsg);\n          this.w.postMessage({ cmd : 'init'});\n        } catch(err) {\n          logger.error('error while initializing TSDemuxerWorker, fallback on regular TSDemuxer');\n          this.demuxer = new TSDemuxer();\n        }\n      } else {\n        this.demuxer = new TSDemuxer();\n      }\n      this.demuxInitialized = true;\n  }\n\n  destroy() {\n    if(this.w) {\n      this.w.removeEventListener('message',this.onwmsg);\n      this.w.terminate();\n      this.w = null;\n    } else {\n      this.demuxer.destroy();\n    }\n  }\n\n  push(data, audioCodec, videoCodec, timeOffset, cc, level, duration) {\n    if(this.w) {\n      // post fragment payload as transferable objects (no copy)\n      this.w.postMessage({ cmd : 'demux' , data : data, audioCodec : audioCodec, videoCodec: videoCodec, timeOffset : timeOffset, cc: cc, level : level, duration : duration},[data]);\n    } else {\n      this.demuxer.push(new Uint8Array(data), audioCodec, videoCodec, timeOffset, cc, level, duration);\n      this.demuxer.end();\n    }\n  }\n\n  onWorkerMessage(ev) {\n    //console.log('onWorkerMessage:' + ev.data.event);\n    switch(ev.data.event) {\n      case Event.FRAG_PARSING_INIT_SEGMENT:\n        var obj = {};\n        if(ev.data.audioMoov) {\n          obj.audioMoov = new Uint8Array(ev.data.audioMoov);\n          obj.audioCodec = ev.data.audioCodec;\n          obj.audioChannelCount = ev.data.audioChannelCount;\n        }\n        if(ev.data.videoMoov) {\n          obj.videoMoov = new Uint8Array(ev.data.videoMoov);\n          obj.videoCodec = ev.data.videoCodec;\n          obj.videoWidth = ev.data.videoWidth;\n          obj.videoHeight = ev.data.videoHeight;\n        }\n        observer.trigger(Event.FRAG_PARSING_INIT_SEGMENT, obj);\n        break;\n      case Event.FRAG_PARSING_DATA:\n        observer.trigger(Event.FRAG_PARSING_DATA,{\n          moof : new Uint8Array(ev.data.moof),\n          mdat : new Uint8Array(ev.data.mdat),\n          startPTS : ev.data.startPTS,\n          endPTS : ev.data.endPTS,\n          startDTS : ev.data.startDTS,\n          endDTS : ev.data.endDTS,\n          type : ev.data.type,\n          nb : ev.data.nb\n        });\n        break;\n      default:\n        observer.trigger(ev.data.event,ev.data.data);\n        break;\n    }\n  }\n}\nexport default Demuxer;\n","/**\n * Parser for exponential Golomb codes, a variable-bitwidth number encoding\n * scheme used by h264.\n */\n\nimport {logger}        from '../utils/logger';\n\nclass ExpGolomb {\n\n  constructor(data) {\n    this.data = data;\n    // the number of bytes left to examine in this.data\n    this.bytesAvailable = this.data.byteLength;\n    // the current word being examined\n    this.word = 0; // :uint\n    // the number of bits left to examine in the current word\n    this.bitsAvailable = 0; // :uint\n  }\n\n  // ():void\n  loadWord() {\n    var\n      position = this.data.byteLength - this.bytesAvailable,\n      workingBytes = new Uint8Array(4),\n      availableBytes = Math.min(4, this.bytesAvailable);\n\n    if (availableBytes === 0) {\n      throw new Error('no bytes available');\n    }\n\n    workingBytes.set(this.data.subarray(position,\n                                          position + availableBytes));\n    this.word = new DataView(workingBytes.buffer).getUint32(0);\n\n    // track the amount of this.data that has been processed\n    this.bitsAvailable = availableBytes * 8;\n    this.bytesAvailable -= availableBytes;\n  }\n\n  // (count:int):void\n  skipBits(count) {\n    var skipBytes; // :int\n    if (this.bitsAvailable > count) {\n      this.word          <<= count;\n      this.bitsAvailable -= count;\n    } else {\n      count -= this.bitsAvailable;\n      skipBytes = count >> 3;\n\n      count -= (skipBytes >> 3);\n      this.bytesAvailable -= skipBytes;\n\n      this.loadWord();\n\n      this.word <<= count;\n      this.bitsAvailable -= count;\n    }\n  }\n\n  // (size:int):uint\n  readBits(size) {\n    var\n      bits = Math.min(this.bitsAvailable, size), // :uint\n      valu = this.word >>> (32 - bits); // :uint\n\n    if(size >32) {\n      logger.error('Cannot read more than 32 bits at a time');\n    }\n\n    this.bitsAvailable -= bits;\n    if (this.bitsAvailable > 0) {\n      this.word <<= bits;\n    } else if (this.bytesAvailable > 0) {\n      this.loadWord();\n    }\n\n    bits = size - bits;\n    if (bits > 0) {\n      return valu << bits | this.readBits(bits);\n    } else {\n      return valu;\n    }\n  }\n\n  // ():uint\n  skipLZ() {\n    var leadingZeroCount; // :uint\n    for (leadingZeroCount = 0 ; leadingZeroCount < this.bitsAvailable ; ++leadingZeroCount) {\n      if (0 !== (this.word & (0x80000000 >>> leadingZeroCount))) {\n        // the first bit of working word is 1\n        this.word <<= leadingZeroCount;\n        this.bitsAvailable -= leadingZeroCount;\n        return leadingZeroCount;\n      }\n    }\n\n    // we exhausted word and still have not found a 1\n    this.loadWord();\n    return leadingZeroCount + this.skipLZ();\n  }\n\n  // ():void\n  skipUEG() {\n    this.skipBits(1 + this.skipLZ());\n  }\n\n  // ():void\n  skipEG() {\n    this.skipBits(1 + this.skipLZ());\n  }\n\n  // ():uint\n  readUEG() {\n    var clz = this.skipLZ(); // :uint\n    return this.readBits(clz + 1) - 1;\n  }\n\n  // ():int\n  readEG() {\n    var valu = this.readUEG(); // :int\n    if (0x01 & valu) {\n      // the number is odd if the low order bit is set\n      return (1 + valu) >>> 1; // add 1 to make it even, and divide by 2\n    } else {\n      return -1 * (valu >>> 1); // divide by two then make it negative\n    }\n  }\n\n  // Some convenience functions\n  // :Boolean\n  readBoolean() {\n    return 1 === this.readBits(1);\n  }\n\n  // ():int\n  readUByte() {\n    return this.readBits(8);\n  }\n\n  /**\n   * Advance the ExpGolomb decoder past a scaling list. The scaling\n   * list is optionally transmitted as part of a sequence parameter\n   * set and is not relevant to transmuxing.\n   * @param count {number} the number of entries in this scaling list\n   * @see Recommendation ITU-T H.264, Section 7.3.2.1.1.1\n   */\n  skipScalingList(count) {\n    var\n      lastScale = 8,\n      nextScale = 8,\n      j,\n      deltaScale;\n\n    for (j = 0; j < count; j++) {\n      if (nextScale !== 0) {\n        deltaScale = this.readEG();\n        nextScale = (lastScale + deltaScale + 256) % 256;\n      }\n\n      lastScale = (nextScale === 0) ? lastScale : nextScale;\n    }\n  }\n\n  /**\n   * Read a sequence parameter set and return some interesting video\n   * properties. A sequence parameter set is the H264 metadata that\n   * describes the properties of upcoming video frames.\n   * @param data {Uint8Array} the bytes of a sequence parameter set\n   * @return {object} an object with configuration parsed from the\n   * sequence parameter set, including the dimensions of the\n   * associated video frames.\n   */\n  readSPS() {\n    var\n      frameCropLeftOffset = 0,\n      frameCropRightOffset = 0,\n      frameCropTopOffset = 0,\n      frameCropBottomOffset = 0,\n      profileIdc,profileCompat,levelIdc,\n      numRefFramesInPicOrderCntCycle, picWidthInMbsMinus1,\n      picHeightInMapUnitsMinus1,\n      frameMbsOnlyFlag,\n      scalingListCount,\n      i;\n\n    this.readUByte();\n    profileIdc = this.readUByte(); // profile_idc\n    profileCompat = this.readBits(5); // constraint_set[0-4]_flag, u(5)\n    this.skipBits(3); // reserved_zero_3bits u(3),\n    levelIdc = this.readUByte(); //level_idc u(8)\n    this.skipUEG(); // seq_parameter_set_id\n\n    // some profiles have more optional data we don't need\n    if (profileIdc === 100 ||\n        profileIdc === 110 ||\n        profileIdc === 122 ||\n        profileIdc === 144) {\n      var chromaFormatIdc = this.readUEG();\n      if (chromaFormatIdc === 3) {\n        this.skipBits(1); // separate_colour_plane_flag\n      }\n      this.skipUEG(); // bit_depth_luma_minus8\n      this.skipUEG(); // bit_depth_chroma_minus8\n      this.skipBits(1); // qpprime_y_zero_transform_bypass_flag\n      if (this.readBoolean()) { // seq_scaling_matrix_present_flag\n        scalingListCount = (chromaFormatIdc !== 3) ? 8 : 12;\n        for (i = 0; i < scalingListCount; i++) {\n          if (this.readBoolean()) { // seq_scaling_list_present_flag[ i ]\n            if (i < 6) {\n              this.skipScalingList(16);\n            } else {\n              this.skipScalingList(64);\n            }\n          }\n        }\n      }\n    }\n\n    this.skipUEG(); // log2_max_frame_num_minus4\n    var picOrderCntType = this.readUEG();\n\n    if (picOrderCntType === 0) {\n      this.readUEG(); //log2_max_pic_order_cnt_lsb_minus4\n    } else if (picOrderCntType === 1) {\n      this.skipBits(1); // delta_pic_order_always_zero_flag\n      this.skipEG(); // offset_for_non_ref_pic\n      this.skipEG(); // offset_for_top_to_bottom_field\n      numRefFramesInPicOrderCntCycle = this.readUEG();\n      for(i = 0; i < numRefFramesInPicOrderCntCycle; i++) {\n        this.skipEG(); // offset_for_ref_frame[ i ]\n      }\n    }\n\n    this.skipUEG(); // max_num_ref_frames\n    this.skipBits(1); // gaps_in_frame_num_value_allowed_flag\n\n    picWidthInMbsMinus1 = this.readUEG();\n    picHeightInMapUnitsMinus1 = this.readUEG();\n\n    frameMbsOnlyFlag = this.readBits(1);\n    if (frameMbsOnlyFlag === 0) {\n      this.skipBits(1); // mb_adaptive_frame_field_flag\n    }\n\n    this.skipBits(1); // direct_8x8_inference_flag\n    if (this.readBoolean()) { // frame_cropping_flag\n      frameCropLeftOffset = this.readUEG();\n      frameCropRightOffset = this.readUEG();\n      frameCropTopOffset = this.readUEG();\n      frameCropBottomOffset = this.readUEG();\n    }\n\n    return {\n      profileIdc : profileIdc,\n      profileCompat : profileCompat,\n      levelIdc : levelIdc,\n      width: ((picWidthInMbsMinus1 + 1) * 16) - frameCropLeftOffset * 2 - frameCropRightOffset * 2,\n      height: ((2 - frameMbsOnlyFlag) * (picHeightInMapUnitsMinus1 + 1) * 16) - (frameCropTopOffset * 2) - (frameCropBottomOffset * 2)\n    };\n  }\n}\n\nexport default ExpGolomb;\n","/**\n * A stream-based mp2ts to mp4 converter. This utility is used to\n * deliver mp4s to a SourceBuffer on platforms that support native\n * Media Source Extensions.\n */\n\n import Event           from '../events';\n import ExpGolomb       from './exp-golomb';\n// import Hex             from '../utils/hex';\n import MP4             from '../remux/mp4-generator';\n import observer        from '../observer';\n import {logger}        from '../utils/logger';\n import {ErrorTypes,ErrorDetails} from '../errors';\n\n class TSDemuxer {\n\n  constructor() {\n    this.lastCC = 0;\n    this.PES_TIMESCALE=90000;\n    this.PES2MP4SCALEFACTOR=4;\n    this.MP4_TIMESCALE=this.PES_TIMESCALE/this.PES2MP4SCALEFACTOR;\n  }\n\n  switchLevel() {\n    this.pmtParsed = false;\n    this._pmtId = this._avcId = this._aacId = -1;\n    this._avcTrack = {type : 'video', sequenceNumber : 0};\n    this._aacTrack = {type : 'audio', sequenceNumber : 0};\n    this._avcSamples = [];\n    this._avcSamplesLength = 0;\n    this._avcSamplesNbNalu = 0;\n    this._aacSamples = [];\n    this._aacSamplesLength = 0;\n    this._initSegGenerated = false;\n  }\n\n  insertDiscontinuity() {\n    this.switchLevel();\n    this._initPTS = this._initDTS = undefined;\n  }\n\n  // feed incoming data to the front of the parsing pipeline\n  push(data,audioCodec, videoCodec,timeOffset,cc,level,duration) {\n    var avcData,aacData,start,len = data.length,stt,pid,atf,offset;\n    this.audioCodec = audioCodec;\n    this.videoCodec = videoCodec;\n    this.timeOffset = timeOffset;\n    this._duration = duration;\n    if(cc !== this.lastCC) {\n      logger.log(`discontinuity detected`);\n      this.insertDiscontinuity();\n      this.lastCC = cc;\n    } else if(level !== this.lastLevel) {\n      logger.log(`level switch detected`);\n      this.switchLevel();\n      this.lastLevel = level;\n    }\n    var pmtParsed=this.pmtParsed,avcId=this._avcId,aacId=this._aacId;\n\n    // loop through TS packets\n    for(start = 0; start < len ; start += 188) {\n      if(data[start] === 0x47) {\n        stt = !!(data[start+1] & 0x40);\n        // pid is a 13-bit field starting at the last bit of TS[1]\n        pid = ((data[start+1] & 0x1f) << 8) + data[start+2];\n        atf = (data[start+3] & 0x30) >> 4;\n        // if an adaption field is present, its length is specified by the fifth byte of the TS packet header.\n        if(atf > 1) {\n          offset = start+5+data[start+4];\n          // continue if there is only adaptation field\n          if(offset === (start+188)) {\n            continue;\n          }\n        } else {\n          offset = start+4;\n        }\n        if(pmtParsed) {\n          if(pid === avcId) {\n            if(stt) {\n              if(avcData) {\n                this._parseAVCPES(this._parsePES(avcData));\n              }\n              avcData = {data: [],size: 0};\n            }\n            if(avcData) {\n              avcData.data.push(data.subarray(offset,start+188));\n              avcData.size+=start+188-offset;\n            }\n          } else if(pid === aacId) {\n            if(stt) {\n              if(aacData) {\n                this._parseAACPES(this._parsePES(aacData));\n              }\n              aacData = {data: [],size: 0};\n            }\n            if(aacData) {\n              aacData.data.push(data.subarray(offset,start+188));\n              aacData.size+=start+188-offset;\n            }\n          }\n        } else {\n          if(stt) {\n            offset += data[offset] + 1;\n          }\n          if(pid === 0) {\n            this._parsePAT(data,offset);\n          } else if(pid === this._pmtId) {\n            this._parsePMT(data,offset);\n            pmtParsed = this.pmtParsed = true;\n            avcId = this._avcId;\n            aacId = this._aacId;\n          }\n        }\n      } else {\n        observer.trigger(Event.ERROR, { type : ErrorTypes.MEDIA_ERROR, details : ErrorDetails.FRAG_PARSING_ERROR, fatal:false, reason : 'TS packet did not start with 0x47'});\n      }\n    }\n  // parse last PES packet\n    if(avcData) {\n      this._parseAVCPES(this._parsePES(avcData));\n    }\n    if(aacData) {\n      this._parseAACPES(this._parsePES(aacData));\n    }\n  }\n\n  end() {\n    // generate Init Segment if needed\n    if(!this._initSegGenerated) {\n      this._generateInitSegment();\n    }\n    //logger.log('nb AVC samples:' + this._avcSamples.length);\n    if(this._avcSamples.length) {\n      this._flushAVCSamples();\n    }\n    //logger.log('nb AAC samples:' + this._aacSamples.length);\n    if(this._aacSamples.length) {\n      this._flushAACSamples();\n    }\n    //notify end of parsing\n    observer.trigger(Event.FRAG_PARSED);\n  }\n\n  destroy() {\n    this.switchLevel();\n    this._initPTS = this._initDTS = undefined;\n    this._duration = 0;\n  }\n\n  _parsePAT(data,offset) {\n    // skip the PSI header and parse the first PMT entry\n    this._pmtId  = (data[offset+10] & 0x1F) << 8 | data[offset+11];\n    //logger.log('PMT PID:'  + this._pmtId);\n  }\n\n  _parsePMT(data,offset) {\n    var sectionLength,tableEnd,programInfoLength,pid;\n    sectionLength = (data[offset+1] & 0x0f) << 8 | data[offset+2];\n    tableEnd = offset + 3 + sectionLength - 4;\n    // to determine where the table is, we have to figure out how\n    // long the program info descriptors are\n    programInfoLength = (data[offset+10] & 0x0f) << 8 | data[offset+11];\n\n    // advance the offset to the first entry in the mapping table\n    offset += 12 + programInfoLength;\n    while (offset < tableEnd) {\n      pid = (data[offset + 1] & 0x1F) << 8 | data[offset + 2];\n      switch(data[offset]) {\n        // ISO/IEC 13818-7 ADTS AAC (MPEG-2 lower bit-rate audio)\n        case 0x0f:\n        //logger.log('AAC PID:'  + pid);\n          this._aacId = pid;\n          this._aacTrack.id = pid;\n        break;\n        // ITU-T Rec. H.264 and ISO/IEC 14496-10 (lower bit-rate video)\n        case 0x1b:\n        //logger.log('AVC PID:'  + pid);\n        this._avcId = pid;\n        this._avcTrack.id = pid;\n        break;\n        default:\n        logger.log('unkown stream type:'  + data[offset]);\n        break;\n      }\n      // move to the next table entry\n      // skip past the elementary stream descriptors, if present\n      offset += ((data[offset + 3] & 0x0F) << 8 | data[offset + 4]) + 5;\n    }\n  }\n\n  _parsePES(stream) {\n    var i = 0,frag,pesFlags,pesPrefix,pesLen,pesHdrLen,pesData,pesPts,pesDts,payloadStartOffset;\n    //retrieve PTS/DTS from first fragment\n    frag = stream.data[0];\n    pesPrefix = (frag[0] << 16) + (frag[1] << 8) + frag[2];\n    if(pesPrefix === 1) {\n      pesLen = (frag[4] << 8) + frag[5];\n      pesFlags = frag[7];\n      if (pesFlags & 0xC0) {\n        /* PES header described here : http://dvd.sourceforge.net/dvdinfo/pes-hdr.html\n            as PTS / DTS is 33 bit we cannot use bitwise operator in JS,\n            as Bitwise operators treat their operands as a sequence of 32 bits */\n        pesPts = (frag[9] & 0x0E)*536870912 +// 1 << 29\n          (frag[10] & 0xFF)*4194304 +// 1 << 22\n          (frag[11] & 0xFE)*16384 +// 1 << 14\n          (frag[12] & 0xFF)*128 +// 1 << 7\n          (frag[13] & 0xFE)/2;\n          // check if greater than 2^32 -1\n          if (pesPts > 4294967295) {\n              // decrement 2^33\n              pesPts -= 8589934592;\n          }\n        if (pesFlags & 0x40) {\n          pesDts = (frag[14] & 0x0E )*536870912 +// 1 << 29\n            (frag[15] & 0xFF )*4194304 +// 1 << 22\n            (frag[16] & 0xFE )*16384 +// 1 << 14\n            (frag[17] & 0xFF )*128 +// 1 << 7\n            (frag[18] & 0xFE )/2;\n          // check if greater than 2^32 -1\n          if (pesDts > 4294967295) {\n              // decrement 2^33\n              pesDts -= 8589934592;\n          }\n        } else {\n          pesDts = pesPts;\n        }\n      }\n      pesHdrLen = frag[8];\n      payloadStartOffset = pesHdrLen+9;\n      // trim PES header\n      stream.data[0] = stream.data[0].subarray(payloadStartOffset);\n      stream.size -= payloadStartOffset;\n      //reassemble PES packet\n      pesData = new Uint8Array(stream.size);\n      // reassemble the packet\n      while (stream.data.length) {\n        frag = stream.data.shift();\n        pesData.set(frag, i);\n        i += frag.byteLength;\n      }\n      return { data : pesData, pts : pesPts, dts : pesDts, len : pesLen};\n    } else {\n      return null;\n    }\n  }\n\n  _parseAVCPES(pes) {\n    var units,track = this._avcTrack,avcSample,key = false;\n    units = this._parseAVCNALu(pes.data);\n    //free pes.data to save up some memory\n    pes.data = null;\n    units.units.forEach(unit => {\n      switch(unit.type) {\n        //IDR\n        case 5:\n          key = true;\n          break;\n        //SPS\n        case 7:\n          if(!track.sps) {\n            var expGolombDecoder = new ExpGolomb(unit.data);\n            var config = expGolombDecoder.readSPS();\n            track.width = config.width;\n            track.height = config.height;\n            track.profileIdc = config.profileIdc;\n            track.profileCompat = config.profileCompat;\n            track.levelIdc = config.levelIdc;\n            track.sps = [unit.data];\n            track.timescale = this.MP4_TIMESCALE;\n            track.duration = this.MP4_TIMESCALE*this._duration;\n            var codecarray = unit.data.subarray(1,4);\n            var codecstring  = 'avc1.';\n            for(var i = 0; i < 3; i++) {\n                var h = codecarray[i].toString(16);\n                if (h.length < 2) {\n                    h = '0' + h;\n                }\n                codecstring += h;\n            }\n            track.codec = codecstring;\n          }\n          break;\n        //PPS\n        case 8:\n          if(!track.pps) {\n            track.pps = [unit.data];\n          }\n          break;\n        default:\n          break;\n      }\n    });\n    //build sample from PES\n    // Annex B to MP4 conversion to be done\n    avcSample = { units : units, pts : pes.pts, dts : pes.dts , key : key};\n    this._avcSamples.push(avcSample);\n    this._avcSamplesLength += units.length;\n    this._avcSamplesNbNalu += units.units.length;\n  }\n\n\n  _flushAVCSamples() {\n    var view,i=8,avcSample,mp4Sample,mp4SampleLength,unit,track = this._avcTrack,\n        lastSampleDTS,mdat,moof,firstPTS,firstDTS,pts,dts,ptsnorm,dtsnorm,samples = [];\n\n    /* concatenate the video data and construct the mdat in place\n      (need 8 more bytes to fill length and mpdat type) */\n    mdat = new Uint8Array(this._avcSamplesLength + (4 * this._avcSamplesNbNalu)+8);\n    view = new DataView(mdat.buffer);\n    view.setUint32(0,mdat.byteLength);\n    mdat.set(MP4.types.mdat,4);\n    while(this._avcSamples.length) {\n      avcSample = this._avcSamples.shift();\n      mp4SampleLength = 0;\n\n      // convert NALU bitstream to MP4 format (prepend NALU with size field)\n      while(avcSample.units.units.length) {\n        unit = avcSample.units.units.shift();\n        view.setUint32(i, unit.data.byteLength);\n        i += 4;\n        mdat.set(unit.data, i);\n        i += unit.data.byteLength;\n        mp4SampleLength+=4+unit.data.byteLength;\n      }\n      pts = avcSample.pts - this._initDTS;\n      dts = avcSample.dts - this._initDTS;\n      //logger.log('Video/PTS/DTS:' + avcSample.pts + '/' + avcSample.dts);\n\n      if(lastSampleDTS !== undefined) {\n        ptsnorm = this._PTSNormalize(pts,lastSampleDTS);\n        dtsnorm = this._PTSNormalize(dts,lastSampleDTS);\n\n        mp4Sample.duration = (dtsnorm - lastSampleDTS)/this.PES2MP4SCALEFACTOR;\n        if(mp4Sample.duration < 0) {\n          //logger.log('invalid sample duration at PTS/DTS::' + avcSample.pts + '/' + avcSample.dts + ':' + mp4Sample.duration);\n          mp4Sample.duration = 0;\n        }\n      } else {\n        ptsnorm = this._PTSNormalize(pts,this.nextAvcPts);\n        dtsnorm = this._PTSNormalize(dts,this.nextAvcPts);\n        // check if fragments are contiguous (i.e. no missing frames between fragment)\n        if(this.nextAvcPts) {\n          var delta = Math.round((ptsnorm - this.nextAvcPts)/90),absdelta=Math.abs(delta);\n          //logger.log('absdelta/avcSample.pts:' + absdelta + '/' + avcSample.pts);\n          // if delta is less than 300 ms, next loaded fragment is assumed to be contiguous with last one\n          if(absdelta < 300) {\n            //logger.log('Video next PTS:' + this.nextAvcPts);\n            if(delta > 1) {\n              logger.log(`AVC:${delta} ms hole between fragments detected,filling it`);\n            } else if (delta < -1) {\n              logger.log(`AVC:${(-delta)} ms overlapping between fragments detected`);\n            }\n            // set PTS to next PTS\n            ptsnorm = this.nextAvcPts;\n            // offset DTS as well, ensure that DTS is smaller or equal than new PTS\n            dtsnorm = Math.max(dtsnorm-delta, this.lastAvcDts);\n           // logger.log('Video/PTS/DTS adjusted:' + avcSample.pts + '/' + avcSample.dts);\n          }\n          else {\n            // not contiguous timestamp, check if PTS is within acceptable range\n            var expectedPTS = this.PES_TIMESCALE*this.timeOffset;\n            // check if there is any unexpected drift between expected timestamp and real one\n            if(Math.abs(expectedPTS - ptsnorm) > this.PES_TIMESCALE*3600 ) {\n              //logger.log(`PTS looping ??? AVC PTS delta:${expectedPTS-ptsnorm}`);\n              var ptsOffset = expectedPTS-ptsnorm;\n              // set PTS to next expected PTS;\n              ptsnorm = expectedPTS;\n              dtsnorm = ptsnorm;\n              // offset initPTS/initDTS to fix computation for following samples\n              this._initPTS-=ptsOffset;\n              this._initDTS-=ptsOffset;\n            }\n          }\n        }\n        // remember first PTS of our avcSamples, ensure value is positive\n        firstPTS = Math.max(0,ptsnorm);\n        firstDTS = Math.max(0,dtsnorm);\n      }\n      //console.log(`PTS/DTS/initDTS/normPTS/normDTS/relative PTS : ${avcSample.pts}/${avcSample.dts}/${this._initDTS}/${ptsnorm}/${dtsnorm}/${(avcSample.pts/4294967296).toFixed(3)}`);\n\n      mp4Sample = {\n        size: mp4SampleLength,\n        duration : 0,\n        cts: (ptsnorm - dtsnorm)/this.PES2MP4SCALEFACTOR,\n        flags: {\n          isLeading: 0,\n          isDependedOn: 0,\n          hasRedundancy: 0,\n          degradPrio: 0\n        }\n      };\n\n      if(avcSample.key === true) {\n        // the current sample is a key frame\n        mp4Sample.flags.dependsOn = 2;\n        mp4Sample.flags.isNonSync = 0;\n      } else {\n        mp4Sample.flags.dependsOn = 1;\n        mp4Sample.flags.isNonSync = 1;\n      }\n      samples.push(mp4Sample);\n      lastSampleDTS = dtsnorm;\n    }\n    if(samples.length >=2) {\n      mp4Sample.duration = samples[samples.length-2].duration;\n    }\n    this.lastAvcDts = dtsnorm;\n    // next AVC sample PTS should be equal to last sample PTS + duration\n    this.nextAvcPts = ptsnorm + mp4Sample.duration*this.PES2MP4SCALEFACTOR;\n    //logger.log('Video/lastAvcDts/nextAvcPts:' + this.lastAvcDts + '/' + this.nextAvcPts);\n\n    this._avcSamplesLength = 0;\n    this._avcSamplesNbNalu = 0;\n\n    track.samples = samples;\n    moof = MP4.moof(track.sequenceNumber++,firstDTS/this.PES2MP4SCALEFACTOR,track);\n    track.samples = [];\n    observer.trigger(Event.FRAG_PARSING_DATA,{\n      moof: moof,\n      mdat: mdat,\n      startPTS : firstPTS/this.PES_TIMESCALE,\n      endPTS : this.nextAvcPts/this.PES_TIMESCALE,\n      startDTS : firstDTS/this.PES_TIMESCALE,\n      endDTS : (dtsnorm + this.PES2MP4SCALEFACTOR*mp4Sample.duration)/this.PES_TIMESCALE,\n      type : 'video',\n      nb : samples.length\n    });\n  }\n\n  _parseAVCNALu(array) {\n    var i = 0,len = array.byteLength,value,overflow,state = 0;\n    var units = [], unit, unitType, lastUnitStart,lastUnitType,length = 0;\n    //logger.log('PES:' + Hex.hexDump(array));\n\n    while(i< len) {\n      value = array[i++];\n      // finding 3 or 4-byte start codes (00 00 01 OR 00 00 00 01)\n      switch(state) {\n        case 0:\n          if(value === 0) {\n            state = 1;\n          }\n          break;\n        case 1:\n          if(value === 0) {\n            state = 2;\n          } else {\n            state = 0;\n          }\n          break;\n        case 2:\n        case 3:\n          if(value === 0) {\n            state = 3;\n          } else if(value === 1) {\n            unitType = array[i] & 0x1f;\n            //logger.log('find NALU @ offset:' + i + ',type:' + unitType);\n            if(lastUnitStart) {\n              unit = { data : array.subarray(lastUnitStart,i-state-1), type : lastUnitType};\n              length+=i-state-1-lastUnitStart;\n              //logger.log('pushing NALU, type/size:' + unit.type + '/' + unit.data.byteLength);\n              units.push(unit);\n            } else {\n              // If NAL units are not starting right at the beginning of the PES packet, push preceding data into previous NAL unit.\n              overflow  = i - state - 1;\n              if (overflow) {\n                  //logger.log('first NALU found with overflow:' + overflow);\n                  if(this._avcSamples.length) {\n                    var lastavcSample = this._avcSamples[this._avcSamples.length-1];\n                    var lastUnit = lastavcSample.units.units[lastavcSample.units.units.length-1];\n                    var tmp = new Uint8Array(lastUnit.data.byteLength+overflow);\n                    tmp.set(lastUnit.data,0);\n                    tmp.set(array.subarray(0,overflow),lastUnit.data.byteLength);\n                    lastUnit.data = tmp;\n                    lastavcSample.units.length+=overflow;\n                    this._avcSamplesLength+=overflow;\n                  }\n              }\n            }\n            lastUnitStart = i;\n            lastUnitType = unitType;\n            if(unitType === 1 || unitType === 5) {\n              // OPTI !!! if IDR/NDR unit, consider it is last NALu\n              i = len;\n            }\n            state = 0;\n          } else {\n            state = 0;\n          }\n          break;\n        default:\n          break;\n      }\n    }\n    if(lastUnitStart) {\n      unit = { data : array.subarray(lastUnitStart,len), type : lastUnitType};\n      length+=len-lastUnitStart;\n      units.push(unit);\n      //logger.log('pushing NALU, type/size:' + unit.type + '/' + unit.data.byteLength);\n    }\n    return { units : units , length : length};\n  }\n\n  _PTSNormalize(value,reference) {\n    var offset;\n    if (reference === undefined) {\n      return value;\n    }\n    if (reference < value) {\n        // - 2^33\n        offset = -8589934592;\n    } else {\n        // + 2^33\n        offset = 8589934592;\n    }\n    /* PTS is 33bit (from 0 to 2^33 -1)\n      if diff between value and reference is bigger than half of the amplitude (2^32) then it means that\n      PTS looping occured. fill the gap */\n    while (Math.abs(value - reference) > 4294967296) {\n        value += offset;\n    }\n    return value;\n  }\n\n  _parseAACPES(pes) {\n    var track = this._aacTrack,aacSample,data = pes.data,config,adtsFrameSize,adtsStartOffset,adtsHeaderLen,stamp,nbSamples,len;\n    if(this.aacOverFlow) {\n      var tmp = new Uint8Array(this.aacOverFlow.byteLength+data.byteLength);\n      tmp.set(this.aacOverFlow,0);\n      tmp.set(data,this.aacOverFlow.byteLength);\n      data = tmp;\n    }\n    // look for ADTS header (0xFFFx)\n    for(adtsStartOffset = 0, len = data.length; adtsStartOffset<len-1; adtsStartOffset++) {\n      if((data[adtsStartOffset] === 0xff) && (data[adtsStartOffset+1] & 0xf0) === 0xf0) {\n        break;\n      }\n    }\n    // if ADTS header does not start straight from the beginning of the PES payload, raise an error\n    if(adtsStartOffset) {\n      var reason,fatal;\n      if(adtsStartOffset < len - 1) {\n        reason = `AAC PES did not start with ADTS header,offset:${adtsStartOffset}`;\n        fatal = false;\n      } else {\n        reason = `no ADTS header found in AAC PES`;\n        fatal = true;\n      }\n      observer.trigger(Event.ERROR, { type : ErrorTypes.MEDIA_ERROR, details : ErrorDetails.FRAG_PARSING_ERROR, fatal:fatal, reason : reason});\n      if(fatal) {\n        return;\n      }\n    }\n\n    if(!track.audiosamplerate) {\n      config = this._ADTStoAudioConfig(data,adtsStartOffset,this.audioCodec);\n      track.config = config.config;\n      track.audiosamplerate = config.samplerate;\n      track.channelCount = config.channelCount;\n      track.codec = config.codec;\n      track.timescale = this.MP4_TIMESCALE;\n      track.duration = this.MP4_TIMESCALE*this._duration;\n      logger.log(`parsed   codec:${track.codec},rate:${config.samplerate},nb channel:${config.channelCount}`);\n    }\n    nbSamples = 0;\n    while((adtsStartOffset + 5) < len) {\n      // retrieve frame size\n      adtsFrameSize = ((data[adtsStartOffset+3] & 0x03) << 11);\n      // byte 4\n      adtsFrameSize |= (data[adtsStartOffset+4] << 3);\n      // byte 5\n      adtsFrameSize |= ((data[adtsStartOffset+5] & 0xE0) >>> 5);\n      adtsHeaderLen = (!!(data[adtsStartOffset+1] & 0x01) ? 7 : 9);\n      adtsFrameSize -= adtsHeaderLen;\n      stamp = Math.round(pes.pts + nbSamples*1024*this.PES_TIMESCALE/track.audiosamplerate);\n      //stamp = pes.pts;\n      //console.log('AAC frame, offset/length/pts:' + (adtsStartOffset+7) + '/' + adtsFrameSize + '/' + stamp.toFixed(0));\n      if(adtsStartOffset+adtsHeaderLen+adtsFrameSize <= len) {\n        aacSample = { unit : data.subarray(adtsStartOffset+adtsHeaderLen,adtsStartOffset+adtsHeaderLen+adtsFrameSize) , pts : stamp, dts : stamp};\n        this._aacSamples.push(aacSample);\n        this._aacSamplesLength += adtsFrameSize;\n        adtsStartOffset+=adtsFrameSize+adtsHeaderLen;\n        nbSamples++;\n      } else {\n        break;\n      }\n    }\n    if(adtsStartOffset < len) {\n      this.aacOverFlow = data.subarray(adtsStartOffset,len);\n    } else {\n      this.aacOverFlow = null;\n    }\n  }\n\n  _flushAACSamples() {\n    var view,i=8,aacSample,mp4Sample,unit,track = this._aacTrack,\n        lastSampleDTS,mdat,moof,firstPTS,firstDTS,pts,dts,ptsnorm,dtsnorm,samples = [];\n\n    /* concatenate the audio data and construct the mdat in place\n      (need 8 more bytes to fill length and mpdat type) */\n    mdat = new Uint8Array(this._aacSamplesLength+8);\n    view = new DataView(mdat.buffer);\n    view.setUint32(0,mdat.byteLength);\n    mdat.set(MP4.types.mdat,4);\n    while(this._aacSamples.length) {\n      aacSample = this._aacSamples.shift();\n      unit = aacSample.unit;\n      mdat.set(unit, i);\n      i += unit.byteLength;\n\n      pts = aacSample.pts - this._initDTS;\n      dts = aacSample.dts - this._initDTS;\n\n      //logger.log('Audio/PTS:' + aacSample.pts.toFixed(0));\n      if(lastSampleDTS !== undefined) {\n        ptsnorm = this._PTSNormalize(pts,lastSampleDTS);\n        dtsnorm = this._PTSNormalize(dts,lastSampleDTS);\n        // we use DTS to compute sample duration, but we use PTS to compute initPTS which is used to sync audio and video\n        mp4Sample.duration = (dtsnorm - lastSampleDTS)/this.PES2MP4SCALEFACTOR;\n        if(mp4Sample.duration < 0) {\n          //logger.log('invalid sample duration at PTS/DTS::' + avcSample.pts + '/' + avcSample.dts + ':' + mp4Sample.duration);\n          mp4Sample.duration = 0;\n        }\n      } else {\n        ptsnorm = this._PTSNormalize(pts,this.nextAacPts);\n        dtsnorm = this._PTSNormalize(dts,this.nextAacPts);\n        // check if fragments are contiguous (i.e. no missing frames between fragment)\n        if(this.nextAacPts && this.nextAacPts !== ptsnorm) {\n          //logger.log('Audio next PTS:' + this.nextAacPts);\n          var delta = Math.round(1000*(ptsnorm - this.nextAacPts)/this.PES_TIMESCALE),absdelta=Math.abs(delta);\n          // if delta is less than 300 ms, next loaded fragment is assumed to be contiguous with last one\n          if(absdelta > 1 && absdelta < 300) {\n            if(delta > 0) {\n              logger.log(`AAC:${delta} ms hole between fragments detected,filling it`);\n              // set PTS to next PTS, and ensure PTS is greater or equal than last DTS\n              ptsnorm = Math.max(this.nextAacPts, this.lastAacDts);\n              dtsnorm = ptsnorm;\n              //logger.log('Audio/PTS/DTS adjusted:' + aacSample.pts + '/' + aacSample.dts);\n            } else {\n              logger.log(`AAC:${(-delta)} ms overlapping between fragments detected`);\n            }\n          }\n          else if (absdelta) {\n            // not contiguous timestamp, check if PTS is within acceptable range\n            var expectedPTS = this.PES_TIMESCALE*this.timeOffset;\n            //logger.log(`expectedPTS/PTSnorm:${expectedPTS}/${ptsnorm}/${expectedPTS-ptsnorm}`);\n            // check if there is any unexpected drift between expected timestamp and real one\n            if(Math.abs(expectedPTS - ptsnorm) > this.PES_TIMESCALE*3600 ) {\n              //logger.log(`PTS looping ??? AAC PTS delta:${expectedPTS-ptsnorm}`);\n              var ptsOffset = expectedPTS-ptsnorm;\n              // set PTS to next expected PTS;\n              ptsnorm = expectedPTS;\n              dtsnorm = ptsnorm;\n              // offset initPTS/initDTS to fix computation for following samples\n              this._initPTS-=ptsOffset;\n              this._initDTS-=ptsOffset;\n            }\n          }\n        }\n        // remember first PTS of our aacSamples, ensure value is positive\n        firstPTS = Math.max(0,ptsnorm);\n        firstDTS = Math.max(0,dtsnorm);\n      }\n      //console.log(`PTS/DTS/initDTS/normPTS/normDTS/relative PTS : ${aacSample.pts}/${aacSample.dts}/${this._initDTS}/${ptsnorm}/${dtsnorm}/${(aacSample.pts/4294967296).toFixed(3)}`);\n      mp4Sample = {\n        size: unit.byteLength,\n        cts: 0,\n        duration:0,\n        flags: {\n          isLeading: 0,\n          isDependedOn: 0,\n          hasRedundancy: 0,\n          degradPrio: 0,\n          dependsOn : 1,\n        }\n      };\n      samples.push(mp4Sample);\n      lastSampleDTS = dtsnorm;\n    }\n    //set last sample duration as being identical to previous sample\n    if(samples.length >=2) {\n      mp4Sample.duration = samples[samples.length-2].duration;\n    }\n    this.lastAacDts = dtsnorm;\n    // next aac sample PTS should be equal to last sample PTS + duration\n    this.nextAacPts = ptsnorm + this.PES2MP4SCALEFACTOR*mp4Sample.duration;\n    //logger.log('Audio/PTS/PTSend:' + aacSample.pts.toFixed(0) + '/' + this.nextAacDts.toFixed(0));\n\n    this._aacSamplesLength = 0;\n    track.samples = samples;\n    moof = MP4.moof(track.sequenceNumber++,firstDTS/this.PES2MP4SCALEFACTOR,track);\n    track.samples = [];\n    observer.trigger(Event.FRAG_PARSING_DATA,{\n      moof: moof,\n      mdat: mdat,\n      startPTS : firstPTS/this.PES_TIMESCALE,\n      endPTS : this.nextAacPts/this.PES_TIMESCALE,\n      startDTS : firstDTS/this.PES_TIMESCALE,\n      endDTS : (dtsnorm + this.PES2MP4SCALEFACTOR*mp4Sample.duration)/this.PES_TIMESCALE,\n      type : 'audio',\n      nb : samples.length\n    });\n  }\n\n  _ADTStoAudioConfig(data,offset,audioCodec) {\n    var adtsObjectType, // :int\n        adtsSampleingIndex, // :int\n        adtsExtensionSampleingIndex, // :int\n        adtsChanelConfig, // :int\n        config,\n        userAgent = navigator.userAgent.toLowerCase(),\n        adtsSampleingRates = [\n            96000, 88200,\n            64000, 48000,\n            44100, 32000,\n            24000, 22050,\n            16000, 12000\n          ];\n\n    // byte 2\n    adtsObjectType = ((data[offset+2] & 0xC0) >>> 6) + 1;\n    adtsSampleingIndex = ((data[offset+2] & 0x3C) >>> 2);\n    adtsChanelConfig = ((data[offset+2] & 0x01) << 2);\n    // byte 3\n    adtsChanelConfig |= ((data[offset+3] & 0xC0) >>> 6);\n\n    logger.log(`manifest codec:${audioCodec},ADTS data:type:${adtsObjectType},sampleingIndex:${adtsSampleingIndex}[${adtsSampleingRates[adtsSampleingIndex]}kHz],channelConfig:${adtsChanelConfig}`);\n\n\n    // firefox: freq less than 24kHz = AAC SBR (HE-AAC)\n    if(userAgent.indexOf('firefox') !== -1) {\n      if(adtsSampleingIndex >=6) {\n        adtsObjectType = 5;\n        config = new Array(4);\n        // HE-AAC uses SBR (Spectral Band Replication) , high frequencies are constructed from low frequencies\n        // there is a factor 2 between frame sample rate and output sample rate\n        // multiply frequency by 2 (see table below, equivalent to substract 3)\n        adtsExtensionSampleingIndex = adtsSampleingIndex-3;\n      } else {\n        adtsObjectType = 2;\n        config = new Array(2);\n        adtsExtensionSampleingIndex = adtsSampleingIndex;\n      }\n      // Android : always use AAC\n    } else if(userAgent.indexOf('android') !== -1) {\n      adtsObjectType = 2;\n      config = new Array(2);\n      adtsExtensionSampleingIndex = adtsSampleingIndex;\n    } else {\n      /*  for other browsers (chrome ...)\n          always force audio type to be HE-AAC SBR, as some browsers do not support audio codec switch properly (like Chrome ...)\n      */\n        adtsObjectType = 5;\n        config = new Array(4);\n       // if (manifest codec is HE-AAC) OR (manifest codec not specified AND frequency less than 24kHz)\n      if((audioCodec && audioCodec.indexOf('mp4a.40.5') !==-1) || (!audioCodec && adtsSampleingIndex >=6))  {\n        // HE-AAC uses SBR (Spectral Band Replication) , high frequencies are constructed from low frequencies\n        // there is a factor 2 between frame sample rate and output sample rate\n        // multiply frequency by 2 (see table below, equivalent to substract 3)\n        adtsExtensionSampleingIndex = adtsSampleingIndex - 3;\n      } else {\n      // if (manifest codec is AAC) AND (frequency less than 24kHz OR nb channel is 1)\n        if(audioCodec && audioCodec.indexOf('mp4a.40.2') !==-1 && (adtsSampleingIndex >= 6 || adtsChanelConfig ===1)) {\n          adtsObjectType = 2;\n          config = new Array(2);\n        }\n        adtsExtensionSampleingIndex = adtsSampleingIndex;\n      }\n    }\n  /* refer to http://wiki.multimedia.cx/index.php?title=MPEG-4_Audio#Audio_Specific_Config\n      ISO 14496-3 (AAC).pdf - Table 1.13 — Syntax of AudioSpecificConfig()\n    Audio Profile / Audio Object Type\n    0: Null\n    1: AAC Main\n    2: AAC LC (Low Complexity)\n    3: AAC SSR (Scalable Sample Rate)\n    4: AAC LTP (Long Term Prediction)\n    5: SBR (Spectral Band Replication)\n    6: AAC Scalable\n   sampling freq\n    0: 96000 Hz\n    1: 88200 Hz\n    2: 64000 Hz\n    3: 48000 Hz\n    4: 44100 Hz\n    5: 32000 Hz\n    6: 24000 Hz\n    7: 22050 Hz\n    8: 16000 Hz\n    9: 12000 Hz\n    10: 11025 Hz\n    11: 8000 Hz\n    12: 7350 Hz\n    13: Reserved\n    14: Reserved\n    15: frequency is written explictly\n    Channel Configurations\n    These are the channel configurations:\n    0: Defined in AOT Specifc Config\n    1: 1 channel: front-center\n    2: 2 channels: front-left, front-right\n  */\n    // audioObjectType = profile => profile, the MPEG-4 Audio Object Type minus 1\n    config[0] = adtsObjectType << 3;\n    // samplingFrequencyIndex\n    config[0] |= (adtsSampleingIndex & 0x0E) >> 1;\n    config[1] |= (adtsSampleingIndex & 0x01) << 7;\n    // channelConfiguration\n    config[1] |= adtsChanelConfig << 3;\n    if(adtsObjectType === 5) {\n      // adtsExtensionSampleingIndex\n      config[1] |= (adtsExtensionSampleingIndex & 0x0E) >> 1;\n      config[2] = (adtsExtensionSampleingIndex & 0x01) << 7;\n      // adtsObjectType (force to 2, chrome is checking that object type is less than 5 ???\n      //    https://chromium.googlesource.com/chromium/src.git/+/master/media/formats/mp4/aac.cc\n      config[2] |= 2 << 2;\n      config[3] = 0;\n    }\n    return { config : config, samplerate : adtsSampleingRates[adtsSampleingIndex], channelCount : adtsChanelConfig, codec : ('mp4a.40.' + adtsObjectType)};\n  }\n\n  _generateInitSegment() {\n    if(this._avcId === -1) {\n      //audio only\n      if(this._aacTrack.config) {\n         observer.trigger(Event.FRAG_PARSING_INIT_SEGMENT,{\n          audioMoov: MP4.initSegment([this._aacTrack]),\n          audioCodec : this._aacTrack.codec,\n          audioChannelCount : this._aacTrack.channelCount\n        });\n        this._initSegGenerated = true;\n      }\n      if(this._initPTS === undefined) {\n        // remember first PTS of this demuxing context\n        this._initPTS = this._aacSamples[0].pts - this.PES_TIMESCALE*this.timeOffset;\n        this._initDTS = this._aacSamples[0].dts - this.PES_TIMESCALE*this.timeOffset;\n      }\n    } else\n    if(this._aacId === -1) {\n      //video only\n      if(this._avcTrack.sps && this._avcTrack.pps) {\n         observer.trigger(Event.FRAG_PARSING_INIT_SEGMENT,{\n          videoMoov: MP4.initSegment([this._avcTrack]),\n          videoCodec : this._avcTrack.codec,\n          videoWidth : this._avcTrack.width,\n          videoHeight : this._avcTrack.height\n        });\n        this._initSegGenerated = true;\n        if(this._initPTS === undefined) {\n          // remember first PTS of this demuxing context\n          this._initPTS = this._avcSamples[0].pts - this.PES_TIMESCALE*this.timeOffset;\n          this._initDTS = this._avcSamples[0].dts - this.PES_TIMESCALE*this.timeOffset;\n        }\n      }\n    } else {\n      //audio and video\n      if(this._aacTrack.config && this._avcTrack.sps && this._avcTrack.pps) {\n         observer.trigger(Event.FRAG_PARSING_INIT_SEGMENT,{\n          audioMoov: MP4.initSegment([this._aacTrack]),\n          audioCodec : this._aacTrack.codec,\n          audioChannelCount : this._aacTrack.channelCount,\n          videoMoov: MP4.initSegment([this._avcTrack]),\n          videoCodec : this._avcTrack.codec,\n          videoWidth : this._avcTrack.width,\n          videoHeight : this._avcTrack.height\n        });\n        this._initSegGenerated = true;\n        if(this._initPTS === undefined) {\n          // remember first PTS of this demuxing context\n          this._initPTS = Math.min(this._avcSamples[0].pts,this._aacSamples[0].pts) - this.PES_TIMESCALE*this.timeOffset;\n          this._initDTS = Math.min(this._avcSamples[0].dts,this._aacSamples[0].dts) - this.PES_TIMESCALE*this.timeOffset;\n        }\n      }\n    }\n  }\n}\n\nexport default TSDemuxer;\n"," import Event                from '../events';\n import TSDemuxer            from '../demux/tsdemuxer';\n import observer             from '../observer';\n\nvar TSDemuxerWorker = function (self) {\n    self.addEventListener('message',function (ev) {\n      //console.log('demuxer cmd:' + ev.data.cmd);\n      switch(ev.data.cmd) {\n        case 'init':\n          self.demuxer = new TSDemuxer();\n          break;\n        case 'demux':\n          self.demuxer.push(new Uint8Array(ev.data.data), ev.data.audioCodec,ev.data.videoCodec, ev.data.timeOffset, ev.data.cc, ev.data.level, ev.data.duration);\n          self.demuxer.end();\n          break;\n        default:\n          break;\n      }\n    });\n\n    // listen to events triggered by TS Demuxer\n    observer.on(Event.FRAG_PARSING_INIT_SEGMENT, function(ev,data) {\n      var objData = { event : ev };\n      var objTransferable = [];\n      if(data.audioCodec) {\n        objData.audioCodec = data.audioCodec;\n        objData.audioMoov = data.audioMoov.buffer;\n        objData.audioChannelCount = data.audioChannelCount;\n        objTransferable.push(objData.audioMoov);\n      }\n      if(data.videoCodec) {\n        objData.videoCodec = data.videoCodec;\n        objData.videoMoov = data.videoMoov.buffer;\n        objData.videoWidth = data.videoWidth;\n        objData.videoHeight = data.videoHeight;\n        objTransferable.push(objData.videoMoov);\n      }\n      // pass moov as transferable object (no copy)\n      self.postMessage(objData,objTransferable);\n    });\n    observer.on(Event.FRAG_PARSING_DATA, function(ev,data) {\n      var objData = { event : ev , type : data.type, startPTS : data.startPTS, endPTS : data.endPTS , startDTS : data.startDTS, endDTS : data.endDTS ,moof : data.moof.buffer, mdat : data.mdat.buffer, nb : data.nb};\n      // pass moof/mdat data as transferable object (no copy)\n      self.postMessage(objData,[objData.moof,objData.mdat]);\n    });\n    observer.on(Event.FRAG_PARSED, function(event) {\n      self.postMessage({event:event});\n    });\n    observer.on(Event.ERROR, function(event,data) {\n      self.postMessage({event:event,data:data});\n    });\n  };\n\nexport default TSDemuxerWorker;\n\n","\nexport var ErrorTypes = {\n  // Identifier for a network error (loading error / timeout ...)\n  NETWORK_ERROR :  'hlsNetworkError',\n  // Identifier for a media Error (video/parsing/mediasource error)\n  MEDIA_ERROR :  'hlsMediaError',\n  // Identifier for all other errors\n  OTHER_ERROR :  'hlsOtherError'\n};\n\nexport var ErrorDetails = {\n  // Identifier for a manifest load error - data: { url : faulty URL, response : XHR response}\n  MANIFEST_LOAD_ERROR :  'manifestLoadError',\n  // Identifier for a manifest load timeout - data: { url : faulty URL, response : XHR response}\n  MANIFEST_LOAD_TIMEOUT :  'manifestLoadTimeOut',\n  // Identifier for a manifest parsing error - data: { url : faulty URL, reason : error reason}\n  MANIFEST_PARSING_ERROR :  'manifestParsingError',\n  // Identifier for playlist load error - data: { url : faulty URL, response : XHR response}\n  LEVEL_LOAD_ERROR :  'levelLoadError',\n  // Identifier for playlist load timeout - data: { url : faulty URL, response : XHR response}\n  LEVEL_LOAD_TIMEOUT :  'levelLoadTimeOut',\n  // Identifier for a level switch error - data: { level : faulty level Id, event : error description}\n  LEVEL_SWITCH_ERROR :  'levelSwitchError',\n  // Identifier for fragment load error - data: { frag : fragment object, response : XHR response}\n  FRAG_LOAD_ERROR :  'fragLoadError',\n  // Identifier for fragment loop loading error - data: { frag : fragment object}\n  FRAG_LOOP_LOADING_ERROR :  'fragLoopLoadingError',\n  // Identifier for fragment load timeout error - data: { frag : fragment object}\n  FRAG_LOAD_TIMEOUT :  'fragLoadTimeOut',\n  // Identifier for a fragment parsing error event - data: parsing error description\n  FRAG_PARSING_ERROR :  'fragParsingError',\n    // Identifier for a fragment appending error event - data: appending error description\n  FRAG_APPENDING_ERROR :  'fragAppendingError'\n};\n","export default {\n  // fired when MediaSource has been succesfully attached to video element - data: { mediaSource }\n  MSE_ATTACHED : 'hlsMediaSourceAttached',\n  // fired when MediaSource has been detached from video element - data: { }\n  MSE_DETACHED : 'hlsMediaSourceDetached',\n  // fired to signal that a manifest loading starts - data: { url : manifestURL}\n  MANIFEST_LOADING  : 'hlsManifestLoading',\n  // fired after manifest has been loaded - data: { levels : [available quality levels] , url : manifestURL, stats : { trequest, tfirst, tload, mtime}}\n  MANIFEST_LOADED  : 'hlsManifestLoaded',\n  // fired after manifest has been parsed - data: { levels : [available quality levels] , firstLevel : index of first quality level appearing in Manifest}\n  MANIFEST_PARSED  : 'hlsManifestParsed',\n  // fired when a level playlist loading starts - data: { url : level URL  level : id of level being loaded}\n  LEVEL_LOADING    : 'hlsLevelLoading',\n  // fired when a level playlist loading finishes - data: { details : levelDetails object, level : id of loaded level, stats : { trequest, tfirst, tload, mtime} }\n  LEVEL_LOADED :  'hlsLevelLoaded',\n  // fired when a level switch is requested - data: { level : id of new level }\n  LEVEL_SWITCH :  'hlsLevelSwitch',\n  // fired when a fragment loading starts - data: { frag : fragment object}\n  FRAG_LOADING :  'hlsFragLoading',\n  // fired when a fragment loading is progressing - data: { frag : fragment object, { trequest, tfirst, loaded}}\n  FRAG_LOAD_PROGRESS :  'hlsFragLoadProgress',\n  // Identifier for fragment load aborting for emergency switch down - data: {frag : fragment object}\n  FRAG_LOAD_EMERGENCY_ABORTED :  'hlsFragLoadEmergencyAborted',\n  // fired when a fragment loading is completed - data: { frag : fragment object, payload : fragment payload, stats : { trequest, tfirst, tload, length}}\n  FRAG_LOADED :  'hlsFragLoaded',\n  // fired when Init Segment has been extracted from fragment - data: { moov : moov MP4 box, codecs : codecs found while parsing fragment}\n  FRAG_PARSING_INIT_SEGMENT :  'hlsFragParsingInitSegment',\n  // fired when moof/mdat have been extracted from fragment - data: { moof : moof MP4 box, mdat : mdat MP4 box}\n  FRAG_PARSING_DATA :  'hlsFragParsingData',\n  // fired when fragment parsing is completed - data: undefined\n  FRAG_PARSED :  'hlsFragParsed',\n  // fired when fragment remuxed MP4 boxes have all been appended into SourceBuffer - data: { frag : fragment object, stats : { trequest, tfirst, tload, tparsed, tbuffered, length} }\n  FRAG_BUFFERED :  'hlsFragBuffered',\n  // fired when fragment matching with current video position is changing - data : { frag : fragment object }\n  FRAG_CHANGED :  'hlsFragChanged',\n    // Identifier for a FPS drop event - data: {curentDropped, currentDecoded, totalDroppedFrames}\n  FPS_DROP :  'hlsFPSDrop',\n  // Identifier for an error event - data: { type : error type, details : error details, fatal : if true, hls.js cannot/will not try to recover, if false, hls.js will try to recover,other error specific data}\n  ERROR : 'hlsError'\n};\n","/**\n * HLS interface\n */\n'use strict';\n\nimport Event                      from './events';\nimport {ErrorTypes,ErrorDetails}  from './errors';\nimport StatsHandler               from './stats';\nimport observer                   from './observer';\nimport PlaylistLoader             from './loader/playlist-loader';\nimport FragmentLoader             from './loader/fragment-loader';\nimport BufferController           from './controller/buffer-controller';\nimport LevelController            from './controller/level-controller';\n//import FPSController              from './controller/fps-controller';\nimport {logger,enableLogs}        from './utils/logger';\nimport XhrLoader                  from './utils/xhr-loader';\n\nclass Hls {\n\n  static isSupported() {\n    return (window.MediaSource && MediaSource.isTypeSupported('video/mp4; codecs=\"avc1.42E01E,mp4a.40.2\"'));\n  }\n\n  static get Events() {\n    return Event;\n  }\n\n  static get ErrorTypes() {\n    return ErrorTypes;\n  }\n\n  static get ErrorDetails() {\n    return ErrorDetails;\n  }\n\n  constructor(config = {}) {\n   var configDefault = {\n      autoStartLoad : true,\n      debug : false,\n      maxBufferLength : 30,\n      maxBufferSize : 60*1000*1000,\n      maxMaxBufferLength : 600,\n      enableWorker : true,\n      fragLoadingTimeOut : 20000,\n      fragLoadingMaxRetry : 1,\n      fragLoadingRetryDelay : 1000,\n      fragLoadingLoopThreshold : 3,\n      manifestLoadingTimeOut : 10000,\n      manifestLoadingMaxRetry : 1,\n      manifestLoadingRetryDelay : 1000,\n      fpsDroppedMonitoringPeriod : 5000,\n      fpsDroppedMonitoringThreshold : 0.2,\n      appendErrorMaxRetry : 200,\n      loader : XhrLoader\n    };\n    for (var prop in configDefault) {\n        if (prop in config) { continue; }\n        config[prop] = configDefault[prop];\n    }\n    enableLogs(config.debug);\n    this.config = config;\n    this.playlistLoader = new PlaylistLoader(this);\n    this.fragmentLoader = new FragmentLoader(this);\n    this.levelController = new LevelController(this);\n    this.bufferController = new BufferController(this);\n    //this.fpsController = new FPSController(this);\n    this.statsHandler = new StatsHandler(this);\n    // observer setup\n    this.on = observer.on.bind(observer);\n    this.off = observer.off.bind(observer);\n  }\n\n  destroy() {\n    logger.log(`destroy`);\n    this.playlistLoader.destroy();\n    this.fragmentLoader.destroy();\n    this.levelController.destroy();\n    this.bufferController.destroy();\n    //this.fpsController.destroy();\n    this.statsHandler.destroy();\n    this.url = null;\n    this.detachVideo();\n    observer.removeAllListeners();\n  }\n\n  attachVideo(video) {\n    logger.log(`attachVideo`);\n    this.video = video;\n    this.statsHandler.attachVideo(video);\n    // setup the media source\n    var ms = this.mediaSource = new MediaSource();\n    //Media Source listeners\n    this.onmso = this.onMediaSourceOpen.bind(this);\n    this.onmse = this.onMediaSourceEnded.bind(this);\n    this.onmsc = this.onMediaSourceClose.bind(this);\n    ms.addEventListener('sourceopen',  this.onmso);\n    ms.addEventListener('sourceended', this.onmse);\n    ms.addEventListener('sourceclose', this.onmsc);\n    // link video and media Source\n    video.src = URL.createObjectURL(ms);\n    video.addEventListener('error',this.onverror);\n  }\n\n  detachVideo() {\n    logger.log(`detachVideo`);\n    var video = this.video;\n    this.statsHandler.detachVideo(video);\n    var ms = this.mediaSource;\n    if(ms) {\n      if(ms.readyState !== 'ended') {\n        ms.endOfStream();\n      }\n      ms.removeEventListener('sourceopen',  this.onmso);\n      ms.removeEventListener('sourceended', this.onmse);\n      ms.removeEventListener('sourceclose', this.onmsc);\n      // unlink MediaSource from video tag\n      video.src = '';\n      this.mediaSource = null;\n      logger.log(`trigger MSE_DETACHED`);\n      observer.trigger(Event.MSE_DETACHED);\n    }\n    this.onmso = this.onmse = this.onmsc = null;\n    if(video) {\n      this.video = null;\n    }\n  }\n\n  loadSource(url) {\n    logger.log(`loadSource:${url}`);\n    this.url = url;\n    // when attaching to a source URL, trigger a playlist load\n    observer.trigger(Event.MANIFEST_LOADING, { url: url });\n  }\n\n  startLoad() {\n    logger.log(`startLoad`);\n    this.bufferController.startLoad();\n  }\n\n  recoverMediaError() {\n    logger.log('recoverMediaError');\n    var video = this.video;\n    this.detachVideo();\n    this.attachVideo(video);\n  }\n\n  /** Return all quality levels **/\n  get levels() {\n    return this.levelController.levels;\n  }\n\n  /** Return current playback quality level **/\n  get currentLevel() {\n    return this.bufferController.currentLevel;\n  }\n\n  /* set quality level immediately (-1 for automatic level selection) */\n  set currentLevel(newLevel) {\n    logger.log(`set currentLevel:${newLevel}`);\n    this.loadLevel = newLevel;\n    this.bufferController.immediateLevelSwitch();\n  }\n\n  /** Return next playback quality level (quality level of next fragment) **/\n  get nextLevel() {\n    return this.bufferController.nextLevel;\n  }\n\n  /* set quality level for next fragment (-1 for automatic level selection) */\n  set nextLevel(newLevel) {\n    logger.log(`set nextLevel:${newLevel}`);\n    this.levelController.manualLevel = newLevel;\n    this.bufferController.nextLevelSwitch();\n  }\n\n  /** Return the quality level of current/last loaded fragment **/\n  get loadLevel() {\n    return this.levelController.level;\n  }\n\n  /* set quality level for current/next loaded fragment (-1 for automatic level selection) */\n  set loadLevel(newLevel) {\n    logger.log(`set loadLevel:${newLevel}`);\n    this.levelController.manualLevel = newLevel;\n  }\n\n  /** Return the quality level of next loaded fragment **/\n  get nextLoadLevel() {\n    return this.levelController.nextLoadLevel();\n  }\n\n  /** set quality level of next loaded fragment **/\n  set nextLoadLevel(level) {\n    this.levelController.level = level;\n  }\n\n  /** Return first level (index of first level referenced in manifest)\n  **/\n  get firstLevel() {\n    return this.levelController.firstLevel;\n  }\n\n  /** set first level (index of first level referenced in manifest)\n  **/\n  set firstLevel(newLevel) {\n    logger.log(`set firstLevel:${newLevel}`);\n    this.levelController.firstLevel = newLevel;\n  }\n\n  /** Return start level (level of first fragment that will be played back)\n      if not overrided by user, first level appearing in manifest will be used as start level\n      if -1 : automatic start level selection, playback will start from level matching download bandwidth (determined from download of first segment)\n  **/\n  get startLevel() {\n    return this.levelController.startLevel;\n  }\n\n  /** set  start level (level of first fragment that will be played back)\n      if not overrided by user, first level appearing in manifest will be used as start level\n      if -1 : automatic start level selection, playback will start from level matching download bandwidth (determined from download of first segment)\n  **/\n  set startLevel(newLevel) {\n    logger.log(`set startLevel:${newLevel}`);\n    this.levelController.startLevel = newLevel;\n  }\n\n  /** Return the capping/max level value that could be used by automatic level selection algorithm **/\n  get autoLevelCapping() {\n    return this.levelController.autoLevelCapping;\n  }\n\n  /** set the capping/max level value that could be used by automatic level selection algorithm **/\n  set autoLevelCapping(newLevel) {\n    logger.log(`set autoLevelCapping:${newLevel}`);\n    this.levelController.autoLevelCapping = newLevel;\n  }\n\n  /* check if we are in automatic level selection mode */\n  get autoLevelEnabled() {\n    return (this.levelController.manualLevel  === -1);\n  }\n\n  /* return manual level */\n  get manualLevel() {\n    return this.levelController.manualLevel;\n  }\n\n\n  /* return playback session stats */\n  get stats() {\n    return this.statsHandler.stats;\n  }\n\n  onMediaSourceOpen() {\n    logger.log('media source opened');\n    observer.trigger(Event.MSE_ATTACHED, { video: this.video, mediaSource : this.mediaSource });\n    // once received, don't listen anymore to sourceopen event\n    this.mediaSource.removeEventListener('sourceopen',  this.onmso);\n  }\n\n  onMediaSourceClose() {\n    logger.log('media source closed');\n  }\n\n  onMediaSourceEnded() {\n    logger.log('media source ended');\n  }\n}\n\nexport default Hls;\n"," /*\n * fragment loader\n *\n */\n\nimport Event                from '../events';\nimport observer             from '../observer';\nimport {ErrorTypes,ErrorDetails} from '../errors';\n\n class FragmentLoader {\n\n  constructor(hls) {\n    this.hls=hls;\n    this.onfl = this.onFragLoading.bind(this);\n    observer.on(Event.FRAG_LOADING, this.onfl);\n  }\n\n  destroy() {\n    if(this.loader) {\n      this.loader.destroy();\n      this.loader = null;\n    }\n    observer.off(Event.FRAG_LOADING, this.onfl);\n  }\n\n  onFragLoading(event,data) {\n    var frag = data.frag;\n    this.frag = frag;\n    this.frag.loaded = 0;\n    var config = this.hls.config;\n    frag.loader = this.loader = new config.loader();\n    this.loader.load(frag.url,'arraybuffer',this.loadsuccess.bind(this), this.loaderror.bind(this), this.loadtimeout.bind(this), config.fragLoadingTimeOut, config.fragLoadingMaxRetry,config.fragLoadingRetryDelay,this.loadprogress.bind(this));\n  }\n\n  loadsuccess(event, stats) {\n    var payload = event.currentTarget.response;\n    stats.length = payload.byteLength;\n    // detach fragment loader on load success\n    this.frag.loader = undefined;\n    observer.trigger(Event.FRAG_LOADED,\n                    { payload : payload,\n                      frag : this.frag ,\n                      stats : stats});\n  }\n\n  loaderror(event) {\n    this.loader.abort();\n    observer.trigger(Event.ERROR, { type : ErrorTypes.NETWORK_ERROR, details : ErrorDetails.FRAG_LOAD_ERROR, fatal:false,frag : this.frag, response:event});\n  }\n\n  loadtimeout() {\n    this.loader.abort();\n    observer.trigger(Event.ERROR, { type : ErrorTypes.NETWORK_ERROR, details : ErrorDetails.FRAG_LOAD_TIMEOUT, fatal:false,frag : this.frag});\n  }\n\n  loadprogress(event, stats) {\n    this.frag.loaded = stats.loaded;\n   observer.trigger(Event.FRAG_LOAD_PROGRESS, { frag : this.frag, stats : stats});\n  }\n}\n\nexport default FragmentLoader;\n","/*\n * playlist loader\n *\n */\n\nimport Event                from '../events';\nimport observer             from '../observer';\nimport {ErrorTypes,ErrorDetails} from '../errors';\n//import {logger}             from '../utils/logger';\n\n class PlaylistLoader {\n\n  constructor(hls) {\n    this.hls = hls;\n    this.onml = this.onManifestLoading.bind(this);\n    this.onll = this.onLevelLoading.bind(this);\n    observer.on(Event.MANIFEST_LOADING, this.onml);\n    observer.on(Event.LEVEL_LOADING, this.onll);\n  }\n\n  destroy() {\n    if(this.loader) {\n      this.loader.destroy();\n      this.loader = null;\n    }\n    this.url = this.id = null;\n    observer.off(Event.MANIFEST_LOADING, this.onml);\n    observer.off(Event.LEVEL_LOADING, this.onll);\n  }\n\n  onManifestLoading(event,data) {\n    this.load(data.url,null);\n  }\n\n  onLevelLoading(event,data) {\n    this.load(data.url,data.level,data.id);\n  }\n\n  load(url,id1,id2) {\n    var config=this.hls.config;\n    this.url = url;\n    this.id = id1;\n    this.id2 = id2;\n    this.loader = new config.loader();\n    this.loader.load(url,'',this.loadsuccess.bind(this), this.loaderror.bind(this), this.loadtimeout.bind(this), config.manifestLoadingTimeOut, config.manifestLoadingMaxRetry,config.manifestLoadingRetryDelay);\n  }\n\n  resolve(url, baseUrl) {\n    var doc      = document,\n        oldBase = doc.getElementsByTagName('base')[0],\n        oldHref = oldBase && oldBase.href,\n        docHead = doc.head || doc.getElementsByTagName('head')[0],\n        ourBase = oldBase || docHead.appendChild(doc.createElement('base')),\n        resolver = doc.createElement('a'),\n        resolvedUrl;\n\n    ourBase.href = baseUrl;\n    resolver.href = url;\n    resolvedUrl  = resolver.href; // browser magic at work here\n\n    if (oldBase) {oldBase.href = oldHref;}\n    else {docHead.removeChild(ourBase);}\n    return resolvedUrl;\n  }\n\n  parseMasterPlaylist(string,baseurl) {\n    var levels = [],level =  {},result,codecs,codec;\n    var re = /#EXT-X-STREAM-INF:([^\\n\\r]*(BAND)WIDTH=(\\d+))?([^\\n\\r]*(CODECS)=\\\"(.*)\\\",)?([^\\n\\r]*(RES)OLUTION=(\\d+)x(\\d+))?([^\\n\\r]*(NAME)=\\\"(.*)\\\")?[^\\n\\r]*[\\r\\n]+([^\\r\\n]+)/g;\n    while((result = re.exec(string)) != null){\n      result.shift();\n      result = result.filter(function(n){ return (n !== undefined);});\n      level.url = this.resolve(result.pop(),baseurl);\n      while(result.length > 0) {\n        switch(result.shift()) {\n          case 'RES':\n            level.width = parseInt(result.shift());\n            level.height = parseInt(result.shift());\n            break;\n          case 'BAND':\n            level.bitrate = parseInt(result.shift());\n            break;\n          case 'NAME':\n            level.name = result.shift();\n            break;\n          case 'CODECS':\n            codecs = result.shift().split(',');\n            while(codecs.length > 0) {\n              codec = codecs.shift();\n              if(codec.indexOf('avc1') !== -1) {\n                level.videoCodec = this.avc1toavcoti(codec);\n              } else {\n                level.audioCodec = codec;\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n      levels.push(level);\n      level = {};\n    }\n    return levels;\n  }\n\n  avc1toavcoti(codec) {\n    var result,avcdata = codec.split('.');\n    if(avcdata.length > 2) {\n      result = avcdata.shift() + '.';\n      result += parseInt(avcdata.shift()).toString(16);\n      result += ('00' + parseInt(avcdata.shift()).toString(16)).substr(-4);\n    } else {\n      result = codec;\n    }\n    return result;\n  }\n\n  parseLevelPlaylist(string, baseurl, id) {\n    var currentSN = 0,totalduration = 0, level = { url : baseurl, fragments : [], live : true, startSN : 0}, result, regexp, cc = 0;\n    regexp = /(?:#EXT-X-(MEDIA-SEQUENCE):(\\d+))|(?:#EXT-X-(TARGETDURATION):(\\d+))|(?:#EXT(INF):([\\d\\.]+)[^\\r\\n]*[\\r\\n]+([^\\r\\n]+)|(?:#EXT-X-(ENDLIST))|(?:#EXT-X-(DIS)CONTINUITY))/g;\n    while((result = regexp.exec(string)) !== null){\n      result.shift();\n      result = result.filter(function(n){ return (n !== undefined);});\n      switch(result[0]) {\n        case 'MEDIA-SEQUENCE':\n          currentSN = level.startSN = parseInt(result[1]);\n          break;\n        case 'TARGETDURATION':\n          level.targetduration = parseFloat(result[1]);\n          break;\n        case 'ENDLIST':\n          level.live = false;\n          break;\n        case 'DIS':\n          cc++;\n          break;\n        case 'INF':\n          var duration = parseFloat(result[1]);\n          level.fragments.push({url : this.resolve(result[2],baseurl), duration : duration, start : totalduration, sn : currentSN++, level:id, cc : cc});\n          totalduration+=duration;\n          break;\n        default:\n          break;\n      }\n    }\n    //logger.log('found ' + level.fragments.length + ' fragments');\n    level.totalduration = totalduration;\n    level.endSN = currentSN - 1;\n    return level;\n  }\n\n  loadsuccess(event, stats) {\n    var string = event.currentTarget.responseText, url = event.currentTarget.responseURL, id = this.id,id2= this.id2, levels;\n    // responseURL not supported on some browsers (it is used to detect URL redirection)\n    if(url === undefined) {\n      // fallback to initial URL\n      url = this.url;\n    }\n    stats.tload = new Date();\n    stats.mtime = new Date(event.currentTarget.getResponseHeader('Last-Modified'));\n\n    if(string.indexOf('#EXTM3U') === 0) {\n      if (string.indexOf('#EXTINF:') > 0) {\n        // 1 level playlist\n        // if first request, fire manifest loaded event, level will be reloaded afterwards\n        // (this is to have a uniform logic for 1 level/multilevel playlists)\n        if(this.id === null) {\n          observer.trigger(Event.MANIFEST_LOADED,\n                          { levels : [{url : url}],\n                            url : url,\n                            stats : stats});\n        } else {\n          observer.trigger(Event.LEVEL_LOADED,\n                          { details : this.parseLevelPlaylist(string,url,id),\n                            level : id,\n                            id : id2,\n                            stats : stats});\n        }\n      } else {\n        levels = this.parseMasterPlaylist(string,url);\n        // multi level playlist, parse level info\n        if(levels.length) {\n          observer.trigger(Event.MANIFEST_LOADED,\n                          { levels : levels,\n                            url : url,\n                            stats : stats});\n        } else {\n          observer.trigger(Event.ERROR, { type : ErrorTypes.NETWORK_ERROR, details : ErrorDetails.MANIFEST_PARSING_ERROR, fatal:true, url : url, reason : 'no level found in manifest'});\n        }\n      }\n    } else {\n      observer.trigger(Event.ERROR, { type : ErrorTypes.NETWORK_ERROR, details : ErrorDetails.MANIFEST_PARSING_ERROR, fatal:true, url : url, reason : 'no EXTM3U delimiter'});\n    }\n  }\n\n  loaderror(event) {\n    var details,fatal;\n    if(this.id === null) {\n      details = ErrorDetails.MANIFEST_LOAD_ERROR;\n      fatal = true;\n    } else {\n      details = ErrorDetails.LEVEL_LOAD_ERROR;\n      fatal = false;\n    }\n    this.loader.abort();\n    observer.trigger(Event.ERROR, {type : ErrorTypes.NETWORK_ERROR, details:details, fatal:fatal, url:this.url, loader : this.loader, response:event.currentTarget, level: this.id, id : this.id2});\n  }\n\n  loadtimeout() {\n    var details,fatal;\n    if(this.id === null) {\n      details = ErrorDetails.MANIFEST_LOAD_TIMEOUT;\n      fatal = true;\n    } else {\n      details = ErrorDetails.LEVEL_LOAD_TIMEOUT;\n      fatal = false;\n    }\n   this.loader.abort();\n   observer.trigger(Event.ERROR, { type : ErrorTypes.NETWORK_ERROR, details:details, fatal:fatal, url : this.url, loader: this.loader, level: this.id, id : this.id2});\n  }\n}\n\nexport default PlaylistLoader;\n","import EventEmitter from 'events';\n\nlet observer = new EventEmitter();\n\nobserver.trigger = function trigger (event, ...data) {\n  observer.emit(event, event, ...data);\n};\n\nobserver.off = function off (event, ...data) {\n  observer.removeListener(event, ...data);\n};\n\n\nexport default observer;\n","/**\n * generate MP4 Box\n */\n\nclass MP4 {\n  static init() {\n    MP4.types = {\n      avc1: [], // codingname\n      avcC: [],\n      btrt: [],\n      dinf: [],\n      dref: [],\n      esds: [],\n      ftyp: [],\n      hdlr: [],\n      mdat: [],\n      mdhd: [],\n      mdia: [],\n      mfhd: [],\n      minf: [],\n      moof: [],\n      moov: [],\n      mp4a: [],\n      mvex: [],\n      mvhd: [],\n      sdtp: [],\n      stbl: [],\n      stco: [],\n      stsc: [],\n      stsd: [],\n      stsz: [],\n      stts: [],\n      tfdt: [],\n      tfhd: [],\n      traf: [],\n      trak: [],\n      trun: [],\n      trex: [],\n      tkhd: [],\n      vmhd: [],\n      smhd: []\n    };\n\n    var i;\n    for (i in MP4.types) {\n      if (MP4.types.hasOwnProperty(i)) {\n        MP4.types[i] = [\n          i.charCodeAt(0),\n          i.charCodeAt(1),\n          i.charCodeAt(2),\n          i.charCodeAt(3)\n        ];\n      }\n    }\n\n    MP4.MAJOR_BRAND = new Uint8Array([\n      'i'.charCodeAt(0),\n      's'.charCodeAt(0),\n      'o'.charCodeAt(0),\n      'm'.charCodeAt(0)\n    ]);\n    MP4.AVC1_BRAND = new Uint8Array([\n      'a'.charCodeAt(0),\n      'v'.charCodeAt(0),\n      'c'.charCodeAt(0),\n      '1'.charCodeAt(0)\n    ]);\n    MP4.MINOR_VERSION = new Uint8Array([0, 0, 0, 1]);\n    MP4.VIDEO_HDLR = new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x00, // pre_defined\n      0x76, 0x69, 0x64, 0x65, // handler_type: 'vide'\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x56, 0x69, 0x64, 0x65,\n      0x6f, 0x48, 0x61, 0x6e,\n      0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'VideoHandler'\n    ]);\n    MP4.AUDIO_HDLR = new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x00, // pre_defined\n      0x73, 0x6f, 0x75, 0x6e, // handler_type: 'soun'\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x53, 0x6f, 0x75, 0x6e,\n      0x64, 0x48, 0x61, 0x6e,\n      0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'SoundHandler'\n    ]);\n    MP4.HDLR_TYPES = {\n      'video':MP4.VIDEO_HDLR,\n      'audio':MP4.AUDIO_HDLR\n    };\n    MP4.DREF = new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x01, // entry_count\n      0x00, 0x00, 0x00, 0x0c, // entry_size\n      0x75, 0x72, 0x6c, 0x20, // 'url' type\n      0x00, // version 0\n      0x00, 0x00, 0x01 // entry_flags\n    ]);\n    MP4.STCO = new Uint8Array([\n      0x00, // version\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x00 // entry_count\n    ]);\n    MP4.STSC = MP4.STCO;\n    MP4.STTS = MP4.STCO;\n    MP4.STSZ = new Uint8Array([\n      0x00, // version\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x00, // sample_size\n      0x00, 0x00, 0x00, 0x00, // sample_count\n    ]);\n    MP4.VMHD = new Uint8Array([\n      0x00, // version\n      0x00, 0x00, 0x01, // flags\n      0x00, 0x00, // graphicsmode\n      0x00, 0x00,\n      0x00, 0x00,\n      0x00, 0x00 // opcolor\n    ]);\n    MP4.SMHD = new Uint8Array([\n      0x00, // version\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, // balance\n      0x00, 0x00 // reserved\n    ]);\n\n    MP4.STSD = new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x01]);// entry_count\n\n    MP4.FTYP = MP4.box(MP4.types.ftyp, MP4.MAJOR_BRAND, MP4.MINOR_VERSION, MP4.MAJOR_BRAND, MP4.AVC1_BRAND);\n    MP4.DINF = MP4.box(MP4.types.dinf, MP4.box(MP4.types.dref, MP4.DREF));\n  }\n\n  static box(type) {\n  var\n    payload = Array.prototype.slice.call(arguments, 1),\n    size = 0,\n    i = payload.length,\n    result,\n    view;\n\n    // calculate the total size we need to allocate\n    while (i--) {\n      size += payload[i].byteLength;\n    }\n    result = new Uint8Array(size + 8);\n    view = new DataView(result.buffer);\n    view.setUint32(0, result.byteLength);\n    result.set(type, 4);\n\n    // copy the payload into the result\n    for (i = 0, size = 8; i < payload.length; i++) {\n      result.set(payload[i], size);\n      size += payload[i].byteLength;\n    }\n    return result;\n  }\n\n  static hdlr(type) {\n    return MP4.box(MP4.types.hdlr, MP4.HDLR_TYPES[type]);\n  }\n\n  static mdat(data) {\n    return MP4.box(MP4.types.mdat, data);\n  }\n\n  static mdhd(timescale,duration) {\n    return MP4.box(MP4.types.mdhd, new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n      0x00, 0x00, 0x00, 0x02, // creation_time\n      0x00, 0x00, 0x00, 0x03, // modification_time\n      (timescale >> 24) & 0xFF,\n      (timescale >> 16) & 0xFF,\n      (timescale >>  8) & 0xFF,\n      timescale & 0xFF, // timescale\n      (duration >> 24),\n      (duration >> 16) & 0xFF,\n      (duration >>  8) & 0xFF,\n      duration & 0xFF, // duration\n      0x55, 0xc4, // 'und' language (undetermined)\n      0x00, 0x00\n    ]));\n  }\n\n  static mdia(track) {\n    return MP4.box(MP4.types.mdia, MP4.mdhd(track.timescale,track.duration), MP4.hdlr(track.type), MP4.minf(track));\n  }\n\n  static mfhd(sequenceNumber) {\n    return MP4.box(MP4.types.mfhd, new Uint8Array([\n      0x00,\n      0x00, 0x00, 0x00, // flags\n      (sequenceNumber >> 24),\n      (sequenceNumber >> 16) & 0xFF,\n      (sequenceNumber >>  8) & 0xFF,\n      sequenceNumber & 0xFF, // sequence_number\n    ]));\n  }\n\n  static minf(track) {\n    if (track.type === 'audio') {\n      return MP4.box(MP4.types.minf, MP4.box(MP4.types.smhd, MP4.SMHD), MP4.DINF, MP4.stbl(track));\n    } else {\n      return MP4.box(MP4.types.minf, MP4.box(MP4.types.vmhd, MP4.VMHD), MP4.DINF, MP4.stbl(track));\n    }\n  }\n\n  static moof(sn, baseMediaDecodeTime, track) {\n    return MP4.box(MP4.types.moof,\n                   MP4.mfhd(sn),\n                   MP4.traf(track,baseMediaDecodeTime));\n  }\n/**\n * @param tracks... (optional) {array} the tracks associated with this movie\n */\n  static moov(tracks) {\n    var\n      i = tracks.length,\n      boxes = [];\n\n    while (i--) {\n      boxes[i] = MP4.trak(tracks[i]);\n    }\n\n    return MP4.box.apply(null, [MP4.types.moov, MP4.mvhd(tracks[0].timescale,tracks[0].duration)].concat(boxes).concat(MP4.mvex(tracks)));\n  }\n\n  static mvex(tracks) {\n    var\n      i = tracks.length,\n      boxes = [];\n\n    while (i--) {\n      boxes[i] = MP4.trex(tracks[i]);\n    }\n    return MP4.box.apply(null, [MP4.types.mvex].concat(boxes));\n  }\n\n  static mvhd(timescale,duration) {\n    var\n      bytes = new Uint8Array([\n        0x00, // version 0\n        0x00, 0x00, 0x00, // flags\n        0x00, 0x00, 0x00, 0x01, // creation_time\n        0x00, 0x00, 0x00, 0x02, // modification_time\n        (timescale >> 24) & 0xFF,\n        (timescale >> 16) & 0xFF,\n        (timescale >>  8) & 0xFF,\n        timescale & 0xFF, // timescale\n        (duration >> 24) & 0xFF,\n        (duration >> 16) & 0xFF,\n        (duration >>  8) & 0xFF,\n        duration & 0xFF, // duration\n        0x00, 0x01, 0x00, 0x00, // 1.0 rate\n        0x01, 0x00, // 1.0 volume\n        0x00, 0x00, // reserved\n        0x00, 0x00, 0x00, 0x00, // reserved\n        0x00, 0x00, 0x00, 0x00, // reserved\n        0x00, 0x01, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x01, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00, // pre_defined\n        0xff, 0xff, 0xff, 0xff // next_track_ID\n      ]);\n    return MP4.box(MP4.types.mvhd, bytes);\n  }\n\n  static sdtp(track) {\n    var\n      samples = track.samples || [],\n      bytes = new Uint8Array(4 + samples.length),\n      flags,\n      i;\n\n    // leave the full box header (4 bytes) all zero\n\n    // write the sample table\n    for (i = 0; i < samples.length; i++) {\n      flags = samples[i].flags;\n      bytes[i + 4] = (flags.dependsOn << 4) |\n        (flags.isDependedOn << 2) |\n        (flags.hasRedundancy);\n    }\n\n    return MP4.box(MP4.types.sdtp,\n               bytes);\n  }\n\n  static stbl(track) {\n    return MP4.box(MP4.types.stbl,\n               MP4.stsd(track),\n               MP4.box(MP4.types.stts, MP4.STTS),\n               MP4.box(MP4.types.stsc, MP4.STSC),\n               MP4.box(MP4.types.stsz, MP4.STSZ),\n               MP4.box(MP4.types.stco, MP4.STCO));\n  }\n\n  static avc1(track) {\n    var sps = [], pps = [], i;\n    // assemble the SPSs\n    for (i = 0; i < track.sps.length; i++) {\n      sps.push((track.sps[i].byteLength >>> 8) & 0xFF);\n      sps.push((track.sps[i].byteLength & 0xFF)); // sequenceParameterSetLength\n      sps = sps.concat(Array.prototype.slice.call(track.sps[i])); // SPS\n    }\n\n    // assemble the PPSs\n    for (i = 0; i < track.pps.length; i++) {\n      pps.push((track.pps[i].byteLength >>> 8) & 0xFF);\n      pps.push((track.pps[i].byteLength & 0xFF));\n      pps = pps.concat(Array.prototype.slice.call(track.pps[i]));\n    }\n\n    return MP4.box(MP4.types.avc1, new Uint8Array([\n        0x00, 0x00, 0x00, // reserved\n        0x00, 0x00, 0x00, // reserved\n        0x00, 0x01, // data_reference_index\n        0x00, 0x00, // pre_defined\n        0x00, 0x00, // reserved\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00, // pre_defined\n        (track.width >> 8) & 0xFF,\n        track.width & 0xff, // width\n        (track.height >> 8) & 0xFF,\n        track.height & 0xff, // height\n        0x00, 0x48, 0x00, 0x00, // horizresolution\n        0x00, 0x48, 0x00, 0x00, // vertresolution\n        0x00, 0x00, 0x00, 0x00, // reserved\n        0x00, 0x01, // frame_count\n        0x13,\n        0x76, 0x69, 0x64, 0x65,\n        0x6f, 0x6a, 0x73, 0x2d,\n        0x63, 0x6f, 0x6e, 0x74,\n        0x72, 0x69, 0x62, 0x2d,\n        0x68, 0x6c, 0x73, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, // compressorname\n        0x00, 0x18, // depth = 24\n        0x11, 0x11]), // pre_defined = -1\n          MP4.box(MP4.types.avcC, new Uint8Array([\n            0x01, // configurationVersion\n            track.profileIdc, // AVCProfileIndication\n            track.profileCompat, // profile_compatibility\n            track.levelIdc, // AVCLevelIndication\n            0xff // lengthSizeMinusOne, hard-coded to 4 bytes\n          ].concat([\n            track.sps.length // numOfSequenceParameterSets\n          ]).concat(sps).concat([\n            track.pps.length // numOfPictureParameterSets\n          ]).concat(pps))), // \"PPS\"\n          MP4.box(MP4.types.btrt, new Uint8Array([\n            0x00, 0x1c, 0x9c, 0x80, // bufferSizeDB\n            0x00, 0x2d, 0xc6, 0xc0, // maxBitrate\n            0x00, 0x2d, 0xc6, 0xc0])) // avgBitrate\n          );\n  }\n\n  static esds(track) {\n    return new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n\n      0x03, // descriptor_type\n      0x17+track.config.length, // length\n      0x00, 0x01, //es_id\n      0x00, // stream_priority\n\n      0x04, // descriptor_type\n      0x0f+track.config.length, // length\n      0x40, //codec : mpeg4_audio\n      0x15, // stream_type\n      0x00, 0x00, 0x00, // buffer_size\n      0x00, 0x00, 0x00, 0x00, // maxBitrate\n      0x00, 0x00, 0x00, 0x00, // avgBitrate\n\n      0x05 // descriptor_type\n      ].concat([track.config.length]).concat(track.config).concat([0x06, 0x01, 0x02])); // GASpecificConfig)); // length + audio config descriptor\n  }\n\n  static mp4a(track) {\n        return MP4.box(MP4.types.mp4a, new Uint8Array([\n        0x00, 0x00, 0x00, // reserved\n        0x00, 0x00, 0x00, // reserved\n        0x00, 0x01, // data_reference_index\n        0x00, 0x00, 0x00, 0x00,\n        0x00, 0x00, 0x00, 0x00, // reserved\n        0x00, track.channelCount, // channelcount\n        0x00, 0x10, // sampleSize:16bits\n        0x00, 0x00, 0x00, 0x00, // reserved2\n        (track.audiosamplerate >> 8) & 0xFF,\n        track.audiosamplerate & 0xff, //\n        0x00, 0x00]),\n        MP4.box(MP4.types.esds, MP4.esds(track)));\n  }\n\n  static stsd(track) {\n    if (track.type === 'audio') {\n      return MP4.box(MP4.types.stsd, MP4.STSD , MP4.mp4a(track));\n    } else {\n      return MP4.box(MP4.types.stsd, MP4.STSD , MP4.avc1(track));\n    }\n  }\n\n  static tkhd(track) {\n    return MP4.box(MP4.types.tkhd, new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x07, // flags\n      0x00, 0x00, 0x00, 0x00, // creation_time\n      0x00, 0x00, 0x00, 0x00, // modification_time\n      (track.id >> 24) & 0xFF,\n      (track.id >> 16) & 0xFF,\n      (track.id >> 8) & 0xFF,\n      track.id & 0xFF, // track_ID\n      0x00, 0x00, 0x00, 0x00, // reserved\n      (track.duration >> 24),\n      (track.duration >> 16) & 0xFF,\n      (track.duration >>  8) & 0xFF,\n      track.duration & 0xFF, // duration\n      0x00, 0x00, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00, // reserved\n      0x00, 0x00, // layer\n      0x00, 0x00, // alternate_group\n      0x00, 0x00, // non-audio track volume\n      0x00, 0x00, // reserved\n      0x00, 0x01, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00,\n      0x00, 0x01, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00,\n      0x00, 0x00, 0x00, 0x00,\n      0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n      (track.width >> 8) & 0xFF,\n      track.width & 0xFF,\n      0x00, 0x00, // width\n      (track.height >> 8) & 0xFF,\n      track.height & 0xFF,\n      0x00, 0x00 // height\n    ]));\n  }\n\n  static traf(track,baseMediaDecodeTime) {\n    var sampleDependencyTable = MP4.sdtp(track);\n    return MP4.box(MP4.types.traf,\n               MP4.box(MP4.types.tfhd, new Uint8Array([\n                 0x00, // version 0\n                 0x00, 0x00, 0x00, // flags\n                 (track.id >> 24),\n                 (track.id >> 16) & 0XFF,\n                 (track.id >> 8) & 0XFF,\n                 (track.id & 0xFF) // track_ID\n               ])),\n               MP4.box(MP4.types.tfdt, new Uint8Array([\n                 0x00, // version 0\n                 0x00, 0x00, 0x00, // flags\n                 (baseMediaDecodeTime >>24),\n                 (baseMediaDecodeTime >> 16) & 0XFF,\n                 (baseMediaDecodeTime >> 8) & 0XFF,\n                 (baseMediaDecodeTime & 0xFF) // baseMediaDecodeTime\n               ])),\n               MP4.trun(track,\n                    sampleDependencyTable.length +\n                    16 + // tfhd\n                    16 + // tfdt\n                    8 +  // traf header\n                    16 + // mfhd\n                    8 +  // moof header\n                    8),  // mdat header\n               sampleDependencyTable);\n  }\n\n  /**\n   * Generate a track box.\n   * @param track {object} a track definition\n   * @return {Uint8Array} the track box\n   */\n  static trak(track) {\n    track.duration = track.duration || 0xffffffff;\n    return MP4.box(MP4.types.trak,\n               MP4.tkhd(track),\n               MP4.mdia(track));\n  }\n\n  static trex(track) {\n    return MP4.box(MP4.types.trex, new Uint8Array([\n      0x00, // version 0\n      0x00, 0x00, 0x00, // flags\n     (track.id >> 24),\n     (track.id >> 16) & 0XFF,\n     (track.id >> 8) & 0XFF,\n     (track.id & 0xFF), // track_ID\n      0x00, 0x00, 0x00, 0x01, // default_sample_description_index\n      0x00, 0x00, 0x00, 0x00, // default_sample_duration\n      0x00, 0x00, 0x00, 0x00, // default_sample_size\n      0x00, 0x01, 0x00, 0x01 // default_sample_flags\n    ]));\n  }\n\n  static trun(track, offset) {\n    var samples, sample, i, array;\n\n    samples = track.samples || [];\n    array = new Uint8Array(12 + (16 * samples.length));\n    offset += 8 + array.byteLength;\n\n    array.set([\n      0x00, // version 0\n      0x00, 0x0f, 0x01, // flags\n      (samples.length >>> 24) & 0xFF,\n      (samples.length >>> 16) & 0xFF,\n      (samples.length >>> 8) & 0xFF,\n      samples.length & 0xFF, // sample_count\n      (offset >>> 24) & 0xFF,\n      (offset >>> 16) & 0xFF,\n      (offset >>> 8) & 0xFF,\n      offset & 0xFF // data_offset\n    ],0);\n\n    for (i = 0; i < samples.length; i++) {\n      sample = samples[i];\n      array.set([\n        (sample.duration >>> 24) & 0xFF,\n        (sample.duration >>> 16) & 0xFF,\n        (sample.duration >>> 8) & 0xFF,\n        sample.duration & 0xFF, // sample_duration\n        (sample.size >>> 24) & 0xFF,\n        (sample.size >>> 16) & 0xFF,\n        (sample.size >>> 8) & 0xFF,\n        sample.size & 0xFF, // sample_size\n        (sample.flags.isLeading << 2) | sample.flags.dependsOn,\n        (sample.flags.isDependedOn << 6) |\n          (sample.flags.hasRedundancy << 4) |\n          (sample.flags.paddingValue << 1) |\n          sample.flags.isNonSync,\n        sample.flags.degradPrio & 0xF0 << 8,\n        sample.flags.degradPrio & 0x0F, // sample_flags\n        (sample.cts >>> 24) & 0xFF,\n        (sample.cts >>> 16) & 0xFF,\n        (sample.cts >>> 8) & 0xFF,\n        sample.cts & 0xFF // sample_composition_time_offset\n      ],12+16*i);\n    }\n    return MP4.box(MP4.types.trun, array);\n  }\n\n  static initSegment(tracks) {\n\n    if(!MP4.types) {\n      MP4.init();\n    }\n    var\n      movie = MP4.moov(tracks),\n      result;\n\n    result = new Uint8Array(MP4.FTYP.byteLength + movie.byteLength);\n    result.set(MP4.FTYP);\n    result.set(movie, MP4.FTYP.byteLength);\n    return result;\n  }\n}\n\nexport default MP4;\n\n\n"," /*\n * Stats Handler\n *\n */\n\nimport Event                from './events';\nimport observer             from './observer';\n\n class StatsHandler {\n\n  constructor(hls) {\n    this.hls=hls;\n    this.onmp = this.onManifestParsed.bind(this);\n    this.onfc = this.onFragmentChanged.bind(this);\n    this.onfb = this.onFragmentBuffered.bind(this);\n    this.onflea = this.onFragmentLoadEmergencyAborted.bind(this);\n    this.onerr = this.onError.bind(this);\n    this.onfpsd = this.onFPSDrop.bind(this);\n    observer.on(Event.MANIFEST_PARSED, this.onmp);\n    observer.on(Event.FRAG_BUFFERED, this.onfb);\n    observer.on(Event.FRAG_CHANGED, this.onfc);\n    observer.on(Event.ERROR, this.onerr);\n    observer.on(Event.FRAG_LOAD_EMERGENCY_ABORTED, this.onflea);\n    observer.on(Event.FPS_DROP, this.onfpsd);\n  }\n\n  destroy() {\n    observer.off(Event.MANIFEST_PARSED, this.onmp);\n    observer.off(Event.FRAG_BUFFERED, this.onfb);\n    observer.off(Event.FRAG_CHANGED, this.onfc);\n    observer.off(Event.ERROR, this.onerr);\n    observer.off(Event.FRAG_LOAD_EMERGENCY_ABORTED, this.onflea);\n    observer.off(Event.FPS_DROP, this.onfpsd);\n  }\n\n  attachVideo(video) {\n    this.video = video;\n  }\n\n  detachVideo() {\n    this.video = null;\n  }\n\n  // reset stats on manifest parsed\n  onManifestParsed(event,data) {\n    this._stats = { tech : 'hls.js', levelNb : data.levels.length};\n  }\n\n  // on fragment changed is triggered whenever playback of a new fragment is starting ...\n  onFragmentChanged(event,data) {\n    var stats = this._stats,level = data.frag.level,autoLevel = data.frag.autoLevel;\n    if(stats) {\n      if(stats.levelStart === undefined) {\n        stats.levelStart = level;\n      }\n      if(autoLevel) {\n        if(stats.fragChangedAuto) {\n          stats.autoLevelMin = Math.min(stats.autoLevelMin,level);\n          stats.autoLevelMax = Math.max(stats.autoLevelMax,level);\n          stats.fragChangedAuto++;\n          if(this.levelLastAuto && level !== stats.autoLevelLast) {\n            stats.autoLevelSwitch++;\n          }\n        } else {\n          stats.autoLevelMin = stats.autoLevelMax = level;\n          stats.autoLevelSwitch = 0;\n          stats.fragChangedAuto = 1;\n          this.sumAutoLevel = 0;\n        }\n        this.sumAutoLevel+=level;\n        stats.autoLevelAvg = Math.round(1000*this.sumAutoLevel/stats.fragChangedAuto)/1000;\n        stats.autoLevelLast = level;\n      } else {\n        if(stats.fragChangedManual) {\n          stats.manualLevelMin = Math.min(stats.manualLevelMin,level);\n          stats.manualLevelMax = Math.max(stats.manualLevelMax,level);\n          stats.fragChangedManual++;\n          if(!this.levelLastAuto && level !== stats.manualLevelLast) {\n            stats.manualLevelSwitch++;\n          }\n        } else {\n          stats.manualLevelMin = stats.manualLevelMax = level;\n          stats.manualLevelSwitch = 0;\n          stats.fragChangedManual = 1;\n        }\n        stats.manualLevelLast = level;\n      }\n      this.levelLastAuto = autoLevel;\n    }\n  }\n\n  // triggered each time a new fragment is buffered\n  onFragmentBuffered(event,data) {\n    var stats = this._stats,latency = data.stats.tfirst - data.stats.trequest, process = data.stats.tbuffered - data.stats.trequest, bitrate = Math.round(8*data.stats.length/(data.stats.tbuffered - data.stats.tfirst));\n    if(stats.fragBuffered) {\n      stats.fragMinLatency = Math.min(stats.fragMinLatency,latency);\n      stats.fragMaxLatency = Math.max(stats.fragMaxLatency,latency);\n      stats.fragMinProcess = Math.min(stats.fragMinProcess,process);\n      stats.fragMaxProcess = Math.max(stats.fragMaxProcess,process);\n      stats.fragMinKbps = Math.min(stats.fragMinKbps,bitrate);\n      stats.fragMaxKbps = Math.max(stats.fragMaxKbps,bitrate);\n      stats.autoLevelCappingMin = Math.min(stats.autoLevelCappingMin,this.hls.autoLevelCapping);\n      stats.autoLevelCappingMax = Math.max(stats.autoLevelCappingMax,this.hls.autoLevelCapping);\n      stats.fragBuffered++;\n    } else {\n      stats.fragMinLatency = stats.fragMaxLatency = latency;\n      stats.fragMinProcess = stats.fragMaxProcess = process;\n      stats.fragMinKbps = stats.fragMaxKbps = bitrate;\n      stats.fragBuffered = 1;\n      stats.fragBufferedBytes = 0;\n      stats.autoLevelCappingMin = stats.autoLevelCappingMax = this.hls.autoLevelCapping;\n      this.sumLatency=0;\n      this.sumKbps=0;\n      this.sumProcess=0;\n    }\n    stats.fraglastLatency=latency;\n    this.sumLatency+=latency;\n    stats.fragAvgLatency = Math.round(this.sumLatency/stats.fragBuffered);\n    stats.fragLastProcess=process;\n    this.sumProcess+=process;\n    stats.fragAvgProcess = Math.round(this.sumProcess/stats.fragBuffered);\n    stats.fragLastKbps=bitrate;\n    this.sumKbps+=bitrate;\n    stats.fragAvgKbps = Math.round(this.sumKbps/stats.fragBuffered);\n    stats.fragBufferedBytes+=data.stats.length;\n    stats.autoLevelCappingLast = this.hls.autoLevelCapping;\n  }\n\n  onFragmentLoadEmergencyAborted() {\n    var stats = this._stats;\n    if(stats) {\n      if(stats.fragLoadEmergencyAborted === undefined) {\n        stats.fragLoadEmergencyAborted =1;\n      } else {\n        stats.fragLoadEmergencyAborted++;\n      }\n    }\n  }\n\n  onError(event,data) {\n    var stats = this._stats;\n    if(stats) {\n      // track all errors independently\n      if(stats[data.details] === undefined) {\n        stats[data.details] =1;\n      } else {\n        stats[data.details]+=1;\n      }\n      // track fatal error\n      if(data.fatal) {\n        if(stats.fatalError === undefined) {\n            stats.fatalError=1;\n        } else {\n            stats.fatalError+=1;\n        }\n      }\n    }\n  }\n\n  onFPSDrop(event,data) {\n    var stats = this._stats;\n    if(stats) {\n     if(stats.fpsDropEvent === undefined) {\n        stats.fpsDropEvent =1;\n      } else {\n        stats.fpsDropEvent++;\n      }\n      stats.fpsTotalDroppedFrames = data.totalDroppedFrames;\n    }\n  }\n\n  get stats() {\n    if(this.video) {\n      this._stats.lastPos = this.video.currentTime.toFixed(3);\n    }\n    return this._stats;\n  }\n}\n\nexport default StatsHandler;\n","'use strict';\n\nfunction noop(){}\nlet fakeLogger = {\n  log: noop,\n  warn: noop,\n  info: noop,\n  error: noop\n};\nlet exportedLogger = fakeLogger;\n\nexport var enableLogs = function(debug) {\n  if (debug === true || typeof debug       === 'object') {\n    exportedLogger.log   = debug.log   ? debug.log.bind(debug)   : console.log.bind(console);\n    exportedLogger.info  = debug.info  ? debug.info.bind(debug)  : console.info.bind(console);\n    exportedLogger.error = debug.error ? debug.error.bind(debug) : console.error.bind(console);\n    exportedLogger.warn  = debug.warn  ? debug.warn.bind(debug)  : console.warn.bind(console);\n\n    // Some browsers don't allow to use bind on console object anyway\n    // fallback to default if needed\n    try {\n     exportedLogger.log();\n    }\n    catch (e) {\n      exportedLogger.log   = noop;\n      exportedLogger.info  = noop;\n      exportedLogger.error = noop;\n      exportedLogger.warn  = noop;\n    }\n  }\n  else {\n    exportedLogger = fakeLogger;\n  }\n};\nexport var logger = exportedLogger;\n"," /*\n  * Xhr based Loader\n  *\n  */\n\nimport {logger}             from '../utils/logger';\n\n class XhrLoader {\n\n  constructor() {\n  }\n\n  destroy() {\n    this.abort();\n    this.loader = null;\n  }\n\n  abort() {\n    if(this.loader &&this.loader.readyState !== 4) {\n      this.stats.aborted = true;\n      this.loader.abort();\n    }\n    if(this.timeoutHandle) {\n      window.clearTimeout(this.timeoutHandle);\n    }\n  }\n\n  load(url,responseType,onSuccess,onError,onTimeout,timeout,maxRetry,retryDelay,onProgress=null) {\n    this.url = url;\n    this.responseType = responseType;\n    this.onSuccess = onSuccess;\n    this.onProgress = onProgress;\n    this.onTimeout = onTimeout;\n    this.onError = onError;\n    this.stats = { trequest:new Date(), retry:0};\n    this.timeout = timeout;\n    this.maxRetry = maxRetry;\n    this.retryDelay = retryDelay;\n    this.timeoutHandle = window.setTimeout(this.loadtimeout.bind(this),timeout);\n    this.loadInternal();\n  }\n\n  loadInternal() {\n    var xhr = this.loader = new XMLHttpRequest();\n    xhr.onload =  this.loadsuccess.bind(this);\n    xhr.onerror = this.loaderror.bind(this);\n    xhr.onprogress = this.loadprogress.bind(this);\n    xhr.open('GET', this.url , true);\n    xhr.responseType = this.responseType;\n    this.stats.tfirst = null;\n    this.stats.loaded = 0;\n    xhr.send();\n  }\n\n  loadsuccess(event) {\n    window.clearTimeout(this.timeoutHandle);\n    this.stats.tload = new Date();\n    this.onSuccess(event,this.stats);\n  }\n\n  loaderror(event) {\n    if(this.stats.retry < this.maxRetry) {\n      logger.warn(`${event.type} while loading ${this.url}, retrying in ${this.retryDelay}...`);\n      this.destroy();\n      window.setTimeout(this.loadInternal.bind(this),this.retryDelay);\n      // exponential backoff\n      this.retryDelay=Math.min(2*this.retryDelay,64000);\n      this.stats.retry++;\n    } else {\n      window.clearTimeout(this.timeoutHandle);\n      logger.error(`${event.type} while loading ${this.url}` );\n      this.onError(event);\n    }\n  }\n\n  loadtimeout(event) {\n    logger.warn(`timeout while loading ${this.url}` );\n    this.onTimeout(event,this.stats);\n  }\n\n  loadprogress(event) {\n    var stats = this.stats;\n    if(stats.tfirst === null) {\n      stats.tfirst = new Date();\n    }\n    stats.loaded = event.loaded;\n    if(this.onProgress) {\n      this.onProgress(event, stats);\n    }\n  }\n}\n\nexport default XhrLoader;\n"]} diff --git a/dist/hls.min.js b/dist/hls.min.js index e9a7e7088ae..8e0ff5ab080 100644 --- a/dist/hls.min.js +++ b/dist/hls.min.js @@ -1,3 +1,3 @@ -!function(e){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=e();else if("function"==typeof define&&define.amd)define([],e);else{var t;t="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:this,t.Hls=e()}}(function(){return function n(e,t,i){function s(a,u){if(!t[a]){if(!e[a]){var l="function"==typeof require&&require;if(!u&&l)return l(a,!0);if(r)return r(a,!0);var d=new Error("Cannot find module '"+a+"'");throw d.code="MODULE_NOT_FOUND",d}var o=t[a]={exports:{}};e[a][0].call(o.exports,function(t){var i=e[a][1][t];return s(i?i:t)},o,o.exports,n,e,t,i)}return t[a].exports}for(var r="function"==typeof require&&require,a=0;ae||isNaN(e))throw TypeError("n must be a positive number");return this._maxListeners=e,this},e.prototype.emit=function(d){var o,a,r,n,e,l;if(this._events||(this._events={}),"error"===d&&(!this._events.error||i(this._events.error)&&!this._events.error.length)){if(o=arguments[1],o instanceof Error)throw o;throw TypeError('Uncaught, unspecified "error" event.')}if(a=this._events[d],s(a))return!1;if(t(a))switch(arguments.length){case 1:a.call(this);break;case 2:a.call(this,arguments[1]);break;case 3:a.call(this,arguments[1],arguments[2]);break;default:for(r=arguments.length,n=new Array(r-1),e=1;r>e;e++)n[e-1]=arguments[e];a.apply(this,n)}else if(i(a)){for(r=arguments.length,n=new Array(r-1),e=1;r>e;e++)n[e-1]=arguments[e];for(l=a.slice(),r=l.length,e=0;r>e;e++)l[e].apply(this,n)}return!0},e.prototype.addListener=function(a,r){var n;if(!t(r))throw TypeError("listener must be a function");if(this._events||(this._events={}),this._events.newListener&&this.emit("newListener",a,t(r.listener)?r.listener:r),this._events[a]?i(this._events[a])?this._events[a].push(r):this._events[a]=[this._events[a],r]:this._events[a]=r,i(this._events[a])&&!this._events[a].warned){var n;n=s(this._maxListeners)?e.defaultMaxListeners:this._maxListeners,n&&n>0&&this._events[a].length>n&&(this._events[a].warned=!0,"function"==typeof console.trace)}return this},e.prototype.on=e.prototype.addListener,e.prototype.once=function(s,e){function i(){this.removeListener(s,i),a||(a=!0,e.apply(this,arguments))}if(!t(e))throw TypeError("listener must be a function");var a=!1;return i.listener=e,this.on(s,i),this},e.prototype.removeListener=function(a,s){var e,n,o,r;if(!t(s))throw TypeError("listener must be a function");if(!this._events||!this._events[a])return this;if(e=this._events[a],o=e.length,n=-1,e===s||t(e.listener)&&e.listener===s)delete this._events[a],this._events.removeListener&&this.emit("removeListener",a,s);else if(i(e)){for(r=o;r-->0;)if(e[r]===s||e[r].listener&&e[r].listener===s){n=r;break}if(0>n)return this;1===e.length?(e.length=0,delete this._events[a]):e.splice(n,1),this._events.removeListener&&this.emit("removeListener",a,s)}return this},e.prototype.removeAllListeners=function(e){var s,i;if(!this._events)return this;if(!this._events.removeListener)return 0===arguments.length?this._events={}:this._events[e]&&delete this._events[e],this;if(0===arguments.length){for(s in this._events)"removeListener"!==s&&this.removeAllListeners(s);return this.removeAllListeners("removeListener"),this._events={},this}if(i=this._events[e],t(i))this.removeListener(e,i);else for(;i.length;)this.removeListener(e,i[i.length-1]);return delete this._events[e],this},e.prototype.listeners=function(e){var i;return i=this._events&&this._events[e]?t(this._events[e])?[this._events[e]]:this._events[e].slice():[]},e.listenerCount=function(e,i){var s;return s=e._events&&e._events[i]?t(e._events[i])?1:e._events[i].length:0}},{}],2:[function(r,s,n){var a=arguments[3],e=arguments[4],i=arguments[5],t=JSON.stringify;s.exports=function(d){for(var s,o=Object.keys(i),r=0,l=o.length;l>r;r++){var n=o[r];if(i[n].exports===d){s=n;break}}if(!s){s=Math.floor(Math.pow(16,8)*Math.random()).toString(16);for(var u={},r=0,l=o.length;l>r;r++){var n=o[r];u[n]=n}e[s]=[Function(["require","module","exports"],"("+d+")(self)"),u]}var h=Math.floor(Math.pow(16,8)*Math.random()).toString(16),f={};f[s]=s,e[h]=[Function(["require"],"require("+t(s)+")(self)"),f];var c="("+a+")({"+Object.keys(e).map(function(i){return t(i)+":["+e[i][0]+","+t(e[i][1])+"]"}).join(",")+"},{},["+t(h)+"])",v=window.URL||window.webkitURL||window.mozURL||window.msURL;return new Worker(v.createObjectURL(new Blob([c],{type:"text/javascript"})))}},{}],3:[function(a,d,n){"use strict";function r(e){return e&&e.__esModule?e:{default:e}}function h(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(n,"__esModule",{value:!0});var o=function(){function e(s,i){for(var t=0;tD){if(this.hls.nextLoadLevel=n,this.level=n,o=this.levels[n].details,"undefined"==typeof o){this.state=this.WAITING_LEVEL;break}var l=o.fragments,a=void 0,L=o.sliding,f=l[0].start+L,p=0;if(f>h&&(this.seekAfterStalling=this.startPosition+L,e.logger.log("buffer end: "+h+" is located before start of live sliding playlist, media position will be reseted to: "+this.seekAfterStalling.toFixed(3)),h=this.seekAfterStalling),o.live&&void 0===o.sliding){if(this.frag){var m=this.frag.sn+1;m>=o.startSN&&m<=o.endSN&&(a=l[m-o.startSN],e.logger.log("live playlist, switching playlist, load frag with next SN: "+a.sn))}a||(a=l[Math.round(l.length/2)],e.logger.log("live playlist, switching playlist, unknown, load middle frag : "+a.sn))}else{for(d=0;d=f&&f+a.duration>h));d++);if(d===l.length)break;if(this.frag&&a.sn===this.frag.sn){if(d===l.length-1)break;a=l[d+1],e.logger.log("SN just loaded, load next one: "+a.sn)}}if(e.logger.log("Loading "+a.sn+" of ["+o.startSN+" ,"+o.endSN+"],level "+n+", currentTime:"+u+",bufferEnd:"+h.toFixed(3)),a.drift=p,a.autoLevel=this.hls.autoLevelEnabled,this.levels.length>1&&(a.expectedLen=Math.round(a.duration*this.levels[n].bitrate/8),a.trequest=new Date),void 0!==this.fragLoadIdx?this.fragLoadIdx++:this.fragLoadIdx=0,a.loadCounter){a.loadCounter++;var b=this.config.fragLoadingLoopThreshold;if(a.loadCounter>b&&Math.abs(this.fragLoadIdx-a.loadIdx)1){var S=new Date-r.trequest;if(S>500*r.duration){var A=1e3*r.loaded/S;r.expectedLenE&&_>R&&(e.logger.warn("loading too slow, abort fragment loading"),e.logger.log("fragLoadedDelay/bufferStarvationDelay/fragLevelNextLoadedDelay :"+_.toFixed(1)+"/"+E.toFixed(1)+"/"+R.toFixed(1)),r.loader.abort(),this.frag=null,i.default.trigger(t.default.FRAG_LOAD_EMERGENCY_ABORTED,{frag:r}),this.state=this.IDLE)}}break;case this.PARSING:break;case this.PARSED:case this.APPENDING:if(this.sourceBuffer){if(this.sourceBuffer.audio&&this.sourceBuffer.audio.updating||this.sourceBuffer.video&&this.sourceBuffer.video.updating);else if(this.mp4segments.length){var g=this.mp4segments.shift();try{this.sourceBuffer[g.type].appendBuffer(g.data),this.appendError=0}catch(a){e.logger.error("error while trying to append buffer:"+a.message+",try appending later"),this.mp4segments.unshift(g),this.appendError?this.appendError++:this.appendError=1;var v={type:s.ErrorTypes.MEDIA_ERROR,details:s.ErrorDetails.FRAG_APPENDING_ERROR,frag:this.frag};if(this.appendError>this.config.appendErrorMaxRetry)return e.logger.log("fail "+this.config.appendErrorMaxRetry+" times to append segment in sourceBuffer"),v.fatal=!0,i.default.trigger(t.default.ERROR,v),void(this.state=this.ERROR);v.fatal=!1,i.default.trigger(t.default.ERROR,v)}this.state=this.APPENDING}}else this.state=this.IDLE;break;case this.BUFFER_FLUSHING:for(;this.flushRange.length;){var k=this.flushRange[0];if(!this.flushBuffer(k.start,k.end))break;this.flushRange.shift()}0===this.flushRange.length&&(this.state=this.IDLE,this.frag=null)}this._checkFragmentChanged()}},{key:"bufferInfo",value:function(s){var r,n,a,e,o=this.video,i=o.buffered,t=[];for(e=0;e=t[e].start&&s=0;e--)if(t=this.bufferRange[e],i>=t.start&&i<=t.end)return t;return null}},{key:"followingBufferRange",value:function(e){return e?this.getBufferRange(e.end+.5):null}},{key:"isBuffered",value:function(i){for(var s=this.video,t=s.buffered,e=0;e=t.start(e)&&i<=t.end(e))return!0;return!1}},{key:"_checkFragmentChanged",value:function(){var a,s;if(this.video&&this.video.seeking===!1&&(this.lastCurrentTime=s=this.video.currentTime,this.isBuffered(s)?a=this.getBufferRange(s):this.isBuffered(s+.1)&&(a=this.getBufferRange(s+.1)),a)){a.frag!==this.fragCurrent&&(this.fragCurrent=a.frag,i.default.trigger(t.default.FRAG_CHANGED,{frag:this.fragCurrent}));var r=this.levels[this.level];r&&r.details&&!r.details.live&&this.video.duration-s<.2&&this.mediaSource&&"open"===this.mediaSource.readyState&&(e.logger.log("end of VoD stream reached, signal endOfStream() to MediaSource"),this.mediaSource.endOfStream())}}},{key:"flushBuffer",value:function(u,l){var i,t,o,n,s,a;if(this.flushBufferCounter++<2*this.bufferRange.length&&this.sourceBuffer)for(var d in this.sourceBuffer){if(i=this.sourceBuffer[d],i.updating)return!1;for(t=0;t.5)return e.logger.log("flush "+d+" ["+s+","+a+"], of ["+o+","+n+"], pos:"+this.video.currentTime),i.remove(s,a),!1}var r,h=[];for(t=0;t=0){var o=s.fragments;r=r&&o>=s&&(a.details.sliding=t.startPTS-i[s-r].start)}e.logger.log(" parsed data, type/startPTS/endPTS/startDTS/endDTS/nb:"+t.type+"/"+t.startPTS.toFixed(3)+"/"+t.endPTS.toFixed(3)+"/"+t.startDTS.toFixed(3)+"/"+t.endDTS.toFixed(3)+"/"+t.nb),this.frag.drift=0,this.mp4segments.push({type:t.type,data:t.moof}),this.mp4segments.push({type:t.type,data:t.mdat}),this.nextLoadPosition=t.endPTS,this.bufferRange.push({type:t.type,start:t.startPTS,end:t.endPTS,frag:this.frag}),this.tick()}else e.logger.warn("not in PARSING state, discarding "+n)}},{key:"onFragmentParsed",value:function(){this.state===this.PARSING&&(this.state=this.PARSED,this.stats.tparsed=new Date,this.tick())}},{key:"onError",value:function(i,t){switch(t.details){case s.ErrorDetails.FRAG_LOAD_ERROR:case s.ErrorDetails.FRAG_LOAD_TIMEOUT:case s.ErrorDetails.FRAG_LOOP_LOADING_ERROR:case s.ErrorDetails.LEVEL_LOAD_ERROR:case s.ErrorDetails.LEVEL_LOAD_TIMEOUT:e.logger.warn("buffer controller: "+t.details+" while loading frag,switch to "+(t.fatal?"ERROR":"IDLE")+" state ..."),this.state=t.fatal?this.ERROR:this.IDLE,this.frag=null}}},{key:"onSourceBufferUpdateEnd",value:function(){this.state===this.APPENDING&&0===this.mp4segments.length&&this.frag&&(this.stats.tbuffered=new Date,i.default.trigger(t.default.FRAG_BUFFERED,{stats:this.stats,frag:this.frag}),this.state=this.IDLE),this.tick()}},{key:"onSourceBufferError",value:function(a){e.logger.error("sourceBuffer error:"+a),this.state=this.ERROR,i.default.trigger(t.default.ERROR,{type:s.ErrorTypes.MEDIA_ERROR,details:s.ErrorDetails.FRAG_APPENDING_ERROR,fatal:!0,frag:this.frag})}},{key:"currentLevel",get:function(){if(this.video){var e=this.getBufferRange(this.video.currentTime);if(e)return e.frag.level}return-1}},{key:"nextBufferRange",get:function(){return this.video?this.followingBufferRange(this.getBufferRange(this.video.currentTime)):null}},{key:"nextLevel",get:function(){var e=this.nextBufferRange;return e?e.frag.level:-1}}]),a}();n.default=v,d.exports=n.default},{"../demux/demuxer":5,"../errors":9,"../events":10,"../observer":14,"../utils/logger":17}],4:[function(a,h,r){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function d(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(r,"__esModule",{value:!0});var u=function(){function e(s,i){for(var t=0;t=0&&a=e;e++)if(t=e<=this._level?.8*s:.7*s,te?(this.word<<=e,this.bitsAvailable-=e):(e-=this.bitsAvailable,t=e>>3,e-=t>>3,this.bytesAvailable-=t,this.loadWord(),this.word<<=e,this.bitsAvailable-=e)}},{key:"readBits",value:function(t){var e=Math.min(this.bitsAvailable,t),i=this.word>>>32-e;return t>32&&r.logger.error("Cannot read more than 32 bits at a time"),this.bitsAvailable-=e,this.bitsAvailable>0?this.word<<=e:this.bytesAvailable>0&&this.loadWord(),e=t-e,e>0?i<>>e))return this.word<<=e,this.bitsAvailable-=e,e;return this.loadWord(),e+this.skipLZ()}},{key:"skipUEG",value:function(){this.skipBits(1+this.skipLZ())}},{key:"skipEG",value:function(){this.skipBits(1+this.skipLZ())}},{key:"readUEG",value:function(){var e=this.skipLZ();return this.readBits(e+1)-1}},{key:"readEG", -value:function(){var e=this.readUEG();return 1&e?1+e>>>1:-1*(e>>>1)}},{key:"readBoolean",value:function(){return 1===this.readBits(1)}},{key:"readUByte",value:function(){return this.readBits(8)}},{key:"skipScalingList",value:function(a){var t,s,i=8,e=8;for(t=0;a>t;t++)0!==e&&(s=this.readEG(),e=(i+s+256)%256),i=0===e?i:e}},{key:"readSPS",value:function(){var t,o,l,s,a,r,i,v,e,d=0,u=0,h=0,f=0;if(this.readUByte(),t=this.readUByte(),o=this.readBits(5),this.skipBits(3),l=this.readUByte(),this.skipUEG(),100===t||110===t||122===t||144===t){var c=this.readUEG();if(3===c&&this.skipBits(1),this.skipUEG(),this.skipUEG(),this.skipBits(1),this.readBoolean())for(v=3!==c?8:12,e=0;v>e;e++)this.readBoolean()&&(6>e?this.skipScalingList(16):this.skipScalingList(64))}this.skipUEG();var n=this.readUEG();if(0===n)this.readUEG();else if(1===n)for(this.skipBits(1),this.skipEG(),this.skipEG(),s=this.readUEG(),e=0;s>e;e++)this.skipEG();return this.skipUEG(),this.skipBits(1),a=this.readUEG(),r=this.readUEG(),i=this.readBits(1),0===i&&this.skipBits(1),this.skipBits(1),this.readBoolean()&&(d=this.readUEG(),u=this.readUEG(),h=this.readUEG(),f=this.readUEG()),{profileIdc:t,profileCompat:o,levelIdc:l,width:16*(a+1)-2*d-2*u,height:(2-i)*(r+1)*16-2*h-2*f}}}]),e}();e.default=n,i.exports=e.default},{"../utils/logger":17}],7:[function(a,l,o){"use strict";function r(e){return e&&e.__esModule?e:{default:e}}function h(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(o,"__esModule",{value:!0});var c=function(){function e(s,i){for(var t=0;ti;i+=188)if(71===a[i]){if(u=!!(64&a[i+1]),d=((31&a[i+1])<<8)+a[i+2],p=(48&a[i+3])>>4,p>1){if(r=i+5+a[i+4],r===i+188)continue}else r=i+4;c?d===g?(u&&(o&&this._parseAVCPES(this._parsePES(o)),o={data:[],size:0}),o&&(o.data.push(a.subarray(r,i+188)),o.size+=i+188-r)):d===h&&(u&&(l&&this._parseAACPES(this._parsePES(l)),l={data:[],size:0}),l&&(l.data.push(a.subarray(r,i+188)),l.size+=i+188-r)):(u&&(r+=a[r]+1),0===d?this._parsePAT(a,r):d===this._pmtId&&(this._parsePMT(a,r),c=this.pmtParsed=!0,g=this._avcId,h=this._aacId))}else s.default.trigger(t.default.ERROR,{type:n.ErrorTypes.MEDIA_ERROR,details:n.ErrorDetails.FRAG_PARSING_ERROR,fatal:!1,reason:"TS packet did not start with 0x47"});o&&this._parseAVCPES(this._parsePES(o)),l&&this._parseAACPES(this._parsePES(l))}},{key:"end",value:function(){this._initSegGenerated||this._generateInitSegment(),this._avcSamples.length&&this._flushAVCSamples(),this._aacSamples.length&&this._flushAACSamples(),s.default.trigger(t.default.FRAG_PARSED)}},{key:"destroy",value:function(){this.switchLevel(),this._initPTS=this._initDTS=void 0,this._duration=0}},{key:"_parsePAT",value:function(e,t){this._pmtId=(31&e[t+10])<<8|e[t+11]}},{key:"_parsePMT",value:function(i,t){var a,r,n,s;for(a=(15&i[t+1])<<8|i[t+2],r=t+3+a-4,n=(15&i[t+10])<<8|i[t+11],t+=12+n;r>t;){switch(s=(31&i[t+1])<<8|i[t+2],i[t]){case 15:this._aacId=s,this._aacTrack.id=s;break;case 27:this._avcId=s,this._avcTrack.id=s;break;default:e.logger.log("unkown stream type:"+i[t])}t+=((15&i[t+3])<<8|i[t+4])+5}}},{key:"_parsePES",value:function(t){var e,a,d,o,u,r,i,s,n,l=0;if(e=t.data[0],d=(e[0]<<16)+(e[1]<<8)+e[2],1===d){for(o=(e[4]<<8)+e[5],a=e[7],192&a&&(i=536870912*(14&e[9])+4194304*(255&e[10])+16384*(254&e[11])+128*(255&e[12])+(254&e[13])/2,i>4294967295&&(i-=8589934592),64&a?(s=536870912*(14&e[14])+4194304*(255&e[15])+16384*(254&e[16])+128*(255&e[17])+(254&e[18])/2,s>4294967295&&(s-=8589934592)):s=i),u=e[8],n=u+9,t.data[0]=t.data[0].subarray(n),t.size-=n,r=new Uint8Array(t.size);t.data.length;)e=t.data.shift(),r.set(e,l),l+=e.byteLength;return{data:r,pts:i,dts:s,len:o}}return null}},{key:"_parseAVCPES",value:function(i){var t,a,s=this,e=this._avcTrack,r=!1;t=this._parseAVCNALu(i.data),i.data=null,t.units.forEach(function(t){switch(t.type){case 5:r=!0;break;case 7:if(!e.sps){var l=new d.default(t.data),i=l.readSPS();e.width=i.width,e.height=i.height,e.profileIdc=i.profileIdc,e.profileCompat=i.profileCompat,e.levelIdc=i.levelIdc,e.sps=[t.data],e.timescale=s.MP4_TIMESCALE,e.duration=s.MP4_TIMESCALE*s._duration;for(var u=t.data.subarray(1,4),o="avc1.",n=0;3>n;n++){var a=u[n].toString(16);a.length<2&&(a="0"+a),o+=a}e.codec=o}break;case 8:e.pps||(e.pps=[t.data])}}),a={units:t,pts:i.pts,dts:i.dts,key:r},this._avcSamples.push(a),this._avcSamplesLength+=t.length,this._avcSamplesNbNalu+=t.units.length}},{key:"_flushAVCSamples",value:function(){var y,o,a,m,f,h,l,A,_,E,g,L,n,r,c=8,v=this._avcTrack,u=[];for(l=new Uint8Array(this._avcSamplesLength+4*this._avcSamplesNbNalu+8),y=new DataView(l.buffer),y.setUint32(0,l.byteLength),l.set(i.default.types.mdat,4);this._avcSamples.length;){for(o=this._avcSamples.shift(),m=0;o.units.units.length;)f=o.units.units.shift(),y.setUint32(c,f.data.byteLength),c+=4,l.set(f.data,c),c+=f.data.byteLength,m+=4+f.data.byteLength;if(g=o.pts-this._initDTS,L=o.dts-this._initDTS,void 0!==h)n=this._PTSNormalize(g,h),r=this._PTSNormalize(L,h),a.duration=(r-h)/this.PES2MP4SCALEFACTOR,a.duration<0&&(a.duration=0);else{if(n=this._PTSNormalize(g,this.nextAvcPts),r=this._PTSNormalize(L,this.nextAvcPts),this.nextAvcPts){var d=Math.round((n-this.nextAvcPts)/90),b=Math.abs(d);if(300>b)d>1?e.logger.log("AVC:"+d+" ms hole between fragments detected,filling it"):-1>d&&e.logger.log("AVC:"+-d+" ms overlapping between fragments detected"),n=this.nextAvcPts,r=Math.max(r-d,this.lastAvcDts);else{var p=this.PES_TIMESCALE*this.timeOffset;if(Math.abs(p-n)>3600*this.PES_TIMESCALE){var S=p-n;n=p,r=n,this._initPTS-=S,this._initDTS-=S}}}_=Math.max(0,n),E=Math.max(0,r)}a={size:m,duration:0,cts:(n-r)/this.PES2MP4SCALEFACTOR,flags:{isLeading:0,isDependedOn:0,hasRedundancy:0,degradPrio:0}},o.key===!0?(a.flags.dependsOn=2,a.flags.isNonSync=0):(a.flags.dependsOn=1,a.flags.isNonSync=1),u.push(a),h=r}u.length>=2&&(a.duration=u[u.length-2].duration),this.lastAvcDts=r,this.nextAvcPts=n+a.duration*this.PES2MP4SCALEFACTOR,this._avcSamplesLength=0,this._avcSamplesNbNalu=0,v.samples=u,A=i.default.moof(v.sequenceNumber++,E/this.PES2MP4SCALEFACTOR,v),v.samples=[],s.default.trigger(t.default.FRAG_PARSING_DATA,{moof:A,mdat:l,startPTS:_/this.PES_TIMESCALE,endPTS:this.nextAvcPts/this.PES_TIMESCALE,startDTS:E/this.PES_TIMESCALE,endDTS:(r+this.PES2MP4SCALEFACTOR*a.duration)/this.PES_TIMESCALE,type:"video",nb:u.length})}},{key:"_parseAVCNALu",value:function(s){for(var r,a,l,n,i,u,t=0,o=s.byteLength,e=0,h=[],f=0;o>t;)switch(r=s[t++],e){case 0:0===r&&(e=1);break;case 1:e=0===r?2:0;break;case 2:case 3:if(0===r)e=3;else if(1===r){if(n=31&s[t],i)l={data:s.subarray(i,t-e-1),type:u},f+=t-e-1-i,h.push(l);else if(a=t-e-1,a&&this._avcSamples.length){var c=this._avcSamples[this._avcSamples.length-1],d=c.units.units[c.units.units.length-1],v=new Uint8Array(d.data.byteLength+a);v.set(d.data,0),v.set(s.subarray(0,a),d.data.byteLength),d.data=v,c.units.length+=a,this._avcSamplesLength+=a}i=t,u=n,(1===n||5===n)&&(t=o),e=0}else e=0}return i&&(l={data:s.subarray(i,o),type:u},f+=o-i,h.push(l)),{units:h,length:f}}},{key:"_PTSNormalize",value:function(e,t){var i;if(void 0===t)return e;for(i=e>t?-8589934592:8589934592;Math.abs(e-t)>4294967296;)e+=i;return e}},{key:"_parseAACPES",value:function(m){var p,l,o,i,u,c,f,d,r=this._aacTrack,a=m.data;if(this.aacOverFlow){var g=new Uint8Array(this.aacOverFlow.byteLength+a.byteLength);g.set(this.aacOverFlow,0),g.set(a,this.aacOverFlow.byteLength),a=g}for(i=0,d=a.length;d-1>i&&(255!==a[i]||240!==(240&a[i+1]));i++);if(i){var v,h;if(d-1>i?(v="AAC PES did not start with ADTS header,offset:"+i,h=!1):(v="no ADTS header found in AAC PES",h=!0),s.default.trigger(t.default.ERROR,{type:n.ErrorTypes.MEDIA_ERROR,details:n.ErrorDetails.FRAG_PARSING_ERROR,fatal:h,reason:v}),h)return}for(r.audiosamplerate||(l=this._ADTStoAudioConfig(a,i,this.audioCodec),r.config=l.config,r.audiosamplerate=l.samplerate,r.channelCount=l.channelCount,r.codec=l.codec,r.timescale=this.MP4_TIMESCALE,r.duration=this.MP4_TIMESCALE*this._duration,e.logger.log("parsed codec:"+r.codec+",rate:"+l.samplerate+",nb channel:"+l.channelCount)),f=0;d>i+5&&(o=(3&a[i+3])<<11,o|=a[i+4]<<3,o|=(224&a[i+5])>>>5,u=1&a[i+1]?7:9,o-=u,c=Math.round(m.pts+1024*f*this.PES_TIMESCALE/r.audiosamplerate),d>=i+u+o);)p={unit:a.subarray(i+u,i+u+o),pts:c,dts:c},this._aacSamples.push(p),this._aacSamplesLength+=o,i+=o+u,f++;d>i?this.aacOverFlow=a.subarray(i,d):this.aacOverFlow=null}},{key:"_flushAACSamples",value:function(){var y,u,n,h,d,o,L,A,g,p,v,a,r,_=8,f=this._aacTrack,l=[];for(o=new Uint8Array(this._aacSamplesLength+8),y=new DataView(o.buffer),y.setUint32(0,o.byteLength),o.set(i.default.types.mdat,4);this._aacSamples.length;){if(u=this._aacSamples.shift(),h=u.unit,o.set(h,_),_+=h.byteLength,p=u.pts-this._initDTS,v=u.dts-this._initDTS,void 0!==d)a=this._PTSNormalize(p,d),r=this._PTSNormalize(v,d),n.duration=(r-d)/this.PES2MP4SCALEFACTOR,n.duration<0&&(n.duration=0);else{if(a=this._PTSNormalize(p,this.nextAacPts),r=this._PTSNormalize(v,this.nextAacPts),this.nextAacPts&&this.nextAacPts!==a){var c=Math.round(1e3*(a-this.nextAacPts)/this.PES_TIMESCALE),m=Math.abs(c);if(m>1&&300>m)c>0?(e.logger.log("AAC:"+c+" ms hole between fragments detected,filling it"),a=Math.max(this.nextAacPts,this.lastAacDts),r=a):e.logger.log("AAC:"+-c+" ms overlapping between fragments detected");else if(m){var E=this.PES_TIMESCALE*this.timeOffset;if(Math.abs(E-a)>3600*this.PES_TIMESCALE){var S=E-a;a=E,r=a,this._initPTS-=S,this._initDTS-=S}}}A=Math.max(0,a),g=Math.max(0,r)}n={size:h.byteLength,cts:0,duration:0,flags:{isLeading:0,isDependedOn:0,hasRedundancy:0,degradPrio:0,dependsOn:1}},l.push(n),d=r}l.length>=2&&(n.duration=l[l.length-2].duration),this.lastAacDts=r,this.nextAacPts=a+this.PES2MP4SCALEFACTOR*n.duration,this._aacSamplesLength=0,f.samples=l,L=i.default.moof(f.sequenceNumber++,g/this.PES2MP4SCALEFACTOR,f),f.samples=[],s.default.trigger(t.default.FRAG_PARSING_DATA,{moof:L,mdat:o,startPTS:A/this.PES_TIMESCALE,endPTS:this.nextAacPts/this.PES_TIMESCALE,startDTS:g/this.PES_TIMESCALE,endDTS:(r+this.PES2MP4SCALEFACTOR*n.duration)/this.PES_TIMESCALE,type:"audio",nb:l.length})}},{key:"_ADTStoAudioConfig",value:function(o,l,r){var s,t,a,n,i,d=navigator.userAgent.toLowerCase(),u=[96e3,88200,64e3,48e3,44100,32e3,24e3,22050,16e3,12e3];return s=((192&o[l+2])>>>6)+1,t=(60&o[l+2])>>>2,n=(1&o[l+2])<<2,n|=(192&o[l+3])>>>6,e.logger.log("manifest codec:"+r+",ADTS data:type:"+s+",sampleingIndex:"+t+"["+u[t]+"kHz],channelConfig:"+n),-1!==d.indexOf("firefox")?t>=6?(s=5,i=new Array(4),a=t-3):(s=2,i=new Array(2),a=t):-1!==d.indexOf("android")?(s=2,i=new Array(2),a=t):(s=5,i=new Array(4),r&&-1!==r.indexOf("mp4a.40.5")||!r&&t>=6?a=t-3:(r&&-1!==r.indexOf("mp4a.40.2")&&(t>=6||1===n)&&(s=2,i=new Array(2)),a=t)),i[0]=s<<3,i[0]|=(14&t)>>1,i[1]|=(1&t)<<7,i[1]|=n<<3,5===s&&(i[1]|=(14&a)>>1,i[2]=(1&a)<<7,i[2]|=8,i[3]=0),{config:i,samplerate:u[t],channelCount:n,codec:"mp4a.40."+s}}},{key:"_generateInitSegment",value:function(){-1===this._avcId?(this._aacTrack.config&&(s.default.trigger(t.default.FRAG_PARSING_INIT_SEGMENT,{audioMoov:i.default.initSegment([this._aacTrack]),audioCodec:this._aacTrack.codec,audioChannelCount:this._aacTrack.channelCount}),this._initSegGenerated=!0),void 0===this._initPTS&&(this._initPTS=this._aacSamples[0].pts-this.PES_TIMESCALE*this.timeOffset,this._initDTS=this._aacSamples[0].dts-this.PES_TIMESCALE*this.timeOffset)):-1===this._aacId?this._avcTrack.sps&&this._avcTrack.pps&&(s.default.trigger(t.default.FRAG_PARSING_INIT_SEGMENT,{videoMoov:i.default.initSegment([this._avcTrack]),videoCodec:this._avcTrack.codec,videoWidth:this._avcTrack.width,videoHeight:this._avcTrack.height}),this._initSegGenerated=!0,void 0===this._initPTS&&(this._initPTS=this._avcSamples[0].pts-this.PES_TIMESCALE*this.timeOffset,this._initDTS=this._avcSamples[0].dts-this.PES_TIMESCALE*this.timeOffset)):this._aacTrack.config&&this._avcTrack.sps&&this._avcTrack.pps&&(s.default.trigger(t.default.FRAG_PARSING_INIT_SEGMENT,{audioMoov:i.default.initSegment([this._aacTrack]),audioCodec:this._aacTrack.codec,audioChannelCount:this._aacTrack.channelCount,videoMoov:i.default.initSegment([this._avcTrack]),videoCodec:this._avcTrack.codec,videoWidth:this._avcTrack.width,videoHeight:this._avcTrack.height}),this._initSegGenerated=!0,void 0===this._initPTS&&(this._initPTS=Math.min(this._avcSamples[0].pts,this._aacSamples[0].pts)-this.PES_TIMESCALE*this.timeOffset,this._initDTS=Math.min(this._avcSamples[0].dts,this._aacSamples[0].dts)-this.PES_TIMESCALE*this.timeOffset))}}]),a}();o.default=g,l.exports=o.default},{"../errors":9,"../events":10,"../observer":14,"../remux/mp4-generator":15,"../utils/logger":17,"./exp-golomb":6}],8:[function(a,r,i){"use strict";function s(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(i,"__esModule",{value:!0});var d=a("../events"),e=s(d),n=a("../demux/tsdemuxer"),o=s(n),l=a("../observer"),t=s(l),u=function(i){i.addEventListener("message",function(e){switch(e.data.cmd){case"init":i.demuxer=new o.default;break;case"demux":i.demuxer.push(new Uint8Array(e.data.data),e.data.audioCodec,e.data.videoCodec,e.data.timeOffset,e.data.cc,e.data.level,e.data.duration),i.demuxer.end()}}),t.default.on(e.default.FRAG_PARSING_INIT_SEGMENT,function(a,t){var e={event:a},s=[];t.audioCodec&&(e.audioCodec=t.audioCodec,e.audioMoov=t.audioMoov.buffer,e.audioChannelCount=t.audioChannelCount,s.push(e.audioMoov)),t.videoCodec&&(e.videoCodec=t.videoCodec,e.videoMoov=t.videoMoov.buffer,e.videoWidth=t.videoWidth,e.videoHeight=t.videoHeight,s.push(e.videoMoov)),i.postMessage(e,s)}),t.default.on(e.default.FRAG_PARSING_DATA,function(s,e){var t={event:s,type:e.type,startPTS:e.startPTS,endPTS:e.endPTS,startDTS:e.startDTS,endDTS:e.endDTS,moof:e.moof.buffer,mdat:e.mdat.buffer,nb:e.nb};i.postMessage(t,[t.moof,t.mdat])}),t.default.on(e.default.FRAG_PARSED,function(e){i.postMessage({event:e})}),t.default.on(e.default.ERROR,function(e,t){i.postMessage({event:e,data:t})})};i.default=u,r.exports=i.default},{"../demux/tsdemuxer":7,"../events":10,"../observer":14}],9:[function(s,a,e){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var t={NETWORK_ERROR:"hlsNetworkError",MEDIA_ERROR:"hlsMediaError",OTHER_ERROR:"hlsOtherError"};e.ErrorTypes=t;var i={MANIFEST_LOAD_ERROR:"manifestLoadError",MANIFEST_LOAD_TIMEOUT:"manifestLoadTimeOut",MANIFEST_PARSING_ERROR:"manifestParsingError",LEVEL_LOAD_ERROR:"levelLoadError",LEVEL_LOAD_TIMEOUT:"levelLoadTimeOut",LEVEL_SWITCH_ERROR:"levelSwitchError",FRAG_LOAD_ERROR:"fragLoadError",FRAG_LOOP_LOADING_ERROR:"fragLoopLoadingError",FRAG_LOAD_TIMEOUT:"fragLoadTimeOut",FRAG_PARSING_ERROR:"fragParsingError",FRAG_APPENDING_ERROR:"fragAppendingError"};e.ErrorDetails=i},{}],10:[function(i,t,e){"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.default={MSE_ATTACHED:"hlsMediaSourceAttached",MSE_DETACHED:"hlsMediaSourceDetached",MANIFEST_LOADING:"hlsManifestLoading",MANIFEST_LOADED:"hlsManifestLoaded",MANIFEST_PARSED:"hlsManifestParsed",LEVEL_LOADING:"hlsLevelLoading",LEVEL_LOADED:"hlsLevelLoaded",LEVEL_SWITCH:"hlsLevelSwitch",FRAG_LOADING:"hlsFragLoading",FRAG_LOAD_PROGRESS:"hlsFragLoadProgress",FRAG_LOAD_EMERGENCY_ABORTED:"hlsFragLoadEmergencyAborted",FRAG_LOADED:"hlsFragLoaded",FRAG_PARSING_INIT_SEGMENT:"hlsFragParsingInitSegment",FRAG_PARSING_DATA:"hlsFragParsingData",FRAG_PARSED:"hlsFragParsed",FRAG_BUFFERED:"hlsFragBuffered",FRAG_CHANGED:"hlsFragChanged",FPS_DROP:"hlsFPSDrop",ERROR:"hlsError"},t.exports=e.default},{}],11:[function(t,f,r){"use strict";function s(e){return e&&e.__esModule?e:{default:e}}function _(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(r,"__esModule",{value:!0});var v=function(){function e(s,i){for(var t=0;t0;)switch(e.shift()){case"RES":t.width=parseInt(e.shift()),t.height=parseInt(e.shift());break;case"BAND":t.bitrate=parseInt(e.shift());break;case"NAME":t.name=e.shift();break;case"CODECS":for(s=e.shift().split(",");s.length>0;)i=s.shift(),-1!==i.indexOf("avc1")?t.videoCodec=this.avc1toavcoti(i):t.audioCodec=i}a.push(t),t={}}return a}},{key:"avc1toavcoti",value:function(i){var e,t=i.split(".");return t.length>2?(e=t.shift()+".",e+=parseInt(t.shift()).toString(16),e+=("00"+parseInt(t.shift()).toString(16)).substr(-4)):e=i,e}},{key:"parseLevelPlaylist",value:function(l,a,d){var e,r,i=0,s=0,t={url:a,fragments:[],live:!0,startSN:0},n=0;for(r=/(?:#EXT-X-(MEDIA-SEQUENCE):(\d+))|(?:#EXT-X-(TARGETDURATION):(\d+))|(?:#EXT(INF):([\d\.]+)[^\r\n]*[\r\n]+([^\r\n]+)|(?:#EXT-X-(ENDLIST))|(?:#EXT-X-(DIS)CONTINUITY))/g;null!==(e=r.exec(l));)switch(e.shift(),e=e.filter(function(e){return void 0!==e}),e[0]){case"MEDIA-SEQUENCE":i=t.startSN=parseInt(e[1]);break;case"TARGETDURATION":t.targetduration=parseFloat(e[1]);break;case"ENDLIST":t.live=!1;break;case"DIS":n++;break;case"INF":var o=parseFloat(e[1]);t.fragments.push({url:this.resolve(e[2],a),duration:o,start:s,sn:i++,level:d,cc:n}),s+=o}return t.totalduration=s,t.endSN=i-1,t}},{key:"loadsuccess",value:function(n,a){var o,r=n.currentTarget.responseText,s=n.currentTarget.responseURL,l=this.id,d=this.id2;void 0===s&&(s=this.url),a.tload=new Date,a.mtime=new Date(n.currentTarget.getResponseHeader("Last-Modified")),0===r.indexOf("#EXTM3U")?r.indexOf("#EXTINF:")>0?null===this.id?t.default.trigger(e.default.MANIFEST_LOADED,{levels:[{url:s}],url:s,stats:a}):t.default.trigger(e.default.LEVEL_LOADED,{details:this.parseLevelPlaylist(r,s,l),level:l,id:d,stats:a}):(o=this.parseMasterPlaylist(r,s),o.length?t.default.trigger(e.default.MANIFEST_LOADED,{levels:o,url:s,stats:a}):t.default.trigger(e.default.ERROR,{type:i.ErrorTypes.NETWORK_ERROR,details:i.ErrorDetails.MANIFEST_PARSING_ERROR,fatal:!0,url:s,reason:"no level found in manifest"})):t.default.trigger(e.default.ERROR,{type:i.ErrorTypes.NETWORK_ERROR,details:i.ErrorDetails.MANIFEST_PARSING_ERROR,fatal:!0,url:s,reason:"no EXTM3U delimiter"})}},{key:"loaderror",value:function(r){var s,a;null===this.id?(s=i.ErrorDetails.MANIFEST_LOAD_ERROR,a=!0):(s=i.ErrorDetails.LEVEL_LOAD_ERROR,a=!1),this.loader.abort(),t.default.trigger(e.default.ERROR,{type:i.ErrorTypes.NETWORK_ERROR,details:s,fatal:a,url:this.url,loader:this.loader,response:r.currentTarget,level:this.id,id:this.id2})}},{key:"loadtimeout",value:function(){var s,a;null===this.id?(s=i.ErrorDetails.MANIFEST_LOAD_TIMEOUT,a=!0):(s=i.ErrorDetails.LEVEL_LOAD_TIMEOUT,a=!1),this.loader.abort(),t.default.trigger(e.default.ERROR,{type:i.ErrorTypes.NETWORK_ERROR,details:s,fatal:a,url:this.url,loader:this.loader,level:this.id,id:this.id2})}}]),s}();a.default=o,n.exports=a.default},{"../errors":9,"../events":10,"../observer":14}],14:[function(i,s,t){"use strict";function a(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var r=i("events"),n=a(r),e=new n.default;e.trigger=function(s){for(var i=arguments.length,a=Array(i>1?i-1:0),t=1;i>t;t++)a[t-1]=arguments[t];e.emit.apply(e,[s,s].concat(a))},e.off=function(a){for(var i=arguments.length,s=Array(i>1?i-1:0),t=1;i>t;t++)s[t-1]=arguments[t];e.removeListener.apply(e,[a].concat(s))},t.default=e,s.exports=t.default},{events:1}],15:[function(r,t,e){"use strict";function i(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(e,"__esModule",{value:!0});var s=function(){function e(s,i){for(var t=0;t>24&255,t>>16&255,t>>8&255,255&t,i>>24,i>>16&255,i>>8&255,255&i,85,196,0,0]))}},{key:"mdia",value:function(t){return e.box(e.types.mdia,e.mdhd(t.timescale,t.duration),e.hdlr(t.type),e.minf(t))}},{key:"mfhd",value:function(t){return e.box(e.types.mfhd,new Uint8Array([0,0,0,0,t>>24,t>>16&255,t>>8&255,255&t]))}},{key:"minf",value:function(t){return"audio"===t.type?e.box(e.types.minf,e.box(e.types.smhd,e.SMHD),e.DINF,e.stbl(t)):e.box(e.types.minf,e.box(e.types.vmhd,e.VMHD),e.DINF,e.stbl(t))}},{key:"moof",value:function(t,i,s){return e.box(e.types.moof,e.mfhd(t),e.traf(s,i))}},{key:"moov",value:function(t){for(var i=t.length,s=[];i--;)s[i]=e.trak(t[i]);return e.box.apply(null,[e.types.moov,e.mvhd(t[0].timescale,t[0].duration)].concat(s).concat(e.mvex(t)))}},{key:"mvex",value:function(i){for(var t=i.length,s=[];t--;)s[t]=e.trex(i[t]);return e.box.apply(null,[e.types.mvex].concat(s))}},{key:"mvhd",value:function(t,i){var s=new Uint8Array([0,0,0,0,0,0,0,1,0,0,0,2,t>>24&255,t>>16&255,t>>8&255,255&t,i>>24&255,i>>16&255,i>>8&255,255&i,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,64,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255]);return e.box(e.types.mvhd,s)}},{key:"sdtp",value:function(r){var i,t,s=r.samples||[],a=new Uint8Array(4+s.length);for(t=0;t>>8&255),s.push(255&t.sps[i].byteLength),s=s.concat(Array.prototype.slice.call(t.sps[i]));for(i=0;i>>8&255),a.push(255&t.pps[i].byteLength),a=a.concat(Array.prototype.slice.call(t.pps[i]));return e.box(e.types.avc1,new Uint8Array([0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,t.width>>8&255,255&t.width,t.height>>8&255,255&t.height,0,72,0,0,0,72,0,0,0,0,0,0,0,1,19,118,105,100,101,111,106,115,45,99,111,110,116,114,105,98,45,104,108,115,0,0,0,0,0,0,0,0,0,0,0,0,0,24,17,17]),e.box(e.types.avcC,new Uint8Array([1,t.profileIdc,t.profileCompat,t.levelIdc,255].concat([t.sps.length]).concat(s).concat([t.pps.length]).concat(a))),e.box(e.types.btrt,new Uint8Array([0,28,156,128,0,45,198,192,0,45,198,192])))}},{key:"esds",value:function(e){return new Uint8Array([0,0,0,0,3,23+e.config.length,0,1,0,4,15+e.config.length,64,21,0,0,0,0,0,0,0,0,0,0,0,5].concat([e.config.length]).concat(e.config).concat([6,1,2]))}},{key:"mp4a",value:function(t){return e.box(e.types.mp4a,new Uint8Array([0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,t.channelCount,0,16,0,0,0,0,t.audiosamplerate>>8&255,255&t.audiosamplerate,0,0]),e.box(e.types.esds,e.esds(t)))}},{key:"stsd",value:function(t){return"audio"===t.type?e.box(e.types.stsd,e.STSD,e.mp4a(t)):e.box(e.types.stsd,e.STSD,e.avc1(t))}},{key:"tkhd",value:function(t){return e.box(e.types.tkhd,new Uint8Array([0,0,0,7,0,0,0,0,0,0,0,0,t.id>>24&255,t.id>>16&255,t.id>>8&255,255&t.id,0,0,0,0,t.duration>>24,t.duration>>16&255,t.duration>>8&255,255&t.duration,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,64,0,0,0,t.width>>8&255,255&t.width,0,0,t.height>>8&255,255&t.height,0,0]))}},{key:"traf",value:function(t,i){var s=e.sdtp(t);return e.box(e.types.traf,e.box(e.types.tfhd,new Uint8Array([0,0,0,0,t.id>>24,t.id>>16&255,t.id>>8&255,255&t.id])),e.box(e.types.tfdt,new Uint8Array([0,0,0,0,i>>24,i>>16&255,i>>8&255,255&i])),e.trun(t,s.length+16+16+8+16+8+8),s)}},{key:"trak",value:function(t){return t.duration=t.duration||4294967295,e.box(e.types.trak,e.tkhd(t),e.mdia(t))}},{key:"trex",value:function(t){return e.box(e.types.trex,new Uint8Array([0,0,0,0,t.id>>24,t.id>>16&255,t.id>>8&255,255&t.id,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,1]))}},{key:"trun",value:function(n,s){var i,t,a,r;for(i=n.samples||[],r=new Uint8Array(12+16*i.length),s+=8+r.byteLength,r.set([0,0,15,1,i.length>>>24&255,i.length>>>16&255,i.length>>>8&255,255&i.length,s>>>24&255,s>>>16&255,s>>>8&255,255&s],0),a=0;a>>24&255,t.duration>>>16&255,t.duration>>>8&255,255&t.duration,t.size>>>24&255,t.size>>>16&255,t.size>>>8&255,255&t.size,t.flags.isLeading<<2|t.flags.dependsOn,t.flags.isDependedOn<<6|t.flags.hasRedundancy<<4|t.flags.paddingValue<<1|t.flags.isNonSync,61440&t.flags.degradPrio,15&t.flags.degradPrio,t.cts>>>24&255,t.cts>>>16&255,t.cts>>>8&255,255&t.cts],12+16*a);return e.box(e.types.trun,r)}},{key:"initSegment",value:function(s){e.types||e.init();var t,i=e.moov(s);return t=new Uint8Array(e.FTYP.byteLength+i.byteLength),t.set(e.FTYP),t.set(i,e.FTYP.byteLength),t}}]),e}();e.default=a,t.exports=e.default},{}],16:[function(s,r,i){"use strict";function a(e){return e&&e.__esModule?e:{default:e}}function d(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(i,"__esModule",{value:!0});var u=function(){function e(s,i){for(var t=0;te||isNaN(e))throw TypeError("n must be a positive number");return this._maxListeners=e,this},e.prototype.emit=function(d){var o,a,r,n,e,l;if(this._events||(this._events={}),"error"===d&&(!this._events.error||i(this._events.error)&&!this._events.error.length)){if(o=arguments[1],o instanceof Error)throw o;throw TypeError('Uncaught, unspecified "error" event.')}if(a=this._events[d],s(a))return!1;if(t(a))switch(arguments.length){case 1:a.call(this);break;case 2:a.call(this,arguments[1]);break;case 3:a.call(this,arguments[1],arguments[2]);break;default:for(r=arguments.length,n=new Array(r-1),e=1;r>e;e++)n[e-1]=arguments[e];a.apply(this,n)}else if(i(a)){for(r=arguments.length,n=new Array(r-1),e=1;r>e;e++)n[e-1]=arguments[e];for(l=a.slice(),r=l.length,e=0;r>e;e++)l[e].apply(this,n)}return!0},e.prototype.addListener=function(a,r){var n;if(!t(r))throw TypeError("listener must be a function");if(this._events||(this._events={}),this._events.newListener&&this.emit("newListener",a,t(r.listener)?r.listener:r),this._events[a]?i(this._events[a])?this._events[a].push(r):this._events[a]=[this._events[a],r]:this._events[a]=r,i(this._events[a])&&!this._events[a].warned){var n;n=s(this._maxListeners)?e.defaultMaxListeners:this._maxListeners,n&&n>0&&this._events[a].length>n&&(this._events[a].warned=!0,"function"==typeof console.trace)}return this},e.prototype.on=e.prototype.addListener,e.prototype.once=function(s,e){function i(){this.removeListener(s,i),a||(a=!0,e.apply(this,arguments))}if(!t(e))throw TypeError("listener must be a function");var a=!1;return i.listener=e,this.on(s,i),this},e.prototype.removeListener=function(a,s){var e,n,o,r;if(!t(s))throw TypeError("listener must be a function");if(!this._events||!this._events[a])return this;if(e=this._events[a],o=e.length,n=-1,e===s||t(e.listener)&&e.listener===s)delete this._events[a],this._events.removeListener&&this.emit("removeListener",a,s);else if(i(e)){for(r=o;r-->0;)if(e[r]===s||e[r].listener&&e[r].listener===s){n=r;break}if(0>n)return this;1===e.length?(e.length=0,delete this._events[a]):e.splice(n,1),this._events.removeListener&&this.emit("removeListener",a,s)}return this},e.prototype.removeAllListeners=function(e){var s,i;if(!this._events)return this;if(!this._events.removeListener)return 0===arguments.length?this._events={}:this._events[e]&&delete this._events[e],this;if(0===arguments.length){for(s in this._events)"removeListener"!==s&&this.removeAllListeners(s);return this.removeAllListeners("removeListener"),this._events={},this}if(i=this._events[e],t(i))this.removeListener(e,i);else for(;i.length;)this.removeListener(e,i[i.length-1]);return delete this._events[e],this},e.prototype.listeners=function(e){var i;return i=this._events&&this._events[e]?t(this._events[e])?[this._events[e]]:this._events[e].slice():[]},e.listenerCount=function(e,i){var s;return s=e._events&&e._events[i]?t(e._events[i])?1:e._events[i].length:0}},{}],2:[function(r,s,n){var a=arguments[3],e=arguments[4],i=arguments[5],t=JSON.stringify;s.exports=function(d){for(var s,o=Object.keys(i),r=0,l=o.length;l>r;r++){var n=o[r];if(i[n].exports===d){s=n;break}}if(!s){s=Math.floor(Math.pow(16,8)*Math.random()).toString(16);for(var h={},r=0,l=o.length;l>r;r++){var n=o[r];h[n]=n}e[s]=[Function(["require","module","exports"],"("+d+")(self)"),h]}var u=Math.floor(Math.pow(16,8)*Math.random()).toString(16),f={};f[s]=s,e[u]=[Function(["require"],"require("+t(s)+")(self)"),f];var c="("+a+")({"+Object.keys(e).map(function(i){return t(i)+":["+e[i][0]+","+t(e[i][1])+"]"}).join(",")+"},{},["+t(u)+"])",v=window.URL||window.webkitURL||window.mozURL||window.msURL;return new Worker(v.createObjectURL(new Blob([c],{type:"text/javascript"})))}},{}],3:[function(a,d,n){"use strict";function r(e){return e&&e.__esModule?e:{default:e}}function u(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(n,"__esModule",{value:!0});var o=function(){function e(s,i){for(var t=0;tD){if(this.hls.nextLoadLevel=n,this.level=n,o=this.levels[n].details,"undefined"==typeof o){this.state=this.WAITING_LEVEL;break}var l=o.fragments,a=void 0,L=o.sliding,f=l[0].start+L,p=0;if(f>u&&(this.seekAfterStalling=this.startPosition+L,e.logger.log("buffer end: "+u+" is located before start of live sliding playlist, media position will be reseted to: "+this.seekAfterStalling.toFixed(3)),u=this.seekAfterStalling),o.live&&void 0===o.sliding){if(this.frag){var m=this.frag.sn+1;m>=o.startSN&&m<=o.endSN&&(a=l[m-o.startSN],e.logger.log("live playlist, switching playlist, load frag with next SN: "+a.sn))}a||(a=l[Math.round(l.length/2)],e.logger.log("live playlist, switching playlist, unknown, load middle frag : "+a.sn))}else{for(d=0;d=f&&f+a.duration>u));d++);if(d===l.length)break;if(this.frag&&a.sn===this.frag.sn){if(d===l.length-1)break;a=l[d+1],e.logger.log("SN just loaded, load next one: "+a.sn)}}if(e.logger.log("Loading "+a.sn+" of ["+o.startSN+" ,"+o.endSN+"],level "+n+", currentTime:"+h+",bufferEnd:"+u.toFixed(3)),a.drift=p,a.autoLevel=this.hls.autoLevelEnabled,this.levels.length>1&&(a.expectedLen=Math.round(a.duration*this.levels[n].bitrate/8),a.trequest=new Date),void 0!==this.fragLoadIdx?this.fragLoadIdx++:this.fragLoadIdx=0,a.loadCounter){a.loadCounter++;var b=this.config.fragLoadingLoopThreshold;if(a.loadCounter>b&&Math.abs(this.fragLoadIdx-a.loadIdx)1){var S=new Date-r.trequest;if(S>500*r.duration){var A=1e3*r.loaded/S;r.expectedLenE&&_>R&&(e.logger.warn("loading too slow, abort fragment loading"),e.logger.log("fragLoadedDelay/bufferStarvationDelay/fragLevelNextLoadedDelay :"+_.toFixed(1)+"/"+E.toFixed(1)+"/"+R.toFixed(1)),r.loader.abort(),this.frag=null,i.default.trigger(t.default.FRAG_LOAD_EMERGENCY_ABORTED,{frag:r}),this.state=this.IDLE)}}break;case this.PARSING:break;case this.PARSED:case this.APPENDING:if(this.sourceBuffer){if(this.sourceBuffer.audio&&this.sourceBuffer.audio.updating||this.sourceBuffer.video&&this.sourceBuffer.video.updating);else if(this.mp4segments.length){var g=this.mp4segments.shift();try{this.sourceBuffer[g.type].appendBuffer(g.data),this.appendError=0}catch(a){e.logger.error("error while trying to append buffer:"+a.message+",try appending later"),this.mp4segments.unshift(g),this.appendError?this.appendError++:this.appendError=1;var v={type:s.ErrorTypes.MEDIA_ERROR,details:s.ErrorDetails.FRAG_APPENDING_ERROR,frag:this.frag};if(this.appendError>this.config.appendErrorMaxRetry)return e.logger.log("fail "+this.config.appendErrorMaxRetry+" times to append segment in sourceBuffer"),v.fatal=!0,i.default.trigger(t.default.ERROR,v),void(this.state=this.ERROR);v.fatal=!1,i.default.trigger(t.default.ERROR,v)}this.state=this.APPENDING}}else this.state=this.IDLE;break;case this.BUFFER_FLUSHING:for(;this.flushRange.length;){var k=this.flushRange[0];if(!this.flushBuffer(k.start,k.end))break;this.flushRange.shift()}0===this.flushRange.length&&(this.state=this.IDLE,this.frag=null)}this._checkFragmentChanged()}},{key:"bufferInfo",value:function(s){var r,n,a,e,o=this.video,i=o.buffered,t=[];for(e=0;e=t[e].start&&s=0;e--)if(t=this.bufferRange[e],i>=t.start&&i<=t.end)return t;return null}},{key:"followingBufferRange",value:function(e){return e?this.getBufferRange(e.end+.5):null}},{key:"isBuffered",value:function(i){for(var s=this.video,t=s.buffered,e=0;e=t.start(e)&&i<=t.end(e))return!0;return!1}},{key:"_checkFragmentChanged",value:function(){var a,s;if(this.video&&this.video.seeking===!1&&(this.lastCurrentTime=s=this.video.currentTime,this.isBuffered(s)?a=this.getBufferRange(s):this.isBuffered(s+.1)&&(a=this.getBufferRange(s+.1)),a)){a.frag!==this.fragCurrent&&(this.fragCurrent=a.frag,i.default.trigger(t.default.FRAG_CHANGED,{frag:this.fragCurrent}));var r=this.levels[this.level];r&&r.details&&!r.details.live&&this.video.duration-s<.2&&this.mediaSource&&"open"===this.mediaSource.readyState&&(e.logger.log("end of VoD stream reached, signal endOfStream() to MediaSource"),this.lastCurrentTime=this.startPosition,this.video=null,this.mediaSource.endOfStream())}}},{key:"flushBuffer",value:function(h,l){var i,t,o,n,s,a;if(this.flushBufferCounter++<2*this.bufferRange.length&&this.sourceBuffer)for(var d in this.sourceBuffer){if(i=this.sourceBuffer[d],i.updating)return!1;for(t=0;t.5)return e.logger.log("flush "+d+" ["+s+","+a+"], of ["+o+","+n+"], pos:"+this.video.currentTime),i.remove(s,a),!1}var r,u=[];for(t=0;t=0){var o=s.fragments;r=r&&o>=s&&(a.details.sliding=t.startPTS-i[s-r].start)}e.logger.log(" parsed data, type/startPTS/endPTS/startDTS/endDTS/nb:"+t.type+"/"+t.startPTS.toFixed(3)+"/"+t.endPTS.toFixed(3)+"/"+t.startDTS.toFixed(3)+"/"+t.endDTS.toFixed(3)+"/"+t.nb),this.frag.drift=0,this.mp4segments.push({type:t.type,data:t.moof}),this.mp4segments.push({type:t.type,data:t.mdat}),this.nextLoadPosition=t.endPTS,this.bufferRange.push({type:t.type,start:t.startPTS,end:t.endPTS,frag:this.frag}),this.tick()}else e.logger.warn("not in PARSING state, discarding "+n)}},{key:"onFragmentParsed",value:function(){this.state===this.PARSING&&(this.state=this.PARSED,this.stats.tparsed=new Date,this.tick())}},{key:"onError",value:function(i,t){switch(t.details){case s.ErrorDetails.FRAG_LOAD_ERROR:case s.ErrorDetails.FRAG_LOAD_TIMEOUT:case s.ErrorDetails.FRAG_LOOP_LOADING_ERROR:case s.ErrorDetails.LEVEL_LOAD_ERROR:case s.ErrorDetails.LEVEL_LOAD_TIMEOUT:e.logger.warn("buffer controller: "+t.details+" while loading frag,switch to "+(t.fatal?"ERROR":"IDLE")+" state ..."),this.state=t.fatal?this.ERROR:this.IDLE,this.frag=null}}},{key:"onSourceBufferUpdateEnd",value:function(){this.state===this.APPENDING&&0===this.mp4segments.length&&this.frag&&(this.stats.tbuffered=new Date,i.default.trigger(t.default.FRAG_BUFFERED,{stats:this.stats,frag:this.frag}),this.state=this.IDLE),this.tick()}},{key:"onSourceBufferError",value:function(a){e.logger.error("sourceBuffer error:"+a),this.state=this.ERROR,i.default.trigger(t.default.ERROR,{type:s.ErrorTypes.MEDIA_ERROR,details:s.ErrorDetails.FRAG_APPENDING_ERROR,fatal:!0,frag:this.frag})}},{key:"currentLevel",get:function(){if(this.video){var e=this.getBufferRange(this.video.currentTime);if(e)return e.frag.level}return-1}},{key:"nextBufferRange",get:function(){return this.video?this.followingBufferRange(this.getBufferRange(this.video.currentTime)):null}},{key:"nextLevel",get:function(){var e=this.nextBufferRange;return e?e.frag.level:-1}}]),a}();n.default=v,d.exports=n.default},{"../demux/demuxer":5,"../errors":9,"../events":10,"../observer":14,"../utils/logger":17}],4:[function(a,u,r){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function d(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(r,"__esModule",{value:!0});var h=function(){function e(s,i){for(var t=0;t=0&&a=e;e++)if(t=e<=this._level?.8*s:.7*s,te?(this.word<<=e,this.bitsAvailable-=e):(e-=this.bitsAvailable,t=e>>3,e-=t>>3,this.bytesAvailable-=t,this.loadWord(),this.word<<=e,this.bitsAvailable-=e)}},{key:"readBits",value:function(t){var e=Math.min(this.bitsAvailable,t),i=this.word>>>32-e;return t>32&&r.logger.error("Cannot read more than 32 bits at a time"),this.bitsAvailable-=e,this.bitsAvailable>0?this.word<<=e:this.bytesAvailable>0&&this.loadWord(),e=t-e,e>0?i<>>e))return this.word<<=e,this.bitsAvailable-=e,e;return this.loadWord(),e+this.skipLZ()}},{key:"skipUEG",value:function(){this.skipBits(1+this.skipLZ())}},{key:"skipEG",value:function(){ +this.skipBits(1+this.skipLZ())}},{key:"readUEG",value:function(){var e=this.skipLZ();return this.readBits(e+1)-1}},{key:"readEG",value:function(){var e=this.readUEG();return 1&e?1+e>>>1:-1*(e>>>1)}},{key:"readBoolean",value:function(){return 1===this.readBits(1)}},{key:"readUByte",value:function(){return this.readBits(8)}},{key:"skipScalingList",value:function(a){var t,s,i=8,e=8;for(t=0;a>t;t++)0!==e&&(s=this.readEG(),e=(i+s+256)%256),i=0===e?i:e}},{key:"readSPS",value:function(){var t,o,l,s,a,r,i,v,e,d=0,h=0,u=0,f=0;if(this.readUByte(),t=this.readUByte(),o=this.readBits(5),this.skipBits(3),l=this.readUByte(),this.skipUEG(),100===t||110===t||122===t||144===t){var c=this.readUEG();if(3===c&&this.skipBits(1),this.skipUEG(),this.skipUEG(),this.skipBits(1),this.readBoolean())for(v=3!==c?8:12,e=0;v>e;e++)this.readBoolean()&&(6>e?this.skipScalingList(16):this.skipScalingList(64))}this.skipUEG();var n=this.readUEG();if(0===n)this.readUEG();else if(1===n)for(this.skipBits(1),this.skipEG(),this.skipEG(),s=this.readUEG(),e=0;s>e;e++)this.skipEG();return this.skipUEG(),this.skipBits(1),a=this.readUEG(),r=this.readUEG(),i=this.readBits(1),0===i&&this.skipBits(1),this.skipBits(1),this.readBoolean()&&(d=this.readUEG(),h=this.readUEG(),u=this.readUEG(),f=this.readUEG()),{profileIdc:t,profileCompat:o,levelIdc:l,width:16*(a+1)-2*d-2*h,height:(2-i)*(r+1)*16-2*u-2*f}}}]),e}();e.default=n,i.exports=e.default},{"../utils/logger":17}],7:[function(a,l,o){"use strict";function r(e){return e&&e.__esModule?e:{default:e}}function u(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(o,"__esModule",{value:!0});var c=function(){function e(s,i){for(var t=0;ti;i+=188)if(71===a[i]){if(h=!!(64&a[i+1]),d=((31&a[i+1])<<8)+a[i+2],p=(48&a[i+3])>>4,p>1){if(r=i+5+a[i+4],r===i+188)continue}else r=i+4;c?d===g?(h&&(o&&this._parseAVCPES(this._parsePES(o)),o={data:[],size:0}),o&&(o.data.push(a.subarray(r,i+188)),o.size+=i+188-r)):d===u&&(h&&(l&&this._parseAACPES(this._parsePES(l)),l={data:[],size:0}),l&&(l.data.push(a.subarray(r,i+188)),l.size+=i+188-r)):(h&&(r+=a[r]+1),0===d?this._parsePAT(a,r):d===this._pmtId&&(this._parsePMT(a,r),c=this.pmtParsed=!0,g=this._avcId,u=this._aacId))}else s.default.trigger(t.default.ERROR,{type:n.ErrorTypes.MEDIA_ERROR,details:n.ErrorDetails.FRAG_PARSING_ERROR,fatal:!1,reason:"TS packet did not start with 0x47"});o&&this._parseAVCPES(this._parsePES(o)),l&&this._parseAACPES(this._parsePES(l))}},{key:"end",value:function(){this._initSegGenerated||this._generateInitSegment(),this._avcSamples.length&&this._flushAVCSamples(),this._aacSamples.length&&this._flushAACSamples(),s.default.trigger(t.default.FRAG_PARSED)}},{key:"destroy",value:function(){this.switchLevel(),this._initPTS=this._initDTS=void 0,this._duration=0}},{key:"_parsePAT",value:function(e,t){this._pmtId=(31&e[t+10])<<8|e[t+11]}},{key:"_parsePMT",value:function(i,t){var a,r,n,s;for(a=(15&i[t+1])<<8|i[t+2],r=t+3+a-4,n=(15&i[t+10])<<8|i[t+11],t+=12+n;r>t;){switch(s=(31&i[t+1])<<8|i[t+2],i[t]){case 15:this._aacId=s,this._aacTrack.id=s;break;case 27:this._avcId=s,this._avcTrack.id=s;break;default:e.logger.log("unkown stream type:"+i[t])}t+=((15&i[t+3])<<8|i[t+4])+5}}},{key:"_parsePES",value:function(t){var e,a,d,o,h,r,i,s,n,l=0;if(e=t.data[0],d=(e[0]<<16)+(e[1]<<8)+e[2],1===d){for(o=(e[4]<<8)+e[5],a=e[7],192&a&&(i=536870912*(14&e[9])+4194304*(255&e[10])+16384*(254&e[11])+128*(255&e[12])+(254&e[13])/2,i>4294967295&&(i-=8589934592),64&a?(s=536870912*(14&e[14])+4194304*(255&e[15])+16384*(254&e[16])+128*(255&e[17])+(254&e[18])/2,s>4294967295&&(s-=8589934592)):s=i),h=e[8],n=h+9,t.data[0]=t.data[0].subarray(n),t.size-=n,r=new Uint8Array(t.size);t.data.length;)e=t.data.shift(),r.set(e,l),l+=e.byteLength;return{data:r,pts:i,dts:s,len:o}}return null}},{key:"_parseAVCPES",value:function(i){var t,a,s=this,e=this._avcTrack,r=!1;t=this._parseAVCNALu(i.data),i.data=null,t.units.forEach(function(t){switch(t.type){case 5:r=!0;break;case 7:if(!e.sps){var l=new d.default(t.data),i=l.readSPS();e.width=i.width,e.height=i.height,e.profileIdc=i.profileIdc,e.profileCompat=i.profileCompat,e.levelIdc=i.levelIdc,e.sps=[t.data],e.timescale=s.MP4_TIMESCALE,e.duration=s.MP4_TIMESCALE*s._duration;for(var h=t.data.subarray(1,4),o="avc1.",n=0;3>n;n++){var a=h[n].toString(16);a.length<2&&(a="0"+a),o+=a}e.codec=o}break;case 8:e.pps||(e.pps=[t.data])}}),a={units:t,pts:i.pts,dts:i.dts,key:r},this._avcSamples.push(a),this._avcSamplesLength+=t.length,this._avcSamplesNbNalu+=t.units.length}},{key:"_flushAVCSamples",value:function(){var y,o,a,m,f,u,l,A,_,E,g,L,n,r,c=8,v=this._avcTrack,h=[];for(l=new Uint8Array(this._avcSamplesLength+4*this._avcSamplesNbNalu+8),y=new DataView(l.buffer),y.setUint32(0,l.byteLength),l.set(i.default.types.mdat,4);this._avcSamples.length;){for(o=this._avcSamples.shift(),m=0;o.units.units.length;)f=o.units.units.shift(),y.setUint32(c,f.data.byteLength),c+=4,l.set(f.data,c),c+=f.data.byteLength,m+=4+f.data.byteLength;if(g=o.pts-this._initDTS,L=o.dts-this._initDTS,void 0!==u)n=this._PTSNormalize(g,u),r=this._PTSNormalize(L,u),a.duration=(r-u)/this.PES2MP4SCALEFACTOR,a.duration<0&&(a.duration=0);else{if(n=this._PTSNormalize(g,this.nextAvcPts),r=this._PTSNormalize(L,this.nextAvcPts),this.nextAvcPts){var d=Math.round((n-this.nextAvcPts)/90),b=Math.abs(d);if(300>b)d>1?e.logger.log("AVC:"+d+" ms hole between fragments detected,filling it"):-1>d&&e.logger.log("AVC:"+-d+" ms overlapping between fragments detected"),n=this.nextAvcPts,r=Math.max(r-d,this.lastAvcDts);else{var p=this.PES_TIMESCALE*this.timeOffset;if(Math.abs(p-n)>3600*this.PES_TIMESCALE){var S=p-n;n=p,r=n,this._initPTS-=S,this._initDTS-=S}}}_=Math.max(0,n),E=Math.max(0,r)}a={size:m,duration:0,cts:(n-r)/this.PES2MP4SCALEFACTOR,flags:{isLeading:0,isDependedOn:0,hasRedundancy:0,degradPrio:0}},o.key===!0?(a.flags.dependsOn=2,a.flags.isNonSync=0):(a.flags.dependsOn=1,a.flags.isNonSync=1),h.push(a),u=r}h.length>=2&&(a.duration=h[h.length-2].duration),this.lastAvcDts=r,this.nextAvcPts=n+a.duration*this.PES2MP4SCALEFACTOR,this._avcSamplesLength=0,this._avcSamplesNbNalu=0,v.samples=h,A=i.default.moof(v.sequenceNumber++,E/this.PES2MP4SCALEFACTOR,v),v.samples=[],s.default.trigger(t.default.FRAG_PARSING_DATA,{moof:A,mdat:l,startPTS:_/this.PES_TIMESCALE,endPTS:this.nextAvcPts/this.PES_TIMESCALE,startDTS:E/this.PES_TIMESCALE,endDTS:(r+this.PES2MP4SCALEFACTOR*a.duration)/this.PES_TIMESCALE,type:"video",nb:h.length})}},{key:"_parseAVCNALu",value:function(s){for(var r,a,l,n,i,h,t=0,o=s.byteLength,e=0,u=[],f=0;o>t;)switch(r=s[t++],e){case 0:0===r&&(e=1);break;case 1:e=0===r?2:0;break;case 2:case 3:if(0===r)e=3;else if(1===r){if(n=31&s[t],i)l={data:s.subarray(i,t-e-1),type:h},f+=t-e-1-i,u.push(l);else if(a=t-e-1,a&&this._avcSamples.length){var c=this._avcSamples[this._avcSamples.length-1],d=c.units.units[c.units.units.length-1],v=new Uint8Array(d.data.byteLength+a);v.set(d.data,0),v.set(s.subarray(0,a),d.data.byteLength),d.data=v,c.units.length+=a,this._avcSamplesLength+=a}i=t,h=n,(1===n||5===n)&&(t=o),e=0}else e=0}return i&&(l={data:s.subarray(i,o),type:h},f+=o-i,u.push(l)),{units:u,length:f}}},{key:"_PTSNormalize",value:function(e,t){var i;if(void 0===t)return e;for(i=e>t?-8589934592:8589934592;Math.abs(e-t)>4294967296;)e+=i;return e}},{key:"_parseAACPES",value:function(m){var p,l,o,i,h,c,f,d,r=this._aacTrack,a=m.data;if(this.aacOverFlow){var g=new Uint8Array(this.aacOverFlow.byteLength+a.byteLength);g.set(this.aacOverFlow,0),g.set(a,this.aacOverFlow.byteLength),a=g}for(i=0,d=a.length;d-1>i&&(255!==a[i]||240!==(240&a[i+1]));i++);if(i){var v,u;if(d-1>i?(v="AAC PES did not start with ADTS header,offset:"+i,u=!1):(v="no ADTS header found in AAC PES",u=!0),s.default.trigger(t.default.ERROR,{type:n.ErrorTypes.MEDIA_ERROR,details:n.ErrorDetails.FRAG_PARSING_ERROR,fatal:u,reason:v}),u)return}for(r.audiosamplerate||(l=this._ADTStoAudioConfig(a,i,this.audioCodec),r.config=l.config,r.audiosamplerate=l.samplerate,r.channelCount=l.channelCount,r.codec=l.codec,r.timescale=this.MP4_TIMESCALE,r.duration=this.MP4_TIMESCALE*this._duration,e.logger.log("parsed codec:"+r.codec+",rate:"+l.samplerate+",nb channel:"+l.channelCount)),f=0;d>i+5&&(o=(3&a[i+3])<<11,o|=a[i+4]<<3,o|=(224&a[i+5])>>>5,h=1&a[i+1]?7:9,o-=h,c=Math.round(m.pts+1024*f*this.PES_TIMESCALE/r.audiosamplerate),d>=i+h+o);)p={unit:a.subarray(i+h,i+h+o),pts:c,dts:c},this._aacSamples.push(p),this._aacSamplesLength+=o,i+=o+h,f++;d>i?this.aacOverFlow=a.subarray(i,d):this.aacOverFlow=null}},{key:"_flushAACSamples",value:function(){var y,h,n,u,d,o,L,A,g,p,v,a,r,_=8,f=this._aacTrack,l=[];for(o=new Uint8Array(this._aacSamplesLength+8),y=new DataView(o.buffer),y.setUint32(0,o.byteLength),o.set(i.default.types.mdat,4);this._aacSamples.length;){if(h=this._aacSamples.shift(),u=h.unit,o.set(u,_),_+=u.byteLength,p=h.pts-this._initDTS,v=h.dts-this._initDTS,void 0!==d)a=this._PTSNormalize(p,d),r=this._PTSNormalize(v,d),n.duration=(r-d)/this.PES2MP4SCALEFACTOR,n.duration<0&&(n.duration=0);else{if(a=this._PTSNormalize(p,this.nextAacPts),r=this._PTSNormalize(v,this.nextAacPts),this.nextAacPts&&this.nextAacPts!==a){var c=Math.round(1e3*(a-this.nextAacPts)/this.PES_TIMESCALE),m=Math.abs(c);if(m>1&&300>m)c>0?(e.logger.log("AAC:"+c+" ms hole between fragments detected,filling it"),a=Math.max(this.nextAacPts,this.lastAacDts),r=a):e.logger.log("AAC:"+-c+" ms overlapping between fragments detected");else if(m){var E=this.PES_TIMESCALE*this.timeOffset;if(Math.abs(E-a)>3600*this.PES_TIMESCALE){var S=E-a;a=E,r=a,this._initPTS-=S,this._initDTS-=S}}}A=Math.max(0,a),g=Math.max(0,r)}n={size:u.byteLength,cts:0,duration:0,flags:{isLeading:0,isDependedOn:0,hasRedundancy:0,degradPrio:0,dependsOn:1}},l.push(n),d=r}l.length>=2&&(n.duration=l[l.length-2].duration),this.lastAacDts=r,this.nextAacPts=a+this.PES2MP4SCALEFACTOR*n.duration,this._aacSamplesLength=0,f.samples=l,L=i.default.moof(f.sequenceNumber++,g/this.PES2MP4SCALEFACTOR,f),f.samples=[],s.default.trigger(t.default.FRAG_PARSING_DATA,{moof:L,mdat:o,startPTS:A/this.PES_TIMESCALE,endPTS:this.nextAacPts/this.PES_TIMESCALE,startDTS:g/this.PES_TIMESCALE,endDTS:(r+this.PES2MP4SCALEFACTOR*n.duration)/this.PES_TIMESCALE,type:"audio",nb:l.length})}},{key:"_ADTStoAudioConfig",value:function(o,l,r){var s,t,a,n,i,d=navigator.userAgent.toLowerCase(),h=[96e3,88200,64e3,48e3,44100,32e3,24e3,22050,16e3,12e3];return s=((192&o[l+2])>>>6)+1,t=(60&o[l+2])>>>2,n=(1&o[l+2])<<2,n|=(192&o[l+3])>>>6,e.logger.log("manifest codec:"+r+",ADTS data:type:"+s+",sampleingIndex:"+t+"["+h[t]+"kHz],channelConfig:"+n),-1!==d.indexOf("firefox")?t>=6?(s=5,i=new Array(4),a=t-3):(s=2,i=new Array(2),a=t):-1!==d.indexOf("android")?(s=2,i=new Array(2),a=t):(s=5,i=new Array(4),r&&-1!==r.indexOf("mp4a.40.5")||!r&&t>=6?a=t-3:(r&&-1!==r.indexOf("mp4a.40.2")&&(t>=6||1===n)&&(s=2,i=new Array(2)),a=t)),i[0]=s<<3,i[0]|=(14&t)>>1,i[1]|=(1&t)<<7,i[1]|=n<<3,5===s&&(i[1]|=(14&a)>>1,i[2]=(1&a)<<7,i[2]|=8,i[3]=0),{config:i,samplerate:h[t],channelCount:n,codec:"mp4a.40."+s}}},{key:"_generateInitSegment",value:function(){-1===this._avcId?(this._aacTrack.config&&(s.default.trigger(t.default.FRAG_PARSING_INIT_SEGMENT,{audioMoov:i.default.initSegment([this._aacTrack]),audioCodec:this._aacTrack.codec,audioChannelCount:this._aacTrack.channelCount}),this._initSegGenerated=!0),void 0===this._initPTS&&(this._initPTS=this._aacSamples[0].pts-this.PES_TIMESCALE*this.timeOffset,this._initDTS=this._aacSamples[0].dts-this.PES_TIMESCALE*this.timeOffset)):-1===this._aacId?this._avcTrack.sps&&this._avcTrack.pps&&(s.default.trigger(t.default.FRAG_PARSING_INIT_SEGMENT,{videoMoov:i.default.initSegment([this._avcTrack]),videoCodec:this._avcTrack.codec,videoWidth:this._avcTrack.width,videoHeight:this._avcTrack.height}),this._initSegGenerated=!0,void 0===this._initPTS&&(this._initPTS=this._avcSamples[0].pts-this.PES_TIMESCALE*this.timeOffset,this._initDTS=this._avcSamples[0].dts-this.PES_TIMESCALE*this.timeOffset)):this._aacTrack.config&&this._avcTrack.sps&&this._avcTrack.pps&&(s.default.trigger(t.default.FRAG_PARSING_INIT_SEGMENT,{audioMoov:i.default.initSegment([this._aacTrack]),audioCodec:this._aacTrack.codec,audioChannelCount:this._aacTrack.channelCount,videoMoov:i.default.initSegment([this._avcTrack]),videoCodec:this._avcTrack.codec,videoWidth:this._avcTrack.width,videoHeight:this._avcTrack.height}),this._initSegGenerated=!0,void 0===this._initPTS&&(this._initPTS=Math.min(this._avcSamples[0].pts,this._aacSamples[0].pts)-this.PES_TIMESCALE*this.timeOffset,this._initDTS=Math.min(this._avcSamples[0].dts,this._aacSamples[0].dts)-this.PES_TIMESCALE*this.timeOffset))}}]),a}();o.default=g,l.exports=o.default},{"../errors":9,"../events":10,"../observer":14,"../remux/mp4-generator":15,"../utils/logger":17,"./exp-golomb":6}],8:[function(a,r,i){"use strict";function s(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(i,"__esModule",{value:!0});var d=a("../events"),e=s(d),n=a("../demux/tsdemuxer"),o=s(n),l=a("../observer"),t=s(l),h=function(i){i.addEventListener("message",function(e){switch(e.data.cmd){case"init":i.demuxer=new o.default;break;case"demux":i.demuxer.push(new Uint8Array(e.data.data),e.data.audioCodec,e.data.videoCodec,e.data.timeOffset,e.data.cc,e.data.level,e.data.duration),i.demuxer.end()}}),t.default.on(e.default.FRAG_PARSING_INIT_SEGMENT,function(a,t){var e={event:a},s=[];t.audioCodec&&(e.audioCodec=t.audioCodec,e.audioMoov=t.audioMoov.buffer,e.audioChannelCount=t.audioChannelCount,s.push(e.audioMoov)),t.videoCodec&&(e.videoCodec=t.videoCodec,e.videoMoov=t.videoMoov.buffer,e.videoWidth=t.videoWidth,e.videoHeight=t.videoHeight,s.push(e.videoMoov)),i.postMessage(e,s)}),t.default.on(e.default.FRAG_PARSING_DATA,function(s,e){var t={event:s,type:e.type,startPTS:e.startPTS,endPTS:e.endPTS,startDTS:e.startDTS,endDTS:e.endDTS,moof:e.moof.buffer,mdat:e.mdat.buffer,nb:e.nb};i.postMessage(t,[t.moof,t.mdat])}),t.default.on(e.default.FRAG_PARSED,function(e){i.postMessage({event:e})}),t.default.on(e.default.ERROR,function(e,t){i.postMessage({event:e,data:t})})};i.default=h,r.exports=i.default},{"../demux/tsdemuxer":7,"../events":10,"../observer":14}],9:[function(s,a,e){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var t={NETWORK_ERROR:"hlsNetworkError",MEDIA_ERROR:"hlsMediaError",OTHER_ERROR:"hlsOtherError"};e.ErrorTypes=t;var i={MANIFEST_LOAD_ERROR:"manifestLoadError",MANIFEST_LOAD_TIMEOUT:"manifestLoadTimeOut",MANIFEST_PARSING_ERROR:"manifestParsingError",LEVEL_LOAD_ERROR:"levelLoadError",LEVEL_LOAD_TIMEOUT:"levelLoadTimeOut",LEVEL_SWITCH_ERROR:"levelSwitchError",FRAG_LOAD_ERROR:"fragLoadError",FRAG_LOOP_LOADING_ERROR:"fragLoopLoadingError",FRAG_LOAD_TIMEOUT:"fragLoadTimeOut",FRAG_PARSING_ERROR:"fragParsingError",FRAG_APPENDING_ERROR:"fragAppendingError"};e.ErrorDetails=i},{}],10:[function(i,t,e){"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.default={MSE_ATTACHED:"hlsMediaSourceAttached",MSE_DETACHED:"hlsMediaSourceDetached",MANIFEST_LOADING:"hlsManifestLoading",MANIFEST_LOADED:"hlsManifestLoaded",MANIFEST_PARSED:"hlsManifestParsed",LEVEL_LOADING:"hlsLevelLoading",LEVEL_LOADED:"hlsLevelLoaded",LEVEL_SWITCH:"hlsLevelSwitch",FRAG_LOADING:"hlsFragLoading",FRAG_LOAD_PROGRESS:"hlsFragLoadProgress",FRAG_LOAD_EMERGENCY_ABORTED:"hlsFragLoadEmergencyAborted",FRAG_LOADED:"hlsFragLoaded",FRAG_PARSING_INIT_SEGMENT:"hlsFragParsingInitSegment",FRAG_PARSING_DATA:"hlsFragParsingData",FRAG_PARSED:"hlsFragParsed",FRAG_BUFFERED:"hlsFragBuffered",FRAG_CHANGED:"hlsFragChanged",FPS_DROP:"hlsFPSDrop",ERROR:"hlsError"},t.exports=e.default},{}],11:[function(t,f,r){"use strict";function s(e){return e&&e.__esModule?e:{default:e}}function v(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(r,"__esModule",{value:!0});var o=function(){function e(s,i){for(var t=0;t0;)switch(e.shift()){case"RES":t.width=parseInt(e.shift()),t.height=parseInt(e.shift());break;case"BAND":t.bitrate=parseInt(e.shift());break;case"NAME":t.name=e.shift();break;case"CODECS":for(s=e.shift().split(",");s.length>0;)i=s.shift(),-1!==i.indexOf("avc1")?t.videoCodec=this.avc1toavcoti(i):t.audioCodec=i}a.push(t),t={}}return a}},{key:"avc1toavcoti",value:function(i){var e,t=i.split(".");return t.length>2?(e=t.shift()+".",e+=parseInt(t.shift()).toString(16),e+=("00"+parseInt(t.shift()).toString(16)).substr(-4)):e=i,e}},{key:"parseLevelPlaylist",value:function(l,a,d){var e,r,i=0,s=0,t={url:a,fragments:[],live:!0,startSN:0},n=0;for(r=/(?:#EXT-X-(MEDIA-SEQUENCE):(\d+))|(?:#EXT-X-(TARGETDURATION):(\d+))|(?:#EXT(INF):([\d\.]+)[^\r\n]*[\r\n]+([^\r\n]+)|(?:#EXT-X-(ENDLIST))|(?:#EXT-X-(DIS)CONTINUITY))/g;null!==(e=r.exec(l));)switch(e.shift(),e=e.filter(function(e){return void 0!==e}),e[0]){case"MEDIA-SEQUENCE":i=t.startSN=parseInt(e[1]);break;case"TARGETDURATION":t.targetduration=parseFloat(e[1]);break;case"ENDLIST":t.live=!1;break;case"DIS":n++;break;case"INF":var o=parseFloat(e[1]);t.fragments.push({url:this.resolve(e[2],a),duration:o,start:s,sn:i++,level:d,cc:n}),s+=o}return t.totalduration=s,t.endSN=i-1,t}},{key:"loadsuccess",value:function(n,a){var o,r=n.currentTarget.responseText,s=n.currentTarget.responseURL,l=this.id,d=this.id2;void 0===s&&(s=this.url),a.tload=new Date,a.mtime=new Date(n.currentTarget.getResponseHeader("Last-Modified")),0===r.indexOf("#EXTM3U")?r.indexOf("#EXTINF:")>0?null===this.id?t.default.trigger(e.default.MANIFEST_LOADED,{levels:[{url:s}],url:s,stats:a}):t.default.trigger(e.default.LEVEL_LOADED,{details:this.parseLevelPlaylist(r,s,l),level:l,id:d,stats:a}):(o=this.parseMasterPlaylist(r,s),o.length?t.default.trigger(e.default.MANIFEST_LOADED,{levels:o,url:s,stats:a}):t.default.trigger(e.default.ERROR,{type:i.ErrorTypes.NETWORK_ERROR,details:i.ErrorDetails.MANIFEST_PARSING_ERROR,fatal:!0,url:s,reason:"no level found in manifest"})):t.default.trigger(e.default.ERROR,{type:i.ErrorTypes.NETWORK_ERROR,details:i.ErrorDetails.MANIFEST_PARSING_ERROR,fatal:!0,url:s,reason:"no EXTM3U delimiter"})}},{key:"loaderror",value:function(r){var s,a;null===this.id?(s=i.ErrorDetails.MANIFEST_LOAD_ERROR,a=!0):(s=i.ErrorDetails.LEVEL_LOAD_ERROR,a=!1),this.loader.abort(),t.default.trigger(e.default.ERROR,{type:i.ErrorTypes.NETWORK_ERROR,details:s,fatal:a,url:this.url,loader:this.loader,response:r.currentTarget,level:this.id,id:this.id2})}},{key:"loadtimeout",value:function(){var s,a;null===this.id?(s=i.ErrorDetails.MANIFEST_LOAD_TIMEOUT,a=!0):(s=i.ErrorDetails.LEVEL_LOAD_TIMEOUT,a=!1),this.loader.abort(),t.default.trigger(e.default.ERROR,{type:i.ErrorTypes.NETWORK_ERROR,details:s,fatal:a,url:this.url,loader:this.loader,level:this.id,id:this.id2})}}]),s}();a.default=o,n.exports=a.default},{"../errors":9,"../events":10,"../observer":14}],14:[function(i,s,t){"use strict";function a(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var r=i("events"),n=a(r),e=new n.default;e.trigger=function(s){for(var i=arguments.length,a=Array(i>1?i-1:0),t=1;i>t;t++)a[t-1]=arguments[t];e.emit.apply(e,[s,s].concat(a))},e.off=function(a){for(var i=arguments.length,s=Array(i>1?i-1:0),t=1;i>t;t++)s[t-1]=arguments[t];e.removeListener.apply(e,[a].concat(s))},t.default=e,s.exports=t.default},{events:1}],15:[function(r,t,e){"use strict";function i(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(e,"__esModule",{value:!0});var s=function(){function e(s,i){for(var t=0;t>24&255,t>>16&255,t>>8&255,255&t,i>>24,i>>16&255,i>>8&255,255&i,85,196,0,0]))}},{key:"mdia",value:function(t){return e.box(e.types.mdia,e.mdhd(t.timescale,t.duration),e.hdlr(t.type),e.minf(t))}},{key:"mfhd",value:function(t){return e.box(e.types.mfhd,new Uint8Array([0,0,0,0,t>>24,t>>16&255,t>>8&255,255&t]))}},{key:"minf",value:function(t){return"audio"===t.type?e.box(e.types.minf,e.box(e.types.smhd,e.SMHD),e.DINF,e.stbl(t)):e.box(e.types.minf,e.box(e.types.vmhd,e.VMHD),e.DINF,e.stbl(t))}},{key:"moof",value:function(t,i,s){return e.box(e.types.moof,e.mfhd(t),e.traf(s,i))}},{key:"moov",value:function(t){for(var i=t.length,s=[];i--;)s[i]=e.trak(t[i]);return e.box.apply(null,[e.types.moov,e.mvhd(t[0].timescale,t[0].duration)].concat(s).concat(e.mvex(t)))}},{key:"mvex",value:function(i){for(var t=i.length,s=[];t--;)s[t]=e.trex(i[t]);return e.box.apply(null,[e.types.mvex].concat(s))}},{key:"mvhd",value:function(t,i){var s=new Uint8Array([0,0,0,0,0,0,0,1,0,0,0,2,t>>24&255,t>>16&255,t>>8&255,255&t,i>>24&255,i>>16&255,i>>8&255,255&i,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,64,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255]);return e.box(e.types.mvhd,s)}},{key:"sdtp",value:function(r){var i,t,s=r.samples||[],a=new Uint8Array(4+s.length);for(t=0;t>>8&255),s.push(255&t.sps[i].byteLength),s=s.concat(Array.prototype.slice.call(t.sps[i]));for(i=0;i>>8&255),a.push(255&t.pps[i].byteLength),a=a.concat(Array.prototype.slice.call(t.pps[i]));return e.box(e.types.avc1,new Uint8Array([0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,t.width>>8&255,255&t.width,t.height>>8&255,255&t.height,0,72,0,0,0,72,0,0,0,0,0,0,0,1,19,118,105,100,101,111,106,115,45,99,111,110,116,114,105,98,45,104,108,115,0,0,0,0,0,0,0,0,0,0,0,0,0,24,17,17]),e.box(e.types.avcC,new Uint8Array([1,t.profileIdc,t.profileCompat,t.levelIdc,255].concat([t.sps.length]).concat(s).concat([t.pps.length]).concat(a))),e.box(e.types.btrt,new Uint8Array([0,28,156,128,0,45,198,192,0,45,198,192])))}},{key:"esds",value:function(e){return new Uint8Array([0,0,0,0,3,23+e.config.length,0,1,0,4,15+e.config.length,64,21,0,0,0,0,0,0,0,0,0,0,0,5].concat([e.config.length]).concat(e.config).concat([6,1,2]))}},{key:"mp4a",value:function(t){return e.box(e.types.mp4a,new Uint8Array([0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,t.channelCount,0,16,0,0,0,0,t.audiosamplerate>>8&255,255&t.audiosamplerate,0,0]),e.box(e.types.esds,e.esds(t)))}},{key:"stsd",value:function(t){return"audio"===t.type?e.box(e.types.stsd,e.STSD,e.mp4a(t)):e.box(e.types.stsd,e.STSD,e.avc1(t))}},{key:"tkhd",value:function(t){return e.box(e.types.tkhd,new Uint8Array([0,0,0,7,0,0,0,0,0,0,0,0,t.id>>24&255,t.id>>16&255,t.id>>8&255,255&t.id,0,0,0,0,t.duration>>24,t.duration>>16&255,t.duration>>8&255,255&t.duration,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,64,0,0,0,t.width>>8&255,255&t.width,0,0,t.height>>8&255,255&t.height,0,0]))}},{key:"traf",value:function(t,i){var s=e.sdtp(t);return e.box(e.types.traf,e.box(e.types.tfhd,new Uint8Array([0,0,0,0,t.id>>24,t.id>>16&255,t.id>>8&255,255&t.id])),e.box(e.types.tfdt,new Uint8Array([0,0,0,0,i>>24,i>>16&255,i>>8&255,255&i])),e.trun(t,s.length+16+16+8+16+8+8),s)}},{key:"trak",value:function(t){return t.duration=t.duration||4294967295,e.box(e.types.trak,e.tkhd(t),e.mdia(t))}},{key:"trex",value:function(t){return e.box(e.types.trex,new Uint8Array([0,0,0,0,t.id>>24,t.id>>16&255,t.id>>8&255,255&t.id,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,1]))}},{key:"trun",value:function(n,s){var i,t,a,r;for(i=n.samples||[],r=new Uint8Array(12+16*i.length),s+=8+r.byteLength,r.set([0,0,15,1,i.length>>>24&255,i.length>>>16&255,i.length>>>8&255,255&i.length,s>>>24&255,s>>>16&255,s>>>8&255,255&s],0),a=0;a>>24&255,t.duration>>>16&255,t.duration>>>8&255,255&t.duration,t.size>>>24&255,t.size>>>16&255,t.size>>>8&255,255&t.size,t.flags.isLeading<<2|t.flags.dependsOn,t.flags.isDependedOn<<6|t.flags.hasRedundancy<<4|t.flags.paddingValue<<1|t.flags.isNonSync,61440&t.flags.degradPrio,15&t.flags.degradPrio,t.cts>>>24&255,t.cts>>>16&255,t.cts>>>8&255,255&t.cts],12+16*a);return e.box(e.types.trun,r)}},{key:"initSegment",value:function(s){e.types||e.init();var t,i=e.moov(s);return t=new Uint8Array(e.FTYP.byteLength+i.byteLength),t.set(e.FTYP),t.set(i,e.FTYP.byteLength),t}}]),e}();e.default=a,t.exports=e.default},{}],16:[function(s,r,i){"use strict";function a(e){return e&&e.__esModule?e:{default:e}}function d(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(i,"__esModule",{value:!0});var h=function(){function e(s,i){for(var t=0;t