mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-04 01:25:38 -05:00
* Merge from vscode bead496a613e475819f89f08e9e882b841bc1fe8 * Bump distro * Upgrade GCC to 4.9 due to yarn install errors * Update build image * Fix bootstrap base url * Bump distro * Fix build errors * Update source map file * Disable checkbox for blocking migration issues (#15131) * disable checkbox for blocking issues * wip * disable checkbox fixes * fix strings * Remove duplicate tsec command * Default to off for tab color if settings not present * re-skip failing tests * Fix mocha error * Bump sqlite version & fix notebooks search view * Turn off esbuild warnings * Update esbuild log level * Fix overflowactionbar tests * Fix ts-ignore in dropdown tests * cleanup/fixes * Fix hygiene * Bundle in entire zone.js module * Remove extra constructor param * bump distro for web compile break * bump distro for web compile break v2 * Undo log level change * New distro * Fix integration test scripts * remove the "no yarn.lock changes" workflow * fix scripts v2 * Update unit test scripts * Ensure ads-kerberos2 updates in .vscodeignore * Try fix unit tests * Upload crash reports * remove nogpu * always upload crashes * Use bash script * Consolidate data/ext dir names * Create in tmp directory Co-authored-by: chlafreniere <hichise@gmail.com> Co-authored-by: Christopher Suh <chsuh@microsoft.com> Co-authored-by: chgagnon <chgagnon@microsoft.com>
150 lines
4.8 KiB
TypeScript
150 lines
4.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 { equals } from 'vs/base/common/arrays';
|
|
import { UriComponents } from 'vs/base/common/uri';
|
|
import { escapeIcons } from 'vs/base/common/iconLabels';
|
|
import { illegalArgument } from 'vs/base/common/errors';
|
|
|
|
export interface IMarkdownString {
|
|
readonly value: string;
|
|
readonly isTrusted?: boolean;
|
|
readonly supportThemeIcons?: boolean;
|
|
uris?: { [href: string]: UriComponents };
|
|
}
|
|
|
|
export const enum MarkdownStringTextNewlineStyle {
|
|
Paragraph = 0,
|
|
Break = 1,
|
|
}
|
|
|
|
export class MarkdownString implements IMarkdownString {
|
|
|
|
public value: string;
|
|
public isTrusted?: boolean;
|
|
public supportThemeIcons?: boolean;
|
|
|
|
constructor(
|
|
value: string = '',
|
|
isTrustedOrOptions: boolean | { isTrusted?: boolean, supportThemeIcons?: boolean } = false,
|
|
) {
|
|
this.value = value;
|
|
if (typeof this.value !== 'string') {
|
|
throw illegalArgument('value');
|
|
}
|
|
|
|
if (typeof isTrustedOrOptions === 'boolean') {
|
|
this.isTrusted = isTrustedOrOptions;
|
|
this.supportThemeIcons = false;
|
|
}
|
|
else {
|
|
this.isTrusted = isTrustedOrOptions.isTrusted ?? undefined;
|
|
this.supportThemeIcons = isTrustedOrOptions.supportThemeIcons ?? false;
|
|
}
|
|
}
|
|
|
|
appendText(value: string, newlineStyle: MarkdownStringTextNewlineStyle = MarkdownStringTextNewlineStyle.Paragraph): MarkdownString {
|
|
this.value += escapeMarkdownSyntaxTokens(this.supportThemeIcons ? escapeIcons(value) : value)
|
|
.replace(/([ \t]+)/g, (_match, g1) => ' '.repeat(g1.length))
|
|
.replace(/^>/gm, '\\>')
|
|
.replace(/\n/g, newlineStyle === MarkdownStringTextNewlineStyle.Break ? '\\\n' : '\n\n');
|
|
|
|
return this;
|
|
}
|
|
|
|
appendMarkdown(value: string): MarkdownString {
|
|
this.value += value;
|
|
return this;
|
|
}
|
|
|
|
appendCodeblock(langId: string, code: string): MarkdownString {
|
|
this.value += '\n```';
|
|
this.value += langId;
|
|
this.value += '\n';
|
|
this.value += code;
|
|
this.value += '\n```\n';
|
|
return this;
|
|
}
|
|
}
|
|
|
|
export function isEmptyMarkdownString(oneOrMany: IMarkdownString | IMarkdownString[] | null | undefined): boolean {
|
|
if (isMarkdownString(oneOrMany)) {
|
|
return !oneOrMany.value;
|
|
} else if (Array.isArray(oneOrMany)) {
|
|
return oneOrMany.every(isEmptyMarkdownString);
|
|
} else {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
export function isMarkdownString(thing: any): thing is IMarkdownString {
|
|
if (thing instanceof MarkdownString) {
|
|
return true;
|
|
} else if (thing && typeof thing === 'object') {
|
|
return typeof (<IMarkdownString>thing).value === 'string'
|
|
&& (typeof (<IMarkdownString>thing).isTrusted === 'boolean' || (<IMarkdownString>thing).isTrusted === undefined)
|
|
&& (typeof (<IMarkdownString>thing).supportThemeIcons === 'boolean' || (<IMarkdownString>thing).supportThemeIcons === undefined);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
export function markedStringsEquals(a: IMarkdownString | IMarkdownString[], b: IMarkdownString | IMarkdownString[]): boolean {
|
|
if (!a && !b) {
|
|
return true;
|
|
} else if (!a || !b) {
|
|
return false;
|
|
} else if (Array.isArray(a) && Array.isArray(b)) {
|
|
return equals(a, b, markdownStringEqual);
|
|
} else if (isMarkdownString(a) && isMarkdownString(b)) {
|
|
return markdownStringEqual(a, b);
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
function markdownStringEqual(a: IMarkdownString, b: IMarkdownString): boolean {
|
|
if (a === b) {
|
|
return true;
|
|
} else if (!a || !b) {
|
|
return false;
|
|
} else {
|
|
return a.value === b.value && a.isTrusted === b.isTrusted && a.supportThemeIcons === b.supportThemeIcons;
|
|
}
|
|
}
|
|
|
|
export function escapeMarkdownSyntaxTokens(text: string): string {
|
|
// escape markdown syntax tokens: http://daringfireball.net/projects/markdown/syntax#backslash
|
|
return text.replace(/[\\`*_{}[\]()#+\-.!]/g, '\\$&');
|
|
}
|
|
|
|
export function removeMarkdownEscapes(text: string): string {
|
|
if (!text) {
|
|
return text;
|
|
}
|
|
return text.replace(/\\([\\`*_{}[\]()#+\-.!])/g, '$1');
|
|
}
|
|
|
|
export function parseHrefAndDimensions(href: string): { href: string, dimensions: string[] } {
|
|
const dimensions: string[] = [];
|
|
const splitted = href.split('|').map(s => s.trim());
|
|
href = splitted[0];
|
|
const parameters = splitted[1];
|
|
if (parameters) {
|
|
const heightFromParams = /height=(\d+)/.exec(parameters);
|
|
const widthFromParams = /width=(\d+)/.exec(parameters);
|
|
const height = heightFromParams ? heightFromParams[1] : '';
|
|
const width = widthFromParams ? widthFromParams[1] : '';
|
|
const widthIsFinite = isFinite(parseInt(width));
|
|
const heightIsFinite = isFinite(parseInt(height));
|
|
if (widthIsFinite) {
|
|
dimensions.push(`width="${width}"`);
|
|
}
|
|
if (heightIsFinite) {
|
|
dimensions.push(`height="${height}"`);
|
|
}
|
|
}
|
|
return { href, dimensions };
|
|
}
|