aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/projectexplorer/userfileaccessor.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/plugins/projectexplorer/userfileaccessor.cpp')
-rw-r--r--src/plugins/projectexplorer/userfileaccessor.cpp9
1 files changed, 4 insertions, 5 deletions
diff --git a/src/plugins/projectexplorer/userfileaccessor.cpp b/src/plugins/projectexplorer/userfileaccessor.cpp
index 17ab86214e..8b40e798c3 100644
--- a/src/plugins/projectexplorer/userfileaccessor.cpp
+++ b/src/plugins/projectexplorer/userfileaccessor.cpp
@@ -342,10 +342,9 @@ static QString generateSuffix(const QString &suffix)
static inline Utils::optional<QString> defineExternalUserFileDir()
{
static const char userFilePathVariable[] = "QTC_USER_FILE_PATH";
- static QString userFilePath = QFile::decodeName(qgetenv(userFilePathVariable));
- if (userFilePath.isEmpty())
- return QString();
- const QFileInfo fi(userFilePath);
+ if (Q_LIKELY(!qEnvironmentVariableIsSet(userFilePathVariable)))
+ return nullopt;
+ const QFileInfo fi(QFile::decodeName(qgetenv(userFilePathVariable)));
const QString path = fi.absoluteFilePath();
if (fi.isDir() || fi.isSymLink())
return path;
@@ -395,7 +394,7 @@ static FileName externalUserFilePath(const Utils::FileName &projectFilePath, con
FileName result;
static const optional<QString> externalUserFileDir = defineExternalUserFileDir();
- if (!externalUserFileDir) {
+ if (externalUserFileDir) {
// Recreate the relative project file hierarchy under the shared directory.
// PersistentSettingsWriter::write() takes care of creating the path.
result = FileName::fromString(externalUserFileDir.value());