vscode/src/vs/workbench/contrib/notebook/common/notebookCommon.ts

887 lines
24 KiB
TypeScript

/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
import { CancellationToken } from 'vs/base/common/cancellation';
import { IDiffResult, ISequence } from 'vs/base/common/diff/diff';
import { Event } from 'vs/base/common/event';
import * as glob from 'vs/base/common/glob';
import { Schemas } from 'vs/base/common/network';
import { basename } from 'vs/base/common/path';
import { isWindows } from 'vs/base/common/platform';
import { ISplice } from 'vs/base/common/sequence';
import { URI, UriComponents } from 'vs/base/common/uri';
import * as editorCommon from 'vs/editor/common/editorCommon';
import { Command } from 'vs/editor/common/modes';
import { IAccessibilityInformation } from 'vs/platform/accessibility/common/accessibility';
import { RawContextKey } from 'vs/platform/contextkey/common/contextkey';
import { IEditorModel } from 'vs/platform/editor/common/editor';
import { ExtensionIdentifier } from 'vs/platform/extensions/common/extensions';
import { ThemeColor } from 'vs/platform/theme/common/themeService';
import { IEditorInput, IRevertOptions, ISaveOptions } from 'vs/workbench/common/editor';
import { NotebookTextModel } from 'vs/workbench/contrib/notebook/common/model/notebookTextModel';
import { ICellRange } from 'vs/workbench/contrib/notebook/common/notebookRange';
import { IWorkingCopyBackupMeta } from 'vs/workbench/services/workingCopy/common/workingCopy';
export enum CellKind {
Markup = 1,
Code = 2
}
export const NOTEBOOK_DISPLAY_ORDER = [
'application/json',
'application/javascript',
'text/html',
'image/svg+xml',
'text/markdown',
'image/png',
'image/jpeg',
'text/plain'
];
export const ACCESSIBLE_NOTEBOOK_DISPLAY_ORDER = [
'text/markdown',
'application/json',
'text/plain',
'text/html',
'image/svg+xml',
'image/png',
'image/jpeg',
];
export const BUILTIN_RENDERER_ID = '_builtin';
export const RENDERER_NOT_AVAILABLE = '_notAvailable';
export enum NotebookRunState {
Running = 1,
Idle = 2
}
export const notebookDocumentMetadataDefaults: Required<NotebookDocumentMetadata> = {
custom: {},
};
export interface NotebookDocumentMetadata {
custom?: { [key: string]: unknown };
[key: string]: unknown;
}
export enum NotebookCellExecutionState {
Idle = 1,
Pending = 2,
Executing = 3,
}
export interface INotebookCellPreviousExecutionResult {
executionOrder?: number;
success?: boolean;
duration?: number;
}
export interface NotebookCellMetadata {
executionOrder?: number;
lastRunSuccess?: boolean;
runState?: NotebookCellExecutionState;
runStartTime?: number;
runStartTimeAdjustment?: number;
runEndTime?: number;
inputCollapsed?: boolean;
outputCollapsed?: boolean;
/**
* custom metadata
*/
[key: string]: unknown;
}
export type TransientCellMetadata = { [K in keyof NotebookCellMetadata]?: boolean };
export type TransientDocumentMetadata = { [K in keyof NotebookDocumentMetadata]?: boolean };
export interface TransientOptions {
transientOutputs: boolean;
transientCellMetadata: TransientCellMetadata;
transientDocumentMetadata: TransientDocumentMetadata;
}
export interface INotebookMimeTypeSelector {
mimeTypes?: string[];
}
/**
* Passed to INotebookRendererInfo.matches when the notebook is initially
* loaded before the kernel is known.
*/
export const AnyRendererApi = Symbol('AnyRendererApi');
/** Note: enum values are used for sorting */
export const enum NotebookRendererMatch {
/** Renderer has a hard dependency on an available kernel */
WithHardKernelDependency = 0,
/** Renderer works better with an available kernel */
WithOptionalKernelDependency = 1,
/** Renderer is kernel-agnostic */
Pure = 2,
/** Renderer is for a different mimeType or has a hard dependency which is unsatisfied */
Never = 3,
}
export interface INotebookRendererInfo {
id: string;
displayName: string;
entrypoint: URI;
preloads: ReadonlyArray<URI>;
extensionLocation: URI;
extensionId: ExtensionIdentifier;
readonly mimeTypes: readonly string[];
readonly dependencies: readonly string[];
matchesWithoutKernel(mimeType: string): NotebookRendererMatch;
matches(mimeType: string, kernelProvides: ReadonlyArray<string>): NotebookRendererMatch;
}
export interface NotebookCellOutputMetadata {
/**
* Additional attributes of a cell metadata.
*/
custom?: { [key: string]: unknown };
}
export interface IOrderedMimeType {
mimeType: string;
rendererId: string;
isTrusted: boolean;
}
export interface IOutputItemDto {
readonly mime: string;
readonly value: unknown;
readonly metadata?: Record<string, unknown>;
}
export interface IOutputDto {
outputs: IOutputItemDto[];
outputId: string;
metadata?: Record<string, unknown>;
}
export interface ICellOutput {
outputs: IOutputItemDto[];
// metadata?: NotebookCellOutsputMetadata;
outputId: string;
onDidChangeData: Event<void>;
replaceData(items: IOutputItemDto[]): void;
appendData(items: IOutputItemDto[]): void;
}
export interface CellMetadataChangedEvent {
readonly runStateChanged?: boolean;
}
export interface ICell {
readonly uri: URI;
handle: number;
language: string;
cellKind: CellKind;
outputs: ICellOutput[];
metadata?: NotebookCellMetadata;
onDidChangeOutputs?: Event<NotebookCellOutputsSplice[]>;
onDidChangeLanguage: Event<string>;
onDidChangeMetadata: Event<CellMetadataChangedEvent>;
}
export interface INotebookTextModel {
readonly viewType: string;
metadata: NotebookDocumentMetadata
readonly uri: URI;
readonly versionId: number;
readonly cells: readonly ICell[];
onWillDispose: Event<void>;
}
export type NotebookCellTextModelSplice<T> = [
start: number,
deleteCount: number,
newItems: T[]
];
export type NotebookCellOutputsSplice = [
start: number /* start */,
deleteCount: number /* delete count */,
newOutputs: ICellOutput[]
];
export interface IMainCellDto {
handle: number;
uri: UriComponents,
source: string[];
eol: string;
language: string;
cellKind: CellKind;
outputs: IOutputDto[];
metadata?: NotebookCellMetadata;
}
export type NotebookCellsSplice2 = [
start: number,
deleteCount: number,
newItems: IMainCellDto[]
];
export enum NotebookCellsChangeType {
ModelChange = 1,
Move = 2,
CellClearOutput = 3,
CellsClearOutput = 4,
ChangeLanguage = 5,
Initialize = 6,
ChangeCellMetadata = 7,
Output = 8,
OutputItem = 9,
ChangeCellContent = 10,
ChangeDocumentMetadata = 11,
Unknown = 12
}
export interface NotebookCellsInitializeEvent<T> {
readonly kind: NotebookCellsChangeType.Initialize;
readonly changes: NotebookCellTextModelSplice<T>[];
}
export interface NotebookCellContentChangeEvent {
readonly kind: NotebookCellsChangeType.ChangeCellContent;
}
export interface NotebookCellsModelChangedEvent<T> {
readonly kind: NotebookCellsChangeType.ModelChange;
readonly changes: NotebookCellTextModelSplice<T>[];
}
export interface NotebookCellsModelMoveEvent<T> {
readonly kind: NotebookCellsChangeType.Move;
readonly index: number;
readonly length: number;
readonly newIdx: number;
readonly cells: T[];
}
export interface NotebookOutputChangedEvent {
readonly kind: NotebookCellsChangeType.Output;
readonly index: number;
readonly outputs: IOutputDto[];
}
export interface NotebookOutputItemChangedEvent {
readonly kind: NotebookCellsChangeType.OutputItem;
readonly index: number;
readonly outputId: string;
readonly outputItems: IOutputItemDto[];
readonly append: boolean;
}
export interface NotebookCellsChangeLanguageEvent {
readonly kind: NotebookCellsChangeType.ChangeLanguage;
readonly index: number;
readonly language: string;
}
export interface NotebookCellsChangeMetadataEvent {
readonly kind: NotebookCellsChangeType.ChangeCellMetadata;
readonly index: number;
readonly metadata: NotebookCellMetadata;
}
export interface NotebookDocumentChangeMetadataEvent {
readonly kind: NotebookCellsChangeType.ChangeDocumentMetadata;
readonly metadata: NotebookDocumentMetadata;
}
export interface NotebookDocumentUnknownChangeEvent {
readonly kind: NotebookCellsChangeType.Unknown;
}
export type NotebookRawContentEventDto = NotebookCellsInitializeEvent<IMainCellDto> | NotebookDocumentChangeMetadataEvent | NotebookCellContentChangeEvent | NotebookCellsModelChangedEvent<IMainCellDto> | NotebookCellsModelMoveEvent<IMainCellDto> | NotebookOutputChangedEvent | NotebookOutputItemChangedEvent | NotebookCellsChangeLanguageEvent | NotebookCellsChangeMetadataEvent | NotebookDocumentUnknownChangeEvent;
export type NotebookCellsChangedEventDto = {
readonly rawEvents: NotebookRawContentEventDto[];
readonly versionId: number;
};
export type NotebookRawContentEvent = (NotebookCellsInitializeEvent<ICell> | NotebookDocumentChangeMetadataEvent | NotebookCellContentChangeEvent | NotebookCellsModelChangedEvent<ICell> | NotebookCellsModelMoveEvent<ICell> | NotebookOutputChangedEvent | NotebookOutputItemChangedEvent | NotebookCellsChangeLanguageEvent | NotebookCellsChangeMetadataEvent | NotebookDocumentUnknownChangeEvent) & { transient: boolean; };
export enum SelectionStateType {
Handle = 0,
Index = 1
}
export interface ISelectionHandleState {
kind: SelectionStateType.Handle;
primary: number | null;
selections: number[];
}
export interface ISelectionIndexState {
kind: SelectionStateType.Index;
focus: ICellRange;
selections: ICellRange[];
}
export type ISelectionState = ISelectionHandleState | ISelectionIndexState;
export type NotebookTextModelChangedEvent = {
readonly rawEvents: NotebookRawContentEvent[];
readonly versionId: number;
readonly synchronous: boolean;
readonly endSelectionState: ISelectionState | undefined;
};
export const enum CellEditType {
Replace = 1,
Output = 2,
Metadata = 3,
CellLanguage = 4,
DocumentMetadata = 5,
Move = 6,
OutputItems = 7,
PartialMetadata = 8
}
export interface ICellDto2 {
source: string;
language: string;
cellKind: CellKind;
outputs: IOutputDto[];
metadata?: NotebookCellMetadata;
}
export interface ICellReplaceEdit {
editType: CellEditType.Replace;
index: number;
count: number;
cells: ICellDto2[];
}
export interface ICellOutputEdit {
editType: CellEditType.Output;
index: number;
outputs: IOutputDto[];
append?: boolean
}
export interface ICellOutputEditByHandle {
editType: CellEditType.Output;
handle: number;
outputs: IOutputDto[];
append?: boolean
}
export interface ICellOutputItemEdit {
editType: CellEditType.OutputItems;
outputId: string;
items: IOutputItemDto[];
append?: boolean;
}
export interface ICellMetadataEdit {
editType: CellEditType.Metadata;
index: number;
metadata: NotebookCellMetadata;
}
export type NullablePartialNotebookCellMetadata = {
[Key in keyof Partial<NotebookCellMetadata>]: NotebookCellMetadata[Key] | null
};
export interface ICellPartialMetadataEdit {
editType: CellEditType.PartialMetadata;
index: number;
metadata: Partial<NullablePartialNotebookCellMetadata>;
}
export interface ICellPartialMetadataEditByHandle {
editType: CellEditType.PartialMetadata;
handle: number;
metadata: Partial<NullablePartialNotebookCellMetadata>;
}
export interface ICellLanguageEdit {
editType: CellEditType.CellLanguage;
index: number;
language: string;
}
export interface IDocumentMetadataEdit {
editType: CellEditType.DocumentMetadata;
metadata: NotebookDocumentMetadata;
}
export interface ICellMoveEdit {
editType: CellEditType.Move;
index: number;
length: number;
newIdx: number;
}
export type IImmediateCellEditOperation = ICellOutputEditByHandle | ICellPartialMetadataEditByHandle | ICellOutputItemEdit;
export type ICellEditOperation = IImmediateCellEditOperation | ICellReplaceEdit | ICellOutputEdit | ICellMetadataEdit | ICellPartialMetadataEdit | IDocumentMetadataEdit | ICellMoveEdit | ICellOutputItemEdit | ICellLanguageEdit;
export interface NotebookDataDto {
readonly cells: ICellDto2[];
readonly metadata: NotebookDocumentMetadata;
}
export interface INotebookContributionData {
extension: ExtensionIdentifier,
providerDisplayName: string;
displayName: string;
filenamePattern: (string | glob.IRelativePattern | INotebookExclusiveDocumentFilter)[];
exclusive: boolean;
}
export function getCellUndoRedoComparisonKey(uri: URI) {
const data = CellUri.parse(uri);
if (!data) {
return uri.toString();
}
return data.notebook.toString();
}
export namespace CellUri {
export const scheme = Schemas.vscodeNotebookCell;
const _regex = /^ch(\d{7,})/;
export function generate(notebook: URI, handle: number): URI {
return notebook.with({
scheme,
fragment: `ch${handle.toString().padStart(7, '0')}${notebook.scheme !== Schemas.file ? notebook.scheme : ''}`
});
}
export function parse(cell: URI): { notebook: URI, handle: number } | undefined {
if (cell.scheme !== scheme) {
return undefined;
}
const match = _regex.exec(cell.fragment);
if (!match) {
return undefined;
}
const handle = Number(match[1]);
return {
handle,
notebook: cell.with({
scheme: cell.fragment.substr(match[0].length) || Schemas.file,
fragment: null
})
};
}
export function parseCellMetadataUri(metadata: URI) {
if (metadata.scheme !== Schemas.vscodeNotebookCellMetadata) {
return undefined;
}
const match = _regex.exec(metadata.fragment);
if (!match) {
return undefined;
}
const handle = Number(match[1]);
return {
handle,
notebook: metadata.with({
scheme: metadata.fragment.substr(match[0].length) || Schemas.file,
fragment: null
})
};
}
export function generateCellUri(notebook: URI, handle: number, scheme: string): URI {
return notebook.with({
scheme: scheme,
fragment: `ch${handle.toString().padStart(7, '0')}${notebook.scheme !== Schemas.file ? notebook.scheme : ''}`
});
}
export function parseCellUri(metadata: URI, scheme: string) {
if (metadata.scheme !== scheme) {
return undefined;
}
const match = _regex.exec(metadata.fragment);
if (!match) {
return undefined;
}
const handle = Number(match[1]);
return {
handle,
notebook: metadata.with({
scheme: metadata.fragment.substr(match[0].length) || Schemas.file,
fragment: null
})
};
}
}
type MimeTypeInfo = {
alwaysSecure?: boolean;
supportedByCore?: boolean;
mergeable?: boolean;
};
const _mimeTypeInfo = new Map<string, MimeTypeInfo>([
['application/json', { alwaysSecure: true, supportedByCore: true }],
['text/markdown', { alwaysSecure: true, supportedByCore: true }],
['image/png', { alwaysSecure: true, supportedByCore: true }],
['text/plain', { alwaysSecure: true, supportedByCore: true }],
['application/javascript', { supportedByCore: true }],
['text/html', { supportedByCore: true }],
['image/svg+xml', { supportedByCore: true }],
['image/jpeg', { supportedByCore: true }],
['text/x-javascript', { supportedByCore: true }],
['application/x.notebook.error-traceback', { alwaysSecure: true, supportedByCore: true }],
['application/x.notebook.stream', { alwaysSecure: true, supportedByCore: true, mergeable: true }],
['application/x.notebook.stdout', { alwaysSecure: true, supportedByCore: true, mergeable: true }],
['application/x.notebook.stderr', { alwaysSecure: true, supportedByCore: true, mergeable: true }],
]);
export function mimeTypeIsAlwaysSecure(mimeType: string): boolean {
return _mimeTypeInfo.get(mimeType)?.alwaysSecure ?? false;
}
export function mimeTypeSupportedByCore(mimeType: string) {
return _mimeTypeInfo.get(mimeType)?.supportedByCore ?? false;
}
export function mimeTypeIsMergeable(mimeType: string): boolean {
return _mimeTypeInfo.get(mimeType)?.mergeable ?? false;
}
// if (isWindows) {
// value = value.replace(/\//g, '\\');
// }
function matchGlobUniversal(pattern: string, path: string) {
if (isWindows) {
pattern = pattern.replace(/\//g, '\\');
path = path.replace(/\//g, '\\');
}
return glob.match(pattern, path);
}
function getMimeTypeOrder(mimeType: string, userDisplayOrder: string[], defaultOrder: string[]) {
let order = 0;
for (let i = 0; i < userDisplayOrder.length; i++) {
if (matchGlobUniversal(userDisplayOrder[i], mimeType)) {
return order;
}
order++;
}
for (let i = 0; i < defaultOrder.length; i++) {
if (matchGlobUniversal(defaultOrder[i], mimeType)) {
return order;
}
order++;
}
return order;
}
export function sortMimeTypes(mimeTypes: string[], userDisplayOrder: string[], defaultOrder: string[]) {
return mimeTypes.sort((a, b) => getMimeTypeOrder(a, userDisplayOrder, defaultOrder) - getMimeTypeOrder(b, userDisplayOrder, defaultOrder));
}
interface IMutableSplice<T> extends ISplice<T> {
deleteCount: number;
}
export function diff<T>(before: T[], after: T[], contains: (a: T) => boolean, equal: (a: T, b: T) => boolean = (a: T, b: T) => a === b): ISplice<T>[] {
const result: IMutableSplice<T>[] = [];
function pushSplice(start: number, deleteCount: number, toInsert: T[]): void {
if (deleteCount === 0 && toInsert.length === 0) {
return;
}
const latest = result[result.length - 1];
if (latest && latest.start + latest.deleteCount === start) {
latest.deleteCount += deleteCount;
latest.toInsert.push(...toInsert);
} else {
result.push({ start, deleteCount, toInsert });
}
}
let beforeIdx = 0;
let afterIdx = 0;
while (true) {
if (beforeIdx === before.length) {
pushSplice(beforeIdx, 0, after.slice(afterIdx));
break;
}
if (afterIdx === after.length) {
pushSplice(beforeIdx, before.length - beforeIdx, []);
break;
}
const beforeElement = before[beforeIdx];
const afterElement = after[afterIdx];
if (equal(beforeElement, afterElement)) {
// equal
beforeIdx += 1;
afterIdx += 1;
continue;
}
if (contains(afterElement)) {
// `afterElement` exists before, which means some elements before `afterElement` are deleted
pushSplice(beforeIdx, 1, []);
beforeIdx += 1;
} else {
// `afterElement` added
pushSplice(beforeIdx, 0, [afterElement]);
afterIdx += 1;
}
}
return result;
}
export interface ICellEditorViewState {
selections: editorCommon.ICursorState[];
}
export const NOTEBOOK_EDITOR_CURSOR_BOUNDARY = new RawContextKey<'none' | 'top' | 'bottom' | 'both'>('notebookEditorCursorAtBoundary', 'none');
export interface INotebookLoadOptions {
/**
* Go to disk bypassing any cache of the model if any.
*/
forceReadFromFile?: boolean;
}
export interface IResolvedNotebookEditorModel extends INotebookEditorModel {
notebook: NotebookTextModel;
}
export interface INotebookEditorModel extends IEditorModel {
readonly onDidChangeDirty: Event<void>;
readonly onDidSave: Event<void>;
readonly onDidChangeOrphaned: Event<void>;
readonly onDidChangeReadonly: Event<void>;
readonly resource: URI;
readonly viewType: string;
readonly notebook: NotebookTextModel | undefined;
isResolved(): this is IResolvedNotebookEditorModel;
isDirty(): boolean;
isReadonly(): boolean;
isOrphaned(): boolean;
load(options?: INotebookLoadOptions): Promise<IResolvedNotebookEditorModel>;
save(options?: ISaveOptions): Promise<boolean>;
saveAs(target: URI): Promise<IEditorInput | undefined>;
revert(options?: IRevertOptions): Promise<void>;
}
export interface INotebookDiffEditorModel extends IEditorModel {
original: IResolvedNotebookEditorModel;
modified: IResolvedNotebookEditorModel;
resolveOriginalFromDisk(): Promise<void>;
resolveModifiedFromDisk(): Promise<void>;
}
export interface INotebookTextModelBackup {
metadata: NotebookDocumentMetadata;
languages: string[];
cells: ICellDto2[]
}
export interface NotebookDocumentBackupData extends IWorkingCopyBackupMeta {
readonly viewType: string;
readonly backupId?: string;
readonly mtime?: number;
}
export enum NotebookEditorPriority {
default = 'default',
option = 'option',
}
export interface INotebookSearchOptions {
regex?: boolean;
wholeWord?: boolean;
caseSensitive?: boolean
wordSeparators?: string;
}
export interface INotebookExclusiveDocumentFilter {
include?: string | glob.IRelativePattern;
exclude?: string | glob.IRelativePattern;
}
export interface INotebookDocumentFilter {
viewType?: string | string[];
filenamePattern?: string | glob.IRelativePattern | INotebookExclusiveDocumentFilter;
}
//TODO@rebornix test
export function isDocumentExcludePattern(filenamePattern: string | glob.IRelativePattern | INotebookExclusiveDocumentFilter): filenamePattern is { include: string | glob.IRelativePattern; exclude: string | glob.IRelativePattern; } {
const arg = filenamePattern as INotebookExclusiveDocumentFilter;
if ((typeof arg.include === 'string' || glob.isRelativePattern(arg.include))
&& (typeof arg.exclude === 'string' || glob.isRelativePattern(arg.exclude))) {
return true;
}
return false;
}
export function notebookDocumentFilterMatch(filter: INotebookDocumentFilter, viewType: string, resource: URI): boolean {
if (Array.isArray(filter.viewType) && filter.viewType.indexOf(viewType) >= 0) {
return true;
}
if (filter.viewType === viewType) {
return true;
}
if (filter.filenamePattern) {
let filenamePattern = isDocumentExcludePattern(filter.filenamePattern) ? filter.filenamePattern.include : (filter.filenamePattern as string | glob.IRelativePattern);
let excludeFilenamePattern = isDocumentExcludePattern(filter.filenamePattern) ? filter.filenamePattern.exclude : undefined;
if (glob.match(filenamePattern, basename(resource.fsPath).toLowerCase())) {
if (excludeFilenamePattern) {
if (glob.match(excludeFilenamePattern, basename(resource.fsPath).toLowerCase())) {
// should exclude
return false;
}
}
return true;
}
}
return false;
}
export interface INotebookKernelChangeEvent {
label?: true;
description?: true;
detail?: true;
supportedLanguages?: true;
hasExecutionOrder?: true;
}
export interface INotebookKernel {
readonly id: string;
readonly viewType: string;
readonly onDidChange: Event<Readonly<INotebookKernelChangeEvent>>;
readonly extension: ExtensionIdentifier;
readonly localResourceRoot: URI;
readonly preloadUris: URI[];
readonly preloadProvides: string[];
label: string;
description?: string;
detail?: string;
supportedLanguages: string[]
implementsInterrupt?: boolean;
implementsExecutionOrder?: boolean;
executeNotebookCellsRequest(uri: URI, cellHandles: number[]): Promise<void>;
cancelNotebookCellExecution(uri: URI, cellHandles: number[]): Promise<void>;
}
export interface INotebookCellStatusBarItemProvider {
viewType: string;
onDidChangeStatusBarItems?: Event<void>;
provideCellStatusBarItems(uri: URI, index: number, token: CancellationToken): Promise<INotebookCellStatusBarItemList | undefined>;
}
export class CellSequence implements ISequence {
constructor(readonly textModel: NotebookTextModel) {
}
getElements(): string[] | number[] | Int32Array {
const hashValue = new Int32Array(this.textModel.cells.length);
for (let i = 0; i < this.textModel.cells.length; i++) {
hashValue[i] = this.textModel.cells[i].getHashValue();
}
return hashValue;
}
}
export interface INotebookDiffResult {
cellsDiff: IDiffResult,
linesDiff?: { originalCellhandle: number, modifiedCellhandle: number, lineChanges: editorCommon.ILineChange[] }[];
}
export interface INotebookCellStatusBarItem {
readonly alignment: CellStatusbarAlignment;
readonly priority?: number;
readonly text: string;
readonly color?: string | ThemeColor;
readonly backgroundColor?: string | ThemeColor;
readonly tooltip?: string;
readonly command?: string | Command;
readonly accessibilityInformation?: IAccessibilityInformation;
readonly opacity?: string;
readonly onlyShowWhenActive?: boolean;
}
export interface INotebookCellStatusBarItemList {
items: INotebookCellStatusBarItem[];
dispose?(): void;
}
export const DisplayOrderKey = 'notebook.displayOrder';
export const CellToolbarLocKey = 'notebook.cellToolbarLocation';
export const CellToolbarVisibility = 'notebook.cellToolbarVisibility';
export const ShowCellStatusBarKey = 'notebook.showCellStatusBar';
export const NotebookTextDiffEditorPreview = 'notebook.diff.enablePreview';
export const ExperimentalUseMarkdownRenderer = 'notebook.experimental.useMarkdownRenderer';
export const enum CellStatusbarAlignment {
Left = 1,
Right = 2
}
export interface INotebookDecorationRenderOptions {
backgroundColor?: string | ThemeColor;
borderColor?: string | ThemeColor;
top?: editorCommon.IContentDecorationRenderOptions;
}
export class NotebookWorkingCopyTypeIdentifier {
private static _prefix = 'notebook/';
static create(viewType: string): string {
return `${NotebookWorkingCopyTypeIdentifier._prefix}/${viewType}`;
}
static parse(candidate: string): string | undefined {
if (candidate.startsWith(NotebookWorkingCopyTypeIdentifier._prefix)) {
return candidate.substr(NotebookWorkingCopyTypeIdentifier._prefix.length);
}
return undefined;
}
}