mirror of
https://github.com/denoland/deno.git
synced 2025-01-21 04:52:26 -05:00
Compile cache and relative imports working.
This commit is contained in:
parent
03af2c7118
commit
5117a8f8a2
10 changed files with 233 additions and 55 deletions
|
@ -1,8 +1,12 @@
|
||||||
language: go
|
language: go
|
||||||
go:
|
go:
|
||||||
- 1.9.2
|
- 1.9.2
|
||||||
cache: ccache
|
cache:
|
||||||
|
directories:
|
||||||
|
- $HOME/.ccache
|
||||||
|
- `go env GOPATH`/src/github.com/ry/v8worker2/out
|
||||||
install:
|
install:
|
||||||
|
- go get github.com/jteeuwen/go-bindata
|
||||||
- go get -d github.com/ry/v8worker2
|
- go get -d github.com/ry/v8worker2
|
||||||
- (cd `go env GOPATH`/src/github.com/ry/v8worker2 && ./tools/build.py)
|
- (cd `go env GOPATH`/src/github.com/ry/v8worker2 && ./tools/build.py)
|
||||||
- make
|
- make
|
||||||
|
|
11
Makefile
11
Makefile
|
@ -1,3 +1,12 @@
|
||||||
|
TS_FILES = \
|
||||||
|
amd.ts \
|
||||||
|
main.ts \
|
||||||
|
msg.pb.js \
|
||||||
|
compiler.ts \
|
||||||
|
msg.pb.d.ts \
|
||||||
|
os.ts \
|
||||||
|
util.ts
|
||||||
|
|
||||||
deno: assets.go msg.pb.go main.go
|
deno: assets.go msg.pb.go main.go
|
||||||
go build -o deno
|
go build -o deno
|
||||||
|
|
||||||
|
@ -13,7 +22,7 @@ msg.pb.js: msg.proto node_modules
|
||||||
msg.pb.d.ts: msg.pb.js node_modules
|
msg.pb.d.ts: msg.pb.js node_modules
|
||||||
./node_modules/.bin/pbts -o msg.pb.d.ts msg.pb.js
|
./node_modules/.bin/pbts -o msg.pb.d.ts msg.pb.js
|
||||||
|
|
||||||
dist/main.js: main.ts compiler.ts os.ts util.ts msg.pb.js msg.pb.d.ts node_modules
|
dist/main.js: $(TS_FILES) node_modules
|
||||||
./node_modules/.bin/tsc --noEmit # Only for type checking.
|
./node_modules/.bin/tsc --noEmit # Only for type checking.
|
||||||
./node_modules/.bin/parcel build --out-dir=dist/ --no-minify main.ts
|
./node_modules/.bin/parcel build --out-dir=dist/ --no-minify main.ts
|
||||||
|
|
||||||
|
|
80
amd.ts
Normal file
80
amd.ts
Normal file
|
@ -0,0 +1,80 @@
|
||||||
|
import * as path from "path";
|
||||||
|
import { assert, log } from "./util";
|
||||||
|
|
||||||
|
namespace ModuleExportsCache {
|
||||||
|
const cache = new Map<string, object>();
|
||||||
|
export function set(fileName: string, moduleExports: object) {
|
||||||
|
fileName = normalizeModuleName(fileName);
|
||||||
|
assert(
|
||||||
|
fileName.startsWith("/"),
|
||||||
|
`Normalized modules should start with /\n${fileName}`
|
||||||
|
);
|
||||||
|
log("ModuleExportsCache set", fileName);
|
||||||
|
cache.set(fileName, moduleExports);
|
||||||
|
}
|
||||||
|
export function get(fileName: string): object {
|
||||||
|
fileName = normalizeModuleName(fileName);
|
||||||
|
log("ModuleExportsCache get", fileName);
|
||||||
|
let moduleExports = cache.get(fileName);
|
||||||
|
if (moduleExports == null) {
|
||||||
|
moduleExports = {};
|
||||||
|
set(fileName, moduleExports);
|
||||||
|
}
|
||||||
|
return moduleExports;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function normalizeModuleName(fileName: string): string {
|
||||||
|
// Remove the extension.
|
||||||
|
return fileName.replace(/\.\w+$/, "");
|
||||||
|
}
|
||||||
|
|
||||||
|
function normalizeRelativeModuleName(contextFn: string, depFn: string): string {
|
||||||
|
if (depFn.startsWith("/")) {
|
||||||
|
return depFn;
|
||||||
|
} else {
|
||||||
|
return path.resolve(path.dirname(contextFn), depFn);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const executeQueue: Array<() => void> = [];
|
||||||
|
|
||||||
|
export function executeQueueDrain(): void {
|
||||||
|
let fn;
|
||||||
|
while ((fn = executeQueue.shift())) {
|
||||||
|
fn();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// tslint:disable-next-line:no-any
|
||||||
|
type AmdFactory = (...args: any[]) => undefined | object;
|
||||||
|
type AmdDefine = (deps: string[], factory: AmdFactory) => void;
|
||||||
|
|
||||||
|
export function makeDefine(fileName: string): AmdDefine {
|
||||||
|
const localDefine = (deps: string[], factory: AmdFactory): void => {
|
||||||
|
const localRequire = (x: string) => {
|
||||||
|
log("localRequire", x);
|
||||||
|
};
|
||||||
|
const localExports = ModuleExportsCache.get(fileName);
|
||||||
|
log("localDefine", fileName, deps, localExports);
|
||||||
|
const args = deps.map(dep => {
|
||||||
|
if (dep === "require") {
|
||||||
|
return localRequire;
|
||||||
|
} else if (dep === "exports") {
|
||||||
|
return localExports;
|
||||||
|
} else {
|
||||||
|
dep = normalizeRelativeModuleName(fileName, dep);
|
||||||
|
return ModuleExportsCache.get(dep);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
executeQueue.push(() => {
|
||||||
|
log("execute", fileName);
|
||||||
|
const r = factory(...args);
|
||||||
|
if (r != null) {
|
||||||
|
ModuleExportsCache.set(fileName, r);
|
||||||
|
throw Error("x");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
return localDefine;
|
||||||
|
}
|
53
compiler.ts
53
compiler.ts
|
@ -1,19 +1,29 @@
|
||||||
import * as ts from "typescript";
|
import * as ts from "typescript";
|
||||||
import { log, assert, globalEval } from "./util";
|
import { log, assert, globalEval, _global } from "./util";
|
||||||
import { exit, readFileSync } from "./os";
|
import * as os from "./os";
|
||||||
import * as path from "path";
|
import * as path from "path";
|
||||||
|
import * as amd from "./amd";
|
||||||
|
|
||||||
|
/*
|
||||||
|
export function makeCacheDir(): string {
|
||||||
|
let cacheDir = path.join(env.HOME, ".deno/cache")
|
||||||
|
os.mkdirp(cacheDir);
|
||||||
|
return cacheDir
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
export function compile(cwd: string, inputFn: string): void {
|
export function compile(cwd: string, inputFn: string): void {
|
||||||
const options: ts.CompilerOptions = {
|
const options: ts.CompilerOptions = {
|
||||||
allowJs: true,
|
allowJs: true,
|
||||||
outDir: "_denoCache_/",
|
module: ts.ModuleKind.AMD,
|
||||||
|
outDir: "/" // Will be placed in ~/.deno/compile
|
||||||
};
|
};
|
||||||
const host = new CompilerHost(cwd);
|
const host = new CompilerHost();
|
||||||
|
|
||||||
const inputExt = path.extname(inputFn);
|
const inputExt = path.extname(inputFn);
|
||||||
if (!EXTENSIONS.includes(inputExt)) {
|
if (!EXTENSIONS.includes(inputExt)) {
|
||||||
console.error(`Bad file name extension for input "${inputFn}"`);
|
console.error(`Bad file name extension for input "${inputFn}"`);
|
||||||
exit(1);
|
os.exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
const program = ts.createProgram([inputFn], options, host);
|
const program = ts.createProgram([inputFn], options, host);
|
||||||
|
@ -27,12 +37,14 @@ export function compile(cwd: string, inputFn: string): void {
|
||||||
for (const msg of errorMessages) {
|
for (const msg of errorMessages) {
|
||||||
console.error(msg);
|
console.error(msg);
|
||||||
}
|
}
|
||||||
exit(2);
|
os.exit(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
const emitResult = program.emit();
|
const emitResult = program.emit();
|
||||||
assert(!emitResult.emitSkipped);
|
assert(!emitResult.emitSkipped);
|
||||||
log("emitResult", emitResult);
|
log("emitResult", emitResult);
|
||||||
|
|
||||||
|
amd.executeQueueDrain();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -80,7 +92,7 @@ function getDiagnostics(program: ts.Program): ReadonlyArray<ts.Diagnostic> {
|
||||||
const EXTENSIONS = [".ts", ".js"];
|
const EXTENSIONS = [".ts", ".js"];
|
||||||
|
|
||||||
export class CompilerHost {
|
export class CompilerHost {
|
||||||
constructor(public cwd: string) {}
|
constructor() {}
|
||||||
|
|
||||||
getSourceFile(
|
getSourceFile(
|
||||||
fileName: string,
|
fileName: string,
|
||||||
|
@ -90,16 +102,14 @@ export class CompilerHost {
|
||||||
): ts.SourceFile | undefined {
|
): ts.SourceFile | undefined {
|
||||||
let sourceText: string;
|
let sourceText: string;
|
||||||
if (fileName === "lib.d.ts") {
|
if (fileName === "lib.d.ts") {
|
||||||
// TODO this should be compiled into the bindata.
|
// TODO This should be compiled into the bindata.
|
||||||
sourceText = readFileSync("node_modules/typescript/lib/lib.d.ts");
|
sourceText = os.readFileSync("node_modules/typescript/lib/lib.d.ts");
|
||||||
} else {
|
} else {
|
||||||
sourceText = readFileSync(fileName);
|
sourceText = os.readFileSync(fileName);
|
||||||
}
|
}
|
||||||
|
// fileName = fileName.replace(/\.\w+$/, ""); // Remove extension.
|
||||||
if (sourceText) {
|
if (sourceText) {
|
||||||
log("getSourceFile", {
|
log("getSourceFile", { fileName });
|
||||||
fileName
|
|
||||||
//sourceText,
|
|
||||||
});
|
|
||||||
return ts.createSourceFile(fileName, sourceText, languageVersion);
|
return ts.createSourceFile(fileName, sourceText, languageVersion);
|
||||||
} else {
|
} else {
|
||||||
log("getSourceFile NOT FOUND", { fileName });
|
log("getSourceFile NOT FOUND", { fileName });
|
||||||
|
@ -134,13 +144,18 @@ export class CompilerHost {
|
||||||
onError: ((message: string) => void) | undefined,
|
onError: ((message: string) => void) | undefined,
|
||||||
sourceFiles: ReadonlyArray<ts.SourceFile>
|
sourceFiles: ReadonlyArray<ts.SourceFile>
|
||||||
): void {
|
): void {
|
||||||
log("writeFile", { fileName, data });
|
//log("writeFile", { fileName, data });
|
||||||
|
|
||||||
|
os.compileOutput(data, fileName);
|
||||||
|
|
||||||
|
_global["define"] = amd.makeDefine(fileName);
|
||||||
globalEval(data);
|
globalEval(data);
|
||||||
|
_global["define"] = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
getCurrentDirectory(): string {
|
getCurrentDirectory(): string {
|
||||||
log("getCurrentDirectory", this.cwd);
|
log("getCurrentDirectory", ".");
|
||||||
return this.cwd;
|
return ".";
|
||||||
}
|
}
|
||||||
|
|
||||||
getDirectories(path: string): string[] {
|
getDirectories(path: string): string[] {
|
||||||
|
@ -165,7 +180,7 @@ export class CompilerHost {
|
||||||
containingFile: string,
|
containingFile: string,
|
||||||
reusedNames?: string[]
|
reusedNames?: string[]
|
||||||
): Array<ts.ResolvedModule | undefined> {
|
): Array<ts.ResolvedModule | undefined> {
|
||||||
log("resolveModuleNames", { moduleNames, reusedNames });
|
//log("resolveModuleNames", { moduleNames, reusedNames });
|
||||||
return moduleNames.map((name: string) => {
|
return moduleNames.map((name: string) => {
|
||||||
if (
|
if (
|
||||||
name.startsWith("/") ||
|
name.startsWith("/") ||
|
||||||
|
@ -177,7 +192,7 @@ export class CompilerHost {
|
||||||
// Relative import.
|
// Relative import.
|
||||||
const containingDir = path.dirname(containingFile);
|
const containingDir = path.dirname(containingFile);
|
||||||
const resolvedFileName = path.join(containingDir, name);
|
const resolvedFileName = path.join(containingDir, name);
|
||||||
log("relative import", { containingFile, name, resolvedFileName });
|
//log("relative import", { containingFile, name, resolvedFileName });
|
||||||
const isExternalLibraryImport = false;
|
const isExternalLibraryImport = false;
|
||||||
return { resolvedFileName, isExternalLibraryImport };
|
return { resolvedFileName, isExternalLibraryImport };
|
||||||
}
|
}
|
||||||
|
|
98
main.go
98
main.go
|
@ -5,8 +5,28 @@ import (
|
||||||
"github.com/ry/v8worker2"
|
"github.com/ry/v8worker2"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
|
"path"
|
||||||
|
"path/filepath"
|
||||||
|
"runtime"
|
||||||
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func HandleCompileOutput(source string, filename string) []byte {
|
||||||
|
// println("compile output from golang", filename)
|
||||||
|
// Remove any ".." elements. This prevents hacking by trying to move up.
|
||||||
|
filename, err := filepath.Rel("/", filename)
|
||||||
|
check(err)
|
||||||
|
if strings.Contains(filename, "..") {
|
||||||
|
panic("Assertion error.")
|
||||||
|
}
|
||||||
|
filename = path.Join(CompileDir, filename)
|
||||||
|
err = os.MkdirAll(path.Dir(filename), 0700)
|
||||||
|
check(err)
|
||||||
|
err = ioutil.WriteFile(filename, []byte(source), 0600)
|
||||||
|
check(err)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
func ReadFileSync(filename string) []byte {
|
func ReadFileSync(filename string) []byte {
|
||||||
buf, err := ioutil.ReadFile(filename)
|
buf, err := ioutil.ReadFile(filename)
|
||||||
msg := &Msg{Kind: Msg_DATA_RESPONSE}
|
msg := &Msg{Kind: Msg_DATA_RESPONSE}
|
||||||
|
@ -16,23 +36,60 @@ func ReadFileSync(filename string) []byte {
|
||||||
msg.Data = buf
|
msg.Data = buf
|
||||||
}
|
}
|
||||||
out, err := proto.Marshal(msg)
|
out, err := proto.Marshal(msg)
|
||||||
if err != nil {
|
check(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
return out
|
return out
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func UserHomeDir() string {
|
||||||
|
if runtime.GOOS == "windows" {
|
||||||
|
home := os.Getenv("HOMEDRIVE") + os.Getenv("HOMEPATH")
|
||||||
|
if home == "" {
|
||||||
|
home = os.Getenv("USERPROFILE")
|
||||||
|
}
|
||||||
|
return home
|
||||||
|
}
|
||||||
|
return os.Getenv("HOME")
|
||||||
|
}
|
||||||
|
|
||||||
|
func loadAsset(w *v8worker2.Worker, path string) {
|
||||||
|
data, err := Asset(path)
|
||||||
|
check(err)
|
||||||
|
err = w.Load(path, string(data))
|
||||||
|
check(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
var DenoDir string
|
||||||
|
var CompileDir string
|
||||||
|
var SrcDir string
|
||||||
|
|
||||||
|
func createDirs() {
|
||||||
|
DenoDir = path.Join(UserHomeDir(), ".deno")
|
||||||
|
CompileDir = path.Join(DenoDir, "compile")
|
||||||
|
err := os.MkdirAll(CompileDir, 0700)
|
||||||
|
check(err)
|
||||||
|
SrcDir = path.Join(DenoDir, "src")
|
||||||
|
err = os.MkdirAll(SrcDir, 0700)
|
||||||
|
check(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func check(e error) {
|
||||||
|
if e != nil {
|
||||||
|
panic(e)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func recv(buf []byte) []byte {
|
func recv(buf []byte) []byte {
|
||||||
msg := &Msg{}
|
msg := &Msg{}
|
||||||
err := proto.Unmarshal(buf, msg)
|
err := proto.Unmarshal(buf, msg)
|
||||||
if err != nil {
|
check(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
switch msg.Kind {
|
switch msg.Kind {
|
||||||
case Msg_READ_FILE_SYNC:
|
case Msg_READ_FILE_SYNC:
|
||||||
return ReadFileSync(msg.Path)
|
return ReadFileSync(msg.Path)
|
||||||
case Msg_EXIT:
|
case Msg_EXIT:
|
||||||
os.Exit(int(msg.Code))
|
os.Exit(int(msg.Code))
|
||||||
|
case Msg_COMPILE_OUTPUT:
|
||||||
|
payload := msg.GetCompileOutput()
|
||||||
|
return HandleCompileOutput(payload.Source, payload.Filename)
|
||||||
default:
|
default:
|
||||||
panic("Unexpected message")
|
panic("Unexpected message")
|
||||||
}
|
}
|
||||||
|
@ -40,33 +97,24 @@ func recv(buf []byte) []byte {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func loadAsset(w *v8worker2.Worker, path string) {
|
|
||||||
data, err := Asset(path)
|
|
||||||
if err != nil {
|
|
||||||
panic("asset not found")
|
|
||||||
}
|
|
||||||
err = w.Load(path, string(data))
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
args := v8worker2.SetFlags(os.Args)
|
args := v8worker2.SetFlags(os.Args)
|
||||||
|
createDirs()
|
||||||
worker := v8worker2.New(recv)
|
worker := v8worker2.New(recv)
|
||||||
loadAsset(worker, "dist/main.js")
|
loadAsset(worker, "dist/main.js")
|
||||||
cwd, err := os.Getwd()
|
cwd, err := os.Getwd()
|
||||||
if err != nil {
|
check(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
out, err := proto.Marshal(&Msg{
|
out, err := proto.Marshal(&Msg{
|
||||||
Kind: Msg_START,
|
Kind: Msg_START,
|
||||||
Cwd: cwd,
|
Payload: &Msg_Start{
|
||||||
Argv: args,
|
Start: &StartMsg{
|
||||||
|
Cwd: cwd,
|
||||||
|
Argv: args,
|
||||||
|
},
|
||||||
|
},
|
||||||
})
|
})
|
||||||
if err != nil {
|
check(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
err = worker.SendBytes(out)
|
err = worker.SendBytes(out)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
os.Stderr.WriteString(err.Error())
|
os.Stderr.WriteString(err.Error())
|
||||||
|
|
2
main.ts
2
main.ts
|
@ -12,7 +12,7 @@ V8Worker2.recv((ab: ArrayBuffer) => {
|
||||||
const msg = pb.Msg.decode(new Uint8Array(ab));
|
const msg = pb.Msg.decode(new Uint8Array(ab));
|
||||||
switch (msg.kind) {
|
switch (msg.kind) {
|
||||||
case pb.Msg.MsgKind.START:
|
case pb.Msg.MsgKind.START:
|
||||||
start(msg.cwd, msg.argv);
|
start(msg.start.cwd, msg.start.argv);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
console.log("Unknown message", msg);
|
console.log("Unknown message", msg);
|
||||||
|
|
22
msg.proto
22
msg.proto
|
@ -7,14 +7,16 @@ message Msg {
|
||||||
READ_FILE_SYNC = 1;
|
READ_FILE_SYNC = 1;
|
||||||
DATA_RESPONSE = 2;
|
DATA_RESPONSE = 2;
|
||||||
EXIT = 3;
|
EXIT = 3;
|
||||||
|
COMPILE_OUTPUT = 4;
|
||||||
}
|
}
|
||||||
MsgKind kind = 10;
|
MsgKind kind = 10;
|
||||||
|
|
||||||
// START
|
oneof payload {
|
||||||
string cwd = 11;
|
StartMsg start = 90;
|
||||||
repeated string argv = 12;
|
CompileOutputMsg compile_output = 100;
|
||||||
|
}
|
||||||
|
|
||||||
// READ_FILE_SYNC
|
// READ_FILE_SYNC and MKDIRP
|
||||||
string path = 20;
|
string path = 20;
|
||||||
|
|
||||||
// DATA_RESPONSE
|
// DATA_RESPONSE
|
||||||
|
@ -24,3 +26,15 @@ message Msg {
|
||||||
// EXIT
|
// EXIT
|
||||||
int32 code = 40;
|
int32 code = 40;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// START
|
||||||
|
message StartMsg {
|
||||||
|
string cwd = 1;
|
||||||
|
repeated string argv = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
// WRITE_COMPILE_OUTPUT
|
||||||
|
message CompileOutputMsg {
|
||||||
|
string source = 1;
|
||||||
|
string filename = 2;
|
||||||
|
}
|
||||||
|
|
7
os.ts
7
os.ts
|
@ -11,6 +11,13 @@ export function exit(code = 0): void {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function compileOutput(source: string, filename: string): void {
|
||||||
|
sendMsgFromObject({
|
||||||
|
kind: pb.Msg.MsgKind.COMPILE_OUTPUT,
|
||||||
|
compileOutput: { source, filename }
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
export function readFileSync(filename: string): string {
|
export function readFileSync(filename: string): string {
|
||||||
const res = sendMsgFromObject({
|
const res = sendMsgFromObject({
|
||||||
kind: pb.Msg.MsgKind.READ_FILE_SYNC,
|
kind: pb.Msg.MsgKind.READ_FILE_SYNC,
|
||||||
|
|
|
@ -35,7 +35,7 @@
|
||||||
"no-debugger": true,
|
"no-debugger": true,
|
||||||
"no-default-export": true,
|
"no-default-export": true,
|
||||||
"no-inferrable-types": true,
|
"no-inferrable-types": true,
|
||||||
"no-namespace": [true, "allow-declarations"],
|
//"no-namespace": [true, "allow-declarations"],
|
||||||
"no-reference": true,
|
"no-reference": true,
|
||||||
"no-require-imports": true,
|
"no-require-imports": true,
|
||||||
"no-string-throw": true,
|
"no-string-throw": true,
|
||||||
|
|
7
util.ts
7
util.ts
|
@ -6,12 +6,13 @@
|
||||||
export const globalEval = eval;
|
export const globalEval = eval;
|
||||||
|
|
||||||
// A reference to the global object.
|
// A reference to the global object.
|
||||||
const _global = globalEval("this");
|
// TODO The underscore is because it's conflicting with @types/node.
|
||||||
|
export const _global = globalEval("this");
|
||||||
|
|
||||||
const print = V8Worker2.print;
|
const print = V8Worker2.print;
|
||||||
|
|
||||||
// To control internal logging output
|
// To control internal logging output
|
||||||
const debug = true;
|
const debug = false;
|
||||||
|
|
||||||
// Internal logging for deno. Use the "debug" variable above to control
|
// Internal logging for deno. Use the "debug" variable above to control
|
||||||
// output.
|
// output.
|
||||||
|
@ -49,6 +50,6 @@ function stringifyArgs(args: any[]): string {
|
||||||
|
|
||||||
export function assert(cond: boolean, msg = "") {
|
export function assert(cond: boolean, msg = "") {
|
||||||
if (!cond) {
|
if (!cond) {
|
||||||
throw Error("Assertion failed. " + msg);
|
throw Error("Assert fail. " + msg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue