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..3c34286d 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 { IUserDataProfile, 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,8 @@ 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 { Schemas } from 'vs/base/common/network' +import { joinPath } from 'vs/base/common/resources' import { unsupported } from './tools' import { getBuiltInExtensionTranslationsUris } from './l10n' @@ -534,18 +536,11 @@ registerSingleton(ITextMateTokenizationService, class NullTextMateService implem createTokenizer = unsupported }, InstantiationType.Eager) +const userRoamingDataHome = URI.from({ scheme: Schemas.vscodeUserData, path: '/User' }) +const defaultProfile = toUserDataProfile('__default__profile__', 'Default', userRoamingDataHome, joinPath(userRoamingDataHome, 'caches', 'CachedProfilesData')) 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: '/' }) + ...defaultProfile, + isDefault: true } registerSingleton(IUserDataProfilesService, class UserDataProfilesService implements IUserDataProfilesService { diff --git a/src/service-override/files.ts b/src/service-override/files.ts index eb89bdd3..33d2594e 100644 --- a/src/service-override/files.ts +++ b/src/service-override/files.ts @@ -462,11 +462,7 @@ class MemoryFileService extends FileService { constructor (@ILogService logService: ILogService) { super(logService) - const userMemoryFileSystem = new InMemoryFileSystemProvider() - - this.registerProvider('user', userMemoryFileSystem) this.registerProvider('extension', extensionFileSystemProvider) - this.registerProvider('cache', new InMemoryFileSystemProvider()) this.registerProvider('logs', new InMemoryFileSystemProvider()) this.registerProvider(Schemas.vscodeUserData, new InMemoryFileSystemProvider()) this.registerProvider(Schemas.tmp, new InMemoryFileSystemProvider())