mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-09 17:52:34 -05:00
* Merge from vscode a5cf1da01d5db3d2557132be8d30f89c38019f6c * remove files we don't want * fix hygiene * update distro * update distro * fix hygiene * fix strict nulls * distro * distro * fix tests * fix tests * add another edit * fix viewlet icon * fix azure dialog * fix some padding * fix more padding issues
311 lines
9.8 KiB
TypeScript
311 lines
9.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 { IDisposable } from 'vs/base/common/lifecycle';
|
|
import { IScrollPosition, Scrollable } from 'vs/base/common/scrollable';
|
|
import * as strings from 'vs/base/common/strings';
|
|
import { IViewLineTokens } from 'vs/editor/common/core/lineTokens';
|
|
import { IPosition, Position } from 'vs/editor/common/core/position';
|
|
import { IRange, Range } from 'vs/editor/common/core/range';
|
|
import { INewScrollPosition } from 'vs/editor/common/editorCommon';
|
|
import { EndOfLinePreference, IActiveIndentGuideInfo, IModelDecorationOptions, TextModelResolvedOptions } from 'vs/editor/common/model';
|
|
import { IViewEventListener } from 'vs/editor/common/view/viewEvents';
|
|
import { IPartialViewLinesViewportData } from 'vs/editor/common/viewLayout/viewLinesViewportData';
|
|
import { IEditorWhitespace, IWhitespaceChangeAccessor } from 'vs/editor/common/viewLayout/linesLayout';
|
|
import { ITheme } from 'vs/platform/theme/common/themeService';
|
|
|
|
export interface IViewWhitespaceViewportData {
|
|
readonly id: string;
|
|
readonly afterLineNumber: number;
|
|
readonly verticalOffset: number;
|
|
readonly height: number;
|
|
}
|
|
|
|
export class Viewport {
|
|
readonly _viewportBrand: void;
|
|
|
|
readonly top: number;
|
|
readonly left: number;
|
|
readonly width: number;
|
|
readonly height: number;
|
|
|
|
constructor(top: number, left: number, width: number, height: number) {
|
|
this.top = top | 0;
|
|
this.left = left | 0;
|
|
this.width = width | 0;
|
|
this.height = height | 0;
|
|
}
|
|
}
|
|
|
|
export interface IViewLayout {
|
|
|
|
readonly scrollable: Scrollable;
|
|
|
|
onMaxLineWidthChanged(width: number): void;
|
|
|
|
getScrollWidth(): number;
|
|
getScrollHeight(): number;
|
|
|
|
getCurrentScrollLeft(): number;
|
|
getCurrentScrollTop(): number;
|
|
getCurrentViewport(): Viewport;
|
|
|
|
getFutureViewport(): Viewport;
|
|
|
|
validateScrollPosition(scrollPosition: INewScrollPosition): IScrollPosition;
|
|
setScrollPositionNow(position: INewScrollPosition): void;
|
|
setScrollPositionSmooth(position: INewScrollPosition): void;
|
|
deltaScrollNow(deltaScrollLeft: number, deltaScrollTop: number): void;
|
|
|
|
getLinesViewportData(): IPartialViewLinesViewportData;
|
|
getLinesViewportDataAtScrollTop(scrollTop: number): IPartialViewLinesViewportData;
|
|
getWhitespaces(): IEditorWhitespace[];
|
|
|
|
isAfterLines(verticalOffset: number): boolean;
|
|
getLineNumberAtVerticalOffset(verticalOffset: number): number;
|
|
getVerticalOffsetForLineNumber(lineNumber: number): number;
|
|
getWhitespaceAtVerticalOffset(verticalOffset: number): IViewWhitespaceViewportData | null;
|
|
|
|
// --------------- Begin vertical whitespace management
|
|
changeWhitespace<T>(callback: (accessor: IWhitespaceChangeAccessor) => T): T;
|
|
|
|
/**
|
|
* Get the layout information for whitespaces currently in the viewport
|
|
*/
|
|
getWhitespaceViewportData(): IViewWhitespaceViewportData[];
|
|
|
|
// TODO@Alex whitespace management should work via a change accessor sort of thing
|
|
onHeightMaybeChanged(): void;
|
|
|
|
// --------------- End vertical whitespace management
|
|
}
|
|
|
|
export interface ICoordinatesConverter {
|
|
// View -> Model conversion and related methods
|
|
convertViewPositionToModelPosition(viewPosition: Position): Position;
|
|
convertViewRangeToModelRange(viewRange: Range): Range;
|
|
validateViewPosition(viewPosition: Position, expectedModelPosition: Position): Position;
|
|
validateViewRange(viewRange: Range, expectedModelRange: Range): Range;
|
|
|
|
// Model -> View conversion and related methods
|
|
convertModelPositionToViewPosition(modelPosition: Position): Position;
|
|
convertModelRangeToViewRange(modelRange: Range): Range;
|
|
modelPositionIsVisible(modelPosition: Position): boolean;
|
|
}
|
|
|
|
export interface IViewModel {
|
|
|
|
addEventListener(listener: IViewEventListener): IDisposable;
|
|
|
|
readonly coordinatesConverter: ICoordinatesConverter;
|
|
|
|
readonly viewLayout: IViewLayout;
|
|
|
|
/**
|
|
* Gives a hint that a lot of requests are about to come in for these line numbers.
|
|
*/
|
|
setViewport(startLineNumber: number, endLineNumber: number, centeredLineNumber: number): void;
|
|
tokenizeViewport(): void;
|
|
setHasFocus(hasFocus: boolean): void;
|
|
|
|
getDecorationsInViewport(visibleRange: Range): ViewModelDecoration[];
|
|
getViewLineRenderingData(visibleRange: Range, lineNumber: number): ViewLineRenderingData;
|
|
getViewLineData(lineNumber: number): ViewLineData;
|
|
getMinimapLinesRenderingData(startLineNumber: number, endLineNumber: number, needed: boolean[]): MinimapLinesRenderingData;
|
|
getCompletelyVisibleViewRange(): Range;
|
|
getCompletelyVisibleViewRangeAtScrollTop(scrollTop: number): Range;
|
|
|
|
getOptions(): TextModelResolvedOptions;
|
|
getLineCount(): number;
|
|
getLineContent(lineNumber: number): string;
|
|
getLineLength(lineNumber: number): number;
|
|
getActiveIndentGuide(lineNumber: number, minLineNumber: number, maxLineNumber: number): IActiveIndentGuideInfo;
|
|
getLinesIndentGuides(startLineNumber: number, endLineNumber: number): number[];
|
|
getLineMinColumn(lineNumber: number): number;
|
|
getLineMaxColumn(lineNumber: number): number;
|
|
getLineFirstNonWhitespaceColumn(lineNumber: number): number;
|
|
getLineLastNonWhitespaceColumn(lineNumber: number): number;
|
|
getAllOverviewRulerDecorations(theme: ITheme): IOverviewRulerDecorations;
|
|
invalidateOverviewRulerColorCache(): void;
|
|
invalidateMinimapColorCache(): void;
|
|
getValueInRange(range: Range, eol: EndOfLinePreference): string;
|
|
|
|
getModelLineMaxColumn(modelLineNumber: number): number;
|
|
validateModelPosition(modelPosition: IPosition): Position;
|
|
validateModelRange(range: IRange): Range;
|
|
|
|
deduceModelPositionRelativeToViewPosition(viewAnchorPosition: Position, deltaOffset: number, lineFeedCnt: number): Position;
|
|
getEOL(): string;
|
|
getPlainTextToCopy(ranges: Range[], emptySelectionClipboard: boolean, forceCRLF: boolean): string | string[];
|
|
getHTMLToCopy(ranges: Range[], emptySelectionClipboard: boolean): string | null;
|
|
}
|
|
|
|
export class MinimapLinesRenderingData {
|
|
public readonly tabSize: number;
|
|
public readonly data: Array<ViewLineData | null>;
|
|
|
|
constructor(
|
|
tabSize: number,
|
|
data: Array<ViewLineData | null>
|
|
) {
|
|
this.tabSize = tabSize;
|
|
this.data = data;
|
|
}
|
|
}
|
|
|
|
export class ViewLineData {
|
|
_viewLineDataBrand: void;
|
|
|
|
/**
|
|
* The content at this view line.
|
|
*/
|
|
public readonly content: string;
|
|
/**
|
|
* Does this line continue with a wrapped line?
|
|
*/
|
|
public readonly continuesWithWrappedLine: boolean;
|
|
/**
|
|
* The minimum allowed column at this view line.
|
|
*/
|
|
public readonly minColumn: number;
|
|
/**
|
|
* The maximum allowed column at this view line.
|
|
*/
|
|
public readonly maxColumn: number;
|
|
/**
|
|
* The tokens at this view line.
|
|
*/
|
|
public readonly tokens: IViewLineTokens;
|
|
|
|
constructor(
|
|
content: string,
|
|
continuesWithWrappedLine: boolean,
|
|
minColumn: number,
|
|
maxColumn: number,
|
|
tokens: IViewLineTokens
|
|
) {
|
|
this.content = content;
|
|
this.continuesWithWrappedLine = continuesWithWrappedLine;
|
|
this.minColumn = minColumn;
|
|
this.maxColumn = maxColumn;
|
|
this.tokens = tokens;
|
|
}
|
|
}
|
|
|
|
export class ViewLineRenderingData {
|
|
/**
|
|
* The minimum allowed column at this view line.
|
|
*/
|
|
public readonly minColumn: number;
|
|
/**
|
|
* The maximum allowed column at this view line.
|
|
*/
|
|
public readonly maxColumn: number;
|
|
/**
|
|
* The content at this view line.
|
|
*/
|
|
public readonly content: string;
|
|
/**
|
|
* Does this line continue with a wrapped line?
|
|
*/
|
|
public readonly continuesWithWrappedLine: boolean;
|
|
/**
|
|
* Describes if `content` contains RTL characters.
|
|
*/
|
|
public readonly containsRTL: boolean;
|
|
/**
|
|
* Describes if `content` contains non basic ASCII chars.
|
|
*/
|
|
public readonly isBasicASCII: boolean;
|
|
/**
|
|
* The tokens at this view line.
|
|
*/
|
|
public readonly tokens: IViewLineTokens;
|
|
/**
|
|
* Inline decorations at this view line.
|
|
*/
|
|
public readonly inlineDecorations: InlineDecoration[];
|
|
/**
|
|
* The tab size for this view model.
|
|
*/
|
|
public readonly tabSize: number;
|
|
|
|
constructor(
|
|
minColumn: number,
|
|
maxColumn: number,
|
|
content: string,
|
|
continuesWithWrappedLine: boolean,
|
|
mightContainRTL: boolean,
|
|
mightContainNonBasicASCII: boolean,
|
|
tokens: IViewLineTokens,
|
|
inlineDecorations: InlineDecoration[],
|
|
tabSize: number
|
|
) {
|
|
this.minColumn = minColumn;
|
|
this.maxColumn = maxColumn;
|
|
this.content = content;
|
|
this.continuesWithWrappedLine = continuesWithWrappedLine;
|
|
|
|
this.isBasicASCII = ViewLineRenderingData.isBasicASCII(content, mightContainNonBasicASCII);
|
|
this.containsRTL = ViewLineRenderingData.containsRTL(content, this.isBasicASCII, mightContainRTL);
|
|
|
|
this.tokens = tokens;
|
|
this.inlineDecorations = inlineDecorations;
|
|
this.tabSize = tabSize;
|
|
}
|
|
|
|
public static isBasicASCII(lineContent: string, mightContainNonBasicASCII: boolean): boolean {
|
|
if (mightContainNonBasicASCII) {
|
|
return strings.isBasicASCII(lineContent);
|
|
}
|
|
return true;
|
|
}
|
|
|
|
public static containsRTL(lineContent: string, isBasicASCII: boolean, mightContainRTL: boolean): boolean {
|
|
if (!isBasicASCII && mightContainRTL) {
|
|
return strings.containsRTL(lineContent);
|
|
}
|
|
return false;
|
|
}
|
|
}
|
|
|
|
export const enum InlineDecorationType {
|
|
Regular = 0,
|
|
Before = 1,
|
|
After = 2,
|
|
RegularAffectingLetterSpacing = 3
|
|
}
|
|
|
|
export class InlineDecoration {
|
|
constructor(
|
|
public readonly range: Range,
|
|
public readonly inlineClassName: string,
|
|
public readonly type: InlineDecorationType
|
|
) {
|
|
}
|
|
}
|
|
|
|
export class ViewModelDecoration {
|
|
_viewModelDecorationBrand: void;
|
|
|
|
public readonly range: Range;
|
|
public readonly options: IModelDecorationOptions;
|
|
|
|
constructor(range: Range, options: IModelDecorationOptions) {
|
|
this.range = range;
|
|
this.options = options;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Decorations are encoded in a number array using the following scheme:
|
|
* - 3*i = lane
|
|
* - 3*i+1 = startLineNumber
|
|
* - 3*i+2 = endLineNumber
|
|
*/
|
|
export interface IOverviewRulerDecorations {
|
|
[color: string]: number[];
|
|
}
|