mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-01-21 01:25:37 -05:00
* Build breaks 1 * Build breaks * Build breaks * Build breaks * More build breaks * Build breaks (#2512) * Runtime breaks * Build breaks * Fix dialog location break * Update typescript * Fix ASAR break issue * Unit test breaks * Update distro * Fix breaks in ADO builds (#2513) * Bump to node 16 * Fix hygiene errors * Bump distro * Remove reference to node type * Delete vscode specific extension * Bump to node 16 in CI yaml * Skip integration tests in CI builds (while fixing) * yarn.lock update * Bump moment dependency in remote yarn * Fix drop-down chevron style * Bump to node 16 * Remove playwrite from ci.yaml * Skip building build scripts in hygine check
60 lines
1.7 KiB
TypeScript
60 lines
1.7 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import * as vscode from 'vscode';
|
|
|
|
type LogLevel = 'Trace' | 'Info' | 'Error';
|
|
|
|
class Log {
|
|
private output: vscode.OutputChannel;
|
|
|
|
constructor() {
|
|
this.output = vscode.window.createOutputChannel('Microsoft Authentication');
|
|
}
|
|
|
|
private data2String(data: any): string {
|
|
if (data instanceof Error) {
|
|
return data.stack || data.message;
|
|
}
|
|
if (data.success === false && data.message) {
|
|
return data.message;
|
|
}
|
|
return data.toString();
|
|
}
|
|
|
|
public trace(message: string, data?: any): void {
|
|
this.logLevel('Trace', message, data);
|
|
}
|
|
|
|
public info(message: string, data?: any): void {
|
|
this.logLevel('Info', message, data);
|
|
}
|
|
|
|
public error(message: string, data?: any): void {
|
|
this.logLevel('Error', message, data);
|
|
}
|
|
|
|
public logLevel(level: LogLevel, message: string, data?: any): void {
|
|
this.output.appendLine(`[${level} - ${this.now()}] ${message}`);
|
|
if (data) {
|
|
this.output.appendLine(this.data2String(data));
|
|
}
|
|
}
|
|
|
|
private now(): string {
|
|
const now = new Date();
|
|
return padLeft(now.getUTCHours() + '', 2, '0')
|
|
+ ':' + padLeft(now.getMinutes() + '', 2, '0')
|
|
+ ':' + padLeft(now.getUTCSeconds() + '', 2, '0') + '.' + now.getMilliseconds();
|
|
}
|
|
}
|
|
|
|
function padLeft(s: string, n: number, pad = ' ') {
|
|
return pad.repeat(Math.max(0, n - s.length)) + s;
|
|
}
|
|
|
|
const Logger = new Log();
|
|
export default Logger;
|