Skip to content

Commit

Permalink
Merge branch 'master' into isidorn/multiRootLaunch
Browse files Browse the repository at this point in the history
  • Loading branch information
isidorn committed Jan 23, 2018
2 parents 82532ab + 4f5b23e commit 32fcea6
Show file tree
Hide file tree
Showing 6 changed files with 123 additions and 45 deletions.
23 changes: 18 additions & 5 deletions build/win32/code.iss
Original file line number Diff line number Diff line change
Expand Up @@ -971,13 +971,18 @@ begin
Result := not IsBackgroundUpdate();
end;
// VS Code will create a flag file before the update starts (/update=C:\foo\bar)
// - if the file exists at this point, the user quit Code before the update finished, so don't start Code after update
// - otherwise, the user has accepted to apply the update and Code should start
function LockFileExists(): Boolean;
begin
Result := FileExists(ExpandConstant('{param:update}'))
end;
function ShouldRunAfterUpdate(): Boolean;
begin
if IsBackgroundUpdate() then
// VS Code will create a flag file before the update starts (/update=C:\foo\bar)
// - if the file exists at this point, the user quit Code before the update finished, so don't start Code after update
// - otherwise, the user has accepted to apply the update and Code should start
Result := not FileExists(ExpandConstant('{param:update}'))
Result := not LockFileExists()
else
Result := True;
end;
Expand All @@ -998,6 +1003,14 @@ begin
Result := ExpandConstant('{app}');
end;
function BoolToStr(Value: Boolean): String;
begin
if Value then
Result := 'true'
else
Result := 'false';
end;
procedure CurStepChanged(CurStep: TSetupStep);
var
UpdateResultCode: Integer;
Expand All @@ -1012,7 +1025,7 @@ begin
Sleep(1000);
end;
Exec(ExpandConstant('{app}\inno_updater.exe'), ExpandConstant('--apply-update _ "{app}\unins000.dat"'), '', SW_SHOW, ewWaitUntilTerminated, UpdateResultCode);
Exec(ExpandConstant('{app}\inno_updater.exe'), ExpandConstant('_ "{app}\unins000.dat" ' + BoolToStr(LockFileExists())), '', SW_SHOW, ewWaitUntilTerminated, UpdateResultCode);
end;
end;
Expand Down
Binary file modified build/win32/inno_updater.exe
Binary file not shown.
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ import { Workspace } from 'vs/platform/workspace/common/workspace';
import { StrictResourceMap } from 'vs/base/common/map';
import URI from 'vs/base/common/uri';

