【问题标题】:Unix Qt 5.6 QSettings cannot find QSettings::SystemScope configuration fileUnix Qt 5.6 QSettings 找不到 QSettings::SystemScope 配置文件
【发布时间】:2023-03-10 09:14:01
【问题描述】:

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 文件的falling back,因为 ASSUMED_USER_CONFIG 文件不存在。因此,“the_value”可以从设置文件中正确检索。

但是,当使用 Qt 5.6 编译时,设置 'filename' 似乎在 'c' 和 'd' 的情况下构造不正确(正确的路径被附加到 "/home/user/Qt5.6/5.6/ gcc_64”)。因此,无法从设置文件中检索“the_value”。

我没有覆盖 Qt Creator 中的任何默认环境变量,并且 Qt 5.6 是由 Qt 维护工具自动安装的。我知道我可以使用环境变量 XDG_CONFIG_HOME 来设置 QSettings::SystemScope 文件的绝对路径,但我认为我不应该这样做。

要重申主要问题,如何将 ASSUMED_SYSTEM_CONFIG 文件(即 QSettings::SystemScope)与 QSettings 一起使用?

还有其他人反对这个吗?我已经在两台不同的机器上进行了测试。

【问题讨论】:

  • 看起来需要在 Qt 错误跟踪器中报告。
  • @Frank。这是个好主意。
  • @vincent,请更新您的问题并提供错误报告链接
  • @user1034749 我刚刚在帖子顶部添加了错误报告的链接。

标签: c++ qt qsettings


【解决方案1】:

这是预编译的 linux 二进制文件的问题。如果你从源代码编译 Qt 5.6,你可以通过编译带有标志 '-sysconfdir=/etc' 的 Qt 来避免这个问题。

如果这不是一个选项,您可以设置环境变量 XDG_CONFIG_HOME。

This bug should now be fixed in the Qt 5.6.1 snapshot

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2013-04-18
    • 2013-12-12
    • 2015-12-25
    • 1970-01-01
    • 1970-01-01
    • 2017-11-16
    • 2011-05-01
    • 2014-09-10
    相关资源
    最近更新 更多