2020-02-15 11:39:45 +00:00
|
|
|
import { SourceMapBuilder } from 'source-map-builder'
|
|
|
|
|
|
|
|
const Arrays = Java.type('java.util.Arrays');
|
|
|
|
const Level = Java.type('java.util.logging.Level');
|
|
|
|
const JavaString = Java.type('java.lang.String');
|
|
|
|
const Files = Java.type('java.nio.file.Files');
|
|
|
|
const Paths = Java.type('java.nio.file.Paths');
|
|
|
|
const ignoreLogPrefix = ['java.', 'net.minecraft.', 'org.bukkit.', 'jdk.nashorn.', 'io.netty.', 'org.spongepowered.'];
|
2020-01-15 08:48:18 +00:00
|
|
|
|
|
|
|
enum LogLevel {
|
|
|
|
ALL,
|
|
|
|
TRACE,
|
|
|
|
DEBUG,
|
|
|
|
INFO,
|
|
|
|
WARN,
|
|
|
|
ERROR,
|
|
|
|
FATAL,
|
|
|
|
OFF
|
|
|
|
}
|
2019-09-07 04:23:15 +00:00
|
|
|
|
|
|
|
export class MiaoScriptConsole implements Console {
|
|
|
|
Console: NodeJS.ConsoleConstructor;
|
|
|
|
|
2020-02-15 11:39:45 +00:00
|
|
|
private sourceMaps: { [key: string]: SourceMapBuilder } = {};
|
2019-09-07 04:23:15 +00:00
|
|
|
private _name: string = '';
|
2020-01-31 18:44:23 +00:00
|
|
|
private _level: LogLevel = LogLevel.INFO;
|
2019-09-07 04:23:15 +00:00
|
|
|
|
2019-09-10 09:21:00 +00:00
|
|
|
protected logger: any;
|
2019-09-07 04:23:15 +00:00
|
|
|
protected prefix: string = '§6[§bMiaoScript§6]§r ';
|
|
|
|
|
2019-09-10 09:21:00 +00:00
|
|
|
constructor(name?: string) {
|
|
|
|
this.name = name;
|
2019-09-07 04:23:15 +00:00
|
|
|
this.logger = global.logger;
|
2020-01-31 18:44:23 +00:00
|
|
|
if (global.debug) {
|
|
|
|
this._level = LogLevel.DEBUG
|
|
|
|
}
|
|
|
|
if (global.level?.toUpperCase() === "TRACE") {
|
|
|
|
this._level = LogLevel.TRACE
|
|
|
|
}
|
2019-09-07 04:23:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
get name() {
|
|
|
|
return this._name;
|
|
|
|
}
|
|
|
|
|
|
|
|
set name(name: string) {
|
|
|
|
if (name) {
|
|
|
|
this._name = `[${name}] `;
|
|
|
|
// noinspection JSUnusedGlobalSymbols
|
|
|
|
this.prefix = `§6[§cMS§6][§b${name}§6]§r `;
|
|
|
|
}
|
|
|
|
}
|
2020-01-15 08:48:18 +00:00
|
|
|
log(...args: any[]): void {
|
2019-09-07 04:23:15 +00:00
|
|
|
this.logger.info(this.name + args.join(' '));
|
|
|
|
}
|
2020-01-15 08:48:18 +00:00
|
|
|
info(...args: any[]) {
|
2019-09-07 04:23:15 +00:00
|
|
|
this.logger.info(this.name + args.join(' '));
|
2020-01-15 08:48:18 +00:00
|
|
|
}
|
|
|
|
warn(...args: any[]) {
|
2019-09-07 04:23:15 +00:00
|
|
|
this.logger.warning(this.name + args.join(' '));
|
2020-01-15 08:48:18 +00:00
|
|
|
}
|
|
|
|
error(...args: any[]) {
|
2019-09-07 04:23:15 +00:00
|
|
|
this.logger.log(Level.SEVERE, this.name + args.join(' '));
|
2020-01-15 08:48:18 +00:00
|
|
|
}
|
|
|
|
debug(...args: any[]) {
|
2019-09-07 04:23:15 +00:00
|
|
|
if (global.debug) {
|
|
|
|
this.logger.info(this.name + '[DEBUG] ' + args.join(' '));
|
|
|
|
}
|
2020-01-15 08:48:18 +00:00
|
|
|
}
|
|
|
|
trace(...args: any[]): void {
|
|
|
|
if (this._level <= LogLevel.TRACE) {
|
|
|
|
this.logger.info(this.name + '[TRACE] ' + args.join(' '));
|
|
|
|
}
|
|
|
|
}
|
2019-09-07 04:23:15 +00:00
|
|
|
sender(...args) {
|
|
|
|
this.info(args)
|
|
|
|
}
|
|
|
|
console(...args) {
|
|
|
|
this.info(args)
|
|
|
|
}
|
|
|
|
object(obj) {
|
|
|
|
for (var i in obj) {
|
|
|
|
this.logger(i, '=>', obj[i])
|
|
|
|
}
|
2020-01-15 08:48:18 +00:00
|
|
|
}
|
2019-09-07 04:23:15 +00:00
|
|
|
ex(ex: Error) {
|
|
|
|
this.stack(ex).forEach(line => this.console(line))
|
2020-01-15 08:48:18 +00:00
|
|
|
}
|
2020-02-19 11:00:26 +00:00
|
|
|
readSourceMap(fileName: string, lineNumber: number) {
|
|
|
|
try {
|
|
|
|
if (fileName.endsWith('js')) {
|
|
|
|
var file = Paths.get(fileName + '.map');
|
|
|
|
if (!this.sourceMaps[fileName]) {
|
|
|
|
if (file.toFile().exists()) {
|
|
|
|
var sourceMapObj = JSON.parse(new JavaString(Files.readAllBytes(file), "UTF-8"))
|
|
|
|
this.sourceMaps[fileName] = new SourceMapBuilder(sourceMapObj)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (this.sourceMaps[fileName]) {
|
|
|
|
var sourceMapping = this.sourceMaps[fileName].getSource(lineNumber, lineNumber);
|
|
|
|
if (sourceMapping) {
|
|
|
|
fileName = fileName.replace(".js", ".ts");
|
|
|
|
lineNumber = sourceMapping.mapping.sourceLine;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
console.debug('search source map', fileName, 'line', lineNumber, 'error:', error)
|
|
|
|
}
|
|
|
|
return {
|
|
|
|
fileName,
|
|
|
|
lineNumber
|
|
|
|
}
|
|
|
|
}
|
2019-09-21 06:58:00 +00:00
|
|
|
stack(ex: Error): string[] {
|
2019-09-07 04:23:15 +00:00
|
|
|
var stack = ex.getStackTrace();
|
|
|
|
var cache = ['§4' + ex];
|
2019-09-21 06:58:00 +00:00
|
|
|
//@ts-ignore
|
2019-09-07 04:23:15 +00:00
|
|
|
if (stack.class) {
|
|
|
|
stack = Arrays.asList(stack)
|
|
|
|
}
|
2020-02-15 11:39:45 +00:00
|
|
|
stack.forEach(trace => {
|
2019-09-07 04:23:15 +00:00
|
|
|
if (trace.className.startsWith('<')) {
|
2020-02-19 11:00:26 +00:00
|
|
|
var { fileName, lineNumber } = this.readSourceMap(trace.fileName, trace.lineNumber)
|
2019-09-10 09:21:00 +00:00
|
|
|
if (fileName.startsWith(root)) { fileName = fileName.split(root)[1] }
|
2020-02-15 11:39:45 +00:00
|
|
|
cache.push(` §e->§c ${fileName} => §4${trace.methodName}:${lineNumber}`)
|
2019-09-07 04:23:15 +00:00
|
|
|
} else {
|
|
|
|
var className = trace.className;
|
2020-02-19 11:00:26 +00:00
|
|
|
var fileName = trace.fileName as string;
|
2019-09-07 04:23:15 +00:00
|
|
|
if (className.startsWith('jdk.nashorn.internal.scripts')) {
|
|
|
|
className = className.substr(className.lastIndexOf('$') + 1)
|
2020-02-19 11:00:26 +00:00
|
|
|
var { fileName, lineNumber } = this.readSourceMap(trace.fileName, trace.lineNumber)
|
2019-09-21 06:58:00 +00:00
|
|
|
if (fileName.startsWith(root)) { fileName = fileName.split(root)[1] }
|
2019-09-07 04:23:15 +00:00
|
|
|
} else {
|
|
|
|
for (var prefix in ignoreLogPrefix) {
|
|
|
|
if (className.startsWith(ignoreLogPrefix[prefix])) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-09-21 06:58:00 +00:00
|
|
|
cache.push(` §e->§c ${className}.${trace.methodName}(§4${fileName}:${trace.lineNumber}§c)`);
|
2019-09-07 04:23:15 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
return cache;
|
|
|
|
}
|
|
|
|
assert(value: any, message?: string, ...optionalParams: any[]): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
clear(): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
count(label?: string): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
countReset(label?: string): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
dir(obj: any, options?: NodeJS.InspectOptions): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
dirxml(...data: any[]): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
group(...label: any[]): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
groupCollapsed(...label: any[]): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
groupEnd(): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
table(tabularData: any, properties?: string[]): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
time(label?: string): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
timeEnd(label?: string): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
timeLog(label?: string, ...data: any[]): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
markTimeline(label?: string): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
profile(label?: string): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
profileEnd(label?: string): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
timeStamp(label?: string): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
timeline(label?: string): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
timelineEnd(label?: string): void {
|
|
|
|
throw new Error("Method not implemented.");
|
|
|
|
}
|
|
|
|
}
|