mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-02 01:25:39 -05:00
* Merge from vscode 504f934659740e9d41501cad9f162b54d7745ad9 * delete unused folders * distro * Bump build node version * update chokidar * FIx hygiene errors * distro * Fix extension lint issues * Remove strict-vscode * Add copyright header exemptions * Bump vscode-extension-telemetry to fix webpacking issue with zone.js * distro * Fix failing tests (revert marked.js back to current one until we decide to update) * Skip searchmodel test * Fix mac build * temp debug script loading * Try disabling coverage * log error too * Revert "log error too" This reverts commit af0183e5d4ab458fdf44b88fbfab9908d090526f. * Revert "temp debug script loading" This reverts commit 3d687d541c76db2c5b55626c78ae448d3c25089c. * Add comments explaining coverage disabling * Fix ansi_up loading issue * Merge latest from ads * Use newer option * Fix compile * add debug logging warn * Always log stack * log more * undo debug * Update to use correct base path (+cleanup) * distro * fix compile errors * Remove strict-vscode * Fix sql editors not showing * Show db dropdown input & fix styling * Fix more info in gallery * Fix gallery asset requests * Delete unused workflow * Fix tapable resolutions for smoke test compile error * Fix smoke compile * Disable crash reporting * Disable interactive Co-authored-by: ADS Merger <karlb@microsoft.com>
59 lines
1.8 KiB
TypeScript
59 lines
1.8 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';
|
|
import { AuthProviderType } from '../github';
|
|
|
|
type LogLevel = 'Trace' | 'Info' | 'Error';
|
|
|
|
export class Log {
|
|
private output: vscode.OutputChannel;
|
|
|
|
constructor(private readonly type: AuthProviderType) {
|
|
const friendlyName = this.type === AuthProviderType.github ? 'GitHub' : 'GitHub Enterprise';
|
|
this.output = vscode.window.createOutputChannel(`${friendlyName} 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;
|
|
}
|