From 647ef09e9f579b698d7c2dabcffa55ce34682508 Mon Sep 17 00:00:00 2001 From: Ives van Hoorne Date: Wed, 8 Nov 2023 03:13:51 +0100 Subject: [PATCH] fix: use same paths as vscode for settings --- demo/src/main.ts | 4 +-- src/missing-services.ts | 51 ++++++++++++++++++----------------- src/service-override/files.ts | 2 -- 3 files changed, 29 insertions(+), 28 deletions(-) diff --git a/demo/src/main.ts b/demo/src/main.ts index 492defe4..d331007a 100644 --- a/demo/src/main.ts +++ b/demo/src/main.ts @@ -95,7 +95,7 @@ diagnostics.set(modelRef.object.textEditorModel!.uri, [{ code: 42 }]) -const settingsModelReference = await createModelReference(monaco.Uri.from({ scheme: 'user', path: '/settings.json' }), `{ +const settingsModelReference = await createModelReference(monaco.Uri.from({ scheme: 'user-store', path: '/User/settings.json' }), `{ "workbench.colorTheme": "Default Dark+", "workbench.iconTheme": "vs-seti", "editor.autoClosingBrackets": "languageDefined", @@ -134,7 +134,7 @@ settingEditor.addAction({ contextMenuGroupId: 'custom' }) -const keybindingsModelReference = await createModelReference(monaco.Uri.from({ scheme: 'user', path: '/keybindings.json' }), `[ +const keybindingsModelReference = await createModelReference(monaco.Uri.from({ scheme: 'user-store', path: '/User/keybindings.json' }), `[ { "key": "ctrl+d", "command": "editor.action.deleteLines", diff --git a/src/missing-services.ts b/src/missing-services.ts index 5d7f80fb..315517bc 100644 --- a/src/missing-services.ts +++ b/src/missing-services.ts @@ -28,7 +28,7 @@ import { IPreferencesService } from 'vs/workbench/services/preferences/common/pr import { IContextKeyService } from 'vs/platform/contextkey/common/contextkey' import { StandaloneServices } from 'vs/editor/standalone/browser/standaloneServices' import { ICodeEditorService } from 'vs/editor/browser/services/codeEditorService' -import { IUserDataProfile, IUserDataProfilesService } from 'vs/platform/userDataProfile/common/userDataProfile' +import { IUserDataProfilesService, toUserDataProfile } from 'vs/platform/userDataProfile/common/userDataProfile' import { IPolicyService } from 'vs/platform/policy/common/policy' import { IUserDataProfileImportExportService, IUserDataProfileService } from 'vs/workbench/services/userDataProfile/common/userDataProfile' import { UserDataProfileService } from 'vs/workbench/services/userDataProfile/common/userDataProfileService' @@ -172,6 +172,7 @@ import { BrowserHostService } from 'vs/workbench/services/host/browser/browserHo import { IBannerService } from 'vs/workbench/services/banner/browser/bannerService' import { ITitleService } from 'vs/workbench/services/title/common/titleService' import { IChatAgentService } from 'vs/workbench/contrib/chat/common/chatAgents' +import { joinPath } from 'vs/base/common/resources' import { unsupported } from './tools' import { getBuiltInExtensionTranslationsUris } from './l10n' @@ -504,9 +505,11 @@ registerSingleton(IUserDataInitializationService, class NullUserDataInitializati registerSingleton(IHostColorSchemeService, BrowserHostColorSchemeService, InstantiationType.Eager) -registerSingleton(IPreferencesService, class PreferencesService implements IPreferencesService { +class PreferencesService implements IPreferencesService { + constructor (@IUserDataProfileService protected readonly profileService: IUserDataProfileService) {} + _serviceBrand: undefined - userSettingsResource = profile.settingsResource + userSettingsResource = this.profileService.currentProfile.settingsResource workspaceSettingsResource = null getFolderSettingsResource = unsupported createPreferencesEditorModel = unsupported @@ -524,7 +527,9 @@ registerSingleton(IPreferencesService, class PreferencesService implements IPref createSplitJsonEditorInput = unsupported openApplicationSettings = unsupported openLanguageSpecificSettings = unsupported -}, InstantiationType.Eager) +} + +registerSingleton(IPreferencesService, PreferencesService, InstantiationType.Eager) registerSingleton(ITextMateTokenizationService, class NullTextMateService implements ITextMateTokenizationService { _serviceBrand: undefined @@ -534,21 +539,9 @@ registerSingleton(ITextMateTokenizationService, class NullTextMateService implem createTokenizer = unsupported }, InstantiationType.Eager) -const profile: IUserDataProfile = { - id: 'default', - isDefault: true, - name: 'default', - location: URI.from({ scheme: 'user', path: '/profile.json' }), - globalStorageHome: URI.from({ scheme: 'user', path: '/globalStorage' }), - settingsResource: URI.from({ scheme: 'user', path: '/settings.json' }), - keybindingsResource: URI.from({ scheme: 'user', path: '/keybindings.json' }), - tasksResource: URI.from({ scheme: 'user', path: '/tasks.json' }), - snippetsHome: URI.from({ scheme: 'user', path: '/snippets' }), - extensionsResource: URI.from({ scheme: 'user', path: '/extensions.json' }), - cacheHome: URI.from({ scheme: 'cache', path: '/' }) -} +class UserDataProfilesService implements IUserDataProfilesService { + constructor (@IUserDataProfileService protected readonly profileService: IUserDataProfileService) {} -registerSingleton(IUserDataProfilesService, class UserDataProfilesService implements IUserDataProfilesService { _serviceBrand: undefined onDidResetWorkspaces = Event.None isEnabled = () => false @@ -558,18 +551,28 @@ registerSingleton(IUserDataProfilesService, class UserDataProfilesService implem cleanUp = unsupported cleanUpTransientProfiles = unsupported get profilesHome () { return unsupported() } - defaultProfile = profile + defaultProfile = this.profileService.currentProfile onDidChangeProfiles = Event.None - profiles = [profile] + profiles = [this.profileService.currentProfile] createProfile = unsupported updateProfile = unsupported setProfileForWorkspace = unsupported - getProfile = () => profile + getProfile = () => this.profileService.currentProfile removeProfile = unsupported -}, InstantiationType.Eager) +} + +registerSingleton(IUserDataProfilesService, UserDataProfilesService, InstantiationType.Eager) class InjectedUserDataProfileService extends UserDataProfileService { - constructor () { - super(profile) + constructor (@IEnvironmentService environmentService: IEnvironmentService) { + super({ + ...toUserDataProfile( + '__default__profile__', + 'Default', + environmentService.userRoamingDataHome, + joinPath(environmentService.cacheHome, 'CachedProfilesData') + ), + isDefault: true + }) } } registerSingleton(IUserDataProfileService, InjectedUserDataProfileService, InstantiationType.Eager) diff --git a/src/service-override/files.ts b/src/service-override/files.ts index 075c6fe5..352a9dda 100644 --- a/src/service-override/files.ts +++ b/src/service-override/files.ts @@ -462,9 +462,7 @@ fileSystemProvider.register(0, new MkdirpOnWriteInMemoryFileSystemProvider()) const extensionFileSystemProvider = new RegisteredFileSystemProvider(true) const providers: Record = { - user: new InMemoryFileSystemProvider(), extension: extensionFileSystemProvider, - cache: new InMemoryFileSystemProvider(), logs: new InMemoryFileSystemProvider(), [Schemas.vscodeUserData]: new InMemoryFileSystemProvider(), [Schemas.tmp]: new InMemoryFileSystemProvider(),