StreamInternals.js [plain text]
function shieldingPromiseResolve(result)
{
const promise = @Promise.@resolve(result);
if (promise.@then === @undefined)
promise.@then = @Promise.prototype.@then;
return promise;
}
function promiseInvokeOrNoopNoCatch(object, key, args)
{
"use strict";
const method = object[key];
if (method === @undefined)
return @Promise.@resolve();
return @shieldingPromiseResolve(method.@apply(object, args));
}
function promiseInvokeOrNoop(object, key, args)
{
"use strict";
try {
return @promiseInvokeOrNoopNoCatch(object, key, args);
}
catch(error) {
return @Promise.@reject(error);
}
}
function promiseInvokeOrFallbackOrNoop(object, key1, args1, key2, args2)
{
"use strict";
try {
const method = object[key1];
if (method === @undefined)
return @promiseInvokeOrNoopNoCatch(object, key2, args2);
return @shieldingPromiseResolve(method.@apply(object, args1));
}
catch(error) {
return @Promise.@reject(error);
}
}
function validateAndNormalizeQueuingStrategy(size, highWaterMark)
{
"use strict";
if (size !== @undefined && typeof size !== "function")
@throwTypeError("size parameter must be a function");
const normalizedStrategy = { };
normalizedStrategy.size = size;
normalizedStrategy.highWaterMark = @Number(highWaterMark);
if (@isNaN(normalizedStrategy.highWaterMark) || normalizedStrategy.highWaterMark < 0)
@throwRangeError("highWaterMark value is negative or not a number");
return normalizedStrategy;
}
function newQueue()
{
"use strict";
return { content: [], size: 0 };
}
function dequeueValue(queue)
{
"use strict";
const record = queue.content.@shift();
queue.size -= record.size;
return record.value;
}
function enqueueValueWithSize(queue, value, size)
{
"use strict";
size = @Number(size);
if (!@isFinite(size) || size < 0)
@throwRangeError("size has an incorrect value");
queue.content.@push({ value: value, size: size });
queue.size += size;
}
function peekQueueValue(queue)
{
"use strict";
@assert(queue.content.length > 0);
return queue.content[0].value;
}