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.