pluotsorbet/jsshell.js

119 строки
2.5 KiB
JavaScript
Executable File

/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set shiftwidth=2 tabstop=2 autoindent cindent expandtab: */
'use strict';
function check() {
}
if (scriptArgs.length !== 1) {
print("error: One main class name must be specified.");
print("usage: jsshell <main class name>");
quit(1);
}
var window = {
setZeroTimeout: function(callback) {
callback();
},
addEventListener: function() {
},
crypto: {
getRandomValues: function() {
},
},
};
var navigator = {
language: "en-US",
};
function Promise() {
// ...
}
var document = {
documentElement: {
classList: {
add: function() {
},
},
},
querySelector: function() {
return {
addEventListener: function() {
},
};
},
getElementById: function() {
return {
addEventListener: function() {
},
getContext: function() {
},
getBoundingClientRect: function() {
return { top: 0, left: 0, width: 0, height: 0 };
}
};
},
addEventListener: function() {
},
};
var config = {
logConsole: "native",
args: "",
};
try {
load("libs/zipfile.js", "blackBox.js", "build/j2me.js",
"libs/encoding.js", "util.js",
"instrument.js",
"override.js", "native.js", "tests/override.js",
"string.js", "libs/console.js", "midp/midp.js",
"libs/long.js", "midp/crypto.js", "libs/forge/md5.js", "libs/forge/util.js");
// load("build/classes.jar.cc.js");
// load("build/program.jar.cc.js");
var dump = putstr;
var console = window.console;
CLASSES.addSourceDirectory("java/cldc1.1.1");
CLASSES.addSourceDirectory("java/midp");
CLASSES.addSourceDirectory("bench/scimark2src");
CLASSES.addPath("java/classes.jar", snarf("java/classes.jar", "binary").buffer);
CLASSES.addPath("tests/tests.jar", snarf("tests/tests.jar", "binary").buffer);
CLASSES.addPath("program.jar", snarf("program.jar", "binary").buffer);
CLASSES.initializeBuiltinClasses();
var start = dateNow();
var jvm = new JVM();
var s = dateNow();
snarf("classes.txt").split("\n").forEach(function (x) {
try {
CLASSES.getClass(x);
} catch (e) {
print(e);
}
});
print("TOOK: " + (dateNow() - s));
print("INITIALIZATION TIME: " + (dateNow() - start));
start = dateNow();
var runtime = jvm.startIsolate0(scriptArgs[0], config.args);
print("RUNNING TIME: " + (dateNow() - start));
// J2ME.interpreterCounter.traceSorted(new J2ME.IndentingWriter());
} catch (x) {
print(x);
print(x.stack);
}