提交 80eee2dc 编写于 作者: R rebornix

mainthreadnotebook does not talk to mainthreadnotebook controller

上级 27c96b7a
...@@ -6,10 +6,10 @@ ...@@ -6,10 +6,10 @@
import * as DOM from 'vs/base/browser/dom'; import * as DOM from 'vs/base/browser/dom';
import { extHostNamedCustomer } from 'vs/workbench/api/common/extHostCustomers'; import { extHostNamedCustomer } from 'vs/workbench/api/common/extHostCustomers';
import { MainContext, MainThreadNotebookShape, NotebookExtensionDescription, IExtHostContext, ExtHostNotebookShape, ExtHostContext, INotebookDocumentsAndEditorsDelta } from '../common/extHost.protocol'; import { MainContext, MainThreadNotebookShape, NotebookExtensionDescription, IExtHostContext, ExtHostNotebookShape, ExtHostContext, INotebookDocumentsAndEditorsDelta } from '../common/extHost.protocol';
import { Disposable, IDisposable, combinedDisposable } from 'vs/base/common/lifecycle'; import { Disposable, IDisposable, combinedDisposable, DisposableStore } from 'vs/base/common/lifecycle';
import { URI, UriComponents } from 'vs/base/common/uri'; import { URI, UriComponents } from 'vs/base/common/uri';
import { INotebookService, IMainNotebookController } from 'vs/workbench/contrib/notebook/common/notebookService'; import { INotebookService, IMainNotebookController } from 'vs/workbench/contrib/notebook/common/notebookService';
import { INotebookTextModel, INotebookMimeTypeSelector, NOTEBOOK_DISPLAY_ORDER, NotebookCellOutputsSplice, NotebookDocumentMetadata, NotebookCellMetadata, ICellEditOperation, ACCESSIBLE_NOTEBOOK_DISPLAY_ORDER, CellEditType, CellKind, INotebookKernelInfo, INotebookKernelInfoDto, IEditor, INotebookRendererInfo, IOutputRenderRequest, IOutputRenderResponse, INotebookDocumentFilter } from 'vs/workbench/contrib/notebook/common/notebookCommon'; import { INotebookMimeTypeSelector, NOTEBOOK_DISPLAY_ORDER, NotebookCellOutputsSplice, NotebookDocumentMetadata, NotebookCellMetadata, ICellEditOperation, ACCESSIBLE_NOTEBOOK_DISPLAY_ORDER, CellEditType, CellKind, INotebookKernelInfo, INotebookKernelInfoDto, IEditor, INotebookRendererInfo, IOutputRenderRequest, IOutputRenderResponse, INotebookDocumentFilter } from 'vs/workbench/contrib/notebook/common/notebookCommon';
import { IConfigurationService } from 'vs/platform/configuration/common/configuration'; import { IConfigurationService } from 'vs/platform/configuration/common/configuration';
import { NotebookTextModel } from 'vs/workbench/contrib/notebook/common/model/notebookTextModel'; import { NotebookTextModel } from 'vs/workbench/contrib/notebook/common/model/notebookTextModel';
import { IEditorService } from 'vs/workbench/services/editor/common/editorService'; import { IEditorService } from 'vs/workbench/services/editor/common/editorService';
...@@ -54,22 +54,8 @@ export class MainThreadNotebookDocument extends Disposable { ...@@ -54,22 +54,8 @@ export class MainThreadNotebookDocument extends Disposable {
})); }));
} }
async applyEdit(modelVersionId: number, edits: ICellEditOperation[], synchronous: boolean): Promise<boolean> {
await this.notebookService.transformEditsOutputs(this.textModel, edits);
if (synchronous) {
return this._textModel.$applyEdit(modelVersionId, edits, synchronous);
} else {
return new Promise(resolve => {
this._register(DOM.scheduleAtNextAnimationFrame(() => {
const ret = this._textModel.$applyEdit(modelVersionId, edits, true);
resolve(ret);
}));
});
}
}
dispose() { dispose() {
this._textModel.dispose(); // this._textModel.dispose();
super.dispose(); super.dispose();
} }
} }
...@@ -189,6 +175,7 @@ export class MainThreadNotebooks extends Disposable implements MainThreadNoteboo ...@@ -189,6 +175,7 @@ export class MainThreadNotebooks extends Disposable implements MainThreadNoteboo
private readonly _proxy: ExtHostNotebookShape; private readonly _proxy: ExtHostNotebookShape;
private _toDisposeOnEditorRemove = new Map<string, IDisposable>(); private _toDisposeOnEditorRemove = new Map<string, IDisposable>();
private _currentState?: DocumentAndEditorState; private _currentState?: DocumentAndEditorState;
private _editorEventListenersMapping: Map<string, DisposableStore> = new Map();
constructor( constructor(
extHostContext: IExtHostContext, extHostContext: IExtHostContext,
...@@ -205,15 +192,40 @@ export class MainThreadNotebooks extends Disposable implements MainThreadNoteboo ...@@ -205,15 +192,40 @@ export class MainThreadNotebooks extends Disposable implements MainThreadNoteboo
} }
async $tryApplyEdits(viewType: string, resource: UriComponents, modelVersionId: number, edits: ICellEditOperation[], renderers: number[]): Promise<boolean> { async $tryApplyEdits(viewType: string, resource: UriComponents, modelVersionId: number, edits: ICellEditOperation[], renderers: number[]): Promise<boolean> {
let controller = this._notebookProviders.get(viewType); const textModel = this._notebookService.getNotebookTextModel(URI.from(resource));
if (textModel) {
if (controller) { await this._notebookService.transformEditsOutputs(textModel, edits);
return controller.tryApplyEdits(resource, modelVersionId, edits, renderers); return textModel.$applyEdit(modelVersionId, edits, true);
} }
return false; return false;
} }
createNotebookTextModelAndBindListeners(uri: URI, viewType: string, supportBackup: boolean) {
const disposableStore = new DisposableStore();
const textModel = this._instantiationService.createInstance(NotebookTextModel, MainThreadNotebookController.documentHandle++, viewType, supportBackup, uri);
disposableStore.add(textModel.onDidModelChangeProxy(e => {
this._proxy.$acceptModelChanged(textModel.uri, e);
this._proxy.$acceptEditorPropertiesChanged(uri, { selections: { selections: textModel.selections }, metadata: null });
}));
disposableStore.add(textModel.onDidSelectionChange(e => {
const selectionsChange = e ? { selections: e } : null;
this._proxy.$acceptEditorPropertiesChanged(uri, { selections: selectionsChange, metadata: null });
}));
this._editorEventListenersMapping.set(textModel.uri.toString(), disposableStore);
return textModel;
}
async removeNotebookTextModel(uri: URI): Promise<void> {
// TODO@rebornix, remove cell should use emitDelta as well to ensure document/editor events are sent together
await this._proxy.$acceptDocumentAndEditorsDelta({ removedDocuments: [uri] });
let textModelDisposableStore = this._editorEventListenersMapping.get(uri.toString());
textModelDisposableStore?.dispose();
this._editorEventListenersMapping.delete(URI.from(uri).toString());
}
private _isDeltaEmpty(delta: INotebookDocumentsAndEditorsDelta) { private _isDeltaEmpty(delta: INotebookDocumentsAndEditorsDelta) {
if (delta.addedDocuments !== undefined && delta.addedDocuments.length > 0) { if (delta.addedDocuments !== undefined && delta.addedDocuments.length > 0) {
return false; return false;
...@@ -279,11 +291,32 @@ export class MainThreadNotebooks extends Disposable implements MainThreadNoteboo ...@@ -279,11 +291,32 @@ export class MainThreadNotebooks extends Disposable implements MainThreadNoteboo
this._removeNotebookEditor(editors); this._removeNotebookEditor(editors);
})); }));
this._register(this._notebookService.onNotebookDocumentAdd(() => { this._register(this._notebookService.onNotebookDocumentAdd((documents) => {
documents.forEach(doc => {
if (!this._editorEventListenersMapping.has(doc.toString())) {
const disposableStore = new DisposableStore();
const textModel = this._notebookService.getNotebookTextModel(doc);
disposableStore.add(textModel!.onDidModelChangeProxy(e => {
this._proxy.$acceptModelChanged(textModel!.uri, e);
this._proxy.$acceptEditorPropertiesChanged(doc, { selections: { selections: textModel!.selections }, metadata: null });
}));
disposableStore.add(textModel!.onDidSelectionChange(e => {
const selectionsChange = e ? { selections: e } : null;
this._proxy.$acceptEditorPropertiesChanged(doc, { selections: selectionsChange, metadata: null });
}));
this._editorEventListenersMapping.set(textModel!.uri.toString(), disposableStore);
}
});
this._updateState(); this._updateState();
})); }));
this._register(this._notebookService.onNotebookDocumentRemove(() => { this._register(this._notebookService.onNotebookDocumentRemove((documents) => {
documents.forEach(doc => {
this._editorEventListenersMapping.get(doc.toString())?.dispose();
this._editorEventListenersMapping.delete(doc.toString());
});
this._updateState(); this._updateState();
})); }));
...@@ -412,10 +445,8 @@ export class MainThreadNotebooks extends Disposable implements MainThreadNoteboo ...@@ -412,10 +445,8 @@ export class MainThreadNotebooks extends Disposable implements MainThreadNoteboo
} }
async $onNotebookChange(viewType: string, uri: UriComponents): Promise<void> { async $onNotebookChange(viewType: string, uri: UriComponents): Promise<void> {
let controller = this._notebookProviders.get(viewType); const textModel = this._notebookService.getNotebookTextModel(URI.from(uri));
if (controller) { textModel?.handleUnknownChange();
controller.handleNotebookChange(uri);
}
} }
async $unregisterNotebookProvider(viewType: string): Promise<void> { async $unregisterNotebookProvider(viewType: string): Promise<void> {
...@@ -485,32 +516,27 @@ export class MainThreadNotebooks extends Disposable implements MainThreadNoteboo ...@@ -485,32 +516,27 @@ export class MainThreadNotebooks extends Disposable implements MainThreadNoteboo
} }
async $updateNotebookLanguages(viewType: string, resource: UriComponents, languages: string[]): Promise<void> { async $updateNotebookLanguages(viewType: string, resource: UriComponents, languages: string[]): Promise<void> {
let controller = this._notebookProviders.get(viewType); const textModel = this._notebookService.getNotebookTextModel(URI.from(resource));
textModel?.updateLanguages(languages);
if (controller) {
controller.updateLanguages(resource, languages);
}
} }
async $updateNotebookMetadata(viewType: string, resource: UriComponents, metadata: NotebookDocumentMetadata): Promise<void> { async $updateNotebookMetadata(viewType: string, resource: UriComponents, metadata: NotebookDocumentMetadata): Promise<void> {
let controller = this._notebookProviders.get(viewType); const textModel = this._notebookService.getNotebookTextModel(URI.from(resource));
textModel?.updateNotebookMetadata(metadata);
if (controller) {
controller.updateNotebookMetadata(resource, metadata);
}
} }
async $updateNotebookCellMetadata(viewType: string, resource: UriComponents, handle: number, metadata: NotebookCellMetadata): Promise<void> { async $updateNotebookCellMetadata(viewType: string, resource: UriComponents, handle: number, metadata: NotebookCellMetadata): Promise<void> {
let controller = this._notebookProviders.get(viewType); const textModel = this._notebookService.getNotebookTextModel(URI.from(resource));
textModel?.updateNotebookCellMetadata(handle, metadata);
if (controller) {
controller.updateNotebookCellMetadata(resource, handle, metadata);
}
} }
async $spliceNotebookCellOutputs(viewType: string, resource: UriComponents, cellHandle: number, splices: NotebookCellOutputsSplice[], renderers: number[]): Promise<void> { async $spliceNotebookCellOutputs(viewType: string, resource: UriComponents, cellHandle: number, splices: NotebookCellOutputsSplice[], renderers: number[]): Promise<void> {
let controller = this._notebookProviders.get(viewType); const textModel = this._notebookService.getNotebookTextModel(URI.from(resource));
await controller?.spliceNotebookCellOutputs(resource, cellHandle, splices, renderers);
if (textModel) {
await this._notebookService.transformSpliceOutputs(textModel, splices);
textModel.$spliceNotebookCellOutputs(cellHandle, splices);
}
} }
async executeNotebookByAttachedKernel(viewType: string, uri: URI, token: CancellationToken): Promise<void> { async executeNotebookByAttachedKernel(viewType: string, uri: URI, token: CancellationToken): Promise<void> {
...@@ -528,18 +554,24 @@ export class MainThreadNotebooks extends Disposable implements MainThreadNoteboo ...@@ -528,18 +554,24 @@ export class MainThreadNotebooks extends Disposable implements MainThreadNoteboo
} }
$onDidEdit(resource: UriComponents, viewType: string, editId: number, label: string | undefined): void { $onDidEdit(resource: UriComponents, viewType: string, editId: number, label: string | undefined): void {
let controller = this._notebookProviders.get(viewType); const textModel = this._notebookService.getNotebookTextModel(URI.from(resource));
controller?.handleEdit(resource, editId, label);
if (textModel) {
textModel.$handleEdit(label, () => {
return this._proxy.$undoNotebook(textModel.viewType, textModel.uri, editId, textModel.isDirty);
}, () => {
return this._proxy.$redoNotebook(textModel.viewType, textModel.uri, editId, textModel.isDirty);
});
}
} }
$onContentChange(resource: UriComponents, viewType: string): void { $onContentChange(resource: UriComponents, viewType: string): void {
let controller = this._notebookProviders.get(viewType); const textModel = this._notebookService.getNotebookTextModel(URI.from(resource));
controller?.handleNotebookChange(resource); textModel?.handleUnknownChange();
} }
} }
export class MainThreadNotebookController implements IMainNotebookController { export class MainThreadNotebookController implements IMainNotebookController {
private _mapping: Map<string, MainThreadNotebookDocument> = new Map();
static documentHandle: number = 0; static documentHandle: number = 0;
constructor( constructor(
...@@ -555,81 +587,60 @@ export class MainThreadNotebookController implements IMainNotebookController { ...@@ -555,81 +587,60 @@ export class MainThreadNotebookController implements IMainNotebookController {
} }
async createNotebook(viewType: string, uri: URI, forceReload: boolean, editorId?: string, backupId?: string): Promise<NotebookTextModel | undefined> { async createNotebook(viewType: string, uri: URI, forceReload: boolean, editorId?: string, backupId?: string): Promise<NotebookTextModel | undefined> {
let mainthreadNotebook = this._mapping.get(URI.from(uri).toString()); let mainthreadTextModel = this.notebookService.getNotebookTextModel(uri);
if (mainthreadNotebook) { if (mainthreadTextModel) {
if (forceReload) { if (forceReload) {
const data = await this._proxy.$resolveNotebookData(viewType, uri); const data = await this._proxy.$resolveNotebookData(viewType, uri);
if (!data) { if (!data) {
return; return;
} }
mainthreadNotebook.textModel.languages = data.languages; mainthreadTextModel.languages = data.languages;
mainthreadNotebook.textModel.metadata = data.metadata; mainthreadTextModel.metadata = data.metadata;
const edits: ICellEditOperation[] = [ const edits: ICellEditOperation[] = [
{ editType: CellEditType.Delete, count: mainthreadNotebook.textModel.cells.length, index: 0 }, { editType: CellEditType.Delete, count: mainthreadTextModel.cells.length, index: 0 },
{ editType: CellEditType.Insert, index: 0, cells: data.cells } { editType: CellEditType.Insert, index: 0, cells: data.cells }
]; ];
await this.notebookService.transformEditsOutputs(mainthreadNotebook.textModel, edits); await this.notebookService.transformEditsOutputs(mainthreadTextModel, edits);
await new Promise(resolve => { await new Promise(resolve => {
DOM.scheduleAtNextAnimationFrame(() => { DOM.scheduleAtNextAnimationFrame(() => {
const ret = mainthreadNotebook!.textModel.$applyEdit(mainthreadNotebook!.textModel.versionId, edits, true); const ret = mainthreadTextModel!.$applyEdit(mainthreadTextModel!.versionId, edits, true);
resolve(ret); resolve(ret);
}); });
}); });
} }
return mainthreadNotebook.textModel; return mainthreadTextModel;
} }
let document = this._instantiationService.createInstance(MainThreadNotebookDocument, this._proxy, MainThreadNotebookController.documentHandle++, viewType, this._supportBackup, uri); const textModel = this._mainThreadNotebook.createNotebookTextModelAndBindListeners(uri, viewType, this._supportBackup);
this._mapping.set(document.uri.toString(), document);
// open notebook document // open notebook document
const data = await this._proxy.$resolveNotebookData(viewType, uri, backupId); const data = await this._proxy.$resolveNotebookData(viewType, uri, backupId);
if (!data) { if (!data) {
return; return;
} }
document.textModel.languages = data.languages; textModel.languages = data.languages;
document.textModel.metadata = data.metadata; textModel.metadata = data.metadata;
if (data.cells.length) { if (data.cells.length) {
document.textModel.initialize(data!.cells); textModel.initialize(data!.cells);
} else { } else {
const mainCell = document.textModel.createCellTextModel([''], document.textModel.languages.length ? document.textModel.languages[0] : '', CellKind.Code, [], undefined); const mainCell = textModel.createCellTextModel([''], textModel.languages.length ? textModel.languages[0] : '', CellKind.Code, [], undefined);
document.textModel.insertTemplateCell(mainCell); textModel.insertTemplateCell(mainCell);
} }
this._proxy.$acceptEditorPropertiesChanged(uri, { selections: null, metadata: document.textModel.metadata }); this._proxy.$acceptEditorPropertiesChanged(uri, { selections: null, metadata: textModel.metadata });
return document.textModel; return textModel;
} }
async resolveNotebookEditor(viewType: string, uri: URI, editorId: string) { async resolveNotebookEditor(viewType: string, uri: URI, editorId: string) {
await this._proxy.$resolveNotebookEditor(viewType, uri, editorId); await this._proxy.$resolveNotebookEditor(viewType, uri, editorId);
} }
async tryApplyEdits(resource: UriComponents, modelVersionId: number, edits: ICellEditOperation[], renderers: number[]): Promise<boolean> {
let mainthreadNotebook = this._mapping.get(URI.from(resource).toString());
if (mainthreadNotebook) {
await this.notebookService.transformEditsOutputs(mainthreadNotebook.textModel, edits);
return mainthreadNotebook.textModel.$applyEdit(modelVersionId, edits, true);
}
return false;
}
async spliceNotebookCellOutputs(resource: UriComponents, cellHandle: number, splices: NotebookCellOutputsSplice[], renderers: number[]): Promise<void> {
let mainthreadNotebook = this._mapping.get(URI.from(resource).toString());
if (mainthreadNotebook) {
await this.notebookService.transformSpliceOutputs(mainthreadNotebook.textModel, splices);
mainthreadNotebook.textModel.$spliceNotebookCellOutputs(cellHandle, splices);
}
}
async executeNotebookByAttachedKernel(viewType: string, uri: URI, token: CancellationToken): Promise<void> { async executeNotebookByAttachedKernel(viewType: string, uri: URI, token: CancellationToken): Promise<void> {
return this._mainThreadNotebook.executeNotebookByAttachedKernel(viewType, uri, token); return this._mainThreadNotebook.executeNotebookByAttachedKernel(viewType, uri, token);
} }
...@@ -638,50 +649,8 @@ export class MainThreadNotebookController implements IMainNotebookController { ...@@ -638,50 +649,8 @@ export class MainThreadNotebookController implements IMainNotebookController {
this._proxy.$onDidReceiveMessage(editorId, rendererType, message); this._proxy.$onDidReceiveMessage(editorId, rendererType, message);
} }
async removeNotebookDocument(notebook: INotebookTextModel): Promise<void> { async removeNotebookDocument(uri: URI): Promise<void> {
let document = this._mapping.get(URI.from(notebook.uri).toString()); return this._mainThreadNotebook.removeNotebookTextModel(uri);
if (!document) {
return;
}
// TODO@rebornix, remove cell should use emitDelta as well to ensure document/editor events are sent together
await this._proxy.$acceptDocumentAndEditorsDelta({ removedDocuments: [notebook.uri] });
document.dispose();
this._mapping.delete(URI.from(notebook.uri).toString());
}
// Methods for ExtHost
handleNotebookChange(resource: UriComponents) {
let document = this._mapping.get(URI.from(resource).toString());
document?.textModel.handleUnknownChange();
}
handleEdit(resource: UriComponents, editId: number, label: string | undefined): void {
let document = this._mapping.get(URI.from(resource).toString());
if (document) {
document.textModel.$handleEdit(label, () => {
return this._proxy.$undoNotebook(document!.textModel.viewType, document!.textModel.uri, editId, document!.textModel.isDirty);
}, () => {
return this._proxy.$redoNotebook(document!.textModel.viewType, document!.textModel.uri, editId, document!.textModel.isDirty);
});
}
}
updateLanguages(resource: UriComponents, languages: string[]) {
let document = this._mapping.get(URI.from(resource).toString());
document?.textModel.updateLanguages(languages);
}
updateNotebookMetadata(resource: UriComponents, metadata: NotebookDocumentMetadata) {
let document = this._mapping.get(URI.from(resource).toString());
document?.textModel.updateNotebookMetadata(metadata);
}
updateNotebookCellMetadata(resource: UriComponents, handle: number, metadata: NotebookCellMetadata) {
let document = this._mapping.get(URI.from(resource).toString());
document?.textModel.updateNotebookCellMetadata(handle, metadata);
} }
async executeNotebookCell(uri: URI, handle: number, token: CancellationToken): Promise<void> { async executeNotebookCell(uri: URI, handle: number, token: CancellationToken): Promise<void> {
......
...@@ -423,6 +423,12 @@ export class NotebookService extends Disposable implements INotebookService, ICu ...@@ -423,6 +423,12 @@ export class NotebookService extends Disposable implements INotebookService, ICu
return modelData.model; return modelData.model;
} }
getNotebookTextModel(uri: URI): NotebookTextModel | undefined {
const modelId = MODEL_ID(uri);
return this._models.get(modelId)?.model;
}
private async _fillInTransformedOutputs<T>( private async _fillInTransformedOutputs<T>(
renderers: Set<string>, renderers: Set<string>,
requestItems: IOutputRenderRequestCellInfo<T>[], requestItems: IOutputRenderRequestCellInfo<T>[],
...@@ -837,7 +843,8 @@ export class NotebookService extends Disposable implements INotebookService, ICu ...@@ -837,7 +843,8 @@ export class NotebookService extends Disposable implements INotebookService, ICu
let provider = this._notebookProviders.get(modelData!.model.viewType); let provider = this._notebookProviders.get(modelData!.model.viewType);
if (provider) { if (provider) {
provider.controller.removeNotebookDocument(modelData!.model); provider.controller.removeNotebookDocument(modelData!.model.uri);
modelData!.model.dispose();
} }
......
...@@ -117,8 +117,8 @@ export class NotebookTextModel extends Disposable implements INotebookTextModel ...@@ -117,8 +117,8 @@ export class NotebookTextModel extends Disposable implements INotebookTextModel
public viewType: string, public viewType: string,
public supportBackup: boolean, public supportBackup: boolean,
public uri: URI, public uri: URI,
private _undoService: IUndoRedoService, @IUndoRedoService private _undoService: IUndoRedoService,
private _modelService: ITextModelService @ITextModelService private _modelService: ITextModelService
) { ) {
super(); super();
this.cells = []; this.cells = [];
......
...@@ -27,7 +27,7 @@ export interface IMainNotebookController { ...@@ -27,7 +27,7 @@ export interface IMainNotebookController {
executeNotebookByAttachedKernel(viewType: string, uri: URI, token: CancellationToken): Promise<void>; executeNotebookByAttachedKernel(viewType: string, uri: URI, token: CancellationToken): Promise<void>;
onDidReceiveMessage(editorId: string, rendererType: string | undefined, message: any): void; onDidReceiveMessage(editorId: string, rendererType: string | undefined, message: any): void;
executeNotebookCell(uri: URI, handle: number, token: CancellationToken): Promise<void>; executeNotebookCell(uri: URI, handle: number, token: CancellationToken): Promise<void>;
removeNotebookDocument(notebook: INotebookTextModel): Promise<void>; removeNotebookDocument(uri: URI): Promise<void>;
save(uri: URI, token: CancellationToken): Promise<boolean>; save(uri: URI, token: CancellationToken): Promise<boolean>;
saveAs(uri: URI, target: URI, token: CancellationToken): Promise<boolean>; saveAs(uri: URI, target: URI, token: CancellationToken): Promise<boolean>;
backup(uri: URI, token: CancellationToken): Promise<string | undefined>; backup(uri: URI, token: CancellationToken): Promise<string | undefined>;
...@@ -58,6 +58,7 @@ export interface INotebookService { ...@@ -58,6 +58,7 @@ export interface INotebookService {
getContributedNotebookKernels2(viewType: string, resource: URI, token: CancellationToken): Promise<INotebookKernelInfo2[]>; getContributedNotebookKernels2(viewType: string, resource: URI, token: CancellationToken): Promise<INotebookKernelInfo2[]>;
getRendererInfo(id: string): INotebookRendererInfo | undefined; getRendererInfo(id: string): INotebookRendererInfo | undefined;
resolveNotebook(viewType: string, uri: URI, forceReload: boolean, editorId?: string, backupId?: string): Promise<NotebookTextModel | undefined>; resolveNotebook(viewType: string, uri: URI, forceReload: boolean, editorId?: string, backupId?: string): Promise<NotebookTextModel | undefined>;
getNotebookTextModel(uri: URI): NotebookTextModel | undefined;
executeNotebook(viewType: string, uri: URI, token: CancellationToken): Promise<void>; executeNotebook(viewType: string, uri: URI, token: CancellationToken): Promise<void>;
executeNotebookCell(viewType: string, uri: URI, handle: number, token: CancellationToken): Promise<void>; executeNotebookCell(viewType: string, uri: URI, handle: number, token: CancellationToken): Promise<void>;
executeNotebook2(viewType: string, uri: URI, kernelId: string, token: CancellationToken): Promise<void>; executeNotebook2(viewType: string, uri: URI, kernelId: string, token: CancellationToken): Promise<void>;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册