export class WorkspaceSettingsModel extends ConfigurationModel {
export class SettingsModel extends ConfigurationModel {

private _unsupportedKeys: string[];

Expand All @@ -32,30 +32,49 @@ export class WorkspaceSettingsModel extends ConfigurationModel {
export class WorkspaceConfigurationModelParser extends ConfigurationModelParser {

private _folders: IStoredWorkspaceFolder[] = [];
private _workspaceSettingsModelParser: FolderSettingsModelParser;
private _settingsModelParser: FolderSettingsModelParser;
private _launchModel: ConfigurationModel;

constructor(name: string) {
super(name);
this._workspaceSettingsModelParser = new FolderSettingsModelParser(name);
this._settingsModelParser = new FolderSettingsModelParser(name);
this._launchModel = new ConfigurationModel();
}

get folders(): IStoredWorkspaceFolder[] {
return this._folders;
}

get workspaceSettingsModel(): WorkspaceSettingsModel {
return this._workspaceSettingsModelParser.folderSettingsModel;
get settingsModel(): SettingsModel {
return this._settingsModelParser.settingsModel;
}

get launchModel(): ConfigurationModel {
return this._launchModel;
}

reprocessWorkspaceSettings(): void {
this._workspaceSettingsModelParser.reprocess();
this._settingsModelParser.reprocess();
}

protected parseRaw(raw: any): IConfigurationModel {
this._folders = (raw['folders'] || []) as IStoredWorkspaceFolder[];
this._workspaceSettingsModelParser.parse(raw['settings']);
this._settingsModelParser.parse(raw['settings']);
this._launchModel = this.createConfigurationModelFrom(raw, 'launch');
return super.parseRaw(raw);
}

private createConfigurationModelFrom(raw: any, key: string): ConfigurationModel {
const data = raw[key];
if (data) {
const contents = toValuesTree(data, message => console.error(`Conflict in settings file ${this._name}: ${message}`));
const scopedContents = Object.create(null);
scopedContents[key] = contents;
const keys = Object.keys(data).map(k => `${key}.${k}`);
return new ConfigurationModel(scopedContents, keys, []);
}
return new ConfigurationModel();
}
}

export class StandaloneConfigurationModelParser extends ConfigurationModelParser {
Expand All @@ -77,7 +96,7 @@ export class StandaloneConfigurationModelParser extends ConfigurationModelParser
export class FolderSettingsModelParser extends ConfigurationModelParser {

private _raw: any;
private _workspaceSettingsModel: WorkspaceSettingsModel;
private _settingsModel: SettingsModel;

constructor(name: string, private configurationScope?: ConfigurationScope) {
super(name);
Expand All @@ -89,11 +108,11 @@ export class FolderSettingsModelParser extends ConfigurationModelParser {
}

get configurationModel(): ConfigurationModel {
return this._workspaceSettingsModel || new WorkspaceSettingsModel({}, [], [], []);
return this._settingsModel || new SettingsModel({}, [], [], []);
}

get folderSettingsModel(): WorkspaceSettingsModel {
return <WorkspaceSettingsModel>this.configurationModel;
get settingsModel(): SettingsModel {
return <SettingsModel>this.configurationModel;
}

reprocess(): void {
Expand All @@ -114,7 +133,7 @@ export class FolderSettingsModelParser extends ConfigurationModelParser {
}
}
const configurationModel = this.parseRaw(rawWorkspaceSettings);
this._workspaceSettingsModel = new WorkspaceSettingsModel(configurationModel.contents, configurationModel.keys, configurationModel.overrides, unsupportedKeys);
this._settingsModel = new SettingsModel(configurationModel.contents, configurationModel.keys, configurationModel.overrides, unsupportedKeys);
}

private getScope(key: string, configurationProperties: { [qualifiedKey: string]: IConfigurationPropertySchema }): ConfigurationScope {
Expand Down
41 changes: 23 additions & 18 deletions src/vs/workbench/services/configuration/node/configuration.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ import { FileChangeType, FileChangesEvent } from 'vs/platform/files/common/files
import { isLinux } from 'vs/base/common/platform';
import { ConfigWatcher } from 'vs/base/node/config';
import { ConfigurationModel, ConfigurationModelParser } from 'vs/platform/configuration/common/configurationModels';
import { WorkspaceConfigurationModelParser, FolderSettingsModelParser, StandaloneConfigurationModelParser, WorkspaceSettingsModel } from 'vs/workbench/services/configuration/common/configurationModels';
import { WorkspaceConfigurationModelParser, FolderSettingsModelParser, StandaloneConfigurationModelParser } from 'vs/workbench/services/configuration/common/configurationModels';
import { WORKSPACE_STANDALONE_CONFIGURATIONS, FOLDER_SETTINGS_PATH, TASKS_CONFIGURATION_KEY, LAUNCH_CONFIGURATION_KEY } from 'vs/workbench/services/configuration/common/configuration';
import { IStoredWorkspace, IStoredWorkspaceFolder } from 'vs/platform/workspaces/common/workspaces';
import * as extfs from 'vs/base/node/extfs';
Expand Down Expand Up @@ -82,6 +82,9 @@ export class WorkspaceConfiguration extends Disposable {
private _onDidUpdateConfiguration: Emitter<void> = this._register(new Emitter<void>());
public readonly onDidUpdateConfiguration: Event<void> = this._onDidUpdateConfiguration.event;

private _workspaceConfigurationModelParser: WorkspaceConfigurationModelParser = new WorkspaceConfigurationModelParser(this._workspaceConfigPath ? this._workspaceConfigPath.fsPath : '');
private _cache: ConfigurationModel = new ConfigurationModel();

load(workspaceConfigPath: URI): TPromise<void> {
if (this._workspaceConfigPath && this._workspaceConfigPath.fsPath === workspaceConfigPath.fsPath) {
return this.reload();
Expand All @@ -98,20 +101,17 @@ export class WorkspaceConfiguration extends Disposable {
onError: error => errors.onUnexpectedError(error),
defaultConfig,
parse: (content: string, parseErrors: any[]) => {
const workspaceConfigurationModel = new WorkspaceConfigurationModelParser(this._workspaceConfigPath.fsPath);
workspaceConfigurationModel.parse(content);
parseErrors = [...workspaceConfigurationModel.errors];
return workspaceConfigurationModel;
this._workspaceConfigurationModelParser = new WorkspaceConfigurationModelParser(this._workspaceConfigPath.fsPath);
this._workspaceConfigurationModelParser.parse(content);
parseErrors = [...this._workspaceConfigurationModelParser.errors];
this.consolidate();
return this._workspaceConfigurationModelParser;
}, initCallback: () => c(null)
});
this.listenToWatcher();
});
}

private get workspaceConfigurationModelParser(): WorkspaceConfigurationModelParser {
return this._workspaceConfigurationWatcher ? this._workspaceConfigurationWatcher.getConfig() : new WorkspaceConfigurationModelParser(this._workspaceConfigPath ? this._workspaceConfigPath.fsPath : '');
}

reload(): TPromise<void> {
this.stopListeningToWatcher();
return new TPromise<void>(c => this._workspaceConfigurationWatcher.reload(() => {
Expand All @@ -121,7 +121,7 @@ export class WorkspaceConfiguration extends Disposable {
}

getFolders(): IStoredWorkspaceFolder[] {
return this.workspaceConfigurationModelParser.folders;
return this._workspaceConfigurationModelParser.folders;
}

setFolders(folders: IStoredWorkspaceFolder[], jsonEditingService: JSONEditingService): TPromise<void> {
Expand All @@ -130,15 +130,16 @@ export class WorkspaceConfiguration extends Disposable {
}

getConfiguration(): ConfigurationModel {
return this.workspaceConfigurationModelParser.workspaceSettingsModel;
return this._cache;
}

getWorkspaceSettings(): WorkspaceSettingsModel {
return this.workspaceConfigurationModelParser.workspaceSettingsModel;
getUnsupportedKeys(): string[] {
return this._workspaceConfigurationModelParser.settingsModel.unsupportedKeys;
}

reprocessWorkspaceSettings(): ConfigurationModel {
this.workspaceConfigurationModelParser.reprocessWorkspaceSettings();
this._workspaceConfigurationModelParser.reprocessWorkspaceSettings();
this.consolidate();
return this.getConfiguration();
}

Expand All @@ -151,6 +152,10 @@ export class WorkspaceConfiguration extends Disposable {
this._workspaceConfigurationWatcherDisposables = dispose(this._workspaceConfigurationWatcherDisposables);
}

private consolidate(): void {
this._cache = this._workspaceConfigurationModelParser.settingsModel.merge(this._workspaceConfigurationModelParser.launchModel);
}

dispose(): void {
dispose(this._workspaceConfigurationWatcherDisposables);
super.dispose();
Expand Down Expand Up @@ -190,20 +195,20 @@ export class FolderConfiguration extends Disposable {
}

reprocess(): ConfigurationModel {
const oldContents = this._folderSettingsModelParser.folderSettingsModel.contents;
const oldContents = this._folderSettingsModelParser.settingsModel.contents;
this._folderSettingsModelParser.reprocess();
if (!equals(oldContents, this._folderSettingsModelParser.folderSettingsModel.contents)) {
if (!equals(oldContents, this._folderSettingsModelParser.settingsModel.contents)) {
this.consolidate();
}
return this._cache;
}

getUnsupportedKeys(): string[] {
return this._folderSettingsModelParser.folderSettingsModel.unsupportedKeys;
return this._folderSettingsModelParser.settingsModel.unsupportedKeys;
}

private consolidate(): void {
this._cache = this._folderSettingsModelParser.folderSettingsModel.merge(...this._standAloneConfigurations);
this._cache = this._folderSettingsModelParser.settingsModel.merge(...this._standAloneConfigurations);
}

private loadWorkspaceConfigFiles(): TPromise<{ [relativeWorkspacePath: string]: ConfigurationModelParser }> {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -279,7 +279,7 @@ export class WorkspaceService extends Disposable implements IWorkspaceConfigurat
}

getUnsupportedWorkspaceKeys(): string[] {
const unsupportedWorkspaceKeys = [...this.workspaceConfiguration.getWorkspaceSettings().unsupportedKeys];
const unsupportedWorkspaceKeys = [...this.workspaceConfiguration.getUnsupportedKeys()];
for (const folder of this.workspace.folders) {
unsupportedWorkspaceKeys.push(...this.cachedFolderConfigs.get(folder.uri).getUnsupportedKeys());
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1038,6 +1038,56 @@ suite('WorkspaceConfigurationService - Multiroot', () => {
});
});

test('get launch configuration', () => {
const expectedLaunchConfiguration = {
'version': '0.1.0',
'configurations': [
{
'type': 'node',
'request': 'launch',
'name': 'Gulp Build',
'program': '${workspaceFolder}/node_modules/gulp/bin/gulp.js',
'stopOnEntry': true,
'args': [
'watch-extension:json-client'
],
'cwd': '${workspaceFolder}'
}
]
};
return jsonEditingServce.write(workspaceContextService.getWorkspace().configuration, { key: 'launch', value: expectedLaunchConfiguration }, true)
.then(() => testObject.reloadConfiguration())
.then(() => {
const actual = testObject.getValue('launch');
assert.deepEqual(actual, expectedLaunchConfiguration);
});
});

test('inspect launch configuration', () => {
const expectedLaunchConfiguration = {
'version': '0.1.0',
'configurations': [
{
'type': 'node',
'request': 'launch',
'name': 'Gulp Build',
'program': '${workspaceFolder}/node_modules/gulp/bin/gulp.js',
'stopOnEntry': true,
'args': [
'watch-extension:json-client'
],
'cwd': '${workspaceFolder}'
}
]
};
return jsonEditingServce.write(workspaceContextService.getWorkspace().configuration, { key: 'launch', value: expectedLaunchConfiguration }, true)
.then(() => testObject.reloadConfiguration())
.then(() => {
const actual = testObject.inspect('launch').workspace;
assert.deepEqual(actual, expectedLaunchConfiguration);
});
});

test('update user configuration', () => {
return testObject.updateValue('configurationService.workspace.testSetting', 'userValue', ConfigurationTarget.USER)
.then(() => assert.equal(testObject.getValue('configurationService.workspace.testSetting'), 'userValue'));
Expand Down Expand Up @@ -1102,13 +1152,4 @@ suite('WorkspaceConfigurationService - Multiroot', () => {
assert.equal(actual.workspace, void 0);
});
});

test('launch configurations are not read from workspace', () => {
return jsonEditingServce.write(workspaceContextService.getWorkspace().configuration, { key: 'launch', value: { 'version': '1.0' } }, true)
.then(() => testObject.reloadConfiguration())
.then(() => {
const actual = testObject.inspect('launch.version');
assert.equal(actual.workspace, void 0);
});
});
});

0 comments on commit 32fcea6

Please sign in to comment.