当前位置: 首页>>代码示例>>TypeScript>>正文


TypeScript Memento.update方法代码示例

本文整理汇总了TypeScript中vscode.Memento.update方法的典型用法代码示例。如果您正苦于以下问题:TypeScript Memento.update方法的具体用法?TypeScript Memento.update怎么用?TypeScript Memento.update使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在vscode.Memento的用法示例。


在下文中一共展示了Memento.update方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。

示例1: switch

			.then(selected => {
				if (!selected) {
					return { oldVersion: this.currentVersion };
				}
				switch (selected.id) {
					case MessageAction.useLocal:
						return this.workspaceState.update(useWorkspaceTsdkStorageKey, true)
							.then(_ => {
								if (localVersion) {
									const previousVersion = this.currentVersion;

									this._currentVersion = localVersion;
									return { oldVersion: previousVersion, newVersion: localVersion };
								}
								return { oldVersion: this.currentVersion };
							});

					case MessageAction.useBundled:
						return this.workspaceState.update(useWorkspaceTsdkStorageKey, false)
							.then(_ => {
								const previousVersion = this.currentVersion;
								this._currentVersion = shippedVersion;
								return { oldVersion: previousVersion, newVersion: shippedVersion };
							});

					case MessageAction.learnMore:
						commands.executeCommand('vscode.open', Uri.parse('https://go.microsoft.com/fwlink/?linkid=839919'));
						return { oldVersion: this.currentVersion };

					default:
						return { oldVersion: this.currentVersion };
				}
			});
开发者ID:naturtle,项目名称:vscode,代码行数:33,代码来源:versionPicker.ts

示例2: show

	public async show(firstRun?: boolean): Promise<{ oldVersion?: TypeScriptVersion, newVersion?: TypeScriptVersion }> {
		const pickOptions: MyQuickPickItem[] = [];

		const shippedVersion = this.versionProvider.defaultVersion;
		pickOptions.push({
			label: (this.currentVersion.path === shippedVersion.path
				? '• '
				: '') + localize('useVSCodeVersionOption', 'Use VSCode\'s Version'),
			description: shippedVersion.version.versionString,
			detail: shippedVersion.label,
			id: MessageAction.useBundled
		});

		for (const version of this.versionProvider.localVersions) {
			pickOptions.push({
				label: (this.currentVersion.path === version.path
					? '• '
					: '') + localize('useWorkspaceVersionOption', 'Use Workspace Version'),
				description: version.version.versionString,
				detail: version.label,
				id: MessageAction.useLocal,
				version: version
			});
		}

		pickOptions.push({
			label: localize('learnMore', 'Learn More'),
			description: '',
			id: MessageAction.learnMore
		});

		const selected = await window.showQuickPick<MyQuickPickItem>(pickOptions, {
			placeHolder: localize(
				'selectTsVersion',
				'Select the TypeScript version used for JavaScript and TypeScript language features'),
			ignoreFocusOut: firstRun
		});

		if (!selected) {
			return { oldVersion: this.currentVersion };
		}

		switch (selected.id) {
			case MessageAction.useLocal:
				await this.workspaceState.update(useWorkspaceTsdkStorageKey, true);
				if (selected.version) {
					const tsConfig = workspace.getConfiguration('typescript');
					await tsConfig.update('tsdk', selected.version.label, false);

					const previousVersion = this.currentVersion;
					this._currentVersion = selected.version;
					return { oldVersion: previousVersion, newVersion: selected.version };
				}
				return { oldVersion: this.currentVersion };

			case MessageAction.useBundled:
				await this.workspaceState.update(useWorkspaceTsdkStorageKey, false);
				const previousVersion = this.currentVersion;
				this._currentVersion = shippedVersion;
				return { oldVersion: previousVersion, newVersion: shippedVersion };


			case MessageAction.learnMore:
				commands.executeCommand('vscode.open', Uri.parse('https://go.microsoft.com/fwlink/?linkid=839919'));
				return { oldVersion: this.currentVersion };

			default:
				return { oldVersion: this.currentVersion };
		}
	}
开发者ID:,项目名称:,代码行数:70,代码来源:


注:本文中的vscode.Memento.update方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。