-
Notifications
You must be signed in to change notification settings - Fork 2.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
core: enable portable-mode #12690
core: enable portable-mode #12690
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@msujew
Thank you for the review. I have changed all of the fs methods to their asynchronous version which makes more sense. However, I am running into a few issues I would like your thoughts on. Even after calling await this.makePortable()
at the beginning of the start method in electron-main-application.ts
, the Local State
file gets written to the appdata
under Theia Electron Example
instead of being written to the data
folder. Everything else seems to work fine, so I assume we are running into a race condition where Theia Electron Example
gets created and written to before making the electron application portable. I will keep digging into it, but do you have any idea why this might be happening ?
@vladarama I see, I wasn't aware of that. I assume that the I'm fine with changing the |
@vladarama This is ready for a re-review, correct? |
@JonasHelming |
This commit aims to address the following review comments: - Switching `fs` methods from synchronous to asynchronous - Caching the `configDirUri` - Avoid using process.cwd() as the application path Issues: switching from sync to async fs methods possibly leads to a race condition where some files get written to the `appdata` before we have the chance to make that folder portable. TO FIX !!! Signed-off-by: Vlad Arama <[email protected]>
This commit reverts the changes from the previous commit to avoid running into a race condition where the electron app fires its `ready` event before we can make the application portable. Signed-off-by: Vlad Arama <[email protected]>
This commit caches the pathExistence of the data folder, the user folder.
This commit caches the pathExistence of the data folder and user data folder in order to avoid accessing the disk on every call of `createConfigDirUri`. This should prevent possible performance regressions. Signed-off-by: Vlad Arama <[email protected]>
c22ea02
to
2a3c3e2
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks looks good to me 👍
Does this even work.. .it's a bit of mission to even try it.. why if if the 'data' folder is created, does it then need me to go messing about copy other folders which in turn require the user to go and install thiea and then run the app to create those default file folders.. etc, its all madness.. should just be an installer with a portable checkbox and then anywhere that is installed, is a portable version, all self contained. I don't mind copy files and folders from an existing setup if I wanted the replicate the same setup, it in portable manner but this is crazy.. and it doesn't even work from what I've tried... running this with that 'data' folder and copy the mentioned existing files and folders.. and it was still just saving/loading settings from the default user and not to the data folder I created. |
Portable Mode in Theia
Creating a
data
folder at the root of a Theia application will make it portable. So all of the app data and user data will get written to thedata
folder instead of their default locations.The
.theia
folder is moved from the user’s home directory (%userprofile%
or~/
) to a folder calleduser-data
inside thedata
folder.user-data
contains all of the settings, preferences and extensions.In addition, all of the application data which is stored by default inside a
Theia App Name (Theia Electron Example)
folder in (%appdata%
or~/.config
) is moved to a folder calledapp-data
inside thedata
folder.app-data
contains all of the application’s cache and layout information.Please refer to the following PR to further understand how the Portable mode is implemented in Theia Blueprint:
eclipse-theia/theia-ide#276
How to test
The following changes should make the
user-data
portable (settings, preferences, recent workspace ...).It also makes the
app-data
portable so all of the electron cache and layout information will be stored indata/app-data
instead of the default location.You can test that the portable mode is functional using the Electron Example Application.
yarn
andyarn electron build
data
folder inside/theia/examples/electron
.yarn electron start
.All of the
user-data
which is stored by default inside the user's directory will be stored inside of/theia/examples/electron/data/user-data
. In addition, all of theapp-data
which is stored by default in~/.config/Theia Electron Example or %appdata%/Theia Electron Example
will be stored inside of/theia/examples/electron/data/app-data
.Review checklist
Reminder for reviewers