diff --git a/resources/linux/bin/code.sh b/resources/linux/bin/code.sh index ce8e57287591a..4df71021fa865 100755 --- a/resources/linux/bin/code.sh +++ b/resources/linux/bin/code.sh @@ -5,21 +5,6 @@ ARGS=$@ -# If root, ensure that --user-data-dir is specified -if [ "$(id -u)" = "0" ]; then - while test $# -gt 0 - do - if [[ $1 == --user-data-dir=* ]]; then - DATA_DIR_SET=1 - fi - shift - done - if [ -z $DATA_DIR_SET ]; then - echo "It is recommended to start vscode as a normal user. To run as root, you must specify an alternate user data directory with the --user-data-dir argument." 1>&2 - exit 1 - fi -fi - if [ ! -L $0 ]; then # if path is not a symlink, find relatively VSCODE_PATH="$(dirname $0)/.." diff --git a/src/main.js b/src/main.js index 362345c3ff19c..50225e69766c7 100644 --- a/src/main.js +++ b/src/main.js @@ -9,6 +9,7 @@ global.vscodeStart = Date.now(); var app = require('electron').app; var fs = require('fs'); var path = require('path'); +var product = require('../product.json'); function stripComments(content) { var regexp = /("(?:[^\\\"]*(?:\\.)?)*")|('(?:[^\\\']*(?:\\.)?)*')|(\/\*(?:\r?\n|.)*?\*\/)|(\/{2,}.*?(?:(?:\r?\n)|$))/g; @@ -95,6 +96,26 @@ function getNLSConfiguration() { return { locale: initialLocale, availableLanguages: {} }; } +function migrateUserDataDir(newDir) { + var oldDir = path.join(process.env.HOME, '.config', product.nameShort); + if (!fs.existsSync(oldDir)) { + return; + } + mkdirp(path.dirname(newDir)); + fs.renameSync(oldDir, newDir); +} + +function mkdirp(newDir) { + var stack = []; + while (!fs.existsSync(newDir)) { + stack.push(newDir); + newDir = path.dirname(newDir); + } + while (stack.length > 0) { + fs.mkdirSync(stack.pop()); + } +} + // Update cwd based on environment and platform try { if (process.platform === 'win32') { @@ -107,12 +128,23 @@ try { console.error(err); } -// Set path according to being built or not +// If root user, use a root-owned directory for user data +var configDir = path.join(process.env.HOME, product.dataFolderName); if (process.env.VSCODE_DEV) { - var appData = app.getPath('appData'); - app.setPath('userData', path.join(appData, 'Code-Development')); + configDir += '-dev'; +} +var userDataDir = path.join(configDir, 'user-data'); +if (process.getuid() === 0) { + userDataDir += '-root'; } +// Attempt migrations if userDataDir does not exist +if (!fs.existsSync(userDataDir)) { + migrateUserDataDir(userDataDir); +} + +app.setPath('userData', userDataDir); + // Use custom user data dir if specified, required to run as root on Linux var args = process.argv; args.forEach(function (arg) {