當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript WorkspaceEdit.insert方法代碼示例

本文整理匯總了TypeScript中vscode.WorkspaceEdit.insert方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript WorkspaceEdit.insert方法的具體用法?TypeScript WorkspaceEdit.insert怎麽用?TypeScript WorkspaceEdit.insert使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在vscode.WorkspaceEdit的用法示例。


在下文中一共展示了WorkspaceEdit.insert方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: async

		saveText: async (text: string) => {
			const filename = await utils.createFile('', getFixturePath([
				rule,
				value,
				'test'
			]));
			const doc = await workspace.openTextDocument(filename);
			await window.showTextDocument(doc);
			const edit = new WorkspaceEdit();
			edit.insert(doc.uri, new Position(0, 0), text);
			assert.strictEqual(
				await workspace.applyEdit(edit),
				true,
				'applies edit'
			);
			return await new Promise(resolve => {
				let saveCount = 0;
				workspace.onDidSaveTextDocument(savedDoc => {
					if (++saveCount === (options.saves || 1)) {
						resolve(savedDoc.getText());
					}
				});
				doc.save();
			});
		}
開發者ID:SamVerschueren,項目名稱:editorconfig-vscode,代碼行數:25,代碼來源:index.test.ts

示例2: applyUsingWorkspaceEdit

	// Applies Edits to given WorkspaceEdit
	applyUsingWorkspaceEdit(workspaceEdit: WorkspaceEdit, fileUri: Uri): void {
		switch (this.action) {
			case EditTypes.EDIT_INSERT:
				workspaceEdit.insert(fileUri, this.start, this.text);
				break;

			case EditTypes.EDIT_DELETE:
				workspaceEdit.delete(fileUri, new Range(this.start, this.end));
				break;

			case EditTypes.EDIT_REPLACE:
				workspaceEdit.replace(fileUri, new Range(this.start, this.end), this.text);
				break;
		}
	}
開發者ID:leaxoy,項目名稱:vscode-go,代碼行數:16,代碼來源:diffUtils.ts

示例3: createDoc

			return new Promise<string>(async resolve => {
				const doc = await createDoc(options.contents);
				workspace.onDidChangeTextDocument(doc.save);
				workspace.onDidSaveTextDocument(savedDoc => {
					assert.strictEqual(savedDoc.isDirty, false, 'dirty saved doc');
					resolve(savedDoc.getText());
				});
				const edit = new WorkspaceEdit();
				edit.insert(doc.uri, new Position(0, 0), text);
				assert.strictEqual(
					await workspace.applyEdit(edit),
					true,
					'editor fails to apply edit'
				);
			});
開發者ID:jedmao,項目名稱:editorconfig-vscode,代碼行數:15,代碼來源:index.test.ts

示例4: async

		saveText: async (text: string) => {
			const doc = await createDoc();
			const edit = new WorkspaceEdit();
			edit.insert(doc.uri, new Position(0, 0), text);
			assert.strictEqual(
				await workspace.applyEdit(edit),
				true,
				'applies edit'
			);
			return await new Promise(resolve => {
				workspace.onDidSaveTextDocument(savedDoc => {
					resolve(savedDoc.getText());
				});
				doc.save();
			});
		}
開發者ID:rlugojr,項目名稱:editorconfig-vscode,代碼行數:16,代碼來源:index.test.ts

示例5: onDocumentOpen

function onDocumentOpen(td: TextDocument) {
	let extension = extname(td.fileName);
	if (extension != ".wurst" && extension != ".jurst") {
		return;
	}
	if (td.lineCount > 1 || td.getText().length > 0) {
		return;
	}

	let packageName = basename(td.fileName, extension);
	let newText = `package ${packageName}\n\n`;

	let edit = new WorkspaceEdit()
	edit.insert(td.uri, new Position(1,1), newText)
	workspace.applyEdit(edit);


}
開發者ID:peq,項目名稱:wurst4vscode,代碼行數:18,代碼來源:fileCreation.ts

示例6: addNewLine

  public addNewLine(document: TextDocument) {
    // get the line count
    let lineCount = document.lineCount;
    console.log('lineCount: ' + lineCount);

    let allText = document.getText();
    let matches = allText.match(/\r?\n$/);
    if (matches) {
      return;
    }

    let workspaceConfiguration = workspace.getConfiguration('editor');
    let lineEnding: string = workspaceConfiguration.get<string>('lineEnding');

    let uri = document.uri;

    let workspaceEdit = new WorkspaceEdit();
    let position = new Position(lineCount, 0);
    workspaceEdit.insert(uri, position, lineEnding);
    workspace.applyEdit(workspaceEdit).then(function() {
      document.save();
    });
  }
開發者ID:jdforsythe,項目名稱:vscode-add-new-line-to-files,代碼行數:23,代碼來源:extension.ts

示例7: test

  test('jj -> <Esc> through modehandler', async () => {
    const expectedDocumentContent = 'lorem ipsum';

    // setup
    await setupWithBindings({
      insertModeKeyBindings: defaultInsertModeKeyBindings,
      normalModeKeyBindings: defaultNormalModeKeyBindings,
      visualModeKeyBindings: defaultVisualModeKeyBindings,
    });

    let remapper = new Remappers();

    const edit = new vscode.WorkspaceEdit();
    edit.insert(
      vscode.window.activeTextEditor!.document.uri,
      new vscode.Position(0, 0),
      expectedDocumentContent
    );
    vscode.workspace.applyEdit(edit);

    await modeHandler.handleKeyEvent('i');
    assertEqual(modeHandler.currentMode.name, ModeName.Insert);

    // act
    let actual = false;
    try {
      actual = await remapper.sendKey(['j', 'j'], modeHandler, modeHandler.vimState);
    } catch (e) {
      assert.fail(e);
    }

    // assert
    assert.equal(actual, true);
    assertEqual(modeHandler.currentMode.name, ModeName.Normal);
    assert.equal(vscode.window.activeTextEditor!.document.getText(), expectedDocumentContent);
  });
開發者ID:arussellk,項目名稱:Vim,代碼行數:36,代碼來源:remapper.test.ts


注:本文中的vscode.WorkspaceEdit.insert方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。