@inst/vscode-bin-darwin
Version:
BINARY ONLY - VSCode binary deployment for macOS
158 lines • 19.6 kB
JavaScript
/*---------------------------------------------------------
* Copyright (C) Microsoft Corporation. All rights reserved.
*--------------------------------------------------------*/
"use strict";
var __extends = (this && this.__extends) || function (d, b) {
for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
var fs = require('fs');
var debugSession_1 = require('./debugSession');
(function (LogLevel) {
LogLevel[LogLevel["Verbose"] = 0] = "Verbose";
LogLevel[LogLevel["Log"] = 1] = "Log";
LogLevel[LogLevel["Warn"] = 2] = "Warn";
LogLevel[LogLevel["Error"] = 3] = "Error";
LogLevel[LogLevel["Stop"] = 4] = "Stop";
})(exports.LogLevel || (exports.LogLevel = {}));
var LogLevel = exports.LogLevel;
var Logger = (function () {
function Logger() {
this._pendingLogQ = [];
}
Logger.prototype.log = function (msg, level) {
if (level === void 0) { level = LogLevel.Log; }
msg = msg + '\n';
this._write(msg, level);
};
Logger.prototype.verbose = function (msg) {
this.log(msg, LogLevel.Verbose);
};
Logger.prototype.warn = function (msg) {
this.log(msg, LogLevel.Warn);
};
Logger.prototype.error = function (msg) {
this.log(msg, LogLevel.Error);
};
/**
* `log` adds a newline, `write` doesn't
*/
Logger.prototype._write = function (msg, level) {
if (level === void 0) { level = LogLevel.Log; }
// [null, undefined] => string
msg = msg + '';
if (this._pendingLogQ) {
this._pendingLogQ.push({ msg: msg, level: level });
}
else {
this._currentLogger.log(msg, level);
}
};
/**
* Set the logger's minimum level to log in the console, and whether to log to the file. Log messages are queued before this is
* called the first time, because minLogLevel defaults to Warn.
*/
Logger.prototype.setup = function (consoleMinLogLevel, logToFile) {
var _this = this;
if (this._currentLogger) {
this._currentLogger.setup(consoleMinLogLevel, logToFile);
// Now that we have a minimum logLevel, we can clear out the queue of pending messages
if (this._pendingLogQ) {
var logQ = this._pendingLogQ;
this._pendingLogQ = null;
logQ.forEach(function (item) { return _this._write(item.msg, item.level); });
}
}
};
Logger.prototype.init = function (logCallback, logFilePath, logToConsole) {
// Re-init, create new global Logger
this._pendingLogQ = this._pendingLogQ || [];
this._currentLogger = new InternalLogger(logCallback, logFilePath, logToConsole);
if (logFilePath) {
var d = new Date();
var timestamp = d.toLocaleTimeString() + ', ' + d.toLocaleDateString();
this.verbose(timestamp);
}
};
return Logger;
}());
exports.Logger = Logger;
exports.logger = new Logger();
/**
* Manages logging, whether to console.log, file, or VS Code console.
* Encapsulates the state specific to each logging session
*/
var InternalLogger = (function () {
function InternalLogger(logCallback, logFilePath, isServer) {
this._logCallback = logCallback;
this._logFilePath = logFilePath;
this._logToConsole = isServer;
this._minLogLevel = LogLevel.Warn;
}
InternalLogger.prototype.setup = function (consoleMinLogLevel, logToFile) {
var _this = this;
this._minLogLevel = consoleMinLogLevel;
// Open a log file in the specified location. Overwritten on each run.
if (logToFile) {
this.log("Verbose logs are written to:\n", LogLevel.Warn);
this.log(this._logFilePath + '\n', LogLevel.Warn);
this._logFileStream = fs.createWriteStream(this._logFilePath);
this._logFileStream.on('error', function (e) {
_this.sendLog("Error involving log file at path: " + _this._logFilePath + ". Error: " + e.toString(), LogLevel.Error);
});
}
};
InternalLogger.prototype.log = function (msg, level) {
if (this._minLogLevel === LogLevel.Stop) {
return;
}
if (level >= this._minLogLevel) {
this.sendLog(msg, level);
}
if (this._logToConsole) {
var logFn = level === LogLevel.Error ? console.error :
level === LogLevel.Warn ? console.warn :
console.log;
logFn(trimLastNewline(msg));
}
// If an error, prepend with '[Error]'
if (level === LogLevel.Error) {
msg = "[" + LogLevel[level] + "] " + msg;
}
if (this._logFileStream) {
this._logFileStream.write(msg);
}
};
InternalLogger.prototype.sendLog = function (msg, level) {
// Truncate long messages, they can hang VS Code
if (msg.length > 1500) {
var endsInNewline = !!msg.match(/(\n|\r\n)$/);
msg = msg.substr(0, 1500) + '[...]';
if (endsInNewline) {
msg = msg + '\n';
}
}
if (this._logCallback) {
var event_1 = new LogOutputEvent(msg, level);
this._logCallback(event_1);
}
};
return InternalLogger;
}());
var LogOutputEvent = (function (_super) {
__extends(LogOutputEvent, _super);
function LogOutputEvent(msg, level) {
var category = level === LogLevel.Error ? 'stderr' :
level === LogLevel.Warn ? 'console' :
'stdout';
_super.call(this, msg, category);
}
return LogOutputEvent;
}(debugSession_1.OutputEvent));
exports.LogOutputEvent = LogOutputEvent;
function trimLastNewline(str) {
return str.replace(/(\n|\r\n)$/, '');
}
exports.trimLastNewline = trimLastNewline;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------\n * Copyright (C) Microsoft Corporation. All rights reserved.\n *--------------------------------------------------------*/\n\nimport * as fs from 'fs';\nimport {OutputEvent} from './debugSession';\n\nexport enum LogLevel {\n\tVerbose = 0,\n\tLog = 1,\n\tWarn = 2,\n\tError = 3,\n\tStop = 4\n}\n\nexport type ILogCallback = (outputEvent: OutputEvent) => void;\n\ninterface ILogItem {\n\tmsg: string;\n\tlevel: LogLevel;\n}\n\nexport interface ILogger {\n\tlog(msg: string, level?: LogLevel): void;\n\tverbose(msg: string): void;\n\twarn(msg: string): void;\n\terror(msg: string): void;\n}\n\nexport class Logger {\n\tprivate _currentLogger: InternalLogger;\n\tprivate _pendingLogQ: ILogItem[] = [];\n\n\tlog(msg: string, level = LogLevel.Log): void {\n\t\tmsg = msg + '\\n';\n\t\tthis._write(msg, level);\n\t}\n\n\tverbose(msg: string): void {\n\t\tthis.log(msg, LogLevel.Verbose);\n\t}\n\n\twarn(msg: string): void {\n\t\tthis.log(msg, LogLevel.Warn);\n\t}\n\n\terror(msg: string): void {\n\t\tthis.log(msg, LogLevel.Error);\n\t}\n\n\t/**\n\t * `log` adds a newline, `write` doesn't\n\t */\n\tprivate _write(msg: string, level = LogLevel.Log): void {\n\t\t// [null, undefined] => string\n\t\tmsg = msg + '';\n\t\tif (this._pendingLogQ) {\n\t\t\tthis._pendingLogQ.push({ msg, level });\n\t\t} else {\n\t\t\tthis._currentLogger.log(msg, level);\n\t\t}\n\t}\n\n\t/**\n\t * Set the logger's minimum level to log in the console, and whether to log to the file. Log messages are queued before this is\n\t * called the first time, because minLogLevel defaults to Warn.\n\t */\n\tsetup(consoleMinLogLevel: LogLevel, logToFile: boolean): void {\n\t\tif (this._currentLogger) {\n\t\t\tthis._currentLogger.setup(consoleMinLogLevel, logToFile);\n\n\t\t\t// Now that we have a minimum logLevel, we can clear out the queue of pending messages\n\t\t\tif (this._pendingLogQ) {\n\t\t\t\tconst logQ = this._pendingLogQ;\n\t\t\t\tthis._pendingLogQ = null;\n\t\t\t\tlogQ.forEach(item => this._write(item.msg, item.level));\n\t\t\t}\n\t\t}\n\t}\n\n\tinit(logCallback: ILogCallback, logFilePath?: string, logToConsole?: boolean): void {\n\t\t// Re-init, create new global Logger\n\t\tthis._pendingLogQ = this._pendingLogQ || [];\n\t\tthis._currentLogger = new InternalLogger(logCallback, logFilePath, logToConsole);\n\t\tif (logFilePath) {\n\t\t\tconst d = new Date();\n\t\t\tconst timestamp = d.toLocaleTimeString() + ', ' + d.toLocaleDateString();\n\t\t\tthis.verbose(timestamp);\n\t\t}\n\t}\n}\n\nexport const logger = new Logger();\n\n/**\n * Manages logging, whether to console.log, file, or VS Code console.\n * Encapsulates the state specific to each logging session\n */\nclass InternalLogger {\n\t/** The path of the log file */\n\tprivate _logFilePath: string;\n\n\tprivate _minLogLevel: LogLevel;\n\tprivate _logToConsole: boolean;\n\n\t/** Log info that meets minLogLevel is sent to this callback. */\n\tprivate _logCallback: ILogCallback;\n\n\t/** Write steam for log file */\n\tprivate _logFileStream: fs.WriteStream;\n\n\tconstructor(logCallback: ILogCallback, logFilePath?: string, isServer?: boolean) {\n\t\tthis._logCallback = logCallback;\n\t\tthis._logFilePath = logFilePath;\n\t\tthis._logToConsole = isServer;\n\n\t\tthis._minLogLevel = LogLevel.Warn;\n\t}\n\n\tpublic setup(consoleMinLogLevel: LogLevel, logToFile: boolean): void {\n\t\tthis._minLogLevel = consoleMinLogLevel;\n\n\t\t// Open a log file in the specified location. Overwritten on each run.\n\t\tif (logToFile) {\n\t\t\tthis.log(`Verbose logs are written to:\\n`, LogLevel.Warn);\n\t\t\tthis.log(this._logFilePath + '\\n', LogLevel.Warn);\n\n\t\t\tthis._logFileStream = fs.createWriteStream(this._logFilePath);\n\t\t\tthis._logFileStream.on('error', e => {\n\t\t\t\tthis.sendLog(`Error involving log file at path: ${this._logFilePath}. Error: ${e.toString()}`, LogLevel.Error);\n\t\t\t});\n\t\t}\n\t}\n\n\tpublic log(msg: string, level: LogLevel): void {\n\n\t\tif (this._minLogLevel === LogLevel.Stop) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (level >= this._minLogLevel) {\n\t\t\tthis.sendLog(msg, level);\n\t\t}\n\n\t\tif (this._logToConsole) {\n\t\t\tconst logFn =\n\t\t\t\tlevel === LogLevel.Error ? console.error :\n\t\t\t\tlevel === LogLevel.Warn ? console.warn :\n\t\t\t\tconsole.log;\n\t\t\tlogFn(trimLastNewline(msg));\n\t\t}\n\n\t\t// If an error, prepend with '[Error]'\n\t\tif (level === LogLevel.Error) {\n\t\t\tmsg = `[${LogLevel[level]}] ${msg}`;\n\t\t}\n\n\t\tif (this._logFileStream) {\n\t\t\tthis._logFileStream.write(msg);\n\t\t}\n\t}\n\n\tprivate sendLog(msg: string, level: LogLevel): void {\n\t\t// Truncate long messages, they can hang VS Code\n\t\tif (msg.length > 1500) {\n\t\t\tconst endsInNewline = !!msg.match(/(\\n|\\r\\n)$/);\n\t\t\tmsg = msg.substr(0, 1500) + '[...]';\n\t\t\tif (endsInNewline) {\n\t\t\t\tmsg = msg + '\\n';\n\t\t\t}\n\t\t}\n\n\t\tif (this._logCallback) {\n\t\t\tconst event = new LogOutputEvent(msg, level);\n\t\t\tthis._logCallback(event);\n\t\t}\n\t}\n}\n\nexport class LogOutputEvent extends OutputEvent {\n\tconstructor(msg: string, level: LogLevel) {\n\t\tconst category =\n\t\t\tlevel === LogLevel.Error ? 'stderr' :\n\t\t\tlevel === LogLevel.Warn ? 'console' :\n\t\t\t'stdout';\n\t\tsuper(msg, category);\n\t}\n}\n\nexport function trimLastNewline(str: string): string {\n\treturn str.replace(/(\\n|\\r\\n)$/, '');\n}\n"]}