mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-01-21 01:25:37 -05:00
* Fix initial build breaks from 1.67 merge (#2514) * Update yarn lock files * Update build scripts * Fix tsconfig * Build breaks * WIP * Update yarn lock files * Misc breaks * Updates to package.json * Breaks * Update yarn * Fix breaks * Breaks * Build breaks * Breaks * Breaks * Breaks * Breaks * Breaks * Missing file * Breaks * Breaks * Breaks * Breaks * Breaks * Fix several runtime breaks (#2515) * Missing files * Runtime breaks * Fix proxy ordering issue * Remove commented code * Fix breaks with opening query editor * Fix post merge break * Updates related to setup build and other breaks (#2516) * Fix bundle build issues * Update distro * Fix distro merge and update build JS files * Disable pipeline steps * Remove stats call * Update license name * Make new RPM dependencies a warning * Fix extension manager version checks * Update JS file * Fix a few runtime breaks * Fixes * Fix runtime issues * Fix build breaks * Update notebook tests (part 1) * Fix broken tests * Linting errors * Fix hygiene * Disable lint rules * Bump distro * Turn off smoke tests * Disable integration tests * Remove failing "activate" test * Remove failed test assertion * Disable other broken test * Disable query history tests * Disable extension unit tests * Disable failing tasks
84 lines
2.0 KiB
TypeScript
84 lines
2.0 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 { lazy } from './util/lazy';
|
|
|
|
enum Trace {
|
|
Off,
|
|
Verbose
|
|
}
|
|
|
|
namespace Trace {
|
|
export function fromString(value: string): Trace {
|
|
value = value.toLowerCase();
|
|
switch (value) {
|
|
case 'off':
|
|
return Trace.Off;
|
|
case 'verbose':
|
|
return Trace.Verbose;
|
|
default:
|
|
return Trace.Off;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
function isString(value: any): value is string {
|
|
return Object.prototype.toString.call(value) === '[object String]';
|
|
}
|
|
|
|
export class Logger {
|
|
private trace?: Trace;
|
|
|
|
private readonly outputChannel = lazy(() => vscode.window.createOutputChannel('Markdown'));
|
|
|
|
constructor() {
|
|
this.updateConfiguration();
|
|
}
|
|
|
|
public log(message: string, data?: any): void {
|
|
if (this.trace === Trace.Verbose) {
|
|
this.appendLine(`[Log - ${this.now()}] ${message}`);
|
|
if (data) {
|
|
this.appendLine(Logger.data2String(data));
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
private now(): string {
|
|
const now = new Date();
|
|
return String(now.getUTCHours()).padStart(2, '0')
|
|
+ ':' + String(now.getMinutes()).padStart(2, '0')
|
|
+ ':' + String(now.getUTCSeconds()).padStart(2, '0') + '.' + now.getMilliseconds();
|
|
}
|
|
|
|
public updateConfiguration() {
|
|
this.trace = this.readTrace();
|
|
}
|
|
|
|
private appendLine(value: string) {
|
|
return this.outputChannel.value.appendLine(value);
|
|
}
|
|
|
|
private readTrace(): Trace {
|
|
return Trace.fromString(vscode.workspace.getConfiguration().get<string>('markdown.trace', 'off'));
|
|
}
|
|
|
|
private static data2String(data: any): string {
|
|
if (data instanceof Error) {
|
|
if (isString(data.stack)) {
|
|
return data.stack;
|
|
}
|
|
return (data as Error).message;
|
|
}
|
|
if (isString(data)) {
|
|
return data;
|
|
}
|
|
return JSON.stringify(data, undefined, 2);
|
|
}
|
|
}
|