public/lib/modules/aurora.js/aurora.js
(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.AV = f()}})(function(){var define,module,exports;return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var Asset, BufferSource, Decoder, Demuxer, EventEmitter, FileSource, HTTPSource,
bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
EventEmitter = require('./core/events');
HTTPSource = require('./sources/node/http');
FileSource = require('./sources/node/file');
BufferSource = require('./sources/buffer');
Demuxer = require('./demuxer');
Decoder = require('./decoder');
Asset = (function(superClass) {
extend(Asset, superClass);
function Asset(source) {
this.source = source;
this._decode = bind(this._decode, this);
this.findDecoder = bind(this.findDecoder, this);
this.probe = bind(this.probe, this);
this.buffered = 0;
this.duration = null;
this.format = null;
this.metadata = null;
this.active = false;
this.demuxer = null;
this.decoder = null;
this.source.once('data', this.probe);
this.source.on('error', (function(_this) {
return function(err) {
_this.emit('error', err);
return _this.stop();
};
})(this));
this.source.on('progress', (function(_this) {
return function(buffered) {
_this.buffered = buffered;
return _this.emit('buffer', _this.buffered);
};
})(this));
}
Asset.fromURL = function(url, opts) {
return new Asset(new HTTPSource(url, opts));
};
Asset.fromFile = function(file) {
return new Asset(new FileSource(file));
};
Asset.fromBuffer = function(buffer) {
return new Asset(new BufferSource(buffer));
};
Asset.prototype.start = function(decode) {
if (this.active) {
return;
}
if (decode != null) {
this.shouldDecode = decode;
}
if (this.shouldDecode == null) {
this.shouldDecode = true;
}
this.active = true;
this.source.start();
if (this.decoder && this.shouldDecode) {
return this._decode();
}
};
Asset.prototype.stop = function() {
if (!this.active) {
return;
}
this.active = false;
return this.source.pause();
};
Asset.prototype.get = function(event, callback) {
if (event !== 'format' && event !== 'duration' && event !== 'metadata') {
return;
}
if (this[event] != null) {
return callback(this[event]);
} else {
this.once(event, (function(_this) {
return function(value) {
_this.stop();
return callback(value);
};
})(this));
return this.start();
}
};
Asset.prototype.decodePacket = function() {
return this.decoder.decode();
};
Asset.prototype.decodeToBuffer = function(callback) {
var chunks, dataHandler, length;
length = 0;
chunks = [];
this.on('data', dataHandler = function(chunk) {
length += chunk.length;
return chunks.push(chunk);
});
this.once('end', function() {
var buf, chunk, j, len, offset;
buf = new Float32Array(length);
offset = 0;
for (j = 0, len = chunks.length; j < len; j++) {
chunk = chunks[j];
buf.set(chunk, offset);
offset += chunk.length;
}
this.off('data', dataHandler);
return callback(buf);
});
return this.start();
};
Asset.prototype.probe = function(chunk) {
var demuxer;
if (!this.active) {
return;
}
demuxer = Demuxer.find(chunk);
if (!demuxer) {
return this.emit('error', 'A demuxer for this container was not found.');
}
this.demuxer = new demuxer(this.source, chunk);
this.demuxer.on('format', this.findDecoder);
this.demuxer.on('duration', (function(_this) {
return function(duration) {
_this.duration = duration;
return _this.emit('duration', _this.duration);
};
})(this));
this.demuxer.on('metadata', (function(_this) {
return function(metadata) {
_this.metadata = metadata;
return _this.emit('metadata', _this.metadata);
};
})(this));
return this.demuxer.on('error', (function(_this) {
return function(err) {
_this.emit('error', err);
return _this.stop();
};
})(this));
};
Asset.prototype.findDecoder = function(format) {
var decoder, div;
this.format = format;
if (!this.active) {
return;
}
this.emit('format', this.format);
decoder = Decoder.find(this.format.formatID);
if (!decoder) {
return this.emit('error', "A decoder for " + this.format.formatID + " was not found.");
}
this.decoder = new decoder(this.demuxer, this.format);
if (this.format.floatingPoint) {
this.decoder.on('data', (function(_this) {
return function(buffer) {
return _this.emit('data', buffer);
};
})(this));
} else {
div = Math.pow(2, this.format.bitsPerChannel - 1);
this.decoder.on('data', (function(_this) {
return function(buffer) {
var buf, i, j, len, sample;
buf = new Float32Array(buffer.length);
for (i = j = 0, len = buffer.length; j < len; i = ++j) {
sample = buffer[i];
buf[i] = sample / div;
}
return _this.emit('data', buf);
};
})(this));
}
this.decoder.on('error', (function(_this) {
return function(err) {
_this.emit('error', err);
return _this.stop();
};
})(this));
this.decoder.on('end', (function(_this) {
return function() {
return _this.emit('end');
};
})(this));
this.emit('decodeStart');
if (this.shouldDecode) {
return this._decode();
}
};
Asset.prototype._decode = function() {
while (this.decoder.decode() && this.active) {
continue;
}
if (this.active) {
return this.decoder.once('data', this._decode);
}
};
Asset.prototype.destroy = function() {
var ref, ref1, ref2;
this.stop();
if ((ref = this.demuxer) != null) {
ref.off();
}
if ((ref1 = this.decoder) != null) {
ref1.off();
}
if ((ref2 = this.source) != null) {
ref2.off();
}
return this.off();
};
return Asset;
})(EventEmitter);
module.exports = Asset;
}).call(this);
},{"./core/events":8,"./decoder":11,"./demuxer":14,"./sources/buffer":31,"./sources/node/file":29,"./sources/node/http":30}],2:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var key, ref, val;
ref = require('./aurora_base');
for (key in ref) {
val = ref[key];
exports[key] = val;
}
require('./demuxers/caf');
require('./demuxers/m4a');
require('./demuxers/aiff');
require('./demuxers/wave');
require('./demuxers/au');
require('./decoders/lpcm');
require('./decoders/xlaw');
}).call(this);
},{"./aurora_base":3,"./decoders/lpcm":12,"./decoders/xlaw":13,"./demuxers/aiff":15,"./demuxers/au":16,"./demuxers/caf":17,"./demuxers/m4a":18,"./demuxers/wave":19}],3:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
exports.Base = require('./core/base');
exports.Buffer = require('./core/buffer');
exports.BufferList = require('./core/bufferlist');
exports.Stream = require('./core/stream');
exports.Bitstream = require('./core/bitstream');
exports.EventEmitter = require('./core/events');
exports.UnderflowError = require('./core/underflow');
exports.HTTPSource = require('./sources/node/http');
exports.FileSource = require('./sources/node/file');
exports.BufferSource = require('./sources/buffer');
exports.Demuxer = require('./demuxer');
exports.Decoder = require('./decoder');
exports.AudioDevice = require('./device');
exports.Asset = require('./asset');
exports.Player = require('./player');
exports.Filter = require('./filter');
exports.VolumeFilter = require('./filters/volume');
exports.BalanceFilter = require('./filters/balance');
}).call(this);
},{"./asset":1,"./core/base":4,"./core/bitstream":5,"./core/buffer":6,"./core/bufferlist":7,"./core/events":8,"./core/stream":9,"./core/underflow":10,"./decoder":11,"./demuxer":14,"./device":20,"./filter":24,"./filters/balance":25,"./filters/volume":26,"./player":27,"./sources/buffer":31,"./sources/node/file":29,"./sources/node/http":30}],4:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var Base,
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty,
indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; };
Base = (function() {
var fnTest;
function Base() {}
fnTest = /\b_super\b/;
Base.extend = function(prop) {
var Class, _super, fn, key, keys, ref;
Class = (function(superClass) {
extend(Class, superClass);
function Class() {
return Class.__super__.constructor.apply(this, arguments);
}
return Class;
})(this);
if (typeof prop === 'function') {
keys = Object.keys(Class.prototype);
prop.call(Class, Class);
prop = {};
ref = Class.prototype;
for (key in ref) {
fn = ref[key];
if (indexOf.call(keys, key) < 0) {
prop[key] = fn;
}
}
}
_super = Class.__super__;
for (key in prop) {
fn = prop[key];
if (typeof fn === 'function' && fnTest.test(fn)) {
(function(key, fn) {
return Class.prototype[key] = function() {
var ret, tmp;
tmp = this._super;
this._super = _super[key];
ret = fn.apply(this, arguments);
this._super = tmp;
return ret;
};
})(key, fn);
} else {
Class.prototype[key] = fn;
}
}
return Class;
};
return Base;
})();
module.exports = Base;
}).call(this);
},{}],5:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var Bitstream;
Bitstream = (function() {
function Bitstream(stream) {
this.stream = stream;
this.bitPosition = 0;
}
Bitstream.prototype.copy = function() {
var result;
result = new Bitstream(this.stream.copy());
result.bitPosition = this.bitPosition;
return result;
};
Bitstream.prototype.offset = function() {
return 8 * this.stream.offset + this.bitPosition;
};
Bitstream.prototype.available = function(bits) {
return this.stream.available((bits + 8 - this.bitPosition) / 8);
};
Bitstream.prototype.advance = function(bits) {
var pos;
pos = this.bitPosition + bits;
this.stream.advance(pos >> 3);
return this.bitPosition = pos & 7;
};
Bitstream.prototype.rewind = function(bits) {
var pos;
pos = this.bitPosition - bits;
this.stream.rewind(Math.abs(pos >> 3));
return this.bitPosition = pos & 7;
};
Bitstream.prototype.seek = function(offset) {
var curOffset;
curOffset = this.offset();
if (offset > curOffset) {
return this.advance(offset - curOffset);
} else if (offset < curOffset) {
return this.rewind(curOffset - offset);
}
};
Bitstream.prototype.align = function() {
if (this.bitPosition !== 0) {
this.bitPosition = 0;
return this.stream.advance(1);
}
};
Bitstream.prototype.read = function(bits, signed) {
var a, a0, a1, a2, a3, a4, mBits;
if (bits === 0) {
return 0;
}
mBits = bits + this.bitPosition;
if (mBits <= 8) {
a = ((this.stream.peekUInt8() << this.bitPosition) & 0xff) >>> (8 - bits);
} else if (mBits <= 16) {
a = ((this.stream.peekUInt16() << this.bitPosition) & 0xffff) >>> (16 - bits);
} else if (mBits <= 24) {
a = ((this.stream.peekUInt24() << this.bitPosition) & 0xffffff) >>> (24 - bits);
} else if (mBits <= 32) {
a = (this.stream.peekUInt32() << this.bitPosition) >>> (32 - bits);
} else if (mBits <= 40) {
a0 = this.stream.peekUInt8(0) * 0x0100000000;
a1 = this.stream.peekUInt8(1) << 24 >>> 0;
a2 = this.stream.peekUInt8(2) << 16;
a3 = this.stream.peekUInt8(3) << 8;
a4 = this.stream.peekUInt8(4);
a = a0 + a1 + a2 + a3 + a4;
a %= Math.pow(2, 40 - this.bitPosition);
a = Math.floor(a / Math.pow(2, 40 - this.bitPosition - bits));
} else {
throw new Error("Too many bits!");
}
if (signed) {
if (mBits < 32) {
if (a >>> (bits - 1)) {
a = ((1 << bits >>> 0) - a) * -1;
}
} else {
if (a / Math.pow(2, bits - 1) | 0) {
a = (Math.pow(2, bits) - a) * -1;
}
}
}
this.advance(bits);
return a;
};
Bitstream.prototype.peek = function(bits, signed) {
var a, a0, a1, a2, a3, a4, mBits;
if (bits === 0) {
return 0;
}
mBits = bits + this.bitPosition;
if (mBits <= 8) {
a = ((this.stream.peekUInt8() << this.bitPosition) & 0xff) >>> (8 - bits);
} else if (mBits <= 16) {
a = ((this.stream.peekUInt16() << this.bitPosition) & 0xffff) >>> (16 - bits);
} else if (mBits <= 24) {
a = ((this.stream.peekUInt24() << this.bitPosition) & 0xffffff) >>> (24 - bits);
} else if (mBits <= 32) {
a = (this.stream.peekUInt32() << this.bitPosition) >>> (32 - bits);
} else if (mBits <= 40) {
a0 = this.stream.peekUInt8(0) * 0x0100000000;
a1 = this.stream.peekUInt8(1) << 24 >>> 0;
a2 = this.stream.peekUInt8(2) << 16;
a3 = this.stream.peekUInt8(3) << 8;
a4 = this.stream.peekUInt8(4);
a = a0 + a1 + a2 + a3 + a4;
a %= Math.pow(2, 40 - this.bitPosition);
a = Math.floor(a / Math.pow(2, 40 - this.bitPosition - bits));
} else {
throw new Error("Too many bits!");
}
if (signed) {
if (mBits < 32) {
if (a >>> (bits - 1)) {
a = ((1 << bits >>> 0) - a) * -1;
}
} else {
if (a / Math.pow(2, bits - 1) | 0) {
a = (Math.pow(2, bits) - a) * -1;
}
}
}
return a;
};
Bitstream.prototype.readLSB = function(bits, signed) {
var a, mBits;
if (bits === 0) {
return 0;
}
if (bits > 40) {
throw new Error("Too many bits!");
}
mBits = bits + this.bitPosition;
a = (this.stream.peekUInt8(0)) >>> this.bitPosition;
if (mBits > 8) {
a |= (this.stream.peekUInt8(1)) << (8 - this.bitPosition);
}
if (mBits > 16) {
a |= (this.stream.peekUInt8(2)) << (16 - this.bitPosition);
}
if (mBits > 24) {
a += (this.stream.peekUInt8(3)) << (24 - this.bitPosition) >>> 0;
}
if (mBits > 32) {
a += (this.stream.peekUInt8(4)) * Math.pow(2, 32 - this.bitPosition);
}
if (mBits >= 32) {
a %= Math.pow(2, bits);
} else {
a &= (1 << bits) - 1;
}
if (signed) {
if (mBits < 32) {
if (a >>> (bits - 1)) {
a = ((1 << bits >>> 0) - a) * -1;
}
} else {
if (a / Math.pow(2, bits - 1) | 0) {
a = (Math.pow(2, bits) - a) * -1;
}
}
}
this.advance(bits);
return a;
};
Bitstream.prototype.peekLSB = function(bits, signed) {
var a, mBits;
if (bits === 0) {
return 0;
}
if (bits > 40) {
throw new Error("Too many bits!");
}
mBits = bits + this.bitPosition;
a = (this.stream.peekUInt8(0)) >>> this.bitPosition;
if (mBits > 8) {
a |= (this.stream.peekUInt8(1)) << (8 - this.bitPosition);
}
if (mBits > 16) {
a |= (this.stream.peekUInt8(2)) << (16 - this.bitPosition);
}
if (mBits > 24) {
a += (this.stream.peekUInt8(3)) << (24 - this.bitPosition) >>> 0;
}
if (mBits > 32) {
a += (this.stream.peekUInt8(4)) * Math.pow(2, 32 - this.bitPosition);
}
if (mBits >= 32) {
a %= Math.pow(2, bits);
} else {
a &= (1 << bits) - 1;
}
if (signed) {
if (mBits < 32) {
if (a >>> (bits - 1)) {
a = ((1 << bits >>> 0) - a) * -1;
}
} else {
if (a / Math.pow(2, bits - 1) | 0) {
a = (Math.pow(2, bits) - a) * -1;
}
}
}
return a;
};
return Bitstream;
})();
module.exports = Bitstream;
}).call(this);
},{}],6:[function(require,module,exports){
(function (global){(function (){
// Generated by CoffeeScript 1.12.7
(function() {
var AVBuffer;
AVBuffer = (function() {
var BlobBuilder, URL;
function AVBuffer(input) {
var ref;
if (input instanceof Uint8Array) {
this.data = input;
} else if (input instanceof ArrayBuffer || Array.isArray(input) || typeof input === 'number' || ((ref = global.Buffer) != null ? ref.isBuffer(input) : void 0)) {
this.data = new Uint8Array(input);
} else if (input.buffer instanceof ArrayBuffer) {
this.data = new Uint8Array(input.buffer, input.byteOffset, input.length * input.BYTES_PER_ELEMENT);
} else if (input instanceof AVBuffer) {
this.data = input.data;
} else {
throw new Error("Constructing buffer with unknown type.");
}
this.length = this.data.length;
this.next = null;
this.prev = null;
}
AVBuffer.allocate = function(size) {
return new AVBuffer(size);
};
AVBuffer.prototype.copy = function() {
return new AVBuffer(new Uint8Array(this.data));
};
AVBuffer.prototype.slice = function(position, length) {
if (length == null) {
length = this.length;
}
if (position === 0 && length >= this.length) {
return new AVBuffer(this.data);
} else {
return new AVBuffer(this.data.subarray(position, position + length));
}
};
BlobBuilder = global.BlobBuilder || global.MozBlobBuilder || global.WebKitBlobBuilder;
URL = global.URL || global.webkitURL || global.mozURL;
AVBuffer.makeBlob = function(data, type) {
var bb;
if (type == null) {
type = 'application/octet-stream';
}
try {
return new Blob([data], {
type: type
});
} catch (error) {}
if (BlobBuilder != null) {
bb = new BlobBuilder;
bb.append(data);
return bb.getBlob(type);
}
return null;
};
AVBuffer.makeBlobURL = function(data, type) {
return URL != null ? URL.createObjectURL(this.makeBlob(data, type)) : void 0;
};
AVBuffer.revokeBlobURL = function(url) {
return URL != null ? URL.revokeObjectURL(url) : void 0;
};
AVBuffer.prototype.toBlob = function() {
return AVBuffer.makeBlob(this.data.buffer);
};
AVBuffer.prototype.toBlobURL = function() {
return AVBuffer.makeBlobURL(this.data.buffer);
};
return AVBuffer;
})();
module.exports = AVBuffer;
}).call(this);
}).call(this)}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
},{}],7:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var BufferList;
BufferList = (function() {
function BufferList() {
this.first = null;
this.last = null;
this.numBuffers = 0;
this.availableBytes = 0;
this.availableBuffers = 0;
}
BufferList.prototype.copy = function() {
var result;
result = new BufferList;
result.first = this.first;
result.last = this.last;
result.numBuffers = this.numBuffers;
result.availableBytes = this.availableBytes;
result.availableBuffers = this.availableBuffers;
return result;
};
BufferList.prototype.append = function(buffer) {
var ref;
buffer.prev = this.last;
if ((ref = this.last) != null) {
ref.next = buffer;
}
this.last = buffer;
if (this.first == null) {
this.first = buffer;
}
this.availableBytes += buffer.length;
this.availableBuffers++;
return this.numBuffers++;
};
BufferList.prototype.advance = function() {
if (this.first) {
this.availableBytes -= this.first.length;
this.availableBuffers--;
this.first = this.first.next;
return this.first != null;
}
return false;
};
BufferList.prototype.rewind = function() {
var ref;
if (this.first && !this.first.prev) {
return false;
}
this.first = ((ref = this.first) != null ? ref.prev : void 0) || this.last;
if (this.first) {
this.availableBytes += this.first.length;
this.availableBuffers++;
}
return this.first != null;
};
BufferList.prototype.reset = function() {
var results;
results = [];
while (this.rewind()) {
continue;
}
return results;
};
return BufferList;
})();
module.exports = BufferList;
}).call(this);
},{}],8:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var Base, EventEmitter,
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty,
slice = [].slice;
Base = require('./base');
EventEmitter = (function(superClass) {
extend(EventEmitter, superClass);
function EventEmitter() {
return EventEmitter.__super__.constructor.apply(this, arguments);
}
EventEmitter.prototype.on = function(event, fn) {
var base;
if (this.events == null) {
this.events = {};
}
if ((base = this.events)[event] == null) {
base[event] = [];
}
return this.events[event].push(fn);
};
EventEmitter.prototype.off = function(event, fn) {
var events, index, ref;
if (this.events == null) {
return;
}
if ((ref = this.events) != null ? ref[event] : void 0) {
if (fn != null) {
index = this.events[event].indexOf(fn);
if (~index) {
return this.events[event].splice(index, 1);
}
} else {
return this.events[event];
}
} else if (event == null) {
return events = {};
}
};
EventEmitter.prototype.once = function(event, fn) {
var cb;
return this.on(event, cb = function() {
this.off(event, cb);
return fn.apply(this, arguments);
});
};
EventEmitter.prototype.emit = function() {
var args, event, fn, i, len, ref, ref1;
event = arguments[0], args = 2 <= arguments.length ? slice.call(arguments, 1) : [];
if (!((ref = this.events) != null ? ref[event] : void 0)) {
return;
}
ref1 = this.events[event].slice();
for (i = 0, len = ref1.length; i < len; i++) {
fn = ref1[i];
fn.apply(this, args);
}
};
return EventEmitter;
})(Base);
module.exports = EventEmitter;
}).call(this);
},{"./base":4}],9:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var AVBuffer, BufferList, Stream, UnderflowError;
BufferList = require('./bufferlist');
AVBuffer = require('./buffer');
UnderflowError = require('./underflow');
Stream = (function() {
var buf, decodeString, float32, float64, float64Fallback, float80, int16, int32, int8, nativeEndian, uint16, uint32, uint8;
buf = new ArrayBuffer(16);
uint8 = new Uint8Array(buf);
int8 = new Int8Array(buf);
uint16 = new Uint16Array(buf);
int16 = new Int16Array(buf);
uint32 = new Uint32Array(buf);
int32 = new Int32Array(buf);
float32 = new Float32Array(buf);
if (typeof Float64Array !== "undefined" && Float64Array !== null) {
float64 = new Float64Array(buf);
}
nativeEndian = new Uint16Array(new Uint8Array([0x12, 0x34]).buffer)[0] === 0x3412;
function Stream(list1) {
this.list = list1;
this.localOffset = 0;
this.offset = 0;
}
Stream.fromBuffer = function(buffer) {
var list;
list = new BufferList;
list.append(buffer);
return new Stream(list);
};
Stream.prototype.copy = function() {
var result;
result = new Stream(this.list.copy());
result.localOffset = this.localOffset;
result.offset = this.offset;
return result;
};
Stream.prototype.available = function(bytes) {
return bytes <= this.list.availableBytes - this.localOffset;
};
Stream.prototype.remainingBytes = function() {
return this.list.availableBytes - this.localOffset;
};
Stream.prototype.advance = function(bytes) {
if (!this.available(bytes)) {
throw new UnderflowError();
}
this.localOffset += bytes;
this.offset += bytes;
while (this.list.first && this.localOffset >= this.list.first.length) {
this.localOffset -= this.list.first.length;
this.list.advance();
}
return this;
};
Stream.prototype.rewind = function(bytes) {
if (bytes > this.offset) {
throw new UnderflowError();
}
if (!this.list.first) {
this.list.rewind();
this.localOffset = this.list.first.length;
}
this.localOffset -= bytes;
this.offset -= bytes;
while (this.list.first.prev && this.localOffset < 0) {
this.list.rewind();
this.localOffset += this.list.first.length;
}
return this;
};
Stream.prototype.seek = function(position) {
if (position > this.offset) {
return this.advance(position - this.offset);
} else if (position < this.offset) {
return this.rewind(this.offset - position);
}
};
Stream.prototype.readUInt8 = function() {
var a;
if (!this.available(1)) {
throw new UnderflowError();
}
a = this.list.first.data[this.localOffset];
this.localOffset += 1;
this.offset += 1;
if (this.localOffset === this.list.first.length) {
this.localOffset = 0;
this.list.advance();
}
return a;
};
Stream.prototype.peekUInt8 = function(offset) {
var buffer;
if (offset == null) {
offset = 0;
}
if (!this.available(offset + 1)) {
throw new UnderflowError();
}
offset = this.localOffset + offset;
buffer = this.list.first;
while (buffer) {
if (buffer.length > offset) {
return buffer.data[offset];
}
offset -= buffer.length;
buffer = buffer.next;
}
return 0;
};
Stream.prototype.read = function(bytes, littleEndian) {
var i, j, k, ref, ref1;
if (littleEndian == null) {
littleEndian = false;
}
if (littleEndian === nativeEndian) {
for (i = j = 0, ref = bytes; j < ref; i = j += 1) {
uint8[i] = this.readUInt8();
}
} else {
for (i = k = ref1 = bytes - 1; k >= 0; i = k += -1) {
uint8[i] = this.readUInt8();
}
}
};
Stream.prototype.peek = function(bytes, offset, littleEndian) {
var i, j, k, ref, ref1;
if (littleEndian == null) {
littleEndian = false;
}
if (littleEndian === nativeEndian) {
for (i = j = 0, ref = bytes; j < ref; i = j += 1) {
uint8[i] = this.peekUInt8(offset + i);
}
} else {
for (i = k = 0, ref1 = bytes; k < ref1; i = k += 1) {
uint8[bytes - i - 1] = this.peekUInt8(offset + i);
}
}
};
Stream.prototype.readInt8 = function() {
this.read(1);
return int8[0];
};
Stream.prototype.peekInt8 = function(offset) {
if (offset == null) {
offset = 0;
}
this.peek(1, offset);
return int8[0];
};
Stream.prototype.readUInt16 = function(littleEndian) {
this.read(2, littleEndian);
return uint16[0];
};
Stream.prototype.peekUInt16 = function(offset, littleEndian) {
if (offset == null) {
offset = 0;
}
this.peek(2, offset, littleEndian);
return uint16[0];
};
Stream.prototype.readInt16 = function(littleEndian) {
this.read(2, littleEndian);
return int16[0];
};
Stream.prototype.peekInt16 = function(offset, littleEndian) {
if (offset == null) {
offset = 0;
}
this.peek(2, offset, littleEndian);
return int16[0];
};
Stream.prototype.readUInt24 = function(littleEndian) {
if (littleEndian) {
return this.readUInt16(true) + (this.readUInt8() << 16);
} else {
return (this.readUInt16() << 8) + this.readUInt8();
}
};
Stream.prototype.peekUInt24 = function(offset, littleEndian) {
if (offset == null) {
offset = 0;
}
if (littleEndian) {
return this.peekUInt16(offset, true) + (this.peekUInt8(offset + 2) << 16);
} else {
return (this.peekUInt16(offset) << 8) + this.peekUInt8(offset + 2);
}
};
Stream.prototype.readInt24 = function(littleEndian) {
if (littleEndian) {
return this.readUInt16(true) + (this.readInt8() << 16);
} else {
return (this.readInt16() << 8) + this.readUInt8();
}
};
Stream.prototype.peekInt24 = function(offset, littleEndian) {
if (offset == null) {
offset = 0;
}
if (littleEndian) {
return this.peekUInt16(offset, true) + (this.peekInt8(offset + 2) << 16);
} else {
return (this.peekInt16(offset) << 8) + this.peekUInt8(offset + 2);
}
};
Stream.prototype.readUInt32 = function(littleEndian) {
this.read(4, littleEndian);
return uint32[0];
};
Stream.prototype.peekUInt32 = function(offset, littleEndian) {
if (offset == null) {
offset = 0;
}
this.peek(4, offset, littleEndian);
return uint32[0];
};
Stream.prototype.readInt32 = function(littleEndian) {
this.read(4, littleEndian);
return int32[0];
};
Stream.prototype.peekInt32 = function(offset, littleEndian) {
if (offset == null) {
offset = 0;
}
this.peek(4, offset, littleEndian);
return int32[0];
};
Stream.prototype.readFloat32 = function(littleEndian) {
this.read(4, littleEndian);
return float32[0];
};
Stream.prototype.peekFloat32 = function(offset, littleEndian) {
if (offset == null) {
offset = 0;
}
this.peek(4, offset, littleEndian);
return float32[0];
};
Stream.prototype.readFloat64 = function(littleEndian) {
this.read(8, littleEndian);
if (float64) {
return float64[0];
} else {
return float64Fallback();
}
};
float64Fallback = function() {
var exp, frac, high, low, out, sign;
low = uint32[0], high = uint32[1];
if (!high || high === 0x80000000) {
return 0.0;
}
sign = 1 - (high >>> 31) * 2;
exp = (high >>> 20) & 0x7ff;
frac = high & 0xfffff;
if (exp === 0x7ff) {
if (frac) {
return 0/0;
}
return sign * 2e308;
}
exp -= 1023;
out = (frac | 0x100000) * Math.pow(2, exp - 20);
out += low * Math.pow(2, exp - 52);
return sign * out;
};
Stream.prototype.peekFloat64 = function(offset, littleEndian) {
if (offset == null) {
offset = 0;
}
this.peek(8, offset, littleEndian);
if (float64) {
return float64[0];
} else {
return float64Fallback();
}
};
Stream.prototype.readFloat80 = function(littleEndian) {
this.read(10, littleEndian);
return float80();
};
float80 = function() {
var a0, a1, exp, high, low, out, sign;
high = uint32[0], low = uint32[1];
a0 = uint8[9];
a1 = uint8[8];
sign = 1 - (a0 >>> 7) * 2;
exp = ((a0 & 0x7F) << 8) | a1;
if (exp === 0 && low === 0 && high === 0) {
return 0;
}
if (exp === 0x7fff) {
if (low === 0 && high === 0) {
return sign * 2e308;
}
return 0/0;
}
exp -= 16383;
out = low * Math.pow(2, exp - 31);
out += high * Math.pow(2, exp - 63);
return sign * out;
};
Stream.prototype.peekFloat80 = function(offset, littleEndian) {
if (offset == null) {
offset = 0;
}
this.peek(10, offset, littleEndian);
return float80();
};
Stream.prototype.readBuffer = function(length) {
var i, j, ref, result, to;
result = AVBuffer.allocate(length);
to = result.data;
for (i = j = 0, ref = length; j < ref; i = j += 1) {
to[i] = this.readUInt8();
}
return result;
};
Stream.prototype.peekBuffer = function(offset, length) {
var i, j, ref, result, to;
if (offset == null) {
offset = 0;
}
result = AVBuffer.allocate(length);
to = result.data;
for (i = j = 0, ref = length; j < ref; i = j += 1) {
to[i] = this.peekUInt8(offset + i);
}
return result;
};
Stream.prototype.readSingleBuffer = function(length) {
var result;
result = this.list.first.slice(this.localOffset, length);
this.advance(result.length);
return result;
};
Stream.prototype.peekSingleBuffer = function(offset, length) {
var result;
result = this.list.first.slice(this.localOffset + offset, length);
return result;
};
Stream.prototype.readString = function(length, encoding) {
if (encoding == null) {
encoding = 'ascii';
}
return decodeString.call(this, 0, length, encoding, true);
};
Stream.prototype.peekString = function(offset, length, encoding) {
if (offset == null) {
offset = 0;
}
if (encoding == null) {
encoding = 'ascii';
}
return decodeString.call(this, offset, length, encoding, false);
};
decodeString = function(offset, length, encoding, advance) {
var b1, b2, b3, b4, bom, c, end, littleEndian, nullEnd, pt, result, w1, w2;
encoding = encoding.toLowerCase();
nullEnd = length === null ? 0 : -1;
if (length == null) {
length = 2e308;
}
end = offset + length;
result = '';
switch (encoding) {
case 'ascii':
case 'latin1':
while (offset < end && (c = this.peekUInt8(offset++)) !== nullEnd) {
result += String.fromCharCode(c);
}
break;
case 'utf8':
case 'utf-8':
while (offset < end && (b1 = this.peekUInt8(offset++)) !== nullEnd) {
if ((b1 & 0x80) === 0) {
result += String.fromCharCode(b1);
} else if ((b1 & 0xe0) === 0xc0) {
b2 = this.peekUInt8(offset++) & 0x3f;
result += String.fromCharCode(((b1 & 0x1f) << 6) | b2);
} else if ((b1 & 0xf0) === 0xe0) {
b2 = this.peekUInt8(offset++) & 0x3f;
b3 = this.peekUInt8(offset++) & 0x3f;
result += String.fromCharCode(((b1 & 0x0f) << 12) | (b2 << 6) | b3);
} else if ((b1 & 0xf8) === 0xf0) {
b2 = this.peekUInt8(offset++) & 0x3f;
b3 = this.peekUInt8(offset++) & 0x3f;
b4 = this.peekUInt8(offset++) & 0x3f;
pt = (((b1 & 0x0f) << 18) | (b2 << 12) | (b3 << 6) | b4) - 0x10000;
result += String.fromCharCode(0xd800 + (pt >> 10), 0xdc00 + (pt & 0x3ff));
}
}
break;
case 'utf16-be':
case 'utf16be':
case 'utf16le':
case 'utf16-le':
case 'utf16bom':
case 'utf16-bom':
switch (encoding) {
case 'utf16be':
case 'utf16-be':
littleEndian = false;
break;
case 'utf16le':
case 'utf16-le':
littleEndian = true;
break;
case 'utf16bom':
case 'utf16-bom':
if (length < 2 || (bom = this.peekUInt16(offset)) === nullEnd) {
if (advance) {
this.advance(offset += 2);
}
return result;
}
littleEndian = bom === 0xfffe;
offset += 2;
}
while (offset < end && (w1 = this.peekUInt16(offset, littleEndian)) !== nullEnd) {
offset += 2;
if (w1 < 0xd800 || w1 > 0xdfff) {
result += String.fromCharCode(w1);
} else {
if (w1 > 0xdbff) {
throw new Error("Invalid utf16 sequence.");
}
w2 = this.peekUInt16(offset, littleEndian);
if (w2 < 0xdc00 || w2 > 0xdfff) {
throw new Error("Invalid utf16 sequence.");
}
result += String.fromCharCode(w1, w2);
offset += 2;
}
}
if (w1 === nullEnd) {
offset += 2;
}
break;
default:
throw new Error("Unknown encoding: " + encoding);
}
if (advance) {
this.advance(offset);
}
return result;
};
return Stream;
})();
module.exports = Stream;
}).call(this);
},{"./buffer":6,"./bufferlist":7,"./underflow":10}],10:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var UnderflowError,
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
UnderflowError = (function(superClass) {
extend(UnderflowError, superClass);
function UnderflowError() {
UnderflowError.__super__.constructor.apply(this, arguments);
this.name = 'UnderflowError';
this.stack = new Error().stack;
}
return UnderflowError;
})(Error);
module.exports = UnderflowError;
}).call(this);
},{}],11:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var Bitstream, BufferList, Decoder, EventEmitter, Stream, UnderflowError,
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
EventEmitter = require('./core/events');
BufferList = require('./core/bufferlist');
Stream = require('./core/stream');
Bitstream = require('./core/bitstream');
UnderflowError = require('./core/underflow');
Decoder = (function(superClass) {
var codecs;
extend(Decoder, superClass);
function Decoder(demuxer, format) {
var list;
this.demuxer = demuxer;
this.format = format;
list = new BufferList;
this.stream = new Stream(list);
this.bitstream = new Bitstream(this.stream);
this.receivedFinalBuffer = false;
this.waiting = false;
this.demuxer.on('cookie', (function(_this) {
return function(cookie) {
var error;
try {
return _this.setCookie(cookie);
} catch (error1) {
error = error1;
return _this.emit('error', error);
}
};
})(this));
this.demuxer.on('data', (function(_this) {
return function(chunk) {
list.append(chunk);
if (_this.waiting) {
return _this.decode();
}
};
})(this));
this.demuxer.on('end', (function(_this) {
return function() {
_this.receivedFinalBuffer = true;
if (_this.waiting) {
return _this.decode();
}
};
})(this));
this.init();
}
Decoder.prototype.init = function() {};
Decoder.prototype.setCookie = function(cookie) {};
Decoder.prototype.readChunk = function() {};
Decoder.prototype.decode = function() {
var error, offset, packet;
this.waiting = !this.receivedFinalBuffer;
offset = this.bitstream.offset();
try {
packet = this.readChunk();
} catch (error1) {
error = error1;
if (!(error instanceof UnderflowError)) {
this.emit('error', error);
return false;
}
}
if (packet) {
this.emit('data', packet);
if (this.receivedFinalBuffer) {
this.emit('end');
}
return true;
} else if (!this.receivedFinalBuffer) {
this.bitstream.seek(offset);
this.waiting = true;
} else {
this.emit('end');
}
return false;
};
Decoder.prototype.seek = function(timestamp) {
var seekPoint;
seekPoint = this.demuxer.seek(timestamp);
this.stream.seek(seekPoint.offset);
return seekPoint.timestamp;
};
codecs = {};
Decoder.register = function(id, decoder) {
return codecs[id] = decoder;
};
Decoder.find = function(id) {
return codecs[id] || null;
};
return Decoder;
})(EventEmitter);
module.exports = Decoder;
}).call(this);
},{"./core/bitstream":5,"./core/bufferlist":7,"./core/events":8,"./core/stream":9,"./core/underflow":10}],12:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var Decoder, LPCMDecoder,
bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
Decoder = require('../decoder');
LPCMDecoder = (function(superClass) {
extend(LPCMDecoder, superClass);
function LPCMDecoder() {
this.readChunk = bind(this.readChunk, this);
return LPCMDecoder.__super__.constructor.apply(this, arguments);
}
Decoder.register('lpcm', LPCMDecoder);
LPCMDecoder.prototype.readChunk = function() {
var chunkSize, i, j, k, l, littleEndian, m, n, o, output, ref, ref1, ref2, ref3, ref4, ref5, samples, stream;
stream = this.stream;
littleEndian = this.format.littleEndian;
chunkSize = Math.min(4096, stream.remainingBytes());
samples = chunkSize / (this.format.bitsPerChannel / 8) | 0;
if (chunkSize < this.format.bitsPerChannel / 8) {
return null;
}
if (this.format.floatingPoint) {
switch (this.format.bitsPerChannel) {
case 32:
output = new Float32Array(samples);
for (i = j = 0, ref = samples; j < ref; i = j += 1) {
output[i] = stream.readFloat32(littleEndian);
}
break;
case 64:
output = new Float64Array(samples);
for (i = k = 0, ref1 = samples; k < ref1; i = k += 1) {
output[i] = stream.readFloat64(littleEndian);
}
break;
default:
throw new Error('Unsupported bit depth.');
}
} else {
switch (this.format.bitsPerChannel) {
case 8:
output = new Int8Array(samples);
for (i = l = 0, ref2 = samples; l < ref2; i = l += 1) {
output[i] = stream.readInt8();
}
break;
case 16:
output = new Int16Array(samples);
for (i = m = 0, ref3 = samples; m < ref3; i = m += 1) {
output[i] = stream.readInt16(littleEndian);
}
break;
case 24:
output = new Int32Array(samples);
for (i = n = 0, ref4 = samples; n < ref4; i = n += 1) {
output[i] = stream.readInt24(littleEndian);
}
break;
case 32:
output = new Int32Array(samples);
for (i = o = 0, ref5 = samples; o < ref5; i = o += 1) {
output[i] = stream.readInt32(littleEndian);
}
break;
default:
throw new Error('Unsupported bit depth.');
}
}
return output;
};
return LPCMDecoder;
})(Decoder);
}).call(this);
},{"../decoder":11}],13:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var Decoder, XLAWDecoder,
bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
Decoder = require('../decoder');
XLAWDecoder = (function(superClass) {
var BIAS, QUANT_MASK, SEG_MASK, SEG_SHIFT, SIGN_BIT;
extend(XLAWDecoder, superClass);
function XLAWDecoder() {
this.readChunk = bind(this.readChunk, this);
return XLAWDecoder.__super__.constructor.apply(this, arguments);
}
Decoder.register('ulaw', XLAWDecoder);
Decoder.register('alaw', XLAWDecoder);
SIGN_BIT = 0x80;
QUANT_MASK = 0xf;
SEG_SHIFT = 4;
SEG_MASK = 0x70;
BIAS = 0x84;
XLAWDecoder.prototype.init = function() {
var i, j, k, seg, t, table, val;
this.format.bitsPerChannel = 16;
this.table = table = new Int16Array(256);
if (this.format.formatID === 'ulaw') {
for (i = j = 0; j < 256; i = ++j) {
val = ~i;
t = ((val & QUANT_MASK) << 3) + BIAS;
t <<= (val & SEG_MASK) >>> SEG_SHIFT;
table[i] = val & SIGN_BIT ? BIAS - t : t - BIAS;
}
} else {
for (i = k = 0; k < 256; i = ++k) {
val = i ^ 0x55;
t = val & QUANT_MASK;
seg = (val & SEG_MASK) >>> SEG_SHIFT;
if (seg) {
t = (t + t + 1 + 32) << (seg + 2);
} else {
t = (t + t + 1) << 3;
}
table[i] = val & SIGN_BIT ? t : -t;
}
}
};
XLAWDecoder.prototype.readChunk = function() {
var i, j, output, ref, ref1, samples, stream, table;
ref = this, stream = ref.stream, table = ref.table;
samples = Math.min(4096, this.stream.remainingBytes());
if (samples === 0) {
return;
}
output = new Int16Array(samples);
for (i = j = 0, ref1 = samples; j < ref1; i = j += 1) {
output[i] = table[stream.readUInt8()];
}
return output;
};
return XLAWDecoder;
})(Decoder);
}).call(this);
},{"../decoder":11}],14:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var BufferList, Demuxer, EventEmitter, Stream,
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
EventEmitter = require('./core/events');
BufferList = require('./core/bufferlist');
Stream = require('./core/stream');
Demuxer = (function(superClass) {
var formats;
extend(Demuxer, superClass);
Demuxer.probe = function(buffer) {
return false;
};
function Demuxer(source, chunk) {
var list, received;
list = new BufferList;
list.append(chunk);
this.stream = new Stream(list);
received = false;
source.on('data', (function(_this) {
return function(chunk) {
var e;
received = true;
list.append(chunk);
try {
return _this.readChunk(chunk);
} catch (error) {
e = error;
return _this.emit('error', e);
}
};
})(this));
source.on('error', (function(_this) {
return function(err) {
return _this.emit('error', err);
};
})(this));
source.on('end', (function(_this) {
return function() {
if (!received) {
_this.readChunk(chunk);
}
return _this.emit('end');
};
})(this));
this.seekPoints = [];
this.init();
}
Demuxer.prototype.init = function() {};
Demuxer.prototype.readChunk = function(chunk) {};
Demuxer.prototype.addSeekPoint = function(offset, timestamp) {
var index;
index = this.searchTimestamp(timestamp);
return this.seekPoints.splice(index, 0, {
offset: offset,
timestamp: timestamp
});
};
Demuxer.prototype.searchTimestamp = function(timestamp, backward) {
var high, low, mid, time;
low = 0;
high = this.seekPoints.length;
if (high > 0 && this.seekPoints[high - 1].timestamp < timestamp) {
return high;
}
while (low < high) {
mid = (low + high) >> 1;
time = this.seekPoints[mid].timestamp;
if (time < timestamp) {
low = mid + 1;
} else if (time >= timestamp) {
high = mid;
}
}
if (high > this.seekPoints.length) {
high = this.seekPoints.length;
}
return high;
};
Demuxer.prototype.seek = function(timestamp) {
var index, seekPoint;
if (this.format && this.format.framesPerPacket > 0 && this.format.bytesPerPacket > 0) {
seekPoint = {
timestamp: timestamp,
offset: this.format.bytesPerPacket * timestamp / this.format.framesPerPacket
};
return seekPoint;
} else {
index = this.searchTimestamp(timestamp);
return this.seekPoints[index];
}
};
formats = [];
Demuxer.register = function(demuxer) {
return formats.push(demuxer);
};
Demuxer.find = function(buffer) {
var e, format, i, len, offset, stream;
stream = Stream.fromBuffer(buffer);
for (i = 0, len = formats.length; i < len; i++) {
format = formats[i];
offset = stream.offset;
try {
if (format.probe(stream)) {
return format;
}
} catch (error) {
e = error;
}
stream.seek(offset);
}
return null;
};
return Demuxer;
})(EventEmitter);
module.exports = Demuxer;
}).call(this);
},{"./core/bufferlist":7,"./core/events":8,"./core/stream":9}],15:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var AIFFDemuxer, Demuxer,
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
Demuxer = require('../demuxer');
AIFFDemuxer = (function(superClass) {
extend(AIFFDemuxer, superClass);
function AIFFDemuxer() {
return AIFFDemuxer.__super__.constructor.apply(this, arguments);
}
Demuxer.register(AIFFDemuxer);
AIFFDemuxer.probe = function(buffer) {
var ref;
return buffer.peekString(0, 4) === 'FORM' && ((ref = buffer.peekString(8, 4)) === 'AIFF' || ref === 'AIFC');
};
AIFFDemuxer.prototype.readChunk = function() {
var buffer, format, offset, ref;
if (!this.readStart && this.stream.available(12)) {
if (this.stream.readString(4) !== 'FORM') {
return this.emit('error', 'Invalid AIFF.');
}
this.fileSize = this.stream.readUInt32();
this.fileType = this.stream.readString(4);
this.readStart = true;
if ((ref = this.fileType) !== 'AIFF' && ref !== 'AIFC') {
return this.emit('error', 'Invalid AIFF.');
}
}
while (this.stream.available(1)) {
if (!this.readHeaders && this.stream.available(8)) {
this.type = this.stream.readString(4);
this.len = this.stream.readUInt32();
}
switch (this.type) {
case 'COMM':
if (!this.stream.available(this.len)) {
return;
}
this.format = {
formatID: 'lpcm',
channelsPerFrame: this.stream.readUInt16(),
sampleCount: this.stream.readUInt32(),
bitsPerChannel: this.stream.readUInt16(),
sampleRate: this.stream.readFloat80(),
framesPerPacket: 1,
littleEndian: false,
floatingPoint: false
};
this.format.bytesPerPacket = (this.format.bitsPerChannel / 8) * this.format.channelsPerFrame;
if (this.fileType === 'AIFC') {
format = this.stream.readString(4);
this.format.littleEndian = format === 'sowt' && this.format.bitsPerChannel > 8;
this.format.floatingPoint = format === 'fl32' || format === 'fl64';
if (format === 'twos' || format === 'sowt' || format === 'fl32' || format === 'fl64' || format === 'NONE') {
format = 'lpcm';
}
this.format.formatID = format;
this.len -= 4;
}
this.stream.advance(this.len - 18);
this.emit('format', this.format);
this.emit('duration', this.format.sampleCount / this.format.sampleRate * 1000 | 0);
break;
case 'SSND':
if (!(this.readSSNDHeader && this.stream.available(4))) {
offset = this.stream.readUInt32();
this.stream.advance(4);
this.stream.advance(offset);
this.readSSNDHeader = true;
}
buffer = this.stream.readSingleBuffer(this.len);
this.len -= buffer.length;
this.readHeaders = this.len > 0;
this.emit('data', buffer);
break;
default:
if (!this.stream.available(this.len)) {
return;
}
this.stream.advance(this.len);
}
if (this.type !== 'SSND') {
this.readHeaders = false;
}
}
};
return AIFFDemuxer;
})(Demuxer);
}).call(this);
},{"../demuxer":14}],16:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var AUDemuxer, Demuxer,
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
Demuxer = require('../demuxer');
AUDemuxer = (function(superClass) {
var bps, formats;
extend(AUDemuxer, superClass);
function AUDemuxer() {
return AUDemuxer.__super__.constructor.apply(this, arguments);
}
Demuxer.register(AUDemuxer);
AUDemuxer.probe = function(buffer) {
return buffer.peekString(0, 4) === '.snd';
};
bps = [8, 8, 16, 24, 32, 32, 64];
bps[26] = 8;
formats = {
1: 'ulaw',
27: 'alaw'
};
AUDemuxer.prototype.readChunk = function() {
var bytes, dataSize, encoding, size;
if (!this.readHeader && this.stream.available(24)) {
if (this.stream.readString(4) !== '.snd') {
return this.emit('error', 'Invalid AU file.');
}
size = this.stream.readUInt32();
dataSize = this.stream.readUInt32();
encoding = this.stream.readUInt32();
this.format = {
formatID: formats[encoding] || 'lpcm',
littleEndian: false,
floatingPoint: encoding === 6 || encoding === 7,
bitsPerChannel: bps[encoding - 1],
sampleRate: this.stream.readUInt32(),
channelsPerFrame: this.stream.readUInt32(),
framesPerPacket: 1
};
if (this.format.bitsPerChannel == null) {
return this.emit('error', 'Unsupported encoding in AU file.');
}
this.format.bytesPerPacket = (this.format.bitsPerChannel / 8) * this.format.channelsPerFrame;
if (dataSize !== 0xffffffff) {
bytes = this.format.bitsPerChannel / 8;
this.emit('duration', dataSize / bytes / this.format.channelsPerFrame / this.format.sampleRate * 1000 | 0);
}
this.emit('format', this.format);
this.readHeader = true;
}
if (this.readHeader) {
while (this.stream.available(1)) {
this.emit('data', this.stream.readSingleBuffer(this.stream.remainingBytes()));
}
}
};
return AUDemuxer;
})(Demuxer);
}).call(this);
},{"../demuxer":14}],17:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var CAFDemuxer, Demuxer, M4ADemuxer,
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
Demuxer = require('../demuxer');
M4ADemuxer = require('./m4a');
CAFDemuxer = (function(superClass) {
extend(CAFDemuxer, superClass);
function CAFDemuxer() {
return CAFDemuxer.__super__.constructor.apply(this, arguments);
}
Demuxer.register(CAFDemuxer);
CAFDemuxer.probe = function(buffer) {
return buffer.peekString(0, 4) === 'caff';
};
CAFDemuxer.prototype.readChunk = function() {
var buffer, byteOffset, cookie, entries, flags, i, j, k, key, metadata, offset, ref, ref1, sampleOffset, value;
if (!this.format && this.stream.available(64)) {
if (this.stream.readString(4) !== 'caff') {
return this.emit('error', "Invalid CAF, does not begin with 'caff'");
}
this.stream.advance(4);
if (this.stream.readString(4) !== 'desc') {
return this.emit('error', "Invalid CAF, 'caff' is not followed by 'desc'");
}
if (!(this.stream.readUInt32() === 0 && this.stream.readUInt32() === 32)) {
return this.emit('error', "Invalid 'desc' size, should be 32");
}
this.format = {};
this.format.sampleRate = this.stream.readFloat64();
this.format.formatID = this.stream.readString(4);
flags = this.stream.readUInt32();
if (this.format.formatID === 'lpcm') {
this.format.floatingPoint = Boolean(flags & 1);
this.format.littleEndian = Boolean(flags & 2);
}
this.format.bytesPerPacket = this.stream.readUInt32();
this.format.framesPerPacket = this.stream.readUInt32();
this.format.channelsPerFrame = this.stream.readUInt32();
this.format.bitsPerChannel = this.stream.readUInt32();
this.emit('format', this.format);
}
while (this.stream.available(1)) {
if (!this.headerCache) {
this.headerCache = {
type: this.stream.readString(4),
oversize: this.stream.readUInt32() !== 0,
size: this.stream.readUInt32()
};
if (this.headerCache.oversize) {
return this.emit('error', "Holy Shit, an oversized file, not supported in JS");
}
}
switch (this.headerCache.type) {
case 'kuki':
if (this.stream.available(this.headerCache.size)) {
if (this.format.formatID === 'aac ') {
offset = this.stream.offset + this.headerCache.size;
if (cookie = M4ADemuxer.readEsds(this.stream)) {
this.emit('cookie', cookie);
}
this.stream.seek(offset);
} else {
buffer = this.stream.readBuffer(this.headerCache.size);
this.emit('cookie', buffer);
}
this.headerCache = null;
}
break;
case 'pakt':
if (this.stream.available(this.headerCache.size)) {
if (this.stream.readUInt32() !== 0) {
return this.emit('error', 'Sizes greater than 32 bits are not supported.');
}
this.numPackets = this.stream.readUInt32();
if (this.stream.readUInt32() !== 0) {
return this.emit('error', 'Sizes greater than 32 bits are not supported.');
}
this.numFrames = this.stream.readUInt32();
this.primingFrames = this.stream.readUInt32();
this.remainderFrames = this.stream.readUInt32();
this.emit('duration', this.numFrames / this.format.sampleRate * 1000 | 0);
this.sentDuration = true;
byteOffset = 0;
sampleOffset = 0;
for (i = j = 0, ref = this.numPackets; j < ref; i = j += 1) {
this.addSeekPoint(byteOffset, sampleOffset);
byteOffset += this.format.bytesPerPacket || M4ADemuxer.readDescrLen(this.stream);
sampleOffset += this.format.framesPerPacket || M4ADemuxer.readDescrLen(this.stream);
}
this.headerCache = null;
}
break;
case 'info':
entries = this.stream.readUInt32();
metadata = {};
for (i = k = 0, ref1 = entries; 0 <= ref1 ? k < ref1 : k > ref1; i = 0 <= ref1 ? ++k : --k) {
key = this.stream.readString(null);
value = this.stream.readString(null);
metadata[key] = value;
}
this.emit('metadata', metadata);
this.headerCache = null;
break;
case 'data':
if (!this.sentFirstDataChunk) {
this.stream.advance(4);
this.headerCache.size -= 4;
if (this.format.bytesPerPacket !== 0 && !this.sentDuration) {
this.numFrames = this.headerCache.size / this.format.bytesPerPacket;
this.emit('duration', this.numFrames / this.format.sampleRate * 1000 | 0);
}
this.sentFirstDataChunk = true;
}
buffer = this.stream.readSingleBuffer(this.headerCache.size);
this.headerCache.size -= buffer.length;
this.emit('data', buffer);
if (this.headerCache.size <= 0) {
this.headerCache = null;
}
break;
default:
if (this.stream.available(this.headerCache.size)) {
this.stream.advance(this.headerCache.size);
this.headerCache = null;
}
}
}
};
return CAFDemuxer;
})(Demuxer);
}).call(this);
},{"../demuxer":14,"./m4a":18}],18:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var Demuxer, M4ADemuxer,
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty,
indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; };
Demuxer = require('../demuxer');
M4ADemuxer = (function(superClass) {
var BITS_PER_CHANNEL, TYPES, after, atom, atoms, bool, containers, diskTrack, genres, meta, string;
extend(M4ADemuxer, superClass);
function M4ADemuxer() {
return M4ADemuxer.__super__.constructor.apply(this, arguments);
}
Demuxer.register(M4ADemuxer);
TYPES = ['M4A ', 'M4P ', 'M4B ', 'M4V ', 'isom', 'mp42', 'qt '];
M4ADemuxer.probe = function(buffer) {
var ref;
return buffer.peekString(4, 4) === 'ftyp' && (ref = buffer.peekString(8, 4), indexOf.call(TYPES, ref) >= 0);
};
M4ADemuxer.prototype.init = function() {
this.atoms = [];
this.offsets = [];
this.track = null;
return this.tracks = [];
};
atoms = {};
containers = {};
atom = function(name, fn) {
var c, container, k, len1, ref;
c = [];
ref = name.split('.').slice(0, -1);
for (k = 0, len1 = ref.length; k < len1; k++) {
container = ref[k];
c.push(container);
containers[c.join('.')] = true;
}
if (atoms[name] == null) {
atoms[name] = {};
}
return atoms[name].fn = fn;
};
after = function(name, fn) {
if (atoms[name] == null) {
atoms[name] = {};
}
return atoms[name].after = fn;
};
M4ADemuxer.prototype.readChunk = function() {
var handler, path, type;
this["break"] = false;
while (this.stream.available(1) && !this["break"]) {
if (!this.readHeaders) {
if (!this.stream.available(8)) {
return;
}
this.len = this.stream.readUInt32() - 8;
this.type = this.stream.readString(4);
if (this.len === 0) {
continue;
}
this.atoms.push(this.type);
this.offsets.push(this.stream.offset + this.len);
this.readHeaders = true;
}
path = this.atoms.join('.');
handler = atoms[path];
if (handler != null ? handler.fn : void 0) {
if (!(this.stream.available(this.len) || path === 'mdat')) {
return;
}
handler.fn.call(this);
if (path in containers) {
this.readHeaders = false;
}
} else if (path in containers) {
this.readHeaders = false;
} else {
if (!this.stream.available(this.len)) {
return;
}
this.stream.advance(this.len);
}
while (this.stream.offset >= this.offsets[this.offsets.length - 1]) {
handler = atoms[this.atoms.join('.')];
if (handler != null ? handler.after : void 0) {
handler.after.call(this);
}
type = this.atoms.pop();
this.offsets.pop();
this.readHeaders = false;
}
}
};
atom('ftyp', function() {
var ref;
if (ref = this.stream.readString(4), indexOf.call(TYPES, ref) < 0) {
return this.emit('error', 'Not a valid M4A file.');
}
return this.stream.advance(this.len - 4);
});
atom('moov.trak', function() {
this.track = {};
return this.tracks.push(this.track);
});
atom('moov.trak.tkhd', function() {
this.stream.advance(4);
this.stream.advance(8);
this.track.id = this.stream.readUInt32();
return this.stream.advance(this.len - 16);
});
atom('moov.trak.mdia.hdlr', function() {
this.stream.advance(4);
this.stream.advance(4);
this.track.type = this.stream.readString(4);
this.stream.advance(12);
return this.stream.advance(this.len - 24);
});
atom('moov.trak.mdia.mdhd', function() {
this.stream.advance(4);
this.stream.advance(8);
this.track.timeScale = this.stream.readUInt32();
this.track.duration = this.stream.readUInt32();
return this.stream.advance(4);
});
BITS_PER_CHANNEL = {
ulaw: 8,
alaw: 8,
in24: 24,
in32: 32,
fl32: 32,
fl64: 64
};
atom('moov.trak.mdia.minf.stbl.stsd', function() {
var format, numEntries, ref, ref1, version;
this.stream.advance(4);
numEntries = this.stream.readUInt32();
if (this.track.type !== 'soun') {
return this.stream.advance(this.len - 8);
}
if (numEntries !== 1) {
return this.emit('error', "Only expecting one entry in sample description atom!");
}
this.stream.advance(4);
format = this.track.format = {};
format.formatID = this.stream.readString(4);
this.stream.advance(6);
this.stream.advance(2);
version = this.stream.readUInt16();
this.stream.advance(6);
format.channelsPerFrame = this.stream.readUInt16();
format.bitsPerChannel = this.stream.readUInt16();
this.stream.advance(4);
format.sampleRate = this.stream.readUInt16();
this.stream.advance(2);
if (version === 1) {
format.framesPerPacket = this.stream.readUInt32();
this.stream.advance(4);
format.bytesPerFrame = this.stream.readUInt32();
this.stream.advance(4);
} else if (version !== 0) {
this.emit('error', 'Unknown version in stsd atom');
}
if (BITS_PER_CHANNEL[format.formatID] != null) {
format.bitsPerChannel = BITS_PER_CHANNEL[format.formatID];
}
format.floatingPoint = (ref = format.formatID) === 'fl32' || ref === 'fl64';
format.littleEndian = format.formatID === 'sowt' && format.bitsPerChannel > 8;
if ((ref1 = format.formatID) === 'twos' || ref1 === 'sowt' || ref1 === 'in24' || ref1 === 'in32' || ref1 === 'fl32' || ref1 === 'fl64' || ref1 === 'raw ' || ref1 === 'NONE') {
return format.formatID = 'lpcm';
}
});
atom('moov.trak.mdia.minf.stbl.stsd.alac', function() {
this.stream.advance(4);
return this.track.cookie = this.stream.readBuffer(this.len - 4);
});
atom('moov.trak.mdia.minf.stbl.stsd.esds', function() {
var offset;
offset = this.stream.offset + this.len;
this.track.cookie = M4ADemuxer.readEsds(this.stream);
return this.stream.seek(offset);
});
atom('moov.trak.mdia.minf.stbl.stsd.wave.enda', function() {
return this.track.format.littleEndian = !!this.stream.readUInt16();
});
M4ADemuxer.readDescrLen = function(stream) {
var c, count, len;
len = 0;
count = 4;
while (count--) {
c = stream.readUInt8();
len = (len << 7) | (c & 0x7f);
if (!(c & 0x80)) {
break;
}
}
return len;
};
M4ADemuxer.readEsds = function(stream) {
var codec_id, flags, len, tag;
stream.advance(4);
tag = stream.readUInt8();
len = M4ADemuxer.readDescrLen(stream);
if (tag === 0x03) {
stream.advance(2);
flags = stream.readUInt8();
if (flags & 0x80) {
stream.advance(2);
}
if (flags & 0x40) {
stream.advance(stream.readUInt8());
}
if (flags & 0x20) {
stream.advance(2);
}
} else {
stream.advance(2);
}
tag = stream.readUInt8();
len = M4ADemuxer.readDescrLen(stream);
if (tag === 0x04) {
codec_id = stream.readUInt8();
stream.advance(1);
stream.advance(3);
stream.advance(4);
stream.advance(4);
tag = stream.readUInt8();
len = M4ADemuxer.readDescrLen(stream);
if (tag === 0x05) {
return stream.readBuffer(len);
}
}
return null;
};
atom('moov.trak.mdia.minf.stbl.stts', function() {
var entries, i, k, ref;
this.stream.advance(4);
entries = this.stream.readUInt32();
this.track.stts = [];
for (i = k = 0, ref = entries; k < ref; i = k += 1) {
this.track.stts[i] = {
count: this.stream.readUInt32(),
duration: this.stream.readUInt32()
};
}
return this.setupSeekPoints();
});
atom('moov.trak.mdia.minf.stbl.stsc', function() {
var entries, i, k, ref;
this.stream.advance(4);
entries = this.stream.readUInt32();
this.track.stsc = [];
for (i = k = 0, ref = entries; k < ref; i = k += 1) {
this.track.stsc[i] = {
first: this.stream.readUInt32(),
count: this.stream.readUInt32(),
id: this.stream.readUInt32()
};
}
return this.setupSeekPoints();
});
atom('moov.trak.mdia.minf.stbl.stsz', function() {
var entries, i, k, ref;
this.stream.advance(4);
this.track.sampleSize = this.stream.readUInt32();
entries = this.stream.readUInt32();
if (this.track.sampleSize === 0 && entries > 0) {
this.track.sampleSizes = [];
for (i = k = 0, ref = entries; k < ref; i = k += 1) {
this.track.sampleSizes[i] = this.stream.readUInt32();
}
}
return this.setupSeekPoints();
});
atom('moov.trak.mdia.minf.stbl.stco', function() {
var entries, i, k, ref;
this.stream.advance(4);
entries = this.stream.readUInt32();
this.track.chunkOffsets = [];
for (i = k = 0, ref = entries; k < ref; i = k += 1) {
this.track.chunkOffsets[i] = this.stream.readUInt32();
}
return this.setupSeekPoints();
});
atom('moov.trak.tref.chap', function() {
var entries, i, k, ref;
entries = this.len >> 2;
this.track.chapterTracks = [];
for (i = k = 0, ref = entries; k < ref; i = k += 1) {
this.track.chapterTracks[i] = this.stream.readUInt32();
}
});
M4ADemuxer.prototype.setupSeekPoints = function() {
var i, j, k, l, len1, offset, position, ref, ref1, results, sampleIndex, size, stscIndex, sttsIndex, sttsSample, timestamp;
if (!((this.track.chunkOffsets != null) && (this.track.stsc != null) && (this.track.sampleSize != null) && (this.track.stts != null))) {
return;
}
stscIndex = 0;
sttsIndex = 0;
sttsIndex = 0;
sttsSample = 0;
sampleIndex = 0;
offset = 0;
timestamp = 0;
this.track.seekPoints = [];
ref = this.track.chunkOffsets;
results = [];
for (i = k = 0, len1 = ref.length; k < len1; i = ++k) {
position = ref[i];
for (j = l = 0, ref1 = this.track.stsc[stscIndex].count; l < ref1; j = l += 1) {
this.track.seekPoints.push({
offset: offset,
position: position,
timestamp: timestamp
});
size = this.track.sampleSize || this.track.sampleSizes[sampleIndex++];
offset += size;
position += size;
timestamp += this.track.stts[sttsIndex].duration;
if (sttsIndex + 1 < this.track.stts.length && ++sttsSample === this.track.stts[sttsIndex].count) {
sttsSample = 0;
sttsIndex++;
}
}
if (stscIndex + 1 < this.track.stsc.length && i + 1 === this.track.stsc[stscIndex + 1].first) {
results.push(stscIndex++);
} else {
results.push(void 0);
}
}
return results;
};
after('moov', function() {
var k, len1, ref, track;
if (this.mdatOffset != null) {
this.stream.seek(this.mdatOffset - 8);
}
ref = this.tracks;
for (k = 0, len1 = ref.length; k < len1; k++) {
track = ref[k];
if (!(track.type === 'soun')) {
continue;
}
this.track = track;
break;
}
if (this.track.type !== 'soun') {
this.track = null;
return this.emit('error', 'No audio tracks in m4a file.');
}
this.emit('format', this.track.format);
this.emit('duration', this.track.duration / this.track.timeScale * 1000 | 0);
if (this.track.cookie) {
this.emit('cookie', this.track.cookie);
}
return this.seekPoints = this.track.seekPoints;
});
atom('mdat', function() {
var bytes, chunkSize, k, length, numSamples, offset, ref, sample, size;
if (!this.startedData) {
if (this.mdatOffset == null) {
this.mdatOffset = this.stream.offset;
}
if (this.tracks.length === 0) {
bytes = Math.min(this.stream.remainingBytes(), this.len);
this.stream.advance(bytes);
this.len -= bytes;
return;
}
this.chunkIndex = 0;
this.stscIndex = 0;
this.sampleIndex = 0;
this.tailOffset = 0;
this.tailSamples = 0;
this.startedData = true;
}
if (!this.readChapters) {
this.readChapters = this.parseChapters();
if (this["break"] = !this.readChapters) {
return;
}
this.stream.seek(this.mdatOffset);
}
offset = this.track.chunkOffsets[this.chunkIndex] + this.tailOffset;
length = 0;
if (!this.stream.available(offset - this.stream.offset)) {
this["break"] = true;
return;
}
this.stream.seek(offset);
while (this.chunkIndex < this.track.chunkOffsets.length) {
numSamples = this.track.stsc[this.stscIndex].count - this.tailSamples;
chunkSize = 0;
for (sample = k = 0, ref = numSamples; k < ref; sample = k += 1) {
size = this.track.sampleSize || this.track.sampleSizes[this.sampleIndex];
if (!this.stream.available(length + size)) {
break;
}
length += size;
chunkSize += size;
this.sampleIndex++;
}
if (sample < numSamples) {
this.tailOffset += chunkSize;
this.tailSamples += sample;
break;
} else {
this.chunkIndex++;
this.tailOffset = 0;
this.tailSamples = 0;
if (this.stscIndex + 1 < this.track.stsc.length && this.chunkIndex + 1 === this.track.stsc[this.stscIndex + 1].first) {
this.stscIndex++;
}
if (offset + length !== this.track.chunkOffsets[this.chunkIndex]) {
break;
}
}
}
if (length > 0) {
this.emit('data', this.stream.readBuffer(length));
return this["break"] = this.chunkIndex === this.track.chunkOffsets.length;
} else {
return this["break"] = true;
}
});
M4ADemuxer.prototype.parseChapters = function() {
var bom, id, k, len, len1, nextTimestamp, point, ref, ref1, ref2, ref3, title, track;
if (!(((ref = this.track.chapterTracks) != null ? ref.length : void 0) > 0)) {
return true;
}
id = this.track.chapterTracks[0];
ref1 = this.tracks;
for (k = 0, len1 = ref1.length; k < len1; k++) {
track = ref1[k];
if (track.id === id) {
break;
}
}
if (track.id !== id) {
this.emit('error', 'Chapter track does not exist.');
}
if (this.chapters == null) {
this.chapters = [];
}
while (this.chapters.length < track.seekPoints.length) {
point = track.seekPoints[this.chapters.length];
if (!this.stream.available(point.position - this.stream.offset + 32)) {
return false;
}
this.stream.seek(point.position);
len = this.stream.readUInt16();
title = null;
if (!this.stream.available(len)) {
return false;
}
if (len > 2) {
bom = this.stream.peekUInt16();
if (bom === 0xfeff || bom === 0xfffe) {
title = this.stream.readString(len, 'utf16-bom');
}
}
if (title == null) {
title = this.stream.readString(len, 'utf8');
}
nextTimestamp = (ref2 = (ref3 = track.seekPoints[this.chapters.length + 1]) != null ? ref3.timestamp : void 0) != null ? ref2 : track.duration;
this.chapters.push({
title: title,
timestamp: point.timestamp / track.timeScale * 1000 | 0,
duration: (nextTimestamp - point.timestamp) / track.timeScale * 1000 | 0
});
}
this.emit('chapters', this.chapters);
return true;
};
atom('moov.udta.meta', function() {
this.metadata = {};
return this.stream.advance(4);
});
after('moov.udta.meta', function() {
return this.emit('metadata', this.metadata);
});
meta = function(field, name, fn) {
return atom("moov.udta.meta.ilst." + field + ".data", function() {
this.stream.advance(8);
this.len -= 8;
return fn.call(this, name);
});
};
string = function(field) {
return this.metadata[field] = this.stream.readString(this.len, 'utf8');
};
meta('©alb', 'album', string);
meta('©arg', 'arranger', string);
meta('©art', 'artist', string);
meta('©ART', 'artist', string);
meta('aART', 'albumArtist', string);
meta('catg', 'category', string);
meta('©com', 'composer', string);
meta('©cpy', 'copyright', string);
meta('cprt', 'copyright', string);
meta('©cmt', 'comments', string);
meta('©day', 'releaseDate', string);
meta('desc', 'description', string);
meta('©gen', 'genre', string);
meta('©grp', 'grouping', string);
meta('©isr', 'ISRC', string);
meta('keyw', 'keywords', string);
meta('©lab', 'recordLabel', string);
meta('ldes', 'longDescription', string);
meta('©lyr', 'lyrics', string);
meta('©nam', 'title', string);
meta('©phg', 'recordingCopyright', string);
meta('©prd', 'producer', string);
meta('©prf', 'performers', string);
meta('purd', 'purchaseDate', string);
meta('purl', 'podcastURL', string);
meta('©swf', 'songwriter', string);
meta('©too', 'encoder', string);
meta('©wrt', 'composer', string);
meta('covr', 'coverArt', function(field) {
return this.metadata[field] = this.stream.readBuffer(this.len);
});
genres = ["Blues", "Classic Rock", "Country", "Dance", "Disco", "Funk", "Grunge", "Hip-Hop", "Jazz", "Metal", "New Age", "Oldies", "Other", "Pop", "R&B", "Rap", "Reggae", "Rock", "Techno", "Industrial", "Alternative", "Ska", "Death Metal", "Pranks", "Soundtrack", "Euro-Techno", "Ambient", "Trip-Hop", "Vocal", "Jazz+Funk", "Fusion", "Trance", "Classical", "Instrumental", "Acid", "House", "Game", "Sound Clip", "Gospel", "Noise", "AlternRock", "Bass", "Soul", "Punk", "Space", "Meditative", "Instrumental Pop", "Instrumental Rock", "Ethnic", "Gothic", "Darkwave", "Techno-Industrial", "Electronic", "Pop-Folk", "Eurodance", "Dream", "Southern Rock", "Comedy", "Cult", "Gangsta", "Top 40", "Christian Rap", "Pop/Funk", "Jungle", "Native American", "Cabaret", "New Wave", "Psychadelic", "Rave", "Showtunes", "Trailer", "Lo-Fi", "Tribal", "Acid Punk", "Acid Jazz", "Polka", "Retro", "Musical", "Rock & Roll", "Hard Rock", "Folk", "Folk/Rock", "National Folk", "Swing", "Fast Fusion", "Bebob", "Latin", "Revival", "Celtic", "Bluegrass", "Avantgarde", "Gothic Rock", "Progressive Rock", "Psychedelic Rock", "Symphonic Rock", "Slow Rock", "Big Band", "Chorus", "Easy Listening", "Acoustic", "Humour", "Speech", "Chanson", "Opera", "Chamber Music", "Sonata", "Symphony", "Booty Bass", "Primus", "Porn Groove", "Satire", "Slow Jam", "Club", "Tango", "Samba", "Folklore", "Ballad", "Power Ballad", "Rhythmic Soul", "Freestyle", "Duet", "Punk Rock", "Drum Solo", "A Capella", "Euro-House", "Dance Hall"];
meta('gnre', 'genre', function(field) {
return this.metadata[field] = genres[this.stream.readUInt16() - 1];
});
meta('tmpo', 'tempo', function(field) {
return this.metadata[field] = this.stream.readUInt16();
});
meta('rtng', 'rating', function(field) {
var rating;
rating = this.stream.readUInt8();
return this.metadata[field] = rating === 2 ? 'Clean' : rating !== 0 ? 'Explicit' : 'None';
});
diskTrack = function(field) {
this.stream.advance(2);
this.metadata[field] = this.stream.readUInt16() + ' of ' + this.stream.readUInt16();
return this.stream.advance(this.len - 6);
};
meta('disk', 'diskNumber', diskTrack);
meta('trkn', 'trackNumber', diskTrack);
bool = function(field) {
return this.metadata[field] = this.stream.readUInt8() === 1;
};
meta('cpil', 'compilation', bool);
meta('pcst', 'podcast', bool);
meta('pgap', 'gapless', bool);
return M4ADemuxer;
})(Demuxer);
module.exports = M4ADemuxer;
}).call(this);
},{"../demuxer":14}],19:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var Demuxer, WAVEDemuxer,
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
Demuxer = require('../demuxer');
WAVEDemuxer = (function(superClass) {
var formats;
extend(WAVEDemuxer, superClass);
function WAVEDemuxer() {
return WAVEDemuxer.__super__.constructor.apply(this, arguments);
}
Demuxer.register(WAVEDemuxer);
WAVEDemuxer.probe = function(buffer) {
return buffer.peekString(0, 4) === 'RIFF' && buffer.peekString(8, 4) === 'WAVE';
};
formats = {
0x0001: 'lpcm',
0x0003: 'lpcm',
0x0006: 'alaw',
0x0007: 'ulaw'
};
WAVEDemuxer.prototype.readChunk = function() {
var buffer, bytes, encoding;
if (!this.readStart && this.stream.available(12)) {
if (this.stream.readString(4) !== 'RIFF') {
return this.emit('error', 'Invalid WAV file.');
}
this.fileSize = this.stream.readUInt32(true);
this.readStart = true;
if (this.stream.readString(4) !== 'WAVE') {
return this.emit('error', 'Invalid WAV file.');
}
}
while (this.stream.available(1)) {
if (!this.readHeaders && this.stream.available(8)) {
this.type = this.stream.readString(4);
this.len = this.stream.readUInt32(true);
}
switch (this.type) {
case 'fmt ':
encoding = this.stream.readUInt16(true);
if (!(encoding in formats)) {
return this.emit('error', 'Unsupported format in WAV file.');
}
this.format = {
formatID: formats[encoding],
floatingPoint: encoding === 0x0003,
littleEndian: formats[encoding] === 'lpcm',
channelsPerFrame: this.stream.readUInt16(true),
sampleRate: this.stream.readUInt32(true),
framesPerPacket: 1
};
this.stream.advance(4);
this.stream.advance(2);
this.format.bitsPerChannel = this.stream.readUInt16(true);
this.format.bytesPerPacket = (this.format.bitsPerChannel / 8) * this.format.channelsPerFrame;
this.emit('format', this.format);
this.stream.advance(this.len - 16);
break;
case 'data':
if (!this.sentDuration) {
bytes = this.format.bitsPerChannel / 8;
this.emit('duration', this.len / bytes / this.format.channelsPerFrame / this.format.sampleRate * 1000 | 0);
this.sentDuration = true;
}
buffer = this.stream.readSingleBuffer(this.len);
this.len -= buffer.length;
this.readHeaders = this.len > 0;
this.emit('data', buffer);
break;
default:
if (!this.stream.available(this.len)) {
return;
}
this.stream.advance(this.len);
}
if (this.type !== 'data') {
this.readHeaders = false;
}
}
};
return WAVEDemuxer;
})(Demuxer);
}).call(this);
},{"../demuxer":14}],20:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var AudioDevice, EventEmitter,
bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
EventEmitter = require('./core/events');
AudioDevice = (function(superClass) {
var devices;
extend(AudioDevice, superClass);
function AudioDevice(sampleRate1, channels1) {
this.sampleRate = sampleRate1;
this.channels = channels1;
this.updateTime = bind(this.updateTime, this);
this.playing = false;
this.currentTime = 0;
this._lastTime = 0;
}
AudioDevice.prototype.start = function() {
if (this.playing) {
return;
}
this.playing = true;
if (this.device == null) {
this.device = AudioDevice.create(this.sampleRate, this.channels);
}
if (!this.device) {
throw new Error("No supported audio device found.");
}
this._lastTime = this.device.getDeviceTime();
this._timer = setInterval(this.updateTime, 200);
return this.device.on('refill', this.refill = (function(_this) {
return function(buffer) {
return _this.emit('refill', buffer);
};
})(this));
};
AudioDevice.prototype.stop = function() {
if (!this.playing) {
return;
}
this.playing = false;
this.device.off('refill', this.refill);
return clearInterval(this._timer);
};
AudioDevice.prototype.destroy = function() {
var ref;
this.stop();
return (ref = this.device) != null ? ref.destroy() : void 0;
};
AudioDevice.prototype.seek = function(currentTime) {
this.currentTime = currentTime;
if (this.playing) {
this._lastTime = this.device.getDeviceTime();
}
return this.emit('timeUpdate', this.currentTime);
};
AudioDevice.prototype.updateTime = function() {
var time;
time = this.device.getDeviceTime();
this.currentTime += (time - this._lastTime) / this.device.sampleRate * 1000 | 0;
this._lastTime = time;
return this.emit('timeUpdate', this.currentTime);
};
devices = [];
AudioDevice.register = function(device) {
return devices.push(device);
};
AudioDevice.create = function(sampleRate, channels) {
var device, i, len;
for (i = 0, len = devices.length; i < len; i++) {
device = devices[i];
if (device.supported) {
return new device(sampleRate, channels);
}
}
return null;
};
return AudioDevice;
})(EventEmitter);
module.exports = AudioDevice;
}).call(this);
},{"./core/events":8}],21:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var AVBuffer, AudioDevice, EventEmitter, MozillaAudioDevice,
bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
EventEmitter = require('../core/events');
AudioDevice = require('../device');
AVBuffer = require('../core/buffer');
MozillaAudioDevice = (function(superClass) {
var createTimer, destroyTimer;
extend(MozillaAudioDevice, superClass);
AudioDevice.register(MozillaAudioDevice);
MozillaAudioDevice.supported = (typeof Audio !== "undefined" && Audio !== null) && 'mozWriteAudio' in new Audio;
function MozillaAudioDevice(sampleRate, channels) {
this.sampleRate = sampleRate;
this.channels = channels;
this.refill = bind(this.refill, this);
this.audio = new Audio;
this.audio.mozSetup(this.channels, this.sampleRate);
this.writePosition = 0;
this.prebufferSize = this.sampleRate / 2;
this.tail = null;
this.timer = createTimer(this.refill, 100);
}
MozillaAudioDevice.prototype.refill = function() {
var available, buffer, currentPosition, written;
if (this.tail) {
written = this.audio.mozWriteAudio(this.tail);
this.writePosition += written;
if (this.writePosition < this.tail.length) {
this.tail = this.tail.subarray(written);
} else {
this.tail = null;
}
}
currentPosition = this.audio.mozCurrentSampleOffset();
available = currentPosition + this.prebufferSize - this.writePosition;
if (available > 0) {
buffer = new Float32Array(available);
this.emit('refill', buffer);
written = this.audio.mozWriteAudio(buffer);
if (written < buffer.length) {
this.tail = buffer.subarray(written);
}
this.writePosition += written;
}
};
MozillaAudioDevice.prototype.destroy = function() {
return destroyTimer(this.timer);
};
MozillaAudioDevice.prototype.getDeviceTime = function() {
return this.audio.mozCurrentSampleOffset() / this.channels;
};
createTimer = function(fn, interval) {
var url, worker;
url = AVBuffer.makeBlobURL("setInterval(function() { postMessage('ping'); }, " + interval + ");");
if (url == null) {
return setInterval(fn, interval);
}
worker = new Worker(url);
worker.onmessage = fn;
worker.url = url;
return worker;
};
destroyTimer = function(timer) {
if (timer.terminate) {
timer.terminate();
return URL.revokeObjectURL(timer.url);
} else {
return clearInterval(timer);
}
};
return MozillaAudioDevice;
})(EventEmitter);
}).call(this);
},{"../core/buffer":6,"../core/events":8,"../device":20}],22:[function(require,module,exports){
//JavaScript Audio Resampler
//Copyright (C) 2011-2015 Grant Galitz
//Released to Public Domain
function Resampler(fromSampleRate, toSampleRate, channels, inputBufferLength) {
this.fromSampleRate = +fromSampleRate;
this.toSampleRate = +toSampleRate;
this.channels = channels | 0;
this.inputBufferLength = inputBufferLength;
this.initialize();
}
Resampler.prototype.initialize = function () {
//Perform some checks:
if (this.fromSampleRate > 0 && this.toSampleRate > 0 && this.channels > 0) {
if (this.fromSampleRate == this.toSampleRate) {
//Setup a resampler bypass:
this.resampler = this.bypassResampler; //Resampler just returns what was passed through.
this.ratioWeight = 1;
} else {
this.ratioWeight = this.fromSampleRate / this.toSampleRate;
if (this.fromSampleRate < this.toSampleRate) {
/*
Use generic linear interpolation if upsampling,
as linear interpolation produces a gradient that we want
and works fine with two input sample points per output in this case.
*/
this.compileLinearInterpolationFunction();
this.lastWeight = 1;
} else {
/*
Custom resampler I wrote that doesn't skip samples
like standard linear interpolation in high downsampling.
This is more accurate than linear interpolation on downsampling.
*/
this.compileMultiTapFunction();
this.tailExists = false;
this.lastWeight = 0;
}
var outputBufferSize = (Math.ceil(this.inputBufferLength * this.toSampleRate / this.fromSampleRate / this.channels * 1.01) * this.channels) + this.channels;
this.outputBuffer = new Float32Array(outputBufferSize);
this.lastOutput = new Float32Array(this.channels);
}
} else {
throw(new Error("Invalid settings specified for the resampler."));
}
};
Resampler.prototype.compileLinearInterpolationFunction = function () {
var toCompile = "var outputOffset = 0;\
var bufferLength = buffer.length;\
if (bufferLength > 0) {\
var weight = this.lastWeight;\
var firstWeight = 0;\
var secondWeight = 0;\
var sourceOffset = 0;\
var outputOffset = 0;\
var outputBuffer = this.outputBuffer;\
for (; weight < 1; weight += " + this.ratioWeight + ") {\
secondWeight = weight % 1;\
firstWeight = 1 - secondWeight;";
for (var channel = 0; channel < this.channels; ++channel) {
toCompile += "outputBuffer[outputOffset++] = (this.lastOutput[" + channel + "] * firstWeight) + (buffer[" + channel + "] * secondWeight);";
}
toCompile += "}\
weight -= 1;\
for (bufferLength -= " + this.channels + ", sourceOffset = Math.floor(weight) * " + this.channels + "; sourceOffset < bufferLength;) {\
secondWeight = weight % 1;\
firstWeight = 1 - secondWeight;";
for (var channel = 0; channel < this.channels; ++channel) {
toCompile += "outputBuffer[outputOffset++] = (buffer[sourceOffset" + ((channel > 0) ? (" + " + channel) : "") + "] * firstWeight) + (buffer[sourceOffset + " + (this.channels + channel) + "] * secondWeight);";
}
toCompile += "weight += " + this.ratioWeight + ";\
sourceOffset = Math.floor(weight) * " + this.channels + ";\
}";
for (var channel = 0; channel < this.channels; ++channel) {
toCompile += "this.lastOutput[" + channel + "] = buffer[sourceOffset++];";
}
toCompile += "this.lastWeight = weight % 1;\
}\
return this.outputBuffer;";
this.resampler = Function("buffer", toCompile);
};
Resampler.prototype.compileMultiTapFunction = function () {
var toCompile = "var outputOffset = 0;\
var bufferLength = buffer.length;\
if (bufferLength > 0) {\
var weight = 0;";
for (var channel = 0; channel < this.channels; ++channel) {
toCompile += "var output" + channel + " = 0;"
}
toCompile += "var actualPosition = 0;\
var amountToNext = 0;\
var alreadyProcessedTail = !this.tailExists;\
this.tailExists = false;\
var outputBuffer = this.outputBuffer;\
var currentPosition = 0;\
do {\
if (alreadyProcessedTail) {\
weight = " + this.ratioWeight + ";";
for (channel = 0; channel < this.channels; ++channel) {
toCompile += "output" + channel + " = 0;"
}
toCompile += "}\
else {\
weight = this.lastWeight;";
for (channel = 0; channel < this.channels; ++channel) {
toCompile += "output" + channel + " = this.lastOutput[" + channel + "];"
}
toCompile += "alreadyProcessedTail = true;\
}\
while (weight > 0 && actualPosition < bufferLength) {\
amountToNext = 1 + actualPosition - currentPosition;\
if (weight >= amountToNext) {";
for (channel = 0; channel < this.channels; ++channel) {
toCompile += "output" + channel + " += buffer[actualPosition++] * amountToNext;"
}
toCompile += "currentPosition = actualPosition;\
weight -= amountToNext;\
}\
else {";
for (channel = 0; channel < this.channels; ++channel) {
toCompile += "output" + channel + " += buffer[actualPosition" + ((channel > 0) ? (" + " + channel) : "") + "] * weight;"
}
toCompile += "currentPosition += weight;\
weight = 0;\
break;\
}\
}\
if (weight <= 0) {";
for (channel = 0; channel < this.channels; ++channel) {
toCompile += "outputBuffer[outputOffset++] = output" + channel + " / " + this.ratioWeight + ";"
}
toCompile += "}\
else {\
this.lastWeight = weight;";
for (channel = 0; channel < this.channels; ++channel) {
toCompile += "this.lastOutput[" + channel + "] = output" + channel + ";"
}
toCompile += "this.tailExists = true;\
break;\
}\
} while (actualPosition < bufferLength);\
}\
return this.outputBuffer;";
this.resampler = Function("buffer", toCompile);
};
Resampler.prototype.bypassResampler = function (inputBuffer) {
return inputBuffer;
};
module.exports = Resampler;
},{}],23:[function(require,module,exports){
(function (global){(function (){
// Generated by CoffeeScript 1.12.7
(function() {
var AudioDevice, EventEmitter, Resampler, WebAudioDevice,
bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
EventEmitter = require('../core/events');
AudioDevice = require('../device');
Resampler = require('./resampler');
WebAudioDevice = (function(superClass) {
var AudioContext, createProcessor, sharedContext;
extend(WebAudioDevice, superClass);
AudioDevice.register(WebAudioDevice);
AudioContext = global.AudioContext || global.webkitAudioContext;
WebAudioDevice.supported = AudioContext && (typeof AudioContext.prototype[createProcessor = 'createScriptProcessor'] === 'function' || typeof AudioContext.prototype[createProcessor = 'createJavaScriptNode'] === 'function');
sharedContext = null;
function WebAudioDevice(sampleRate, channels1) {
this.sampleRate = sampleRate;
this.channels = channels1;
this.refill = bind(this.refill, this);
this.context = sharedContext != null ? sharedContext : sharedContext = new AudioContext;
this.deviceSampleRate = this.context.sampleRate;
this.bufferSize = Math.ceil(4096 / (this.deviceSampleRate / this.sampleRate) * this.channels);
this.bufferSize += this.bufferSize % this.channels;
if (this.deviceSampleRate !== this.sampleRate) {
this.resampler = new Resampler(this.sampleRate, this.deviceSampleRate, this.channels, this.bufferSize);
}
this.node = this.context[createProcessor](4096, this.channels, this.channels);
this.node.onaudioprocess = this.refill;
this.node.connect(this.context.destination);
}
WebAudioDevice.prototype.refill = function(event) {
var channelCount, channels, data, i, j, k, l, n, outputBuffer, ref, ref1, ref2;
outputBuffer = event.outputBuffer;
channelCount = outputBuffer.numberOfChannels;
channels = new Array(channelCount);
for (i = j = 0, ref = channelCount; j < ref; i = j += 1) {
channels[i] = outputBuffer.getChannelData(i);
}
data = new Float32Array(this.bufferSize);
this.emit('refill', data);
if (this.resampler) {
data = this.resampler.resampler(data);
}
for (i = k = 0, ref1 = outputBuffer.length; k < ref1; i = k += 1) {
for (n = l = 0, ref2 = channelCount; l < ref2; n = l += 1) {
channels[n][i] = data[i * channelCount + n];
}
}
};
WebAudioDevice.prototype.destroy = function() {
return this.node.disconnect(0);
};
WebAudioDevice.prototype.getDeviceTime = function() {
return this.context.currentTime * this.sampleRate;
};
return WebAudioDevice;
})(EventEmitter);
}).call(this);
}).call(this)}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
},{"../core/events":8,"../device":20,"./resampler":22}],24:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var Filter;
Filter = (function() {
function Filter(context, key) {
if (context && key) {
Object.defineProperty(this, 'value', {
get: function() {
return context[key];
}
});
}
}
Filter.prototype.process = function(buffer) {};
return Filter;
})();
module.exports = Filter;
}).call(this);
},{}],25:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var BalanceFilter, Filter,
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
Filter = require('../filter');
BalanceFilter = (function(superClass) {
extend(BalanceFilter, superClass);
function BalanceFilter() {
return BalanceFilter.__super__.constructor.apply(this, arguments);
}
BalanceFilter.prototype.process = function(buffer) {
var i, j, pan, ref;
if (this.value === 0) {
return;
}
pan = Math.max(-50, Math.min(50, this.value));
for (i = j = 0, ref = buffer.length; j < ref; i = j += 2) {
buffer[i] *= Math.min(1, (50 - pan) / 50);
buffer[i + 1] *= Math.min(1, (50 + pan) / 50);
}
};
return BalanceFilter;
})(Filter);
module.exports = BalanceFilter;
}).call(this);
},{"../filter":24}],26:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var Filter, VolumeFilter,
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
Filter = require('../filter');
VolumeFilter = (function(superClass) {
extend(VolumeFilter, superClass);
function VolumeFilter() {
return VolumeFilter.__super__.constructor.apply(this, arguments);
}
VolumeFilter.prototype.process = function(buffer) {
var i, j, ref, vol;
if (this.value >= 100) {
return;
}
vol = Math.max(0, Math.min(100, this.value)) / 100;
for (i = j = 0, ref = buffer.length; j < ref; i = j += 1) {
buffer[i] *= vol;
}
};
return VolumeFilter;
})(Filter);
module.exports = VolumeFilter;
}).call(this);
},{"../filter":24}],27:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var Asset, AudioDevice, BalanceFilter, EventEmitter, Player, Queue, VolumeFilter,
bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
EventEmitter = require('./core/events');
Asset = require('./asset');
VolumeFilter = require('./filters/volume');
BalanceFilter = require('./filters/balance');
Queue = require('./queue');
AudioDevice = require('./device');
Player = (function(superClass) {
extend(Player, superClass);
function Player(asset) {
this.asset = asset;
this.startPlaying = bind(this.startPlaying, this);
this.playing = false;
this.buffered = 0;
this.currentTime = 0;
this.duration = 0;
this.volume = 100;
this.pan = 0;
this.metadata = {};
this.filters = [new VolumeFilter(this, 'volume'), new BalanceFilter(this, 'pan')];
this.asset.on('buffer', (function(_this) {
return function(buffered) {
_this.buffered = buffered;
return _this.emit('buffer', _this.buffered);
};
})(this));
this.asset.on('decodeStart', (function(_this) {
return function() {
_this.queue = new Queue(_this.asset);
return _this.queue.once('ready', _this.startPlaying);
};
})(this));
this.asset.on('format', (function(_this) {
return function(format) {
_this.format = format;
return _this.emit('format', _this.format);
};
})(this));
this.asset.on('metadata', (function(_this) {
return function(metadata) {
_this.metadata = metadata;
return _this.emit('metadata', _this.metadata);
};
})(this));
this.asset.on('duration', (function(_this) {
return function(duration) {
_this.duration = duration;
return _this.emit('duration', _this.duration);
};
})(this));
this.asset.on('error', (function(_this) {
return function(error) {
return _this.emit('error', error);
};
})(this));
}
Player.fromURL = function(url, opts) {
return new Player(Asset.fromURL(url, opts));
};
Player.fromFile = function(file) {
return new Player(Asset.fromFile(file));
};
Player.fromBuffer = function(buffer) {
return new Player(Asset.fromBuffer(buffer));
};
Player.prototype.preload = function() {
if (!this.asset) {
return;
}
this.startedPreloading = true;
return this.asset.start(false);
};
Player.prototype.play = function() {
var ref;
if (this.playing) {
return;
}
if (!this.startedPreloading) {
this.preload();
}
this.playing = true;
return (ref = this.device) != null ? ref.start() : void 0;
};
Player.prototype.pause = function() {
var ref;
if (!this.playing) {
return;
}
this.playing = false;
return (ref = this.device) != null ? ref.stop() : void 0;
};
Player.prototype.togglePlayback = function() {
if (this.playing) {
return this.pause();
} else {
return this.play();
}
};
Player.prototype.stop = function() {
var ref;
this.pause();
this.asset.stop();
return (ref = this.device) != null ? ref.destroy() : void 0;
};
Player.prototype.seek = function(timestamp) {
var ref;
if ((ref = this.device) != null) {
ref.stop();
}
this.queue.once('ready', (function(_this) {
return function() {
var ref1, ref2;
if ((ref1 = _this.device) != null) {
ref1.seek(_this.currentTime);
}
if (_this.playing) {
return (ref2 = _this.device) != null ? ref2.start() : void 0;
}
};
})(this));
timestamp = (timestamp / 1000) * this.format.sampleRate;
timestamp = this.asset.decoder.seek(timestamp);
this.currentTime = timestamp / this.format.sampleRate * 1000 | 0;
this.queue.reset();
return this.currentTime;
};
Player.prototype.startPlaying = function() {
var frame, frameOffset;
frame = this.queue.read();
frameOffset = 0;
this.device = new AudioDevice(this.format.sampleRate, this.format.channelsPerFrame);
this.device.on('timeUpdate', (function(_this) {
return function(currentTime) {
_this.currentTime = currentTime;
return _this.emit('progress', _this.currentTime);
};
})(this));
this.refill = (function(_this) {
return function(buffer) {
var bufferOffset, filter, i, j, k, len, max, ref, ref1;
if (!_this.playing) {
return;
}
if (!frame) {
frame = _this.queue.read();
frameOffset = 0;
}
bufferOffset = 0;
while (frame && bufferOffset < buffer.length) {
max = Math.min(frame.length - frameOffset, buffer.length - bufferOffset);
for (i = j = 0, ref = max; j < ref; i = j += 1) {
buffer[bufferOffset++] = frame[frameOffset++];
}
if (frameOffset === frame.length) {
frame = _this.queue.read();
frameOffset = 0;
}
}
ref1 = _this.filters;
for (k = 0, len = ref1.length; k < len; k++) {
filter = ref1[k];
filter.process(buffer);
}
if (!frame) {
if (_this.queue.ended) {
_this.currentTime = _this.duration;
_this.emit('progress', _this.currentTime);
_this.emit('end');
_this.stop();
} else {
_this.device.stop();
}
}
};
})(this);
this.device.on('refill', this.refill);
if (this.playing) {
this.device.start();
}
return this.emit('ready');
};
Player.prototype.destroy = function() {
var ref, ref1;
this.stop();
if ((ref = this.device) != null) {
ref.off();
}
if ((ref1 = this.asset) != null) {
ref1.destroy();
}
return this.off();
};
return Player;
})(EventEmitter);
module.exports = Player;
}).call(this);
},{"./asset":1,"./core/events":8,"./device":20,"./filters/balance":25,"./filters/volume":26,"./queue":28}],28:[function(require,module,exports){
// Generated by CoffeeScript 1.12.7
(function() {
var EventEmitter, Queue,
bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
EventEmitter = require('./core/events');
Queue = (function(superClass) {
extend(Queue, superClass);
function Queue(asset) {
this.asset = asset;
this.write = bind(this.write, this);
this.readyMark = 64;
this.finished = false;
this.buffering = true;
this.ended = false;
this.buffers = [];
this.asset.on('data', this.write);
this.asset.on('end', (function(_this) {
return function() {
return _this.ended = true;
};
})(this));
this.asset.decodePacket();
}
Queue.prototype.write = function(buffer) {
if (buffer) {
this.buffers.push(buffer);
}
if (this.buffering) {
if (this.buffers.length >= this.readyMark || this.ended) {
this.buffering = false;
return this.emit('ready');
} else {
return this.asset.decodePacket();
}
}
};
Queue.prototype.read = function() {
if (this.buffers.length === 0) {
return null;
}
this.asset.decodePacket();
return this.buffers.shift();
};
Queue.prototype.reset = function() {
this.buffers.length = 0;
this.buffering = true;
return this.asset.decodePacket();
};
return Queue;
})(EventEmitter);
module.exports = Queue;
}).call(this);
},{"./core/events":8}],29:[function(require,module,exports){
var AVBuffer, EventEmitter, FileSource,
__hasProp = {}.hasOwnProperty,
__extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; };
EventEmitter = require('../../core/events');
AVBuffer = require('../../core/buffer');
FileSource = (function(_super) {
__extends(FileSource, _super);
function FileSource(file) {
this.file = file;
if (typeof FileReader === "undefined" || FileReader === null) {
return this.emit('error', 'This browser does not have FileReader support.');
}
this.offset = 0;
this.length = this.file.size;
this.chunkSize = 1 << 20;
this.file[this.slice = 'slice'] || this.file[this.slice = 'webkitSlice'] || this.file[this.slice = 'mozSlice'];
}
FileSource.prototype.start = function() {
if (this.reader) {
if (!this.active) {
return this.loop();
}
}
this.reader = new FileReader;
this.active = true;
this.reader.onload = (function(_this) {
return function(e) {
var buf;
buf = new AVBuffer(new Uint8Array(e.target.result));
_this.offset += buf.length;
_this.emit('data', buf);
_this.active = false;
if (_this.offset < _this.length) {
return _this.loop();
}
};
})(this);
this.reader.onloadend = (function(_this) {
return function() {
if (_this.offset === _this.length) {
_this.emit('end');
return _this.reader = null;
}
};
})(this);
this.reader.onerror = (function(_this) {
return function(e) {
return _this.emit('error', e);
};
})(this);
this.reader.onprogress = (function(_this) {
return function(e) {
return _this.emit('progress', (_this.offset + e.loaded) / _this.length * 100);
};
})(this);
return this.loop();
};
FileSource.prototype.loop = function() {
var blob, endPos;
this.active = true;
endPos = Math.min(this.offset + this.chunkSize, this.length);
blob = this.file[this.slice](this.offset, endPos);
return this.reader.readAsArrayBuffer(blob);
};
FileSource.prototype.pause = function() {
var _ref;
this.active = false;
try {
return (_ref = this.reader) != null ? _ref.abort() : void 0;
} catch (_error) {}
};
FileSource.prototype.reset = function() {
this.pause();
return this.offset = 0;
};
return FileSource;
})(EventEmitter);
module.exports = FileSource;
},{"../../core/buffer":6,"../../core/events":8}],30:[function(require,module,exports){
var AVBuffer, EventEmitter, HTTPSource,
__hasProp = {}.hasOwnProperty,
__extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; };
EventEmitter = require('../../core/events');
AVBuffer = require('../../core/buffer');
HTTPSource = (function(_super) {
__extends(HTTPSource, _super);
function HTTPSource(url, opts) {
this.url = url;
this.opts = opts != null ? opts : {};
this.chunkSize = 1 << 20;
this.inflight = false;
if (this.opts.length) {
this.length = this.opts.length;
}
this.reset();
}
HTTPSource.prototype.start = function() {
if (this.length) {
if (!this.inflight) {
return this.loop();
}
}
this.inflight = true;
this.xhr = new XMLHttpRequest();
this.xhr.onload = (function(_this) {
return function(event) {
_this.length = parseInt(_this.xhr.getResponseHeader("Content-Length"));
_this.inflight = false;
return _this.loop();
};
})(this);
this.xhr.onerror = (function(_this) {
return function(err) {
_this.pause();
return _this.emit('error', err);
};
})(this);
this.xhr.onabort = (function(_this) {
return function(event) {
return _this.inflight = false;
};
})(this);
this.xhr.open("HEAD", this.url, true);
return this.xhr.send(null);
};
HTTPSource.prototype.loop = function() {
var endPos;
if (this.inflight || !this.length) {
return this.emit('error', 'Something is wrong in HTTPSource.loop');
}
this.inflight = true;
this.xhr = new XMLHttpRequest();
this.xhr.onload = (function(_this) {
return function(event) {
var buf, buffer, i, txt, _i, _ref;
if (_this.xhr.response) {
buf = new Uint8Array(_this.xhr.response);
} else {
txt = _this.xhr.responseText;
buf = new Uint8Array(txt.length);
for (i = _i = 0, _ref = txt.length; 0 <= _ref ? _i < _ref : _i > _ref; i = 0 <= _ref ? ++_i : --_i) {
buf[i] = txt.charCodeAt(i) & 0xff;
}
}
buffer = new AVBuffer(buf);
_this.offset += buffer.length;
_this.emit('data', buffer);
if (_this.offset >= _this.length) {
_this.emit('end');
}
_this.inflight = false;
if (!(_this.offset >= _this.length)) {
return _this.loop();
}
};
})(this);
this.xhr.onprogress = (function(_this) {
return function(event) {
return _this.emit('progress', (_this.offset + event.loaded) / _this.length * 100);
};
})(this);
this.xhr.onerror = (function(_this) {
return function(err) {
_this.emit('error', err);
return _this.pause();
};
})(this);
this.xhr.onabort = (function(_this) {
return function(event) {
return _this.inflight = false;
};
})(this);
this.xhr.open("GET", this.url, true);
this.xhr.responseType = "arraybuffer";
endPos = Math.min(this.offset + this.chunkSize, this.length - 1);
this.xhr.setRequestHeader("If-None-Match", "webkit-no-cache");
this.xhr.setRequestHeader("Range", "bytes=" + this.offset + "-" + endPos);
this.xhr.overrideMimeType('text/plain; charset=x-user-defined');
return this.xhr.send(null);
};
HTTPSource.prototype.pause = function() {
var _ref;
this.inflight = false;
return (_ref = this.xhr) != null ? _ref.abort() : void 0;
};
HTTPSource.prototype.reset = function() {
this.pause();
return this.offset = 0;
};
return HTTPSource;
})(EventEmitter);
module.exports = HTTPSource;
},{"../../core/buffer":6,"../../core/events":8}],31:[function(require,module,exports){
(function (global){(function (){
// Generated by CoffeeScript 1.12.7
(function() {
var AVBuffer, BufferList, BufferSource, EventEmitter,
bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
EventEmitter = require('../core/events');
BufferList = require('../core/bufferlist');
AVBuffer = require('../core/buffer');
BufferSource = (function(superClass) {
var clearImmediate, setImmediate;
extend(BufferSource, superClass);
function BufferSource(input) {
this.loop = bind(this.loop, this);
if (input instanceof BufferList) {
this.list = input;
} else {
this.list = new BufferList;
this.list.append(new AVBuffer(input));
}
this.paused = true;
}
setImmediate = global.setImmediate || function(fn) {
return global.setTimeout(fn, 0);
};
clearImmediate = global.clearImmediate || function(timer) {
return global.clearTimeout(timer);
};
BufferSource.prototype.start = function() {
this.paused = false;
return this._timer = setImmediate(this.loop);
};
BufferSource.prototype.loop = function() {
this.emit('progress', (this.list.numBuffers - this.list.availableBuffers + 1) / this.list.numBuffers * 100 | 0);
this.emit('data', this.list.first);
if (this.list.advance()) {
return setImmediate(this.loop);
} else {
return this.emit('end');
}
};
BufferSource.prototype.pause = function() {
clearImmediate(this._timer);
return this.paused = true;
};
BufferSource.prototype.reset = function() {
this.pause();
return this.list.rewind();
};
return BufferSource;
})(EventEmitter);
module.exports = BufferSource;
}).call(this);
}).call(this)}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
},{"../core/buffer":6,"../core/bufferlist":7,"../core/events":8}],32:[function(require,module,exports){
var key, val, _ref;
_ref = require('./src/aurora');
for (key in _ref) {
val = _ref[key];
exports[key] = val;
}
require('./src/devices/webaudio');
require('./src/devices/mozilla');
},{"./src/aurora":2,"./src/devices/mozilla":21,"./src/devices/webaudio":23}]},{},[32])(32)
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","src/asset.js","src/aurora.js","src/aurora_base.js","src/core/base.js","src/core/bitstream.js","src/core/buffer.js","src/core/bufferlist.js","src/core/events.js","src/core/stream.js","src/core/underflow.js","src/decoder.js","src/decoders/lpcm.js","src/decoders/xlaw.js","src/demuxer.js","src/demuxers/aiff.js","src/demuxers/au.js","src/demuxers/caf.js","src/demuxers/m4a.js","src/demuxers/wave.js","src/device.js","src/devices/mozilla.js","src/devices/resampler.js","src/devices/webaudio.js","src/filter.js","src/filters/balance.js","src/filters/volume.js","src/player.js","src/queue.js","/home/user/aurora.js-0.4.9/src/sources/browser/file.coffee","/home/user/aurora.js-0.4.9/src/sources/browser/http.coffee","src/sources/buffer.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;;ACjPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACnOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACzFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClgBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC5JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC3EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChEA,IAAA,kCAAA;EAAA;iSAAA;;AAAA,YAAA,GAAe,OAAA,CAAQ,mBAAR,CAAf,CAAA;;AAAA,QACA,GAAW,OAAA,CAAQ,mBAAR,CADX,CAAA;;AAAA;AAII,+BAAA,CAAA;;AAAa,EAAA,oBAAE,IAAF,GAAA;AACT,IADU,IAAC,CAAA,OAAA,IACX,CAAA;AAAA,IAAA,IAAO,wDAAP;AACI,aAAO,IAAC,CAAA,IAAD,CAAM,OAAN,EAAe,gDAAf,CAAP,CADJ;KAAA;AAAA,IAGA,IAAC,CAAA,MAAD,GAAU,CAHV,CAAA;AAAA,IAIA,IAAC,CAAA,MAAD,GAAU,IAAC,CAAA,IAAI,CAAC,IAJhB,CAAA;AAAA,IAKA,IAAC,CAAA,SAAD,GAAa,CAAA,IAAK,EALlB,CAAA;AAAA,IAMA,IAAC,CAAA,IAAK,CAAA,IAAC,CAAA,KAAD,GAAS,OAAT,CAAN,IAA2B,IAAC,CAAA,IAAK,CAAA,IAAC,CAAA,KAAD,GAAS,aAAT,CAAjC,IAA4D,IAAC,CAAA,IAAK,CAAA,IAAC,CAAA,KAAD,GAAS,UAAT,CANlE,CADS;EAAA,CAAb;;AAAA,uBASA,KAAA,GAAO,SAAA,GAAA;AACH,IAAA,IAAG,IAAC,CAAA,MAAJ;AACI,MAAA,IAAA,CAAA,IAAuB,CAAA,MAAvB;AAAA,eAAO,IAAC,CAAA,IAAD,CAAA,CAAP,CAAA;OADJ;KAAA;AAAA,IAGA,IAAC,CAAA,MAAD,GAAU,GAAA,CAAA,UAHV,CAAA;AAAA,IAIA,IAAC,CAAA,MAAD,GAAU,IAJV,CAAA;AAAA,IAMA,IAAC,CAAA,MAAM,CAAC,MAAR,GAAiB,CAAA,SAAA,KAAA,GAAA;aAAA,SAAC,CAAD,GAAA;AACb,YAAA,GAAA;AAAA,QAAA,GAAA,GAAU,IAAA,QAAA,CAAa,IAAA,UAAA,CAAW,CAAC,CAAC,MAAM,CAAC,MAApB,CAAb,CAAV,CAAA;AAAA,QACA,KAAC,CAAA,MAAD,IAAW,GAAG,CAAC,MADf,CAAA;AAAA,QAGA,KAAC,CAAA,IAAD,CAAM,MAAN,EAAc,GAAd,CAHA,CAAA;AAAA,QAIA,KAAC,CAAA,MAAD,GAAU,KAJV,CAAA;AAKA,QAAA,IAAW,KAAC,CAAA,MAAD,GAAU,KAAC,CAAA,MAAtB;iBAAA,KAAC,CAAA,IAAD,CAAA,EAAA;SANa;MAAA,EAAA;IAAA,CAAA,CAAA,CAAA,IAAA,CANjB,CAAA;AAAA,IAcA,IAAC,CAAA,MAAM,CAAC,SAAR,GAAoB,CAAA,SAAA,KAAA,GAAA;aAAA,SAAA,GAAA;AAChB,QAAA,IAAG,KAAC,CAAA,MAAD,KAAW,KAAC,CAAA,MAAf;AACI,UAAA,KAAC,CAAA,IAAD,CAAM,KAAN,CAAA,CAAA;iBACA,KAAC,CAAA,MAAD,GAAU,KAFd;SADgB;MAAA,EAAA;IAAA,CAAA,CAAA,CAAA,IAAA,CAdpB,CAAA;AAAA,IAmBA,IAAC,CAAA,MAAM,CAAC,OAAR,GAAkB,CAAA,SAAA,KAAA,GAAA;aAAA,SAAC,CAAD,GAAA;eACd,KAAC,CAAA,IAAD,CAAM,OAAN,EAAe,CAAf,EADc;MAAA,EAAA;IAAA,CAAA,CAAA,CAAA,IAAA,CAnBlB,CAAA;AAAA,IAsBA,IAAC,CAAA,MAAM,CAAC,UAAR,GAAqB,CAAA,SAAA,KAAA,GAAA;aAAA,SAAC,CAAD,GAAA;eACjB,KAAC,CAAA,IAAD,CAAM,UAAN,EAAkB,CAAC,KAAC,CAAA,MAAD,GAAU,CAAC,CAAC,MAAb,CAAA,GAAuB,KAAC,CAAA,MAAxB,GAAiC,GAAnD,EADiB;MAAA,EAAA;IAAA,CAAA,CAAA,CAAA,IAAA,CAtBrB,CAAA;WAyBA,IAAC,CAAA,IAAD,CAAA,EA1BG;EAAA,CATP,CAAA;;AAAA,uBAqCA,IAAA,GAAM,SAAA,GAAA;AACF,QAAA,YAAA;AAAA,IAAA,IAAC,CAAA,MAAD,GAAU,IAAV,CAAA;AAAA,IACA,MAAA,GAAS,IAAI,CAAC,GAAL,CAAS,IAAC,CAAA,MAAD,GAAU,IAAC,CAAA,SAApB,EAA+B,IAAC,CAAA,MAAhC,CADT,CAAA;AAAA,IAGA,IAAA,GAAO,IAAC,CAAA,IAAK,CAAA,IAAC,CAAA,KAAD,CAAN,CAAc,IAAC,CAAA,MAAf,EAAuB,MAAvB,CAHP,CAAA;WAIA,IAAC,CAAA,MAAM,CAAC,iBAAR,CAA0B,IAA1B,EALE;EAAA,CArCN,CAAA;;AAAA,uBA4CA,KAAA,GAAO,SAAA,GAAA;AACH,QAAA,IAAA;AAAA,IAAA,IAAC,CAAA,MAAD,GAAU,KAAV,CAAA;AACA;gDACS,CAAE,KAAT,CAAA,WADF;KAAA,kBAFG;EAAA,CA5CP,CAAA;;AAAA,uBAiDA,KAAA,GAAO,SAAA,GAAA;AACH,IAAA,IAAC,CAAA,KAAD,CAAA,CAAA,CAAA;WACA,IAAC,CAAA,MAAD,GAAU,EAFP;EAAA,CAjDP,CAAA;;oBAAA;;GADqB,aAHzB,CAAA;;AAAA,MAyDM,CAAC,OAAP,GAAiB,UAzDjB,CAAA;;;ACAA,IAAA,kCAAA;EAAA;iSAAA;;AAAA,YAAA,GAAe,OAAA,CAAQ,mBAAR,CAAf,CAAA;;AAAA,QACA,GAAW,OAAA,CAAQ,mBAAR,CADX,CAAA;;AAAA;AAII,+BAAA,CAAA;;AAAa,EAAA,oBAAE,GAAF,EAAQ,IAAR,GAAA;AACT,IADU,IAAC,CAAA,MAAA,GACX,CAAA;AAAA,IADgB,IAAC,CAAA,sBAAA,OAAO,EACxB,CAAA;AAAA,IAAA,IAAC,CAAA,SAAD,GAAa,CAAA,IAAK,EAAlB,CAAA;AAAA,IACA,IAAC,CAAA,QAAD,GAAY,KADZ,CAAA;AAEA,IAAA,IAAG,IAAC,CAAA,IAAI,CAAC,MAAT;AACI,MAAA,IAAC,CAAA,MAAD,GAAU,IAAC,CAAA,IAAI,CAAC,MAAhB,CADJ;KAFA;AAAA,IAIA,IAAC,CAAA,KAAD,CAAA,CAJA,CADS;EAAA,CAAb;;AAAA,uBAOA,KAAA,GAAO,SAAA,GAAA;AACH,IAAA,IAAG,IAAC,CAAA,MAAJ;AACI,MAAA,IAAA,CAAA,IAAuB,CAAA,QAAvB;AAAA,eAAO,IAAC,CAAA,IAAD,CAAA,CAAP,CAAA;OADJ;KAAA;AAAA,IAGA,IAAC,CAAA,QAAD,GAAY,IAHZ,CAAA;AAAA,IAIA,IAAC,CAAA,GAAD,GAAW,IAAA,cAAA,CAAA,CAJX,CAAA;AAAA,IAMA,IAAC,CAAA,GAAG,CAAC,MAAL,GAAc,CAAA,SAAA,KAAA,GAAA;aAAA,SAAC,KAAD,GAAA;AACV,QAAA,KAAC,CAAA,MAAD,GAAU,QAAA,CAAS,KAAC,CAAA,GAAG,CAAC,iBAAL,CAAuB,gBAAvB,CAAT,CAAV,CAAA;AAAA,QACA,KAAC,CAAA,QAAD,GAAY,KADZ,CAAA;eAEA,KAAC,CAAA,IAAD,CAAA,EAHU;MAAA,EAAA;IAAA,CAAA,CAAA,CAAA,IAAA,CANd,CAAA;AAAA,IAWA,IAAC,CAAA,GAAG,CAAC,OAAL,GAAe,CAAA,SAAA,KAAA,GAAA;aAAA,SAAC,GAAD,GAAA;AACX,QAAA,KAAC,CAAA,KAAD,CAAA,CAAA,CAAA;eACA,KAAC,CAAA,IAAD,CAAM,OAAN,EAAe,GAAf,EAFW;MAAA,EAAA;IAAA,CAAA,CAAA,CAAA,IAAA,CAXf,CAAA;AAAA,IAeA,IAAC,CAAA,GAAG,CAAC,OAAL,GAAe,CAAA,SAAA,KAAA,GAAA;aAAA,SAAC,KAAD,GAAA;eACX,KAAC,CAAA,QAAD,GAAY,MADD;MAAA,EAAA;IAAA,CAAA,CAAA,CAAA,IAAA,CAff,CAAA;AAAA,IAkBA,IAAC,CAAA,GAAG,CAAC,IAAL,CAAU,MAAV,EAAkB,IAAC,CAAA,GAAnB,EAAwB,IAAxB,CAlBA,CAAA;WAmBA,IAAC,CAAA,GAAG,CAAC,IAAL,CAAU,IAAV,EApBG;EAAA,CAPP,CAAA;;AAAA,uBA6BA,IAAA,GAAM,SAAA,GAAA;AACF,QAAA,MAAA;AAAA,IAAA,IAAG,IAAC,CAAA,QAAD,IAAa,CAAA,IAAK,CAAA,MAArB;AACI,aAAO,IAAC,CAAA,IAAD,CAAM,OAAN,EAAe,uCAAf,CAAP,CADJ;KAAA;AAAA,IAGA,IAAC,CAAA,QAAD,GAAY,IAHZ,CAAA;AAAA,IAIA,IAAC,CAAA,GAAD,GAAW,IAAA,cAAA,CAAA,CAJX,CAAA;AAAA,IAMA,IAAC,CAAA,GAAG,CAAC,MAAL,GAAc,CAAA,SAAA,KAAA,GAAA;aAAA,SAAC,KAAD,GAAA;AACV,YAAA,6BAAA;AAAA,QAAA,IAAG,KAAC,CAAA,GAAG,CAAC,QAAR;AACI,UAAA,GAAA,GAAU,IAAA,UAAA,CAAW,KAAC,CAAA,GAAG,CAAC,QAAhB,CAAV,CADJ;SAAA,MAAA;AAGI,UAAA,GAAA,GAAM,KAAC,CAAA,GAAG,CAAC,YAAX,CAAA;AAAA,UACA,GAAA,GAAU,IAAA,UAAA,CAAW,GAAG,CAAC,MAAf,CADV,CAAA;AAEA,eAAS,6FAAT,GAAA;AACI,YAAA,GAAI,CAAA,CAAA,CAAJ,GAAS,GAAG,CAAC,UAAJ,CAAe,CAAf,CAAA,GAAoB,IAA7B,CADJ;AAAA,WALJ;SAAA;AAAA,QAQA,MAAA,GAAa,IAAA,QAAA,CAAS,GAAT,CARb,CAAA;AAAA,QASA,KAAC,CAAA,MAAD,IAAW,MAAM,CAAC,MATlB,CAAA;AAAA,QAWA,KAAC,CAAA,IAAD,CAAM,MAAN,EAAc,MAAd,CAXA,CAAA;AAYA,QAAA,IAAe,KAAC,CAAA,MAAD,IAAW,KAAC,CAAA,MAA3B;AAAA,UAAA,KAAC,CAAA,IAAD,CAAM,KAAN,CAAA,CAAA;SAZA;AAAA,QAcA,KAAC,CAAA,QAAD,GAAY,KAdZ,CAAA;AAeA,QAAA,IAAA,CAAA,CAAe,KAAC,CAAA,MAAD,IAAW,KAAC,CAAA,MAA3B,CAAA;iBAAA,KAAC,CAAA,IAAD,CAAA,EAAA;SAhBU;MAAA,EAAA;IAAA,CAAA,CAAA,CAAA,IAAA,CANd,CAAA;AAAA,IAwBA,IAAC,CAAA,GAAG,CAAC,UAAL,GAAkB,CAAA,SAAA,KAAA,GAAA;aAAA,SAAC,KAAD,GAAA;eACd,KAAC,CAAA,IAAD,CAAM,UAAN,EAAkB,CAAC,KAAC,CAAA,MAAD,GAAU,KAAK,CAAC,MAAjB,CAAA,GAA2B,KAAC,CAAA,MAA5B,GAAqC,GAAvD,EADc;MAAA,EAAA;IAAA,CAAA,CAAA,CAAA,IAAA,CAxBlB,CAAA;AAAA,IA2BA,IAAC,CAAA,GAAG,CAAC,OAAL,GAAe,CAAA,SAAA,KAAA,GAAA;aAAA,SAAC,GAAD,GAAA;AACX,QAAA,KAAC,CAAA,IAAD,CAAM,OAAN,EAAe,GAAf,CAAA,CAAA;eACA,KAAC,CAAA,KAAD,CAAA,EAFW;MAAA,EAAA;IAAA,CAAA,CAAA,CAAA,IAAA,CA3Bf,CAAA;AAAA,IA+BA,IAAC,CAAA,GAAG,CAAC,OAAL,GAAe,CAAA,SAAA,KAAA,GAAA;aAAA,SAAC,KAAD,GAAA;eACX,KAAC,CAAA,QAAD,GAAY,MADD;MAAA,EAAA;IAAA,CAAA,CAAA,CAAA,IAAA,CA/Bf,CAAA;AAAA,IAkCA,IAAC,CAAA,GAAG,CAAC,IAAL,CAAU,KAAV,EAAiB,IAAC,CAAA,GAAlB,EAAuB,IAAvB,CAlCA,CAAA;AAAA,IAmCA,IAAC,CAAA,GAAG,CAAC,YAAL,GAAoB,aAnCpB,CAAA;AAAA,IAqCA,MAAA,GAAS,IAAI,CAAC,GAAL,CAAS,IAAC,CAAA,MAAD,GAAU,IAAC,CAAA,SAApB,EAA+B,IAAC,CAAA,MAAD,GAAU,CAAzC,CArCT,CAAA;AAAA,IAsCA,IAAC,CAAA,GAAG,CAAC,gBAAL,CAAsB,eAAtB,EAAuC,iBAAvC,CAtCA,CAAA;AAAA,IAuCA,IAAC,CAAA,GAAG,CAAC,gBAAL,CAAsB,OAAtB,EAAgC,QAAA,GAAO,IAAC,CAAA,MAAR,GAAgB,GAAhB,GAAkB,MAAlD,CAvCA,CAAA;AAAA,IAwCA,IAAC,CAAA,GAAG,CAAC,gBAAL,CAAsB,oCAAtB,CAxCA,CAAA;WAyCA,IAAC,CAAA,GAAG,CAAC,IAAL,CAAU,IAAV,EA1CE;EAAA,CA7BN,CAAA;;AAAA,uBAyEA,KAAA,GAAO,SAAA,GAAA;AACH,QAAA,IAAA;AAAA,IAAA,IAAC,CAAA,QAAD,GAAY,KAAZ,CAAA;2CACI,CAAE,KAAN,CAAA,WAFG;EAAA,CAzEP,CAAA;;AAAA,uBA6EA,KAAA,GAAO,SAAA,GAAA;AACH,IAAA,IAAC,CAAA,KAAD,CAAA,CAAA,CAAA;WACA,IAAC,CAAA,MAAD,GAAU,EAFP;EAAA,CA7EP,CAAA;;oBAAA;;GADqB,aAHzB,CAAA;;AAAA,MAqFM,CAAC,OAAP,GAAiB,UArFjB,CAAA;;;;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","file":"generated.js","sourceRoot":"","sourcesContent":["(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=\"function\"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error(\"Cannot find module '\"+i+\"'\");throw a.code=\"MODULE_NOT_FOUND\",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=\"function\"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()","// Generated by CoffeeScript 1.12.7\n(function() {\n  var Asset, BufferSource, Decoder, Demuxer, EventEmitter, FileSource, HTTPSource,\n    bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  EventEmitter = require('./core/events');\n\n  HTTPSource = require('./sources/node/http');\n\n  FileSource = require('./sources/node/file');\n\n  BufferSource = require('./sources/buffer');\n\n  Demuxer = require('./demuxer');\n\n  Decoder = require('./decoder');\n\n  Asset = (function(superClass) {\n    extend(Asset, superClass);\n\n    function Asset(source) {\n      this.source = source;\n      this._decode = bind(this._decode, this);\n      this.findDecoder = bind(this.findDecoder, this);\n      this.probe = bind(this.probe, this);\n      this.buffered = 0;\n      this.duration = null;\n      this.format = null;\n      this.metadata = null;\n      this.active = false;\n      this.demuxer = null;\n      this.decoder = null;\n      this.source.once('data', this.probe);\n      this.source.on('error', (function(_this) {\n        return function(err) {\n          _this.emit('error', err);\n          return _this.stop();\n        };\n      })(this));\n      this.source.on('progress', (function(_this) {\n        return function(buffered) {\n          _this.buffered = buffered;\n          return _this.emit('buffer', _this.buffered);\n        };\n      })(this));\n    }\n\n    Asset.fromURL = function(url, opts) {\n      return new Asset(new HTTPSource(url, opts));\n    };\n\n    Asset.fromFile = function(file) {\n      return new Asset(new FileSource(file));\n    };\n\n    Asset.fromBuffer = function(buffer) {\n      return new Asset(new BufferSource(buffer));\n    };\n\n    Asset.prototype.start = function(decode) {\n      if (this.active) {\n        return;\n      }\n      if (decode != null) {\n        this.shouldDecode = decode;\n      }\n      if (this.shouldDecode == null) {\n        this.shouldDecode = true;\n      }\n      this.active = true;\n      this.source.start();\n      if (this.decoder && this.shouldDecode) {\n        return this._decode();\n      }\n    };\n\n    Asset.prototype.stop = function() {\n      if (!this.active) {\n        return;\n      }\n      this.active = false;\n      return this.source.pause();\n    };\n\n    Asset.prototype.get = function(event, callback) {\n      if (event !== 'format' && event !== 'duration' && event !== 'metadata') {\n        return;\n      }\n      if (this[event] != null) {\n        return callback(this[event]);\n      } else {\n        this.once(event, (function(_this) {\n          return function(value) {\n            _this.stop();\n            return callback(value);\n          };\n        })(this));\n        return this.start();\n      }\n    };\n\n    Asset.prototype.decodePacket = function() {\n      return this.decoder.decode();\n    };\n\n    Asset.prototype.decodeToBuffer = function(callback) {\n      var chunks, dataHandler, length;\n      length = 0;\n      chunks = [];\n      this.on('data', dataHandler = function(chunk) {\n        length += chunk.length;\n        return chunks.push(chunk);\n      });\n      this.once('end', function() {\n        var buf, chunk, j, len, offset;\n        buf = new Float32Array(length);\n        offset = 0;\n        for (j = 0, len = chunks.length; j < len; j++) {\n          chunk = chunks[j];\n          buf.set(chunk, offset);\n          offset += chunk.length;\n        }\n        this.off('data', dataHandler);\n        return callback(buf);\n      });\n      return this.start();\n    };\n\n    Asset.prototype.probe = function(chunk) {\n      var demuxer;\n      if (!this.active) {\n        return;\n      }\n      demuxer = Demuxer.find(chunk);\n      if (!demuxer) {\n        return this.emit('error', 'A demuxer for this container was not found.');\n      }\n      this.demuxer = new demuxer(this.source, chunk);\n      this.demuxer.on('format', this.findDecoder);\n      this.demuxer.on('duration', (function(_this) {\n        return function(duration) {\n          _this.duration = duration;\n          return _this.emit('duration', _this.duration);\n        };\n      })(this));\n      this.demuxer.on('metadata', (function(_this) {\n        return function(metadata) {\n          _this.metadata = metadata;\n          return _this.emit('metadata', _this.metadata);\n        };\n      })(this));\n      return this.demuxer.on('error', (function(_this) {\n        return function(err) {\n          _this.emit('error', err);\n          return _this.stop();\n        };\n      })(this));\n    };\n\n    Asset.prototype.findDecoder = function(format) {\n      var decoder, div;\n      this.format = format;\n      if (!this.active) {\n        return;\n      }\n      this.emit('format', this.format);\n      decoder = Decoder.find(this.format.formatID);\n      if (!decoder) {\n        return this.emit('error', \"A decoder for \" + this.format.formatID + \" was not found.\");\n      }\n      this.decoder = new decoder(this.demuxer, this.format);\n      if (this.format.floatingPoint) {\n        this.decoder.on('data', (function(_this) {\n          return function(buffer) {\n            return _this.emit('data', buffer);\n          };\n        })(this));\n      } else {\n        div = Math.pow(2, this.format.bitsPerChannel - 1);\n        this.decoder.on('data', (function(_this) {\n          return function(buffer) {\n            var buf, i, j, len, sample;\n            buf = new Float32Array(buffer.length);\n            for (i = j = 0, len = buffer.length; j < len; i = ++j) {\n              sample = buffer[i];\n              buf[i] = sample / div;\n            }\n            return _this.emit('data', buf);\n          };\n        })(this));\n      }\n      this.decoder.on('error', (function(_this) {\n        return function(err) {\n          _this.emit('error', err);\n          return _this.stop();\n        };\n      })(this));\n      this.decoder.on('end', (function(_this) {\n        return function() {\n          return _this.emit('end');\n        };\n      })(this));\n      this.emit('decodeStart');\n      if (this.shouldDecode) {\n        return this._decode();\n      }\n    };\n\n    Asset.prototype._decode = function() {\n      while (this.decoder.decode() && this.active) {\n        continue;\n      }\n      if (this.active) {\n        return this.decoder.once('data', this._decode);\n      }\n    };\n\n    Asset.prototype.destroy = function() {\n      var ref, ref1, ref2;\n      this.stop();\n      if ((ref = this.demuxer) != null) {\n        ref.off();\n      }\n      if ((ref1 = this.decoder) != null) {\n        ref1.off();\n      }\n      if ((ref2 = this.source) != null) {\n        ref2.off();\n      }\n      return this.off();\n    };\n\n    return Asset;\n\n  })(EventEmitter);\n\n  module.exports = Asset;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var key, ref, val;\n\n  ref = require('./aurora_base');\n  for (key in ref) {\n    val = ref[key];\n    exports[key] = val;\n  }\n\n  require('./demuxers/caf');\n\n  require('./demuxers/m4a');\n\n  require('./demuxers/aiff');\n\n  require('./demuxers/wave');\n\n  require('./demuxers/au');\n\n  require('./decoders/lpcm');\n\n  require('./decoders/xlaw');\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  exports.Base = require('./core/base');\n\n  exports.Buffer = require('./core/buffer');\n\n  exports.BufferList = require('./core/bufferlist');\n\n  exports.Stream = require('./core/stream');\n\n  exports.Bitstream = require('./core/bitstream');\n\n  exports.EventEmitter = require('./core/events');\n\n  exports.UnderflowError = require('./core/underflow');\n\n  exports.HTTPSource = require('./sources/node/http');\n\n  exports.FileSource = require('./sources/node/file');\n\n  exports.BufferSource = require('./sources/buffer');\n\n  exports.Demuxer = require('./demuxer');\n\n  exports.Decoder = require('./decoder');\n\n  exports.AudioDevice = require('./device');\n\n  exports.Asset = require('./asset');\n\n  exports.Player = require('./player');\n\n  exports.Filter = require('./filter');\n\n  exports.VolumeFilter = require('./filters/volume');\n\n  exports.BalanceFilter = require('./filters/balance');\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var Base,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty,\n    indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; };\n\n  Base = (function() {\n    var fnTest;\n\n    function Base() {}\n\n    fnTest = /\\b_super\\b/;\n\n    Base.extend = function(prop) {\n      var Class, _super, fn, key, keys, ref;\n      Class = (function(superClass) {\n        extend(Class, superClass);\n\n        function Class() {\n          return Class.__super__.constructor.apply(this, arguments);\n        }\n\n        return Class;\n\n      })(this);\n      if (typeof prop === 'function') {\n        keys = Object.keys(Class.prototype);\n        prop.call(Class, Class);\n        prop = {};\n        ref = Class.prototype;\n        for (key in ref) {\n          fn = ref[key];\n          if (indexOf.call(keys, key) < 0) {\n            prop[key] = fn;\n          }\n        }\n      }\n      _super = Class.__super__;\n      for (key in prop) {\n        fn = prop[key];\n        if (typeof fn === 'function' && fnTest.test(fn)) {\n          (function(key, fn) {\n            return Class.prototype[key] = function() {\n              var ret, tmp;\n              tmp = this._super;\n              this._super = _super[key];\n              ret = fn.apply(this, arguments);\n              this._super = tmp;\n              return ret;\n            };\n          })(key, fn);\n        } else {\n          Class.prototype[key] = fn;\n        }\n      }\n      return Class;\n    };\n\n    return Base;\n\n  })();\n\n  module.exports = Base;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var Bitstream;\n\n  Bitstream = (function() {\n    function Bitstream(stream) {\n      this.stream = stream;\n      this.bitPosition = 0;\n    }\n\n    Bitstream.prototype.copy = function() {\n      var result;\n      result = new Bitstream(this.stream.copy());\n      result.bitPosition = this.bitPosition;\n      return result;\n    };\n\n    Bitstream.prototype.offset = function() {\n      return 8 * this.stream.offset + this.bitPosition;\n    };\n\n    Bitstream.prototype.available = function(bits) {\n      return this.stream.available((bits + 8 - this.bitPosition) / 8);\n    };\n\n    Bitstream.prototype.advance = function(bits) {\n      var pos;\n      pos = this.bitPosition + bits;\n      this.stream.advance(pos >> 3);\n      return this.bitPosition = pos & 7;\n    };\n\n    Bitstream.prototype.rewind = function(bits) {\n      var pos;\n      pos = this.bitPosition - bits;\n      this.stream.rewind(Math.abs(pos >> 3));\n      return this.bitPosition = pos & 7;\n    };\n\n    Bitstream.prototype.seek = function(offset) {\n      var curOffset;\n      curOffset = this.offset();\n      if (offset > curOffset) {\n        return this.advance(offset - curOffset);\n      } else if (offset < curOffset) {\n        return this.rewind(curOffset - offset);\n      }\n    };\n\n    Bitstream.prototype.align = function() {\n      if (this.bitPosition !== 0) {\n        this.bitPosition = 0;\n        return this.stream.advance(1);\n      }\n    };\n\n    Bitstream.prototype.read = function(bits, signed) {\n      var a, a0, a1, a2, a3, a4, mBits;\n      if (bits === 0) {\n        return 0;\n      }\n      mBits = bits + this.bitPosition;\n      if (mBits <= 8) {\n        a = ((this.stream.peekUInt8() << this.bitPosition) & 0xff) >>> (8 - bits);\n      } else if (mBits <= 16) {\n        a = ((this.stream.peekUInt16() << this.bitPosition) & 0xffff) >>> (16 - bits);\n      } else if (mBits <= 24) {\n        a = ((this.stream.peekUInt24() << this.bitPosition) & 0xffffff) >>> (24 - bits);\n      } else if (mBits <= 32) {\n        a = (this.stream.peekUInt32() << this.bitPosition) >>> (32 - bits);\n      } else if (mBits <= 40) {\n        a0 = this.stream.peekUInt8(0) * 0x0100000000;\n        a1 = this.stream.peekUInt8(1) << 24 >>> 0;\n        a2 = this.stream.peekUInt8(2) << 16;\n        a3 = this.stream.peekUInt8(3) << 8;\n        a4 = this.stream.peekUInt8(4);\n        a = a0 + a1 + a2 + a3 + a4;\n        a %= Math.pow(2, 40 - this.bitPosition);\n        a = Math.floor(a / Math.pow(2, 40 - this.bitPosition - bits));\n      } else {\n        throw new Error(\"Too many bits!\");\n      }\n      if (signed) {\n        if (mBits < 32) {\n          if (a >>> (bits - 1)) {\n            a = ((1 << bits >>> 0) - a) * -1;\n          }\n        } else {\n          if (a / Math.pow(2, bits - 1) | 0) {\n            a = (Math.pow(2, bits) - a) * -1;\n          }\n        }\n      }\n      this.advance(bits);\n      return a;\n    };\n\n    Bitstream.prototype.peek = function(bits, signed) {\n      var a, a0, a1, a2, a3, a4, mBits;\n      if (bits === 0) {\n        return 0;\n      }\n      mBits = bits + this.bitPosition;\n      if (mBits <= 8) {\n        a = ((this.stream.peekUInt8() << this.bitPosition) & 0xff) >>> (8 - bits);\n      } else if (mBits <= 16) {\n        a = ((this.stream.peekUInt16() << this.bitPosition) & 0xffff) >>> (16 - bits);\n      } else if (mBits <= 24) {\n        a = ((this.stream.peekUInt24() << this.bitPosition) & 0xffffff) >>> (24 - bits);\n      } else if (mBits <= 32) {\n        a = (this.stream.peekUInt32() << this.bitPosition) >>> (32 - bits);\n      } else if (mBits <= 40) {\n        a0 = this.stream.peekUInt8(0) * 0x0100000000;\n        a1 = this.stream.peekUInt8(1) << 24 >>> 0;\n        a2 = this.stream.peekUInt8(2) << 16;\n        a3 = this.stream.peekUInt8(3) << 8;\n        a4 = this.stream.peekUInt8(4);\n        a = a0 + a1 + a2 + a3 + a4;\n        a %= Math.pow(2, 40 - this.bitPosition);\n        a = Math.floor(a / Math.pow(2, 40 - this.bitPosition - bits));\n      } else {\n        throw new Error(\"Too many bits!\");\n      }\n      if (signed) {\n        if (mBits < 32) {\n          if (a >>> (bits - 1)) {\n            a = ((1 << bits >>> 0) - a) * -1;\n          }\n        } else {\n          if (a / Math.pow(2, bits - 1) | 0) {\n            a = (Math.pow(2, bits) - a) * -1;\n          }\n        }\n      }\n      return a;\n    };\n\n    Bitstream.prototype.readLSB = function(bits, signed) {\n      var a, mBits;\n      if (bits === 0) {\n        return 0;\n      }\n      if (bits > 40) {\n        throw new Error(\"Too many bits!\");\n      }\n      mBits = bits + this.bitPosition;\n      a = (this.stream.peekUInt8(0)) >>> this.bitPosition;\n      if (mBits > 8) {\n        a |= (this.stream.peekUInt8(1)) << (8 - this.bitPosition);\n      }\n      if (mBits > 16) {\n        a |= (this.stream.peekUInt8(2)) << (16 - this.bitPosition);\n      }\n      if (mBits > 24) {\n        a += (this.stream.peekUInt8(3)) << (24 - this.bitPosition) >>> 0;\n      }\n      if (mBits > 32) {\n        a += (this.stream.peekUInt8(4)) * Math.pow(2, 32 - this.bitPosition);\n      }\n      if (mBits >= 32) {\n        a %= Math.pow(2, bits);\n      } else {\n        a &= (1 << bits) - 1;\n      }\n      if (signed) {\n        if (mBits < 32) {\n          if (a >>> (bits - 1)) {\n            a = ((1 << bits >>> 0) - a) * -1;\n          }\n        } else {\n          if (a / Math.pow(2, bits - 1) | 0) {\n            a = (Math.pow(2, bits) - a) * -1;\n          }\n        }\n      }\n      this.advance(bits);\n      return a;\n    };\n\n    Bitstream.prototype.peekLSB = function(bits, signed) {\n      var a, mBits;\n      if (bits === 0) {\n        return 0;\n      }\n      if (bits > 40) {\n        throw new Error(\"Too many bits!\");\n      }\n      mBits = bits + this.bitPosition;\n      a = (this.stream.peekUInt8(0)) >>> this.bitPosition;\n      if (mBits > 8) {\n        a |= (this.stream.peekUInt8(1)) << (8 - this.bitPosition);\n      }\n      if (mBits > 16) {\n        a |= (this.stream.peekUInt8(2)) << (16 - this.bitPosition);\n      }\n      if (mBits > 24) {\n        a += (this.stream.peekUInt8(3)) << (24 - this.bitPosition) >>> 0;\n      }\n      if (mBits > 32) {\n        a += (this.stream.peekUInt8(4)) * Math.pow(2, 32 - this.bitPosition);\n      }\n      if (mBits >= 32) {\n        a %= Math.pow(2, bits);\n      } else {\n        a &= (1 << bits) - 1;\n      }\n      if (signed) {\n        if (mBits < 32) {\n          if (a >>> (bits - 1)) {\n            a = ((1 << bits >>> 0) - a) * -1;\n          }\n        } else {\n          if (a / Math.pow(2, bits - 1) | 0) {\n            a = (Math.pow(2, bits) - a) * -1;\n          }\n        }\n      }\n      return a;\n    };\n\n    return Bitstream;\n\n  })();\n\n  module.exports = Bitstream;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var AVBuffer;\n\n  AVBuffer = (function() {\n    var BlobBuilder, URL;\n\n    function AVBuffer(input) {\n      var ref;\n      if (input instanceof Uint8Array) {\n        this.data = input;\n      } else if (input instanceof ArrayBuffer || Array.isArray(input) || typeof input === 'number' || ((ref = global.Buffer) != null ? ref.isBuffer(input) : void 0)) {\n        this.data = new Uint8Array(input);\n      } else if (input.buffer instanceof ArrayBuffer) {\n        this.data = new Uint8Array(input.buffer, input.byteOffset, input.length * input.BYTES_PER_ELEMENT);\n      } else if (input instanceof AVBuffer) {\n        this.data = input.data;\n      } else {\n        throw new Error(\"Constructing buffer with unknown type.\");\n      }\n      this.length = this.data.length;\n      this.next = null;\n      this.prev = null;\n    }\n\n    AVBuffer.allocate = function(size) {\n      return new AVBuffer(size);\n    };\n\n    AVBuffer.prototype.copy = function() {\n      return new AVBuffer(new Uint8Array(this.data));\n    };\n\n    AVBuffer.prototype.slice = function(position, length) {\n      if (length == null) {\n        length = this.length;\n      }\n      if (position === 0 && length >= this.length) {\n        return new AVBuffer(this.data);\n      } else {\n        return new AVBuffer(this.data.subarray(position, position + length));\n      }\n    };\n\n    BlobBuilder = global.BlobBuilder || global.MozBlobBuilder || global.WebKitBlobBuilder;\n\n    URL = global.URL || global.webkitURL || global.mozURL;\n\n    AVBuffer.makeBlob = function(data, type) {\n      var bb;\n      if (type == null) {\n        type = 'application/octet-stream';\n      }\n      try {\n        return new Blob([data], {\n          type: type\n        });\n      } catch (error) {}\n      if (BlobBuilder != null) {\n        bb = new BlobBuilder;\n        bb.append(data);\n        return bb.getBlob(type);\n      }\n      return null;\n    };\n\n    AVBuffer.makeBlobURL = function(data, type) {\n      return URL != null ? URL.createObjectURL(this.makeBlob(data, type)) : void 0;\n    };\n\n    AVBuffer.revokeBlobURL = function(url) {\n      return URL != null ? URL.revokeObjectURL(url) : void 0;\n    };\n\n    AVBuffer.prototype.toBlob = function() {\n      return AVBuffer.makeBlob(this.data.buffer);\n    };\n\n    AVBuffer.prototype.toBlobURL = function() {\n      return AVBuffer.makeBlobURL(this.data.buffer);\n    };\n\n    return AVBuffer;\n\n  })();\n\n  module.exports = AVBuffer;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var BufferList;\n\n  BufferList = (function() {\n    function BufferList() {\n      this.first = null;\n      this.last = null;\n      this.numBuffers = 0;\n      this.availableBytes = 0;\n      this.availableBuffers = 0;\n    }\n\n    BufferList.prototype.copy = function() {\n      var result;\n      result = new BufferList;\n      result.first = this.first;\n      result.last = this.last;\n      result.numBuffers = this.numBuffers;\n      result.availableBytes = this.availableBytes;\n      result.availableBuffers = this.availableBuffers;\n      return result;\n    };\n\n    BufferList.prototype.append = function(buffer) {\n      var ref;\n      buffer.prev = this.last;\n      if ((ref = this.last) != null) {\n        ref.next = buffer;\n      }\n      this.last = buffer;\n      if (this.first == null) {\n        this.first = buffer;\n      }\n      this.availableBytes += buffer.length;\n      this.availableBuffers++;\n      return this.numBuffers++;\n    };\n\n    BufferList.prototype.advance = function() {\n      if (this.first) {\n        this.availableBytes -= this.first.length;\n        this.availableBuffers--;\n        this.first = this.first.next;\n        return this.first != null;\n      }\n      return false;\n    };\n\n    BufferList.prototype.rewind = function() {\n      var ref;\n      if (this.first && !this.first.prev) {\n        return false;\n      }\n      this.first = ((ref = this.first) != null ? ref.prev : void 0) || this.last;\n      if (this.first) {\n        this.availableBytes += this.first.length;\n        this.availableBuffers++;\n      }\n      return this.first != null;\n    };\n\n    BufferList.prototype.reset = function() {\n      var results;\n      results = [];\n      while (this.rewind()) {\n        continue;\n      }\n      return results;\n    };\n\n    return BufferList;\n\n  })();\n\n  module.exports = BufferList;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var Base, EventEmitter,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty,\n    slice = [].slice;\n\n  Base = require('./base');\n\n  EventEmitter = (function(superClass) {\n    extend(EventEmitter, superClass);\n\n    function EventEmitter() {\n      return EventEmitter.__super__.constructor.apply(this, arguments);\n    }\n\n    EventEmitter.prototype.on = function(event, fn) {\n      var base;\n      if (this.events == null) {\n        this.events = {};\n      }\n      if ((base = this.events)[event] == null) {\n        base[event] = [];\n      }\n      return this.events[event].push(fn);\n    };\n\n    EventEmitter.prototype.off = function(event, fn) {\n      var events, index, ref;\n      if (this.events == null) {\n        return;\n      }\n      if ((ref = this.events) != null ? ref[event] : void 0) {\n        if (fn != null) {\n          index = this.events[event].indexOf(fn);\n          if (~index) {\n            return this.events[event].splice(index, 1);\n          }\n        } else {\n          return this.events[event];\n        }\n      } else if (event == null) {\n        return events = {};\n      }\n    };\n\n    EventEmitter.prototype.once = function(event, fn) {\n      var cb;\n      return this.on(event, cb = function() {\n        this.off(event, cb);\n        return fn.apply(this, arguments);\n      });\n    };\n\n    EventEmitter.prototype.emit = function() {\n      var args, event, fn, i, len, ref, ref1;\n      event = arguments[0], args = 2 <= arguments.length ? slice.call(arguments, 1) : [];\n      if (!((ref = this.events) != null ? ref[event] : void 0)) {\n        return;\n      }\n      ref1 = this.events[event].slice();\n      for (i = 0, len = ref1.length; i < len; i++) {\n        fn = ref1[i];\n        fn.apply(this, args);\n      }\n    };\n\n    return EventEmitter;\n\n  })(Base);\n\n  module.exports = EventEmitter;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var AVBuffer, BufferList, Stream, UnderflowError;\n\n  BufferList = require('./bufferlist');\n\n  AVBuffer = require('./buffer');\n\n  UnderflowError = require('./underflow');\n\n  Stream = (function() {\n    var buf, decodeString, float32, float64, float64Fallback, float80, int16, int32, int8, nativeEndian, uint16, uint32, uint8;\n\n    buf = new ArrayBuffer(16);\n\n    uint8 = new Uint8Array(buf);\n\n    int8 = new Int8Array(buf);\n\n    uint16 = new Uint16Array(buf);\n\n    int16 = new Int16Array(buf);\n\n    uint32 = new Uint32Array(buf);\n\n    int32 = new Int32Array(buf);\n\n    float32 = new Float32Array(buf);\n\n    if (typeof Float64Array !== \"undefined\" && Float64Array !== null) {\n      float64 = new Float64Array(buf);\n    }\n\n    nativeEndian = new Uint16Array(new Uint8Array([0x12, 0x34]).buffer)[0] === 0x3412;\n\n    function Stream(list1) {\n      this.list = list1;\n      this.localOffset = 0;\n      this.offset = 0;\n    }\n\n    Stream.fromBuffer = function(buffer) {\n      var list;\n      list = new BufferList;\n      list.append(buffer);\n      return new Stream(list);\n    };\n\n    Stream.prototype.copy = function() {\n      var result;\n      result = new Stream(this.list.copy());\n      result.localOffset = this.localOffset;\n      result.offset = this.offset;\n      return result;\n    };\n\n    Stream.prototype.available = function(bytes) {\n      return bytes <= this.list.availableBytes - this.localOffset;\n    };\n\n    Stream.prototype.remainingBytes = function() {\n      return this.list.availableBytes - this.localOffset;\n    };\n\n    Stream.prototype.advance = function(bytes) {\n      if (!this.available(bytes)) {\n        throw new UnderflowError();\n      }\n      this.localOffset += bytes;\n      this.offset += bytes;\n      while (this.list.first && this.localOffset >= this.list.first.length) {\n        this.localOffset -= this.list.first.length;\n        this.list.advance();\n      }\n      return this;\n    };\n\n    Stream.prototype.rewind = function(bytes) {\n      if (bytes > this.offset) {\n        throw new UnderflowError();\n      }\n      if (!this.list.first) {\n        this.list.rewind();\n        this.localOffset = this.list.first.length;\n      }\n      this.localOffset -= bytes;\n      this.offset -= bytes;\n      while (this.list.first.prev && this.localOffset < 0) {\n        this.list.rewind();\n        this.localOffset += this.list.first.length;\n      }\n      return this;\n    };\n\n    Stream.prototype.seek = function(position) {\n      if (position > this.offset) {\n        return this.advance(position - this.offset);\n      } else if (position < this.offset) {\n        return this.rewind(this.offset - position);\n      }\n    };\n\n    Stream.prototype.readUInt8 = function() {\n      var a;\n      if (!this.available(1)) {\n        throw new UnderflowError();\n      }\n      a = this.list.first.data[this.localOffset];\n      this.localOffset += 1;\n      this.offset += 1;\n      if (this.localOffset === this.list.first.length) {\n        this.localOffset = 0;\n        this.list.advance();\n      }\n      return a;\n    };\n\n    Stream.prototype.peekUInt8 = function(offset) {\n      var buffer;\n      if (offset == null) {\n        offset = 0;\n      }\n      if (!this.available(offset + 1)) {\n        throw new UnderflowError();\n      }\n      offset = this.localOffset + offset;\n      buffer = this.list.first;\n      while (buffer) {\n        if (buffer.length > offset) {\n          return buffer.data[offset];\n        }\n        offset -= buffer.length;\n        buffer = buffer.next;\n      }\n      return 0;\n    };\n\n    Stream.prototype.read = function(bytes, littleEndian) {\n      var i, j, k, ref, ref1;\n      if (littleEndian == null) {\n        littleEndian = false;\n      }\n      if (littleEndian === nativeEndian) {\n        for (i = j = 0, ref = bytes; j < ref; i = j += 1) {\n          uint8[i] = this.readUInt8();\n        }\n      } else {\n        for (i = k = ref1 = bytes - 1; k >= 0; i = k += -1) {\n          uint8[i] = this.readUInt8();\n        }\n      }\n    };\n\n    Stream.prototype.peek = function(bytes, offset, littleEndian) {\n      var i, j, k, ref, ref1;\n      if (littleEndian == null) {\n        littleEndian = false;\n      }\n      if (littleEndian === nativeEndian) {\n        for (i = j = 0, ref = bytes; j < ref; i = j += 1) {\n          uint8[i] = this.peekUInt8(offset + i);\n        }\n      } else {\n        for (i = k = 0, ref1 = bytes; k < ref1; i = k += 1) {\n          uint8[bytes - i - 1] = this.peekUInt8(offset + i);\n        }\n      }\n    };\n\n    Stream.prototype.readInt8 = function() {\n      this.read(1);\n      return int8[0];\n    };\n\n    Stream.prototype.peekInt8 = function(offset) {\n      if (offset == null) {\n        offset = 0;\n      }\n      this.peek(1, offset);\n      return int8[0];\n    };\n\n    Stream.prototype.readUInt16 = function(littleEndian) {\n      this.read(2, littleEndian);\n      return uint16[0];\n    };\n\n    Stream.prototype.peekUInt16 = function(offset, littleEndian) {\n      if (offset == null) {\n        offset = 0;\n      }\n      this.peek(2, offset, littleEndian);\n      return uint16[0];\n    };\n\n    Stream.prototype.readInt16 = function(littleEndian) {\n      this.read(2, littleEndian);\n      return int16[0];\n    };\n\n    Stream.prototype.peekInt16 = function(offset, littleEndian) {\n      if (offset == null) {\n        offset = 0;\n      }\n      this.peek(2, offset, littleEndian);\n      return int16[0];\n    };\n\n    Stream.prototype.readUInt24 = function(littleEndian) {\n      if (littleEndian) {\n        return this.readUInt16(true) + (this.readUInt8() << 16);\n      } else {\n        return (this.readUInt16() << 8) + this.readUInt8();\n      }\n    };\n\n    Stream.prototype.peekUInt24 = function(offset, littleEndian) {\n      if (offset == null) {\n        offset = 0;\n      }\n      if (littleEndian) {\n        return this.peekUInt16(offset, true) + (this.peekUInt8(offset + 2) << 16);\n      } else {\n        return (this.peekUInt16(offset) << 8) + this.peekUInt8(offset + 2);\n      }\n    };\n\n    Stream.prototype.readInt24 = function(littleEndian) {\n      if (littleEndian) {\n        return this.readUInt16(true) + (this.readInt8() << 16);\n      } else {\n        return (this.readInt16() << 8) + this.readUInt8();\n      }\n    };\n\n    Stream.prototype.peekInt24 = function(offset, littleEndian) {\n      if (offset == null) {\n        offset = 0;\n      }\n      if (littleEndian) {\n        return this.peekUInt16(offset, true) + (this.peekInt8(offset + 2) << 16);\n      } else {\n        return (this.peekInt16(offset) << 8) + this.peekUInt8(offset + 2);\n      }\n    };\n\n    Stream.prototype.readUInt32 = function(littleEndian) {\n      this.read(4, littleEndian);\n      return uint32[0];\n    };\n\n    Stream.prototype.peekUInt32 = function(offset, littleEndian) {\n      if (offset == null) {\n        offset = 0;\n      }\n      this.peek(4, offset, littleEndian);\n      return uint32[0];\n    };\n\n    Stream.prototype.readInt32 = function(littleEndian) {\n      this.read(4, littleEndian);\n      return int32[0];\n    };\n\n    Stream.prototype.peekInt32 = function(offset, littleEndian) {\n      if (offset == null) {\n        offset = 0;\n      }\n      this.peek(4, offset, littleEndian);\n      return int32[0];\n    };\n\n    Stream.prototype.readFloat32 = function(littleEndian) {\n      this.read(4, littleEndian);\n      return float32[0];\n    };\n\n    Stream.prototype.peekFloat32 = function(offset, littleEndian) {\n      if (offset == null) {\n        offset = 0;\n      }\n      this.peek(4, offset, littleEndian);\n      return float32[0];\n    };\n\n    Stream.prototype.readFloat64 = function(littleEndian) {\n      this.read(8, littleEndian);\n      if (float64) {\n        return float64[0];\n      } else {\n        return float64Fallback();\n      }\n    };\n\n    float64Fallback = function() {\n      var exp, frac, high, low, out, sign;\n      low = uint32[0], high = uint32[1];\n      if (!high || high === 0x80000000) {\n        return 0.0;\n      }\n      sign = 1 - (high >>> 31) * 2;\n      exp = (high >>> 20) & 0x7ff;\n      frac = high & 0xfffff;\n      if (exp === 0x7ff) {\n        if (frac) {\n          return 0/0;\n        }\n        return sign * 2e308;\n      }\n      exp -= 1023;\n      out = (frac | 0x100000) * Math.pow(2, exp - 20);\n      out += low * Math.pow(2, exp - 52);\n      return sign * out;\n    };\n\n    Stream.prototype.peekFloat64 = function(offset, littleEndian) {\n      if (offset == null) {\n        offset = 0;\n      }\n      this.peek(8, offset, littleEndian);\n      if (float64) {\n        return float64[0];\n      } else {\n        return float64Fallback();\n      }\n    };\n\n    Stream.prototype.readFloat80 = function(littleEndian) {\n      this.read(10, littleEndian);\n      return float80();\n    };\n\n    float80 = function() {\n      var a0, a1, exp, high, low, out, sign;\n      high = uint32[0], low = uint32[1];\n      a0 = uint8[9];\n      a1 = uint8[8];\n      sign = 1 - (a0 >>> 7) * 2;\n      exp = ((a0 & 0x7F) << 8) | a1;\n      if (exp === 0 && low === 0 && high === 0) {\n        return 0;\n      }\n      if (exp === 0x7fff) {\n        if (low === 0 && high === 0) {\n          return sign * 2e308;\n        }\n        return 0/0;\n      }\n      exp -= 16383;\n      out = low * Math.pow(2, exp - 31);\n      out += high * Math.pow(2, exp - 63);\n      return sign * out;\n    };\n\n    Stream.prototype.peekFloat80 = function(offset, littleEndian) {\n      if (offset == null) {\n        offset = 0;\n      }\n      this.peek(10, offset, littleEndian);\n      return float80();\n    };\n\n    Stream.prototype.readBuffer = function(length) {\n      var i, j, ref, result, to;\n      result = AVBuffer.allocate(length);\n      to = result.data;\n      for (i = j = 0, ref = length; j < ref; i = j += 1) {\n        to[i] = this.readUInt8();\n      }\n      return result;\n    };\n\n    Stream.prototype.peekBuffer = function(offset, length) {\n      var i, j, ref, result, to;\n      if (offset == null) {\n        offset = 0;\n      }\n      result = AVBuffer.allocate(length);\n      to = result.data;\n      for (i = j = 0, ref = length; j < ref; i = j += 1) {\n        to[i] = this.peekUInt8(offset + i);\n      }\n      return result;\n    };\n\n    Stream.prototype.readSingleBuffer = function(length) {\n      var result;\n      result = this.list.first.slice(this.localOffset, length);\n      this.advance(result.length);\n      return result;\n    };\n\n    Stream.prototype.peekSingleBuffer = function(offset, length) {\n      var result;\n      result = this.list.first.slice(this.localOffset + offset, length);\n      return result;\n    };\n\n    Stream.prototype.readString = function(length, encoding) {\n      if (encoding == null) {\n        encoding = 'ascii';\n      }\n      return decodeString.call(this, 0, length, encoding, true);\n    };\n\n    Stream.prototype.peekString = function(offset, length, encoding) {\n      if (offset == null) {\n        offset = 0;\n      }\n      if (encoding == null) {\n        encoding = 'ascii';\n      }\n      return decodeString.call(this, offset, length, encoding, false);\n    };\n\n    decodeString = function(offset, length, encoding, advance) {\n      var b1, b2, b3, b4, bom, c, end, littleEndian, nullEnd, pt, result, w1, w2;\n      encoding = encoding.toLowerCase();\n      nullEnd = length === null ? 0 : -1;\n      if (length == null) {\n        length = 2e308;\n      }\n      end = offset + length;\n      result = '';\n      switch (encoding) {\n        case 'ascii':\n        case 'latin1':\n          while (offset < end && (c = this.peekUInt8(offset++)) !== nullEnd) {\n            result += String.fromCharCode(c);\n          }\n          break;\n        case 'utf8':\n        case 'utf-8':\n          while (offset < end && (b1 = this.peekUInt8(offset++)) !== nullEnd) {\n            if ((b1 & 0x80) === 0) {\n              result += String.fromCharCode(b1);\n            } else if ((b1 & 0xe0) === 0xc0) {\n              b2 = this.peekUInt8(offset++) & 0x3f;\n              result += String.fromCharCode(((b1 & 0x1f) << 6) | b2);\n            } else if ((b1 & 0xf0) === 0xe0) {\n              b2 = this.peekUInt8(offset++) & 0x3f;\n              b3 = this.peekUInt8(offset++) & 0x3f;\n              result += String.fromCharCode(((b1 & 0x0f) << 12) | (b2 << 6) | b3);\n            } else if ((b1 & 0xf8) === 0xf0) {\n              b2 = this.peekUInt8(offset++) & 0x3f;\n              b3 = this.peekUInt8(offset++) & 0x3f;\n              b4 = this.peekUInt8(offset++) & 0x3f;\n              pt = (((b1 & 0x0f) << 18) | (b2 << 12) | (b3 << 6) | b4) - 0x10000;\n              result += String.fromCharCode(0xd800 + (pt >> 10), 0xdc00 + (pt & 0x3ff));\n            }\n          }\n          break;\n        case 'utf16-be':\n        case 'utf16be':\n        case 'utf16le':\n        case 'utf16-le':\n        case 'utf16bom':\n        case 'utf16-bom':\n          switch (encoding) {\n            case 'utf16be':\n            case 'utf16-be':\n              littleEndian = false;\n              break;\n            case 'utf16le':\n            case 'utf16-le':\n              littleEndian = true;\n              break;\n            case 'utf16bom':\n            case 'utf16-bom':\n              if (length < 2 || (bom = this.peekUInt16(offset)) === nullEnd) {\n                if (advance) {\n                  this.advance(offset += 2);\n                }\n                return result;\n              }\n              littleEndian = bom === 0xfffe;\n              offset += 2;\n          }\n          while (offset < end && (w1 = this.peekUInt16(offset, littleEndian)) !== nullEnd) {\n            offset += 2;\n            if (w1 < 0xd800 || w1 > 0xdfff) {\n              result += String.fromCharCode(w1);\n            } else {\n              if (w1 > 0xdbff) {\n                throw new Error(\"Invalid utf16 sequence.\");\n              }\n              w2 = this.peekUInt16(offset, littleEndian);\n              if (w2 < 0xdc00 || w2 > 0xdfff) {\n                throw new Error(\"Invalid utf16 sequence.\");\n              }\n              result += String.fromCharCode(w1, w2);\n              offset += 2;\n            }\n          }\n          if (w1 === nullEnd) {\n            offset += 2;\n          }\n          break;\n        default:\n          throw new Error(\"Unknown encoding: \" + encoding);\n      }\n      if (advance) {\n        this.advance(offset);\n      }\n      return result;\n    };\n\n    return Stream;\n\n  })();\n\n  module.exports = Stream;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var UnderflowError,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  UnderflowError = (function(superClass) {\n    extend(UnderflowError, superClass);\n\n    function UnderflowError() {\n      UnderflowError.__super__.constructor.apply(this, arguments);\n      this.name = 'UnderflowError';\n      this.stack = new Error().stack;\n    }\n\n    return UnderflowError;\n\n  })(Error);\n\n  module.exports = UnderflowError;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var Bitstream, BufferList, Decoder, EventEmitter, Stream, UnderflowError,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  EventEmitter = require('./core/events');\n\n  BufferList = require('./core/bufferlist');\n\n  Stream = require('./core/stream');\n\n  Bitstream = require('./core/bitstream');\n\n  UnderflowError = require('./core/underflow');\n\n  Decoder = (function(superClass) {\n    var codecs;\n\n    extend(Decoder, superClass);\n\n    function Decoder(demuxer, format) {\n      var list;\n      this.demuxer = demuxer;\n      this.format = format;\n      list = new BufferList;\n      this.stream = new Stream(list);\n      this.bitstream = new Bitstream(this.stream);\n      this.receivedFinalBuffer = false;\n      this.waiting = false;\n      this.demuxer.on('cookie', (function(_this) {\n        return function(cookie) {\n          var error;\n          try {\n            return _this.setCookie(cookie);\n          } catch (error1) {\n            error = error1;\n            return _this.emit('error', error);\n          }\n        };\n      })(this));\n      this.demuxer.on('data', (function(_this) {\n        return function(chunk) {\n          list.append(chunk);\n          if (_this.waiting) {\n            return _this.decode();\n          }\n        };\n      })(this));\n      this.demuxer.on('end', (function(_this) {\n        return function() {\n          _this.receivedFinalBuffer = true;\n          if (_this.waiting) {\n            return _this.decode();\n          }\n        };\n      })(this));\n      this.init();\n    }\n\n    Decoder.prototype.init = function() {};\n\n    Decoder.prototype.setCookie = function(cookie) {};\n\n    Decoder.prototype.readChunk = function() {};\n\n    Decoder.prototype.decode = function() {\n      var error, offset, packet;\n      this.waiting = !this.receivedFinalBuffer;\n      offset = this.bitstream.offset();\n      try {\n        packet = this.readChunk();\n      } catch (error1) {\n        error = error1;\n        if (!(error instanceof UnderflowError)) {\n          this.emit('error', error);\n          return false;\n        }\n      }\n      if (packet) {\n        this.emit('data', packet);\n        if (this.receivedFinalBuffer) {\n          this.emit('end');\n        }\n        return true;\n      } else if (!this.receivedFinalBuffer) {\n        this.bitstream.seek(offset);\n        this.waiting = true;\n      } else {\n        this.emit('end');\n      }\n      return false;\n    };\n\n    Decoder.prototype.seek = function(timestamp) {\n      var seekPoint;\n      seekPoint = this.demuxer.seek(timestamp);\n      this.stream.seek(seekPoint.offset);\n      return seekPoint.timestamp;\n    };\n\n    codecs = {};\n\n    Decoder.register = function(id, decoder) {\n      return codecs[id] = decoder;\n    };\n\n    Decoder.find = function(id) {\n      return codecs[id] || null;\n    };\n\n    return Decoder;\n\n  })(EventEmitter);\n\n  module.exports = Decoder;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var Decoder, LPCMDecoder,\n    bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  Decoder = require('../decoder');\n\n  LPCMDecoder = (function(superClass) {\n    extend(LPCMDecoder, superClass);\n\n    function LPCMDecoder() {\n      this.readChunk = bind(this.readChunk, this);\n      return LPCMDecoder.__super__.constructor.apply(this, arguments);\n    }\n\n    Decoder.register('lpcm', LPCMDecoder);\n\n    LPCMDecoder.prototype.readChunk = function() {\n      var chunkSize, i, j, k, l, littleEndian, m, n, o, output, ref, ref1, ref2, ref3, ref4, ref5, samples, stream;\n      stream = this.stream;\n      littleEndian = this.format.littleEndian;\n      chunkSize = Math.min(4096, stream.remainingBytes());\n      samples = chunkSize / (this.format.bitsPerChannel / 8) | 0;\n      if (chunkSize < this.format.bitsPerChannel / 8) {\n        return null;\n      }\n      if (this.format.floatingPoint) {\n        switch (this.format.bitsPerChannel) {\n          case 32:\n            output = new Float32Array(samples);\n            for (i = j = 0, ref = samples; j < ref; i = j += 1) {\n              output[i] = stream.readFloat32(littleEndian);\n            }\n            break;\n          case 64:\n            output = new Float64Array(samples);\n            for (i = k = 0, ref1 = samples; k < ref1; i = k += 1) {\n              output[i] = stream.readFloat64(littleEndian);\n            }\n            break;\n          default:\n            throw new Error('Unsupported bit depth.');\n        }\n      } else {\n        switch (this.format.bitsPerChannel) {\n          case 8:\n            output = new Int8Array(samples);\n            for (i = l = 0, ref2 = samples; l < ref2; i = l += 1) {\n              output[i] = stream.readInt8();\n            }\n            break;\n          case 16:\n            output = new Int16Array(samples);\n            for (i = m = 0, ref3 = samples; m < ref3; i = m += 1) {\n              output[i] = stream.readInt16(littleEndian);\n            }\n            break;\n          case 24:\n            output = new Int32Array(samples);\n            for (i = n = 0, ref4 = samples; n < ref4; i = n += 1) {\n              output[i] = stream.readInt24(littleEndian);\n            }\n            break;\n          case 32:\n            output = new Int32Array(samples);\n            for (i = o = 0, ref5 = samples; o < ref5; i = o += 1) {\n              output[i] = stream.readInt32(littleEndian);\n            }\n            break;\n          default:\n            throw new Error('Unsupported bit depth.');\n        }\n      }\n      return output;\n    };\n\n    return LPCMDecoder;\n\n  })(Decoder);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var Decoder, XLAWDecoder,\n    bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  Decoder = require('../decoder');\n\n  XLAWDecoder = (function(superClass) {\n    var BIAS, QUANT_MASK, SEG_MASK, SEG_SHIFT, SIGN_BIT;\n\n    extend(XLAWDecoder, superClass);\n\n    function XLAWDecoder() {\n      this.readChunk = bind(this.readChunk, this);\n      return XLAWDecoder.__super__.constructor.apply(this, arguments);\n    }\n\n    Decoder.register('ulaw', XLAWDecoder);\n\n    Decoder.register('alaw', XLAWDecoder);\n\n    SIGN_BIT = 0x80;\n\n    QUANT_MASK = 0xf;\n\n    SEG_SHIFT = 4;\n\n    SEG_MASK = 0x70;\n\n    BIAS = 0x84;\n\n    XLAWDecoder.prototype.init = function() {\n      var i, j, k, seg, t, table, val;\n      this.format.bitsPerChannel = 16;\n      this.table = table = new Int16Array(256);\n      if (this.format.formatID === 'ulaw') {\n        for (i = j = 0; j < 256; i = ++j) {\n          val = ~i;\n          t = ((val & QUANT_MASK) << 3) + BIAS;\n          t <<= (val & SEG_MASK) >>> SEG_SHIFT;\n          table[i] = val & SIGN_BIT ? BIAS - t : t - BIAS;\n        }\n      } else {\n        for (i = k = 0; k < 256; i = ++k) {\n          val = i ^ 0x55;\n          t = val & QUANT_MASK;\n          seg = (val & SEG_MASK) >>> SEG_SHIFT;\n          if (seg) {\n            t = (t + t + 1 + 32) << (seg + 2);\n          } else {\n            t = (t + t + 1) << 3;\n          }\n          table[i] = val & SIGN_BIT ? t : -t;\n        }\n      }\n    };\n\n    XLAWDecoder.prototype.readChunk = function() {\n      var i, j, output, ref, ref1, samples, stream, table;\n      ref = this, stream = ref.stream, table = ref.table;\n      samples = Math.min(4096, this.stream.remainingBytes());\n      if (samples === 0) {\n        return;\n      }\n      output = new Int16Array(samples);\n      for (i = j = 0, ref1 = samples; j < ref1; i = j += 1) {\n        output[i] = table[stream.readUInt8()];\n      }\n      return output;\n    };\n\n    return XLAWDecoder;\n\n  })(Decoder);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var BufferList, Demuxer, EventEmitter, Stream,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  EventEmitter = require('./core/events');\n\n  BufferList = require('./core/bufferlist');\n\n  Stream = require('./core/stream');\n\n  Demuxer = (function(superClass) {\n    var formats;\n\n    extend(Demuxer, superClass);\n\n    Demuxer.probe = function(buffer) {\n      return false;\n    };\n\n    function Demuxer(source, chunk) {\n      var list, received;\n      list = new BufferList;\n      list.append(chunk);\n      this.stream = new Stream(list);\n      received = false;\n      source.on('data', (function(_this) {\n        return function(chunk) {\n          var e;\n          received = true;\n          list.append(chunk);\n          try {\n            return _this.readChunk(chunk);\n          } catch (error) {\n            e = error;\n            return _this.emit('error', e);\n          }\n        };\n      })(this));\n      source.on('error', (function(_this) {\n        return function(err) {\n          return _this.emit('error', err);\n        };\n      })(this));\n      source.on('end', (function(_this) {\n        return function() {\n          if (!received) {\n            _this.readChunk(chunk);\n          }\n          return _this.emit('end');\n        };\n      })(this));\n      this.seekPoints = [];\n      this.init();\n    }\n\n    Demuxer.prototype.init = function() {};\n\n    Demuxer.prototype.readChunk = function(chunk) {};\n\n    Demuxer.prototype.addSeekPoint = function(offset, timestamp) {\n      var index;\n      index = this.searchTimestamp(timestamp);\n      return this.seekPoints.splice(index, 0, {\n        offset: offset,\n        timestamp: timestamp\n      });\n    };\n\n    Demuxer.prototype.searchTimestamp = function(timestamp, backward) {\n      var high, low, mid, time;\n      low = 0;\n      high = this.seekPoints.length;\n      if (high > 0 && this.seekPoints[high - 1].timestamp < timestamp) {\n        return high;\n      }\n      while (low < high) {\n        mid = (low + high) >> 1;\n        time = this.seekPoints[mid].timestamp;\n        if (time < timestamp) {\n          low = mid + 1;\n        } else if (time >= timestamp) {\n          high = mid;\n        }\n      }\n      if (high > this.seekPoints.length) {\n        high = this.seekPoints.length;\n      }\n      return high;\n    };\n\n    Demuxer.prototype.seek = function(timestamp) {\n      var index, seekPoint;\n      if (this.format && this.format.framesPerPacket > 0 && this.format.bytesPerPacket > 0) {\n        seekPoint = {\n          timestamp: timestamp,\n          offset: this.format.bytesPerPacket * timestamp / this.format.framesPerPacket\n        };\n        return seekPoint;\n      } else {\n        index = this.searchTimestamp(timestamp);\n        return this.seekPoints[index];\n      }\n    };\n\n    formats = [];\n\n    Demuxer.register = function(demuxer) {\n      return formats.push(demuxer);\n    };\n\n    Demuxer.find = function(buffer) {\n      var e, format, i, len, offset, stream;\n      stream = Stream.fromBuffer(buffer);\n      for (i = 0, len = formats.length; i < len; i++) {\n        format = formats[i];\n        offset = stream.offset;\n        try {\n          if (format.probe(stream)) {\n            return format;\n          }\n        } catch (error) {\n          e = error;\n        }\n        stream.seek(offset);\n      }\n      return null;\n    };\n\n    return Demuxer;\n\n  })(EventEmitter);\n\n  module.exports = Demuxer;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var AIFFDemuxer, Demuxer,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  Demuxer = require('../demuxer');\n\n  AIFFDemuxer = (function(superClass) {\n    extend(AIFFDemuxer, superClass);\n\n    function AIFFDemuxer() {\n      return AIFFDemuxer.__super__.constructor.apply(this, arguments);\n    }\n\n    Demuxer.register(AIFFDemuxer);\n\n    AIFFDemuxer.probe = function(buffer) {\n      var ref;\n      return buffer.peekString(0, 4) === 'FORM' && ((ref = buffer.peekString(8, 4)) === 'AIFF' || ref === 'AIFC');\n    };\n\n    AIFFDemuxer.prototype.readChunk = function() {\n      var buffer, format, offset, ref;\n      if (!this.readStart && this.stream.available(12)) {\n        if (this.stream.readString(4) !== 'FORM') {\n          return this.emit('error', 'Invalid AIFF.');\n        }\n        this.fileSize = this.stream.readUInt32();\n        this.fileType = this.stream.readString(4);\n        this.readStart = true;\n        if ((ref = this.fileType) !== 'AIFF' && ref !== 'AIFC') {\n          return this.emit('error', 'Invalid AIFF.');\n        }\n      }\n      while (this.stream.available(1)) {\n        if (!this.readHeaders && this.stream.available(8)) {\n          this.type = this.stream.readString(4);\n          this.len = this.stream.readUInt32();\n        }\n        switch (this.type) {\n          case 'COMM':\n            if (!this.stream.available(this.len)) {\n              return;\n            }\n            this.format = {\n              formatID: 'lpcm',\n              channelsPerFrame: this.stream.readUInt16(),\n              sampleCount: this.stream.readUInt32(),\n              bitsPerChannel: this.stream.readUInt16(),\n              sampleRate: this.stream.readFloat80(),\n              framesPerPacket: 1,\n              littleEndian: false,\n              floatingPoint: false\n            };\n            this.format.bytesPerPacket = (this.format.bitsPerChannel / 8) * this.format.channelsPerFrame;\n            if (this.fileType === 'AIFC') {\n              format = this.stream.readString(4);\n              this.format.littleEndian = format === 'sowt' && this.format.bitsPerChannel > 8;\n              this.format.floatingPoint = format === 'fl32' || format === 'fl64';\n              if (format === 'twos' || format === 'sowt' || format === 'fl32' || format === 'fl64' || format === 'NONE') {\n                format = 'lpcm';\n              }\n              this.format.formatID = format;\n              this.len -= 4;\n            }\n            this.stream.advance(this.len - 18);\n            this.emit('format', this.format);\n            this.emit('duration', this.format.sampleCount / this.format.sampleRate * 1000 | 0);\n            break;\n          case 'SSND':\n            if (!(this.readSSNDHeader && this.stream.available(4))) {\n              offset = this.stream.readUInt32();\n              this.stream.advance(4);\n              this.stream.advance(offset);\n              this.readSSNDHeader = true;\n            }\n            buffer = this.stream.readSingleBuffer(this.len);\n            this.len -= buffer.length;\n            this.readHeaders = this.len > 0;\n            this.emit('data', buffer);\n            break;\n          default:\n            if (!this.stream.available(this.len)) {\n              return;\n            }\n            this.stream.advance(this.len);\n        }\n        if (this.type !== 'SSND') {\n          this.readHeaders = false;\n        }\n      }\n    };\n\n    return AIFFDemuxer;\n\n  })(Demuxer);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var AUDemuxer, Demuxer,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  Demuxer = require('../demuxer');\n\n  AUDemuxer = (function(superClass) {\n    var bps, formats;\n\n    extend(AUDemuxer, superClass);\n\n    function AUDemuxer() {\n      return AUDemuxer.__super__.constructor.apply(this, arguments);\n    }\n\n    Demuxer.register(AUDemuxer);\n\n    AUDemuxer.probe = function(buffer) {\n      return buffer.peekString(0, 4) === '.snd';\n    };\n\n    bps = [8, 8, 16, 24, 32, 32, 64];\n\n    bps[26] = 8;\n\n    formats = {\n      1: 'ulaw',\n      27: 'alaw'\n    };\n\n    AUDemuxer.prototype.readChunk = function() {\n      var bytes, dataSize, encoding, size;\n      if (!this.readHeader && this.stream.available(24)) {\n        if (this.stream.readString(4) !== '.snd') {\n          return this.emit('error', 'Invalid AU file.');\n        }\n        size = this.stream.readUInt32();\n        dataSize = this.stream.readUInt32();\n        encoding = this.stream.readUInt32();\n        this.format = {\n          formatID: formats[encoding] || 'lpcm',\n          littleEndian: false,\n          floatingPoint: encoding === 6 || encoding === 7,\n          bitsPerChannel: bps[encoding - 1],\n          sampleRate: this.stream.readUInt32(),\n          channelsPerFrame: this.stream.readUInt32(),\n          framesPerPacket: 1\n        };\n        if (this.format.bitsPerChannel == null) {\n          return this.emit('error', 'Unsupported encoding in AU file.');\n        }\n        this.format.bytesPerPacket = (this.format.bitsPerChannel / 8) * this.format.channelsPerFrame;\n        if (dataSize !== 0xffffffff) {\n          bytes = this.format.bitsPerChannel / 8;\n          this.emit('duration', dataSize / bytes / this.format.channelsPerFrame / this.format.sampleRate * 1000 | 0);\n        }\n        this.emit('format', this.format);\n        this.readHeader = true;\n      }\n      if (this.readHeader) {\n        while (this.stream.available(1)) {\n          this.emit('data', this.stream.readSingleBuffer(this.stream.remainingBytes()));\n        }\n      }\n    };\n\n    return AUDemuxer;\n\n  })(Demuxer);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var CAFDemuxer, Demuxer, M4ADemuxer,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  Demuxer = require('../demuxer');\n\n  M4ADemuxer = require('./m4a');\n\n  CAFDemuxer = (function(superClass) {\n    extend(CAFDemuxer, superClass);\n\n    function CAFDemuxer() {\n      return CAFDemuxer.__super__.constructor.apply(this, arguments);\n    }\n\n    Demuxer.register(CAFDemuxer);\n\n    CAFDemuxer.probe = function(buffer) {\n      return buffer.peekString(0, 4) === 'caff';\n    };\n\n    CAFDemuxer.prototype.readChunk = function() {\n      var buffer, byteOffset, cookie, entries, flags, i, j, k, key, metadata, offset, ref, ref1, sampleOffset, value;\n      if (!this.format && this.stream.available(64)) {\n        if (this.stream.readString(4) !== 'caff') {\n          return this.emit('error', \"Invalid CAF, does not begin with 'caff'\");\n        }\n        this.stream.advance(4);\n        if (this.stream.readString(4) !== 'desc') {\n          return this.emit('error', \"Invalid CAF, 'caff' is not followed by 'desc'\");\n        }\n        if (!(this.stream.readUInt32() === 0 && this.stream.readUInt32() === 32)) {\n          return this.emit('error', \"Invalid 'desc' size, should be 32\");\n        }\n        this.format = {};\n        this.format.sampleRate = this.stream.readFloat64();\n        this.format.formatID = this.stream.readString(4);\n        flags = this.stream.readUInt32();\n        if (this.format.formatID === 'lpcm') {\n          this.format.floatingPoint = Boolean(flags & 1);\n          this.format.littleEndian = Boolean(flags & 2);\n        }\n        this.format.bytesPerPacket = this.stream.readUInt32();\n        this.format.framesPerPacket = this.stream.readUInt32();\n        this.format.channelsPerFrame = this.stream.readUInt32();\n        this.format.bitsPerChannel = this.stream.readUInt32();\n        this.emit('format', this.format);\n      }\n      while (this.stream.available(1)) {\n        if (!this.headerCache) {\n          this.headerCache = {\n            type: this.stream.readString(4),\n            oversize: this.stream.readUInt32() !== 0,\n            size: this.stream.readUInt32()\n          };\n          if (this.headerCache.oversize) {\n            return this.emit('error', \"Holy Shit, an oversized file, not supported in JS\");\n          }\n        }\n        switch (this.headerCache.type) {\n          case 'kuki':\n            if (this.stream.available(this.headerCache.size)) {\n              if (this.format.formatID === 'aac ') {\n                offset = this.stream.offset + this.headerCache.size;\n                if (cookie = M4ADemuxer.readEsds(this.stream)) {\n                  this.emit('cookie', cookie);\n                }\n                this.stream.seek(offset);\n              } else {\n                buffer = this.stream.readBuffer(this.headerCache.size);\n                this.emit('cookie', buffer);\n              }\n              this.headerCache = null;\n            }\n            break;\n          case 'pakt':\n            if (this.stream.available(this.headerCache.size)) {\n              if (this.stream.readUInt32() !== 0) {\n                return this.emit('error', 'Sizes greater than 32 bits are not supported.');\n              }\n              this.numPackets = this.stream.readUInt32();\n              if (this.stream.readUInt32() !== 0) {\n                return this.emit('error', 'Sizes greater than 32 bits are not supported.');\n              }\n              this.numFrames = this.stream.readUInt32();\n              this.primingFrames = this.stream.readUInt32();\n              this.remainderFrames = this.stream.readUInt32();\n              this.emit('duration', this.numFrames / this.format.sampleRate * 1000 | 0);\n              this.sentDuration = true;\n              byteOffset = 0;\n              sampleOffset = 0;\n              for (i = j = 0, ref = this.numPackets; j < ref; i = j += 1) {\n                this.addSeekPoint(byteOffset, sampleOffset);\n                byteOffset += this.format.bytesPerPacket || M4ADemuxer.readDescrLen(this.stream);\n                sampleOffset += this.format.framesPerPacket || M4ADemuxer.readDescrLen(this.stream);\n              }\n              this.headerCache = null;\n            }\n            break;\n          case 'info':\n            entries = this.stream.readUInt32();\n            metadata = {};\n            for (i = k = 0, ref1 = entries; 0 <= ref1 ? k < ref1 : k > ref1; i = 0 <= ref1 ? ++k : --k) {\n              key = this.stream.readString(null);\n              value = this.stream.readString(null);\n              metadata[key] = value;\n            }\n            this.emit('metadata', metadata);\n            this.headerCache = null;\n            break;\n          case 'data':\n            if (!this.sentFirstDataChunk) {\n              this.stream.advance(4);\n              this.headerCache.size -= 4;\n              if (this.format.bytesPerPacket !== 0 && !this.sentDuration) {\n                this.numFrames = this.headerCache.size / this.format.bytesPerPacket;\n                this.emit('duration', this.numFrames / this.format.sampleRate * 1000 | 0);\n              }\n              this.sentFirstDataChunk = true;\n            }\n            buffer = this.stream.readSingleBuffer(this.headerCache.size);\n            this.headerCache.size -= buffer.length;\n            this.emit('data', buffer);\n            if (this.headerCache.size <= 0) {\n              this.headerCache = null;\n            }\n            break;\n          default:\n            if (this.stream.available(this.headerCache.size)) {\n              this.stream.advance(this.headerCache.size);\n              this.headerCache = null;\n            }\n        }\n      }\n    };\n\n    return CAFDemuxer;\n\n  })(Demuxer);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var Demuxer, M4ADemuxer,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty,\n    indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; };\n\n  Demuxer = require('../demuxer');\n\n  M4ADemuxer = (function(superClass) {\n    var BITS_PER_CHANNEL, TYPES, after, atom, atoms, bool, containers, diskTrack, genres, meta, string;\n\n    extend(M4ADemuxer, superClass);\n\n    function M4ADemuxer() {\n      return M4ADemuxer.__super__.constructor.apply(this, arguments);\n    }\n\n    Demuxer.register(M4ADemuxer);\n\n    TYPES = ['M4A ', 'M4P ', 'M4B ', 'M4V ', 'isom', 'mp42', 'qt  '];\n\n    M4ADemuxer.probe = function(buffer) {\n      var ref;\n      return buffer.peekString(4, 4) === 'ftyp' && (ref = buffer.peekString(8, 4), indexOf.call(TYPES, ref) >= 0);\n    };\n\n    M4ADemuxer.prototype.init = function() {\n      this.atoms = [];\n      this.offsets = [];\n      this.track = null;\n      return this.tracks = [];\n    };\n\n    atoms = {};\n\n    containers = {};\n\n    atom = function(name, fn) {\n      var c, container, k, len1, ref;\n      c = [];\n      ref = name.split('.').slice(0, -1);\n      for (k = 0, len1 = ref.length; k < len1; k++) {\n        container = ref[k];\n        c.push(container);\n        containers[c.join('.')] = true;\n      }\n      if (atoms[name] == null) {\n        atoms[name] = {};\n      }\n      return atoms[name].fn = fn;\n    };\n\n    after = function(name, fn) {\n      if (atoms[name] == null) {\n        atoms[name] = {};\n      }\n      return atoms[name].after = fn;\n    };\n\n    M4ADemuxer.prototype.readChunk = function() {\n      var handler, path, type;\n      this[\"break\"] = false;\n      while (this.stream.available(1) && !this[\"break\"]) {\n        if (!this.readHeaders) {\n          if (!this.stream.available(8)) {\n            return;\n          }\n          this.len = this.stream.readUInt32() - 8;\n          this.type = this.stream.readString(4);\n          if (this.len === 0) {\n            continue;\n          }\n          this.atoms.push(this.type);\n          this.offsets.push(this.stream.offset + this.len);\n          this.readHeaders = true;\n        }\n        path = this.atoms.join('.');\n        handler = atoms[path];\n        if (handler != null ? handler.fn : void 0) {\n          if (!(this.stream.available(this.len) || path === 'mdat')) {\n            return;\n          }\n          handler.fn.call(this);\n          if (path in containers) {\n            this.readHeaders = false;\n          }\n        } else if (path in containers) {\n          this.readHeaders = false;\n        } else {\n          if (!this.stream.available(this.len)) {\n            return;\n          }\n          this.stream.advance(this.len);\n        }\n        while (this.stream.offset >= this.offsets[this.offsets.length - 1]) {\n          handler = atoms[this.atoms.join('.')];\n          if (handler != null ? handler.after : void 0) {\n            handler.after.call(this);\n          }\n          type = this.atoms.pop();\n          this.offsets.pop();\n          this.readHeaders = false;\n        }\n      }\n    };\n\n    atom('ftyp', function() {\n      var ref;\n      if (ref = this.stream.readString(4), indexOf.call(TYPES, ref) < 0) {\n        return this.emit('error', 'Not a valid M4A file.');\n      }\n      return this.stream.advance(this.len - 4);\n    });\n\n    atom('moov.trak', function() {\n      this.track = {};\n      return this.tracks.push(this.track);\n    });\n\n    atom('moov.trak.tkhd', function() {\n      this.stream.advance(4);\n      this.stream.advance(8);\n      this.track.id = this.stream.readUInt32();\n      return this.stream.advance(this.len - 16);\n    });\n\n    atom('moov.trak.mdia.hdlr', function() {\n      this.stream.advance(4);\n      this.stream.advance(4);\n      this.track.type = this.stream.readString(4);\n      this.stream.advance(12);\n      return this.stream.advance(this.len - 24);\n    });\n\n    atom('moov.trak.mdia.mdhd', function() {\n      this.stream.advance(4);\n      this.stream.advance(8);\n      this.track.timeScale = this.stream.readUInt32();\n      this.track.duration = this.stream.readUInt32();\n      return this.stream.advance(4);\n    });\n\n    BITS_PER_CHANNEL = {\n      ulaw: 8,\n      alaw: 8,\n      in24: 24,\n      in32: 32,\n      fl32: 32,\n      fl64: 64\n    };\n\n    atom('moov.trak.mdia.minf.stbl.stsd', function() {\n      var format, numEntries, ref, ref1, version;\n      this.stream.advance(4);\n      numEntries = this.stream.readUInt32();\n      if (this.track.type !== 'soun') {\n        return this.stream.advance(this.len - 8);\n      }\n      if (numEntries !== 1) {\n        return this.emit('error', \"Only expecting one entry in sample description atom!\");\n      }\n      this.stream.advance(4);\n      format = this.track.format = {};\n      format.formatID = this.stream.readString(4);\n      this.stream.advance(6);\n      this.stream.advance(2);\n      version = this.stream.readUInt16();\n      this.stream.advance(6);\n      format.channelsPerFrame = this.stream.readUInt16();\n      format.bitsPerChannel = this.stream.readUInt16();\n      this.stream.advance(4);\n      format.sampleRate = this.stream.readUInt16();\n      this.stream.advance(2);\n      if (version === 1) {\n        format.framesPerPacket = this.stream.readUInt32();\n        this.stream.advance(4);\n        format.bytesPerFrame = this.stream.readUInt32();\n        this.stream.advance(4);\n      } else if (version !== 0) {\n        this.emit('error', 'Unknown version in stsd atom');\n      }\n      if (BITS_PER_CHANNEL[format.formatID] != null) {\n        format.bitsPerChannel = BITS_PER_CHANNEL[format.formatID];\n      }\n      format.floatingPoint = (ref = format.formatID) === 'fl32' || ref === 'fl64';\n      format.littleEndian = format.formatID === 'sowt' && format.bitsPerChannel > 8;\n      if ((ref1 = format.formatID) === 'twos' || ref1 === 'sowt' || ref1 === 'in24' || ref1 === 'in32' || ref1 === 'fl32' || ref1 === 'fl64' || ref1 === 'raw ' || ref1 === 'NONE') {\n        return format.formatID = 'lpcm';\n      }\n    });\n\n    atom('moov.trak.mdia.minf.stbl.stsd.alac', function() {\n      this.stream.advance(4);\n      return this.track.cookie = this.stream.readBuffer(this.len - 4);\n    });\n\n    atom('moov.trak.mdia.minf.stbl.stsd.esds', function() {\n      var offset;\n      offset = this.stream.offset + this.len;\n      this.track.cookie = M4ADemuxer.readEsds(this.stream);\n      return this.stream.seek(offset);\n    });\n\n    atom('moov.trak.mdia.minf.stbl.stsd.wave.enda', function() {\n      return this.track.format.littleEndian = !!this.stream.readUInt16();\n    });\n\n    M4ADemuxer.readDescrLen = function(stream) {\n      var c, count, len;\n      len = 0;\n      count = 4;\n      while (count--) {\n        c = stream.readUInt8();\n        len = (len << 7) | (c & 0x7f);\n        if (!(c & 0x80)) {\n          break;\n        }\n      }\n      return len;\n    };\n\n    M4ADemuxer.readEsds = function(stream) {\n      var codec_id, flags, len, tag;\n      stream.advance(4);\n      tag = stream.readUInt8();\n      len = M4ADemuxer.readDescrLen(stream);\n      if (tag === 0x03) {\n        stream.advance(2);\n        flags = stream.readUInt8();\n        if (flags & 0x80) {\n          stream.advance(2);\n        }\n        if (flags & 0x40) {\n          stream.advance(stream.readUInt8());\n        }\n        if (flags & 0x20) {\n          stream.advance(2);\n        }\n      } else {\n        stream.advance(2);\n      }\n      tag = stream.readUInt8();\n      len = M4ADemuxer.readDescrLen(stream);\n      if (tag === 0x04) {\n        codec_id = stream.readUInt8();\n        stream.advance(1);\n        stream.advance(3);\n        stream.advance(4);\n        stream.advance(4);\n        tag = stream.readUInt8();\n        len = M4ADemuxer.readDescrLen(stream);\n        if (tag === 0x05) {\n          return stream.readBuffer(len);\n        }\n      }\n      return null;\n    };\n\n    atom('moov.trak.mdia.minf.stbl.stts', function() {\n      var entries, i, k, ref;\n      this.stream.advance(4);\n      entries = this.stream.readUInt32();\n      this.track.stts = [];\n      for (i = k = 0, ref = entries; k < ref; i = k += 1) {\n        this.track.stts[i] = {\n          count: this.stream.readUInt32(),\n          duration: this.stream.readUInt32()\n        };\n      }\n      return this.setupSeekPoints();\n    });\n\n    atom('moov.trak.mdia.minf.stbl.stsc', function() {\n      var entries, i, k, ref;\n      this.stream.advance(4);\n      entries = this.stream.readUInt32();\n      this.track.stsc = [];\n      for (i = k = 0, ref = entries; k < ref; i = k += 1) {\n        this.track.stsc[i] = {\n          first: this.stream.readUInt32(),\n          count: this.stream.readUInt32(),\n          id: this.stream.readUInt32()\n        };\n      }\n      return this.setupSeekPoints();\n    });\n\n    atom('moov.trak.mdia.minf.stbl.stsz', function() {\n      var entries, i, k, ref;\n      this.stream.advance(4);\n      this.track.sampleSize = this.stream.readUInt32();\n      entries = this.stream.readUInt32();\n      if (this.track.sampleSize === 0 && entries > 0) {\n        this.track.sampleSizes = [];\n        for (i = k = 0, ref = entries; k < ref; i = k += 1) {\n          this.track.sampleSizes[i] = this.stream.readUInt32();\n        }\n      }\n      return this.setupSeekPoints();\n    });\n\n    atom('moov.trak.mdia.minf.stbl.stco', function() {\n      var entries, i, k, ref;\n      this.stream.advance(4);\n      entries = this.stream.readUInt32();\n      this.track.chunkOffsets = [];\n      for (i = k = 0, ref = entries; k < ref; i = k += 1) {\n        this.track.chunkOffsets[i] = this.stream.readUInt32();\n      }\n      return this.setupSeekPoints();\n    });\n\n    atom('moov.trak.tref.chap', function() {\n      var entries, i, k, ref;\n      entries = this.len >> 2;\n      this.track.chapterTracks = [];\n      for (i = k = 0, ref = entries; k < ref; i = k += 1) {\n        this.track.chapterTracks[i] = this.stream.readUInt32();\n      }\n    });\n\n    M4ADemuxer.prototype.setupSeekPoints = function() {\n      var i, j, k, l, len1, offset, position, ref, ref1, results, sampleIndex, size, stscIndex, sttsIndex, sttsSample, timestamp;\n      if (!((this.track.chunkOffsets != null) && (this.track.stsc != null) && (this.track.sampleSize != null) && (this.track.stts != null))) {\n        return;\n      }\n      stscIndex = 0;\n      sttsIndex = 0;\n      sttsIndex = 0;\n      sttsSample = 0;\n      sampleIndex = 0;\n      offset = 0;\n      timestamp = 0;\n      this.track.seekPoints = [];\n      ref = this.track.chunkOffsets;\n      results = [];\n      for (i = k = 0, len1 = ref.length; k < len1; i = ++k) {\n        position = ref[i];\n        for (j = l = 0, ref1 = this.track.stsc[stscIndex].count; l < ref1; j = l += 1) {\n          this.track.seekPoints.push({\n            offset: offset,\n            position: position,\n            timestamp: timestamp\n          });\n          size = this.track.sampleSize || this.track.sampleSizes[sampleIndex++];\n          offset += size;\n          position += size;\n          timestamp += this.track.stts[sttsIndex].duration;\n          if (sttsIndex + 1 < this.track.stts.length && ++sttsSample === this.track.stts[sttsIndex].count) {\n            sttsSample = 0;\n            sttsIndex++;\n          }\n        }\n        if (stscIndex + 1 < this.track.stsc.length && i + 1 === this.track.stsc[stscIndex + 1].first) {\n          results.push(stscIndex++);\n        } else {\n          results.push(void 0);\n        }\n      }\n      return results;\n    };\n\n    after('moov', function() {\n      var k, len1, ref, track;\n      if (this.mdatOffset != null) {\n        this.stream.seek(this.mdatOffset - 8);\n      }\n      ref = this.tracks;\n      for (k = 0, len1 = ref.length; k < len1; k++) {\n        track = ref[k];\n        if (!(track.type === 'soun')) {\n          continue;\n        }\n        this.track = track;\n        break;\n      }\n      if (this.track.type !== 'soun') {\n        this.track = null;\n        return this.emit('error', 'No audio tracks in m4a file.');\n      }\n      this.emit('format', this.track.format);\n      this.emit('duration', this.track.duration / this.track.timeScale * 1000 | 0);\n      if (this.track.cookie) {\n        this.emit('cookie', this.track.cookie);\n      }\n      return this.seekPoints = this.track.seekPoints;\n    });\n\n    atom('mdat', function() {\n      var bytes, chunkSize, k, length, numSamples, offset, ref, sample, size;\n      if (!this.startedData) {\n        if (this.mdatOffset == null) {\n          this.mdatOffset = this.stream.offset;\n        }\n        if (this.tracks.length === 0) {\n          bytes = Math.min(this.stream.remainingBytes(), this.len);\n          this.stream.advance(bytes);\n          this.len -= bytes;\n          return;\n        }\n        this.chunkIndex = 0;\n        this.stscIndex = 0;\n        this.sampleIndex = 0;\n        this.tailOffset = 0;\n        this.tailSamples = 0;\n        this.startedData = true;\n      }\n      if (!this.readChapters) {\n        this.readChapters = this.parseChapters();\n        if (this[\"break\"] = !this.readChapters) {\n          return;\n        }\n        this.stream.seek(this.mdatOffset);\n      }\n      offset = this.track.chunkOffsets[this.chunkIndex] + this.tailOffset;\n      length = 0;\n      if (!this.stream.available(offset - this.stream.offset)) {\n        this[\"break\"] = true;\n        return;\n      }\n      this.stream.seek(offset);\n      while (this.chunkIndex < this.track.chunkOffsets.length) {\n        numSamples = this.track.stsc[this.stscIndex].count - this.tailSamples;\n        chunkSize = 0;\n        for (sample = k = 0, ref = numSamples; k < ref; sample = k += 1) {\n          size = this.track.sampleSize || this.track.sampleSizes[this.sampleIndex];\n          if (!this.stream.available(length + size)) {\n            break;\n          }\n          length += size;\n          chunkSize += size;\n          this.sampleIndex++;\n        }\n        if (sample < numSamples) {\n          this.tailOffset += chunkSize;\n          this.tailSamples += sample;\n          break;\n        } else {\n          this.chunkIndex++;\n          this.tailOffset = 0;\n          this.tailSamples = 0;\n          if (this.stscIndex + 1 < this.track.stsc.length && this.chunkIndex + 1 === this.track.stsc[this.stscIndex + 1].first) {\n            this.stscIndex++;\n          }\n          if (offset + length !== this.track.chunkOffsets[this.chunkIndex]) {\n            break;\n          }\n        }\n      }\n      if (length > 0) {\n        this.emit('data', this.stream.readBuffer(length));\n        return this[\"break\"] = this.chunkIndex === this.track.chunkOffsets.length;\n      } else {\n        return this[\"break\"] = true;\n      }\n    });\n\n    M4ADemuxer.prototype.parseChapters = function() {\n      var bom, id, k, len, len1, nextTimestamp, point, ref, ref1, ref2, ref3, title, track;\n      if (!(((ref = this.track.chapterTracks) != null ? ref.length : void 0) > 0)) {\n        return true;\n      }\n      id = this.track.chapterTracks[0];\n      ref1 = this.tracks;\n      for (k = 0, len1 = ref1.length; k < len1; k++) {\n        track = ref1[k];\n        if (track.id === id) {\n          break;\n        }\n      }\n      if (track.id !== id) {\n        this.emit('error', 'Chapter track does not exist.');\n      }\n      if (this.chapters == null) {\n        this.chapters = [];\n      }\n      while (this.chapters.length < track.seekPoints.length) {\n        point = track.seekPoints[this.chapters.length];\n        if (!this.stream.available(point.position - this.stream.offset + 32)) {\n          return false;\n        }\n        this.stream.seek(point.position);\n        len = this.stream.readUInt16();\n        title = null;\n        if (!this.stream.available(len)) {\n          return false;\n        }\n        if (len > 2) {\n          bom = this.stream.peekUInt16();\n          if (bom === 0xfeff || bom === 0xfffe) {\n            title = this.stream.readString(len, 'utf16-bom');\n          }\n        }\n        if (title == null) {\n          title = this.stream.readString(len, 'utf8');\n        }\n        nextTimestamp = (ref2 = (ref3 = track.seekPoints[this.chapters.length + 1]) != null ? ref3.timestamp : void 0) != null ? ref2 : track.duration;\n        this.chapters.push({\n          title: title,\n          timestamp: point.timestamp / track.timeScale * 1000 | 0,\n          duration: (nextTimestamp - point.timestamp) / track.timeScale * 1000 | 0\n        });\n      }\n      this.emit('chapters', this.chapters);\n      return true;\n    };\n\n    atom('moov.udta.meta', function() {\n      this.metadata = {};\n      return this.stream.advance(4);\n    });\n\n    after('moov.udta.meta', function() {\n      return this.emit('metadata', this.metadata);\n    });\n\n    meta = function(field, name, fn) {\n      return atom(\"moov.udta.meta.ilst.\" + field + \".data\", function() {\n        this.stream.advance(8);\n        this.len -= 8;\n        return fn.call(this, name);\n      });\n    };\n\n    string = function(field) {\n      return this.metadata[field] = this.stream.readString(this.len, 'utf8');\n    };\n\n    meta('©alb', 'album', string);\n\n    meta('©arg', 'arranger', string);\n\n    meta('©art', 'artist', string);\n\n    meta('©ART', 'artist', string);\n\n    meta('aART', 'albumArtist', string);\n\n    meta('catg', 'category', string);\n\n    meta('©com', 'composer', string);\n\n    meta('©cpy', 'copyright', string);\n\n    meta('cprt', 'copyright', string);\n\n    meta('©cmt', 'comments', string);\n\n    meta('©day', 'releaseDate', string);\n\n    meta('desc', 'description', string);\n\n    meta('©gen', 'genre', string);\n\n    meta('©grp', 'grouping', string);\n\n    meta('©isr', 'ISRC', string);\n\n    meta('keyw', 'keywords', string);\n\n    meta('©lab', 'recordLabel', string);\n\n    meta('ldes', 'longDescription', string);\n\n    meta('©lyr', 'lyrics', string);\n\n    meta('©nam', 'title', string);\n\n    meta('©phg', 'recordingCopyright', string);\n\n    meta('©prd', 'producer', string);\n\n    meta('©prf', 'performers', string);\n\n    meta('purd', 'purchaseDate', string);\n\n    meta('purl', 'podcastURL', string);\n\n    meta('©swf', 'songwriter', string);\n\n    meta('©too', 'encoder', string);\n\n    meta('©wrt', 'composer', string);\n\n    meta('covr', 'coverArt', function(field) {\n      return this.metadata[field] = this.stream.readBuffer(this.len);\n    });\n\n    genres = [\"Blues\", \"Classic Rock\", \"Country\", \"Dance\", \"Disco\", \"Funk\", \"Grunge\", \"Hip-Hop\", \"Jazz\", \"Metal\", \"New Age\", \"Oldies\", \"Other\", \"Pop\", \"R&B\", \"Rap\", \"Reggae\", \"Rock\", \"Techno\", \"Industrial\", \"Alternative\", \"Ska\", \"Death Metal\", \"Pranks\", \"Soundtrack\", \"Euro-Techno\", \"Ambient\", \"Trip-Hop\", \"Vocal\", \"Jazz+Funk\", \"Fusion\", \"Trance\", \"Classical\", \"Instrumental\", \"Acid\", \"House\", \"Game\", \"Sound Clip\", \"Gospel\", \"Noise\", \"AlternRock\", \"Bass\", \"Soul\", \"Punk\", \"Space\", \"Meditative\", \"Instrumental Pop\", \"Instrumental Rock\", \"Ethnic\", \"Gothic\", \"Darkwave\", \"Techno-Industrial\", \"Electronic\", \"Pop-Folk\", \"Eurodance\", \"Dream\", \"Southern Rock\", \"Comedy\", \"Cult\", \"Gangsta\", \"Top 40\", \"Christian Rap\", \"Pop/Funk\", \"Jungle\", \"Native American\", \"Cabaret\", \"New Wave\", \"Psychadelic\", \"Rave\", \"Showtunes\", \"Trailer\", \"Lo-Fi\", \"Tribal\", \"Acid Punk\", \"Acid Jazz\", \"Polka\", \"Retro\", \"Musical\", \"Rock & Roll\", \"Hard Rock\", \"Folk\", \"Folk/Rock\", \"National Folk\", \"Swing\", \"Fast Fusion\", \"Bebob\", \"Latin\", \"Revival\", \"Celtic\", \"Bluegrass\", \"Avantgarde\", \"Gothic Rock\", \"Progressive Rock\", \"Psychedelic Rock\", \"Symphonic Rock\", \"Slow Rock\", \"Big Band\", \"Chorus\", \"Easy Listening\", \"Acoustic\", \"Humour\", \"Speech\", \"Chanson\", \"Opera\", \"Chamber Music\", \"Sonata\", \"Symphony\", \"Booty Bass\", \"Primus\", \"Porn Groove\", \"Satire\", \"Slow Jam\", \"Club\", \"Tango\", \"Samba\", \"Folklore\", \"Ballad\", \"Power Ballad\", \"Rhythmic Soul\", \"Freestyle\", \"Duet\", \"Punk Rock\", \"Drum Solo\", \"A Capella\", \"Euro-House\", \"Dance Hall\"];\n\n    meta('gnre', 'genre', function(field) {\n      return this.metadata[field] = genres[this.stream.readUInt16() - 1];\n    });\n\n    meta('tmpo', 'tempo', function(field) {\n      return this.metadata[field] = this.stream.readUInt16();\n    });\n\n    meta('rtng', 'rating', function(field) {\n      var rating;\n      rating = this.stream.readUInt8();\n      return this.metadata[field] = rating === 2 ? 'Clean' : rating !== 0 ? 'Explicit' : 'None';\n    });\n\n    diskTrack = function(field) {\n      this.stream.advance(2);\n      this.metadata[field] = this.stream.readUInt16() + ' of ' + this.stream.readUInt16();\n      return this.stream.advance(this.len - 6);\n    };\n\n    meta('disk', 'diskNumber', diskTrack);\n\n    meta('trkn', 'trackNumber', diskTrack);\n\n    bool = function(field) {\n      return this.metadata[field] = this.stream.readUInt8() === 1;\n    };\n\n    meta('cpil', 'compilation', bool);\n\n    meta('pcst', 'podcast', bool);\n\n    meta('pgap', 'gapless', bool);\n\n    return M4ADemuxer;\n\n  })(Demuxer);\n\n  module.exports = M4ADemuxer;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var Demuxer, WAVEDemuxer,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  Demuxer = require('../demuxer');\n\n  WAVEDemuxer = (function(superClass) {\n    var formats;\n\n    extend(WAVEDemuxer, superClass);\n\n    function WAVEDemuxer() {\n      return WAVEDemuxer.__super__.constructor.apply(this, arguments);\n    }\n\n    Demuxer.register(WAVEDemuxer);\n\n    WAVEDemuxer.probe = function(buffer) {\n      return buffer.peekString(0, 4) === 'RIFF' && buffer.peekString(8, 4) === 'WAVE';\n    };\n\n    formats = {\n      0x0001: 'lpcm',\n      0x0003: 'lpcm',\n      0x0006: 'alaw',\n      0x0007: 'ulaw'\n    };\n\n    WAVEDemuxer.prototype.readChunk = function() {\n      var buffer, bytes, encoding;\n      if (!this.readStart && this.stream.available(12)) {\n        if (this.stream.readString(4) !== 'RIFF') {\n          return this.emit('error', 'Invalid WAV file.');\n        }\n        this.fileSize = this.stream.readUInt32(true);\n        this.readStart = true;\n        if (this.stream.readString(4) !== 'WAVE') {\n          return this.emit('error', 'Invalid WAV file.');\n        }\n      }\n      while (this.stream.available(1)) {\n        if (!this.readHeaders && this.stream.available(8)) {\n          this.type = this.stream.readString(4);\n          this.len = this.stream.readUInt32(true);\n        }\n        switch (this.type) {\n          case 'fmt ':\n            encoding = this.stream.readUInt16(true);\n            if (!(encoding in formats)) {\n              return this.emit('error', 'Unsupported format in WAV file.');\n            }\n            this.format = {\n              formatID: formats[encoding],\n              floatingPoint: encoding === 0x0003,\n              littleEndian: formats[encoding] === 'lpcm',\n              channelsPerFrame: this.stream.readUInt16(true),\n              sampleRate: this.stream.readUInt32(true),\n              framesPerPacket: 1\n            };\n            this.stream.advance(4);\n            this.stream.advance(2);\n            this.format.bitsPerChannel = this.stream.readUInt16(true);\n            this.format.bytesPerPacket = (this.format.bitsPerChannel / 8) * this.format.channelsPerFrame;\n            this.emit('format', this.format);\n            this.stream.advance(this.len - 16);\n            break;\n          case 'data':\n            if (!this.sentDuration) {\n              bytes = this.format.bitsPerChannel / 8;\n              this.emit('duration', this.len / bytes / this.format.channelsPerFrame / this.format.sampleRate * 1000 | 0);\n              this.sentDuration = true;\n            }\n            buffer = this.stream.readSingleBuffer(this.len);\n            this.len -= buffer.length;\n            this.readHeaders = this.len > 0;\n            this.emit('data', buffer);\n            break;\n          default:\n            if (!this.stream.available(this.len)) {\n              return;\n            }\n            this.stream.advance(this.len);\n        }\n        if (this.type !== 'data') {\n          this.readHeaders = false;\n        }\n      }\n    };\n\n    return WAVEDemuxer;\n\n  })(Demuxer);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var AudioDevice, EventEmitter,\n    bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  EventEmitter = require('./core/events');\n\n  AudioDevice = (function(superClass) {\n    var devices;\n\n    extend(AudioDevice, superClass);\n\n    function AudioDevice(sampleRate1, channels1) {\n      this.sampleRate = sampleRate1;\n      this.channels = channels1;\n      this.updateTime = bind(this.updateTime, this);\n      this.playing = false;\n      this.currentTime = 0;\n      this._lastTime = 0;\n    }\n\n    AudioDevice.prototype.start = function() {\n      if (this.playing) {\n        return;\n      }\n      this.playing = true;\n      if (this.device == null) {\n        this.device = AudioDevice.create(this.sampleRate, this.channels);\n      }\n      if (!this.device) {\n        throw new Error(\"No supported audio device found.\");\n      }\n      this._lastTime = this.device.getDeviceTime();\n      this._timer = setInterval(this.updateTime, 200);\n      return this.device.on('refill', this.refill = (function(_this) {\n        return function(buffer) {\n          return _this.emit('refill', buffer);\n        };\n      })(this));\n    };\n\n    AudioDevice.prototype.stop = function() {\n      if (!this.playing) {\n        return;\n      }\n      this.playing = false;\n      this.device.off('refill', this.refill);\n      return clearInterval(this._timer);\n    };\n\n    AudioDevice.prototype.destroy = function() {\n      var ref;\n      this.stop();\n      return (ref = this.device) != null ? ref.destroy() : void 0;\n    };\n\n    AudioDevice.prototype.seek = function(currentTime) {\n      this.currentTime = currentTime;\n      if (this.playing) {\n        this._lastTime = this.device.getDeviceTime();\n      }\n      return this.emit('timeUpdate', this.currentTime);\n    };\n\n    AudioDevice.prototype.updateTime = function() {\n      var time;\n      time = this.device.getDeviceTime();\n      this.currentTime += (time - this._lastTime) / this.device.sampleRate * 1000 | 0;\n      this._lastTime = time;\n      return this.emit('timeUpdate', this.currentTime);\n    };\n\n    devices = [];\n\n    AudioDevice.register = function(device) {\n      return devices.push(device);\n    };\n\n    AudioDevice.create = function(sampleRate, channels) {\n      var device, i, len;\n      for (i = 0, len = devices.length; i < len; i++) {\n        device = devices[i];\n        if (device.supported) {\n          return new device(sampleRate, channels);\n        }\n      }\n      return null;\n    };\n\n    return AudioDevice;\n\n  })(EventEmitter);\n\n  module.exports = AudioDevice;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var AVBuffer, AudioDevice, EventEmitter, MozillaAudioDevice,\n    bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  EventEmitter = require('../core/events');\n\n  AudioDevice = require('../device');\n\n  AVBuffer = require('../core/buffer');\n\n  MozillaAudioDevice = (function(superClass) {\n    var createTimer, destroyTimer;\n\n    extend(MozillaAudioDevice, superClass);\n\n    AudioDevice.register(MozillaAudioDevice);\n\n    MozillaAudioDevice.supported = (typeof Audio !== \"undefined\" && Audio !== null) && 'mozWriteAudio' in new Audio;\n\n    function MozillaAudioDevice(sampleRate, channels) {\n      this.sampleRate = sampleRate;\n      this.channels = channels;\n      this.refill = bind(this.refill, this);\n      this.audio = new Audio;\n      this.audio.mozSetup(this.channels, this.sampleRate);\n      this.writePosition = 0;\n      this.prebufferSize = this.sampleRate / 2;\n      this.tail = null;\n      this.timer = createTimer(this.refill, 100);\n    }\n\n    MozillaAudioDevice.prototype.refill = function() {\n      var available, buffer, currentPosition, written;\n      if (this.tail) {\n        written = this.audio.mozWriteAudio(this.tail);\n        this.writePosition += written;\n        if (this.writePosition < this.tail.length) {\n          this.tail = this.tail.subarray(written);\n        } else {\n          this.tail = null;\n        }\n      }\n      currentPosition = this.audio.mozCurrentSampleOffset();\n      available = currentPosition + this.prebufferSize - this.writePosition;\n      if (available > 0) {\n        buffer = new Float32Array(available);\n        this.emit('refill', buffer);\n        written = this.audio.mozWriteAudio(buffer);\n        if (written < buffer.length) {\n          this.tail = buffer.subarray(written);\n        }\n        this.writePosition += written;\n      }\n    };\n\n    MozillaAudioDevice.prototype.destroy = function() {\n      return destroyTimer(this.timer);\n    };\n\n    MozillaAudioDevice.prototype.getDeviceTime = function() {\n      return this.audio.mozCurrentSampleOffset() / this.channels;\n    };\n\n    createTimer = function(fn, interval) {\n      var url, worker;\n      url = AVBuffer.makeBlobURL(\"setInterval(function() { postMessage('ping'); }, \" + interval + \");\");\n      if (url == null) {\n        return setInterval(fn, interval);\n      }\n      worker = new Worker(url);\n      worker.onmessage = fn;\n      worker.url = url;\n      return worker;\n    };\n\n    destroyTimer = function(timer) {\n      if (timer.terminate) {\n        timer.terminate();\n        return URL.revokeObjectURL(timer.url);\n      } else {\n        return clearInterval(timer);\n      }\n    };\n\n    return MozillaAudioDevice;\n\n  })(EventEmitter);\n\n}).call(this);\n","//JavaScript Audio Resampler\n//Copyright (C) 2011-2015 Grant Galitz\n//Released to Public Domain\nfunction Resampler(fromSampleRate, toSampleRate, channels, inputBufferLength) {\n  this.fromSampleRate = +fromSampleRate;\n  this.toSampleRate = +toSampleRate;\n  this.channels = channels | 0;\n  this.inputBufferLength = inputBufferLength;\n  this.initialize();\n}\n\nResampler.prototype.initialize = function () {\n  //Perform some checks:\n  if (this.fromSampleRate > 0 && this.toSampleRate > 0 && this.channels > 0) {\n    if (this.fromSampleRate == this.toSampleRate) {\n      //Setup a resampler bypass:\n      this.resampler = this.bypassResampler;    //Resampler just returns what was passed through.\n      this.ratioWeight = 1;\n    } else {\n      this.ratioWeight = this.fromSampleRate / this.toSampleRate;\n      if (this.fromSampleRate < this.toSampleRate) {\n        /*\n          Use generic linear interpolation if upsampling,\n          as linear interpolation produces a gradient that we want\n          and works fine with two input sample points per output in this case.\n        */\n        this.compileLinearInterpolationFunction();\n        this.lastWeight = 1;\n      } else {\n        /*\n          Custom resampler I wrote that doesn't skip samples\n          like standard linear interpolation in high downsampling.\n          This is more accurate than linear interpolation on downsampling.\n        */\n        this.compileMultiTapFunction();\n        this.tailExists = false;\n        this.lastWeight = 0;\n      }\n      \n      var outputBufferSize = (Math.ceil(this.inputBufferLength * this.toSampleRate / this.fromSampleRate / this.channels * 1.01) * this.channels) + this.channels;\n      this.outputBuffer = new Float32Array(outputBufferSize);\n      this.lastOutput = new Float32Array(this.channels);\n    }\n  } else {\n    throw(new Error(\"Invalid settings specified for the resampler.\"));\n  }\n};\n\nResampler.prototype.compileLinearInterpolationFunction = function () {\n  var toCompile = \"var outputOffset = 0;\\\n    var bufferLength = buffer.length;\\\n    if (bufferLength > 0) {\\\n      var weight = this.lastWeight;\\\n      var firstWeight = 0;\\\n      var secondWeight = 0;\\\n      var sourceOffset = 0;\\\n      var outputOffset = 0;\\\n      var outputBuffer = this.outputBuffer;\\\n      for (; weight < 1; weight += \" + this.ratioWeight + \") {\\\n        secondWeight = weight % 1;\\\n        firstWeight = 1 - secondWeight;\";\n        for (var channel = 0; channel < this.channels; ++channel) {\n          toCompile += \"outputBuffer[outputOffset++] = (this.lastOutput[\" + channel + \"] * firstWeight) + (buffer[\" + channel + \"] * secondWeight);\";\n        }\n      toCompile += \"}\\\n      weight -= 1;\\\n      for (bufferLength -= \" + this.channels + \", sourceOffset = Math.floor(weight) * \" + this.channels + \"; sourceOffset < bufferLength;) {\\\n        secondWeight = weight % 1;\\\n        firstWeight = 1 - secondWeight;\";\n        for (var channel = 0; channel < this.channels; ++channel) {\n          toCompile += \"outputBuffer[outputOffset++] = (buffer[sourceOffset\" + ((channel > 0) ? (\" + \" + channel) : \"\") + \"] * firstWeight) + (buffer[sourceOffset + \" + (this.channels + channel) + \"] * secondWeight);\";\n        }\n        toCompile += \"weight += \" + this.ratioWeight + \";\\\n        sourceOffset = Math.floor(weight) * \" + this.channels + \";\\\n      }\";\n      for (var channel = 0; channel < this.channels; ++channel) {\n        toCompile += \"this.lastOutput[\" + channel + \"] = buffer[sourceOffset++];\";\n      }\n      toCompile += \"this.lastWeight = weight % 1;\\\n    }\\\n    return this.outputBuffer;\";\n    \n  this.resampler = Function(\"buffer\", toCompile);\n};\n\nResampler.prototype.compileMultiTapFunction = function () {\n  var toCompile = \"var outputOffset = 0;\\\n    var bufferLength = buffer.length;\\\n    if (bufferLength > 0) {\\\n      var weight = 0;\";\n      for (var channel = 0; channel < this.channels; ++channel) {\n        toCompile += \"var output\" + channel + \" = 0;\"\n      }\n      toCompile += \"var actualPosition = 0;\\\n      var amountToNext = 0;\\\n      var alreadyProcessedTail = !this.tailExists;\\\n      this.tailExists = false;\\\n      var outputBuffer = this.outputBuffer;\\\n      var currentPosition = 0;\\\n      do {\\\n        if (alreadyProcessedTail) {\\\n          weight = \" + this.ratioWeight + \";\";\n          for (channel = 0; channel < this.channels; ++channel) {\n            toCompile += \"output\" + channel + \" = 0;\"\n          }\n        toCompile += \"}\\\n        else {\\\n          weight = this.lastWeight;\";\n          for (channel = 0; channel < this.channels; ++channel) {\n            toCompile += \"output\" + channel + \" = this.lastOutput[\" + channel + \"];\"\n          }\n          toCompile += \"alreadyProcessedTail = true;\\\n        }\\\n        while (weight > 0 && actualPosition < bufferLength) {\\\n          amountToNext = 1 + actualPosition - currentPosition;\\\n          if (weight >= amountToNext) {\";\n            for (channel = 0; channel < this.channels; ++channel) {\n              toCompile += \"output\" + channel + \" += buffer[actualPosition++] * amountToNext;\"\n            }\n            toCompile += \"currentPosition = actualPosition;\\\n            weight -= amountToNext;\\\n          }\\\n          else {\";\n            for (channel = 0; channel < this.channels; ++channel) {\n              toCompile += \"output\" + channel + \" += buffer[actualPosition\" + ((channel > 0) ? (\" + \" + channel) : \"\") + \"] * weight;\"\n            }\n            toCompile += \"currentPosition += weight;\\\n            weight = 0;\\\n            break;\\\n          }\\\n        }\\\n        if (weight <= 0) {\";\n          for (channel = 0; channel < this.channels; ++channel) {\n            toCompile += \"outputBuffer[outputOffset++] = output\" + channel + \" / \" + this.ratioWeight + \";\"\n          }\n        toCompile += \"}\\\n        else {\\\n          this.lastWeight = weight;\";\n          for (channel = 0; channel < this.channels; ++channel) {\n            toCompile += \"this.lastOutput[\" + channel + \"] = output\" + channel + \";\"\n          }\n          toCompile += \"this.tailExists = true;\\\n          break;\\\n        }\\\n      } while (actualPosition < bufferLength);\\\n    }\\\n    return this.outputBuffer;\";\n  \n  this.resampler = Function(\"buffer\", toCompile);\n};\n\nResampler.prototype.bypassResampler = function (inputBuffer) {\n  return inputBuffer;\n};\n\nmodule.exports = Resampler;\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var AudioDevice, EventEmitter, Resampler, WebAudioDevice,\n    bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  EventEmitter = require('../core/events');\n\n  AudioDevice = require('../device');\n\n  Resampler = require('./resampler');\n\n  WebAudioDevice = (function(superClass) {\n    var AudioContext, createProcessor, sharedContext;\n\n    extend(WebAudioDevice, superClass);\n\n    AudioDevice.register(WebAudioDevice);\n\n    AudioContext = global.AudioContext || global.webkitAudioContext;\n\n    WebAudioDevice.supported = AudioContext && (typeof AudioContext.prototype[createProcessor = 'createScriptProcessor'] === 'function' || typeof AudioContext.prototype[createProcessor = 'createJavaScriptNode'] === 'function');\n\n    sharedContext = null;\n\n    function WebAudioDevice(sampleRate, channels1) {\n      this.sampleRate = sampleRate;\n      this.channels = channels1;\n      this.refill = bind(this.refill, this);\n      this.context = sharedContext != null ? sharedContext : sharedContext = new AudioContext;\n      this.deviceSampleRate = this.context.sampleRate;\n      this.bufferSize = Math.ceil(4096 / (this.deviceSampleRate / this.sampleRate) * this.channels);\n      this.bufferSize += this.bufferSize % this.channels;\n      if (this.deviceSampleRate !== this.sampleRate) {\n        this.resampler = new Resampler(this.sampleRate, this.deviceSampleRate, this.channels, this.bufferSize);\n      }\n      this.node = this.context[createProcessor](4096, this.channels, this.channels);\n      this.node.onaudioprocess = this.refill;\n      this.node.connect(this.context.destination);\n    }\n\n    WebAudioDevice.prototype.refill = function(event) {\n      var channelCount, channels, data, i, j, k, l, n, outputBuffer, ref, ref1, ref2;\n      outputBuffer = event.outputBuffer;\n      channelCount = outputBuffer.numberOfChannels;\n      channels = new Array(channelCount);\n      for (i = j = 0, ref = channelCount; j < ref; i = j += 1) {\n        channels[i] = outputBuffer.getChannelData(i);\n      }\n      data = new Float32Array(this.bufferSize);\n      this.emit('refill', data);\n      if (this.resampler) {\n        data = this.resampler.resampler(data);\n      }\n      for (i = k = 0, ref1 = outputBuffer.length; k < ref1; i = k += 1) {\n        for (n = l = 0, ref2 = channelCount; l < ref2; n = l += 1) {\n          channels[n][i] = data[i * channelCount + n];\n        }\n      }\n    };\n\n    WebAudioDevice.prototype.destroy = function() {\n      return this.node.disconnect(0);\n    };\n\n    WebAudioDevice.prototype.getDeviceTime = function() {\n      return this.context.currentTime * this.sampleRate;\n    };\n\n    return WebAudioDevice;\n\n  })(EventEmitter);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var Filter;\n\n  Filter = (function() {\n    function Filter(context, key) {\n      if (context && key) {\n        Object.defineProperty(this, 'value', {\n          get: function() {\n            return context[key];\n          }\n        });\n      }\n    }\n\n    Filter.prototype.process = function(buffer) {};\n\n    return Filter;\n\n  })();\n\n  module.exports = Filter;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var BalanceFilter, Filter,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  Filter = require('../filter');\n\n  BalanceFilter = (function(superClass) {\n    extend(BalanceFilter, superClass);\n\n    function BalanceFilter() {\n      return BalanceFilter.__super__.constructor.apply(this, arguments);\n    }\n\n    BalanceFilter.prototype.process = function(buffer) {\n      var i, j, pan, ref;\n      if (this.value === 0) {\n        return;\n      }\n      pan = Math.max(-50, Math.min(50, this.value));\n      for (i = j = 0, ref = buffer.length; j < ref; i = j += 2) {\n        buffer[i] *= Math.min(1, (50 - pan) / 50);\n        buffer[i + 1] *= Math.min(1, (50 + pan) / 50);\n      }\n    };\n\n    return BalanceFilter;\n\n  })(Filter);\n\n  module.exports = BalanceFilter;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var Filter, VolumeFilter,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  Filter = require('../filter');\n\n  VolumeFilter = (function(superClass) {\n    extend(VolumeFilter, superClass);\n\n    function VolumeFilter() {\n      return VolumeFilter.__super__.constructor.apply(this, arguments);\n    }\n\n    VolumeFilter.prototype.process = function(buffer) {\n      var i, j, ref, vol;\n      if (this.value >= 100) {\n        return;\n      }\n      vol = Math.max(0, Math.min(100, this.value)) / 100;\n      for (i = j = 0, ref = buffer.length; j < ref; i = j += 1) {\n        buffer[i] *= vol;\n      }\n    };\n\n    return VolumeFilter;\n\n  })(Filter);\n\n  module.exports = VolumeFilter;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var Asset, AudioDevice, BalanceFilter, EventEmitter, Player, Queue, VolumeFilter,\n    bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  EventEmitter = require('./core/events');\n\n  Asset = require('./asset');\n\n  VolumeFilter = require('./filters/volume');\n\n  BalanceFilter = require('./filters/balance');\n\n  Queue = require('./queue');\n\n  AudioDevice = require('./device');\n\n  Player = (function(superClass) {\n    extend(Player, superClass);\n\n    function Player(asset) {\n      this.asset = asset;\n      this.startPlaying = bind(this.startPlaying, this);\n      this.playing = false;\n      this.buffered = 0;\n      this.currentTime = 0;\n      this.duration = 0;\n      this.volume = 100;\n      this.pan = 0;\n      this.metadata = {};\n      this.filters = [new VolumeFilter(this, 'volume'), new BalanceFilter(this, 'pan')];\n      this.asset.on('buffer', (function(_this) {\n        return function(buffered) {\n          _this.buffered = buffered;\n          return _this.emit('buffer', _this.buffered);\n        };\n      })(this));\n      this.asset.on('decodeStart', (function(_this) {\n        return function() {\n          _this.queue = new Queue(_this.asset);\n          return _this.queue.once('ready', _this.startPlaying);\n        };\n      })(this));\n      this.asset.on('format', (function(_this) {\n        return function(format) {\n          _this.format = format;\n          return _this.emit('format', _this.format);\n        };\n      })(this));\n      this.asset.on('metadata', (function(_this) {\n        return function(metadata) {\n          _this.metadata = metadata;\n          return _this.emit('metadata', _this.metadata);\n        };\n      })(this));\n      this.asset.on('duration', (function(_this) {\n        return function(duration) {\n          _this.duration = duration;\n          return _this.emit('duration', _this.duration);\n        };\n      })(this));\n      this.asset.on('error', (function(_this) {\n        return function(error) {\n          return _this.emit('error', error);\n        };\n      })(this));\n    }\n\n    Player.fromURL = function(url, opts) {\n      return new Player(Asset.fromURL(url, opts));\n    };\n\n    Player.fromFile = function(file) {\n      return new Player(Asset.fromFile(file));\n    };\n\n    Player.fromBuffer = function(buffer) {\n      return new Player(Asset.fromBuffer(buffer));\n    };\n\n    Player.prototype.preload = function() {\n      if (!this.asset) {\n        return;\n      }\n      this.startedPreloading = true;\n      return this.asset.start(false);\n    };\n\n    Player.prototype.play = function() {\n      var ref;\n      if (this.playing) {\n        return;\n      }\n      if (!this.startedPreloading) {\n        this.preload();\n      }\n      this.playing = true;\n      return (ref = this.device) != null ? ref.start() : void 0;\n    };\n\n    Player.prototype.pause = function() {\n      var ref;\n      if (!this.playing) {\n        return;\n      }\n      this.playing = false;\n      return (ref = this.device) != null ? ref.stop() : void 0;\n    };\n\n    Player.prototype.togglePlayback = function() {\n      if (this.playing) {\n        return this.pause();\n      } else {\n        return this.play();\n      }\n    };\n\n    Player.prototype.stop = function() {\n      var ref;\n      this.pause();\n      this.asset.stop();\n      return (ref = this.device) != null ? ref.destroy() : void 0;\n    };\n\n    Player.prototype.seek = function(timestamp) {\n      var ref;\n      if ((ref = this.device) != null) {\n        ref.stop();\n      }\n      this.queue.once('ready', (function(_this) {\n        return function() {\n          var ref1, ref2;\n          if ((ref1 = _this.device) != null) {\n            ref1.seek(_this.currentTime);\n          }\n          if (_this.playing) {\n            return (ref2 = _this.device) != null ? ref2.start() : void 0;\n          }\n        };\n      })(this));\n      timestamp = (timestamp / 1000) * this.format.sampleRate;\n      timestamp = this.asset.decoder.seek(timestamp);\n      this.currentTime = timestamp / this.format.sampleRate * 1000 | 0;\n      this.queue.reset();\n      return this.currentTime;\n    };\n\n    Player.prototype.startPlaying = function() {\n      var frame, frameOffset;\n      frame = this.queue.read();\n      frameOffset = 0;\n      this.device = new AudioDevice(this.format.sampleRate, this.format.channelsPerFrame);\n      this.device.on('timeUpdate', (function(_this) {\n        return function(currentTime) {\n          _this.currentTime = currentTime;\n          return _this.emit('progress', _this.currentTime);\n        };\n      })(this));\n      this.refill = (function(_this) {\n        return function(buffer) {\n          var bufferOffset, filter, i, j, k, len, max, ref, ref1;\n          if (!_this.playing) {\n            return;\n          }\n          if (!frame) {\n            frame = _this.queue.read();\n            frameOffset = 0;\n          }\n          bufferOffset = 0;\n          while (frame && bufferOffset < buffer.length) {\n            max = Math.min(frame.length - frameOffset, buffer.length - bufferOffset);\n            for (i = j = 0, ref = max; j < ref; i = j += 1) {\n              buffer[bufferOffset++] = frame[frameOffset++];\n            }\n            if (frameOffset === frame.length) {\n              frame = _this.queue.read();\n              frameOffset = 0;\n            }\n          }\n          ref1 = _this.filters;\n          for (k = 0, len = ref1.length; k < len; k++) {\n            filter = ref1[k];\n            filter.process(buffer);\n          }\n          if (!frame) {\n            if (_this.queue.ended) {\n              _this.currentTime = _this.duration;\n              _this.emit('progress', _this.currentTime);\n              _this.emit('end');\n              _this.stop();\n            } else {\n              _this.device.stop();\n            }\n          }\n        };\n      })(this);\n      this.device.on('refill', this.refill);\n      if (this.playing) {\n        this.device.start();\n      }\n      return this.emit('ready');\n    };\n\n    Player.prototype.destroy = function() {\n      var ref, ref1;\n      this.stop();\n      if ((ref = this.device) != null) {\n        ref.off();\n      }\n      if ((ref1 = this.asset) != null) {\n        ref1.destroy();\n      }\n      return this.off();\n    };\n\n    return Player;\n\n  })(EventEmitter);\n\n  module.exports = Player;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var EventEmitter, Queue,\n    bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  EventEmitter = require('./core/events');\n\n  Queue = (function(superClass) {\n    extend(Queue, superClass);\n\n    function Queue(asset) {\n      this.asset = asset;\n      this.write = bind(this.write, this);\n      this.readyMark = 64;\n      this.finished = false;\n      this.buffering = true;\n      this.ended = false;\n      this.buffers = [];\n      this.asset.on('data', this.write);\n      this.asset.on('end', (function(_this) {\n        return function() {\n          return _this.ended = true;\n        };\n      })(this));\n      this.asset.decodePacket();\n    }\n\n    Queue.prototype.write = function(buffer) {\n      if (buffer) {\n        this.buffers.push(buffer);\n      }\n      if (this.buffering) {\n        if (this.buffers.length >= this.readyMark || this.ended) {\n          this.buffering = false;\n          return this.emit('ready');\n        } else {\n          return this.asset.decodePacket();\n        }\n      }\n    };\n\n    Queue.prototype.read = function() {\n      if (this.buffers.length === 0) {\n        return null;\n      }\n      this.asset.decodePacket();\n      return this.buffers.shift();\n    };\n\n    Queue.prototype.reset = function() {\n      this.buffers.length = 0;\n      this.buffering = true;\n      return this.asset.decodePacket();\n    };\n\n    return Queue;\n\n  })(EventEmitter);\n\n  module.exports = Queue;\n\n}).call(this);\n","EventEmitter = require '../../core/events'\nAVBuffer = require '../../core/buffer'\n\nclass FileSource extends EventEmitter\n    constructor: (@file) ->\n        if not FileReader?\n            return @emit 'error', 'This browser does not have FileReader support.'\n        \n        @offset = 0\n        @length = @file.size\n        @chunkSize = 1 << 20\n        @file[@slice = 'slice'] or @file[@slice = 'webkitSlice'] or @file[@slice = 'mozSlice']\n            \n    start: ->\n        if @reader\n            return @loop() unless @active\n        \n        @reader = new FileReader\n        @active = true\n        \n        @reader.onload = (e) =>\n            buf = new AVBuffer(new Uint8Array(e.target.result))\n            @offset += buf.length\n        \n            @emit 'data', buf   \n            @active = false     \n            @loop() if @offset < @length\n        \n        @reader.onloadend = =>\n            if @offset is @length\n                @emit 'end'\n                @reader = null\n        \n        @reader.onerror = (e) =>\n            @emit 'error', e\n        \n        @reader.onprogress = (e) =>\n            @emit 'progress', (@offset + e.loaded) / @length * 100\n        \n        @loop()\n        \n    loop: ->\n        @active = true\n        endPos = Math.min(@offset + @chunkSize, @length)\n        \n        blob = @file[@slice](@offset, endPos)\n        @reader.readAsArrayBuffer(blob)\n        \n    pause: ->\n        @active = false\n        try\n          @reader?.abort()\n        \n    reset: ->\n        @pause()\n        @offset = 0\n\nmodule.exports = FileSource\n","EventEmitter = require '../../core/events'\nAVBuffer = require '../../core/buffer'\n\nclass HTTPSource extends EventEmitter\n    constructor: (@url, @opts = {}) ->\n        @chunkSize = 1 << 20\n        @inflight = false\n        if @opts.length\n            @length = @opts.length\n        @reset()\n        \n    start: ->\n        if @length\n            return @loop() unless @inflight\n        \n        @inflight = true\n        @xhr = new XMLHttpRequest()\n        \n        @xhr.onload = (event) =>\n            @length = parseInt @xhr.getResponseHeader(\"Content-Length\")                \n            @inflight = false\n            @loop()\n        \n        @xhr.onerror = (err) =>\n            @pause()\n            @emit 'error', err\n            \n        @xhr.onabort = (event) =>\n            @inflight = false\n        \n        @xhr.open(\"HEAD\", @url, true)\n        @xhr.send(null)\n        \n    loop: ->\n        if @inflight or not @length\n            return @emit 'error', 'Something is wrong in HTTPSource.loop'\n            \n        @inflight = true\n        @xhr = new XMLHttpRequest()\n        \n        @xhr.onload = (event) =>\n            if @xhr.response\n                buf = new Uint8Array(@xhr.response)\n            else\n                txt = @xhr.responseText\n                buf = new Uint8Array(txt.length)\n                for i in [0...txt.length]\n                    buf[i] = txt.charCodeAt(i) & 0xff\n\n            buffer = new AVBuffer(buf)\n            @offset += buffer.length\n            \n            @emit 'data', buffer\n            @emit 'end' if @offset >= @length\n\n            @inflight = false\n            @loop() unless @offset >= @length\n            \n        @xhr.onprogress = (event) =>\n            @emit 'progress', (@offset + event.loaded) / @length * 100\n\n        @xhr.onerror = (err) =>\n            @emit 'error', err\n            @pause()\n\n        @xhr.onabort = (event) =>\n            @inflight = false\n\n        @xhr.open(\"GET\", @url, true)\n        @xhr.responseType = \"arraybuffer\"\n\n        endPos = Math.min(@offset + @chunkSize, @length - 1)\n        @xhr.setRequestHeader(\"If-None-Match\", \"webkit-no-cache\")\n        @xhr.setRequestHeader(\"Range\", \"bytes=#{@offset}-#{endPos}\")\n        @xhr.overrideMimeType('text/plain; charset=x-user-defined')\n        @xhr.send(null)\n        \n    pause: ->\n        @inflight = false\n        @xhr?.abort()\n        \n    reset: ->\n        @pause()\n        @offset = 0\n        \nmodule.exports = HTTPSource\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var AVBuffer, BufferList, BufferSource, EventEmitter,\n    bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  EventEmitter = require('../core/events');\n\n  BufferList = require('../core/bufferlist');\n\n  AVBuffer = require('../core/buffer');\n\n  BufferSource = (function(superClass) {\n    var clearImmediate, setImmediate;\n\n    extend(BufferSource, superClass);\n\n    function BufferSource(input) {\n      this.loop = bind(this.loop, this);\n      if (input instanceof BufferList) {\n        this.list = input;\n      } else {\n        this.list = new BufferList;\n        this.list.append(new AVBuffer(input));\n      }\n      this.paused = true;\n    }\n\n    setImmediate = global.setImmediate || function(fn) {\n      return global.setTimeout(fn, 0);\n    };\n\n    clearImmediate = global.clearImmediate || function(timer) {\n      return global.clearTimeout(timer);\n    };\n\n    BufferSource.prototype.start = function() {\n      this.paused = false;\n      return this._timer = setImmediate(this.loop);\n    };\n\n    BufferSource.prototype.loop = function() {\n      this.emit('progress', (this.list.numBuffers - this.list.availableBuffers + 1) / this.list.numBuffers * 100 | 0);\n      this.emit('data', this.list.first);\n      if (this.list.advance()) {\n        return setImmediate(this.loop);\n      } else {\n        return this.emit('end');\n      }\n    };\n\n    BufferSource.prototype.pause = function() {\n      clearImmediate(this._timer);\n      return this.paused = true;\n    };\n\n    BufferSource.prototype.reset = function() {\n      this.pause();\n      return this.list.rewind();\n    };\n\n    return BufferSource;\n\n  })(EventEmitter);\n\n  module.exports = BufferSource;\n\n}).call(this);\n"]}