Unix Qt 5.6 QSettings не может найти файл конфигурации QSettings::SystemScope

Ссылка на отчет об ошибке Qt: QTBUG-53313

Переход с Qt 5.5 на Qt 5.6 представляет проблему с QSettings, когда он не может найти файл конфигурации QSettings в области системы. В main.cpp ниже QSettings инициализируется различными способами, затем запрашиваются его свойства:

// File: main.cpp

#include <QApplication>
#include <QDebug>
#include <QSettings>
#include <QCoreApplication>

#define ASSUMED_SYSTEM_CONFIG "/etc/xdg/TheOrg/TheApp.conf"
#define ASSUMED_USER_CONFIG "/home/user/.config/TheOrg/TheApp.conf"

void print_info(const QSettings& settings, const char& use_case);

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);

    QCoreApplication::setOrganizationName("TheOrg");
    QCoreApplication::setApplicationName("TheApp");

    QSettings settings_a;
    QSettings settings_b("TheOrg", "TheApp");
    QSettings settings_c(QSettings::SystemScope, "TheOrg", "TheApp");
    QSettings settings_d(QSettings::NativeFormat, QSettings::SystemScope, "TheOrg", "TheApp");

    print_info(settings_a, 'a');    
    print_info(settings_b, 'b');    
    print_info(settings_c, 'c');    
    print_info(settings_d, 'd');

    return a.exec();
}

void print_info(const QSettings& settings, const char& use_case)
{
    int value = settings.value("the_value").toInt();

    qDebug() << "Using case (" << use_case << ")";

    qDebug() << "The value is " << value;

    qDebug() << "Settings scope is: " << ((settings.scope() == QSettings::SystemScope) ? "System" : "User");
    qDebug() << "Settings organization is: " << settings.organizationName();
    qDebug() << "Settings application name is: " << settings.applicationName();
    qDebug() << "Settings fallbackEnabled is: " << settings.fallbacksEnabled();
    qDebug() << "Settings filename is: " << settings.fileName() << "\n";
}

Файл ASSUMED_USER_CONFIG не существует в системе.

Файл ASSUMED_SYSTEM_CONFIG существует в системе и содержит:

the_value = 42

Скомпилированная с Qt 5.5, программа возвращает:

Using case ( a )
The value is  42
Settings scope is:  User
Settings organization is:  "TheOrg"
Settings application name is:  "TheApp"
Settings fallbackEnabled is:  true
Settings filename is:  "/home/user/.config/TheOrg/TheApp.conf" 

Using case ( b )
The value is  42
Settings scope is:  User
Settings organization is:  "TheOrg"
Settings application name is:  "TheApp"
Settings fallbackEnabled is:  true
Settings filename is:  "/home/user/.config/TheOrg/TheApp.conf" 

Using case ( c )
The value is  42
Settings scope is:  System
Settings organization is:  "TheOrg"
Settings application name is:  "TheApp"
Settings fallbackEnabled is:  true
Settings filename is:  "/etc/xdg/TheOrg/TheApp.conf" 

Using case ( d )
The value is  42
Settings scope is:  System
Settings organization is:  "TheOrg"
Settings application name is:  "TheApp"
Settings fallbackEnabled is:  true
Settings filename is:  "/etc/xdg/TheOrg/TheApp.conf" 

Скомпилированная с Qt 5.6, программа возвращает:

Using case ( a )
The value is  0
Settings scope is:  User
Settings organization is:  "TheOrg"
Settings application name is:  "TheApp"
Settings fallbackEnabled is:  true
Settings filename is:  "/home/user/.config/TheOrg/TheApp.conf" 

Using case ( b )
The value is  0
Settings scope is:  User
Settings organization is:  "TheOrg"
Settings application name is:  "TheApp"
Settings fallbackEnabled is:  true
Settings filename is:  "/home/user/.config/TheOrg/TheApp.conf" 

Using case ( c )
The value is  0
Settings scope is:  System
Settings organization is:  "TheOrg"
Settings application name is:  "TheApp"
Settings fallbackEnabled is:  true
Settings filename is:  "/home/user/Qt5.6/5.6/gcc_64/etc/xdg/TheOrg/TheApp.conf" 

Using case ( d )
The value is  0
Settings scope is:  System
Settings organization is:  "TheOrg"
Settings application name is:  "TheApp"
Settings fallbackEnabled is:  true
Settings filename is:  "/home/user/Qt5.6/5.6/gcc_64/etc/xdg/TheOrg/TheApp.conf" 

Здесь есть несколько вопросов:

Когда скомпилировано с Qt 5.5, "имя файла" настроек создается так, как ожидается для всех случаев (a,b,c,d). Случаи "a" и "b" возвращаются к файлу ASSUMED_SYSTEM_CONFIG, поскольку файл ASSUMED_USER_CONFIG не существует. Из-за этого the_value правильно извлекается из файла настроек.

Тем не менее, при компиляции с Qt 5.6 параметры 'имя файла', похоже, создаются неправильно для случаев 'c' и 'd' (правильный путь добавляется в "/home/user/Qt5.6/5.6/gcc_64"), Из-за этого "the_value" не может быть получено из файла настроек.

Я не переопределил никакие переменные среды по умолчанию в Qt Creator, и Qt 5.6 был установлен автоматически с помощью инструмента Qt Maintenance. Я знаю, что могу использовать переменную окружения, XDG_CONFIG_HOME, чтобы установить абсолютный путь к файлу QSettings::SystemScope, но я не думаю, что должен это делать.

Чтобы переформулировать основную проблему, как я могу использовать файл ASSUMED_SYSTEM_CONFIG (то есть QSettings::SystemScope) с QSettings?

Кто-нибудь еще сталкивался с этим? Я проверил это на двух отдельных машинах.

1 ответ

Решение

Это проблема для скомпилированных исполняемых файлов Linux. Если вы компилируете Qt 5.6 из исходного кода, вы можете избежать этой проблемы, скомпилировав Qt с флагом '-sysconfdir=/etc'.

Если это не вариант, вы можете установить переменную окружения, XDG_CONFIG_HOME.

Эта ошибка теперь должна быть исправлена ​​в снимке Qt 5.6.1.

Другие вопросы по тегам