Source code

Revision control

Copy as Markdown

Other Tools

/*
* Copyright (C) 2017 Apple Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
"use strict";
let currentTime;
if (this.performance && performance.now)
currentTime = function() { return performance.now() };
else if (this.preciseTime)
currentTime = function() { return preciseTime() * 1000; };
else
currentTime = function() { return +new Date(); };
class BabylonBenchmark {
constructor(verbose = 0)
{
let sources = [];
const files = [
["./Babylon/air-blob.js", {}]
, ["./Babylon/basic-blob.js", {}]
, ["./Babylon/inspector-blob.js", {}]
, ["./Babylon/babylon-blob.js", {sourceType: "module"}]
];
for (let [file, options] of files) {
function appendSource(s) {
sources.push([file, s, options]);
}
let s;
const isInBrowser = typeof window !== "undefined";
if (isInBrowser) {
let request = new XMLHttpRequest();
request.open('GET', file, false);
request.send(null);
if (!request.responseText.length)
throw new Error("Expect non-empty sources");
appendSource(request.responseText);
} else {
appendSource(read(file));
}
}
this.sources = sources;
}
runIteration()
{
const Parser = parserIndexJS;
const { plugins } = parserIndexJS;
const { types : tokTypes } = tokenizerTypesJS;
const estreePlugin = pluginsEstreeJS;
const flowPlugin = pluginsFlowJS;
const jsxPlugin = pluginsJsxIndexJS;
plugins.estree = estreePlugin;
plugins.flow = flowPlugin;
plugins.jsx = jsxPlugin;
function parse(input, options) {
return new Parser(options, input).parse();
}
function parseExpression(input, options) {
const parser = new Parser(options, input);
if (parser.options.strictMode) {
parser.state.strict = true;
}
return parser.getExpression();
}
for (let [fileName, source, options] of this.sources) {
parse(source, options);
}
}
}
function runBenchmark()
{
const verbose = 0;
const numIterations = 150;
let before = currentTime();
let benchmark = new Benchmark(verbose);
for (let iteration = 0; iteration < numIterations; ++iteration)
benchmark.runIteration();
let after = currentTime();
return after - before;
}