使用Qt,c,c ++

时间:2018-01-17 01:00:07

标签: c++ c macos qt osx-snow-leopard

构建环境: QT 4.7OS X 10.6
运行环境: OS X 10.6OS X 10.13Windows XP及更晚

我正在使用一个非常大的,高度图形密集的QT应用程序。我需要找出我正在运行的OS X / MacOS版本 - 10.6 ... 10.10 ... 10.12等。

我在OS X中寻找 c c ++ 功能,我可以直播;这是一个运行时问题。它需要从10.6开始工作。我正在写 c ++ ,所以我可以像 c ++ 一样方便地使用 c 解决方案。

我有这个:

#ifdef Q_OS_WIN
    QApplication::setGraphicsSystem("raster");
#else
    QApplication::setGraphicsSystem("native");
#endif

以上工作用于确定我正在构建的Windows或OS X.在上面片段的else里面,我需要做一些进一步的检查;我不需要“原生”图形系统,除了OS X 10.12,QT“光栅”系统存在问题。我喜欢“光栅”系统,因为它更快,但后来的机器也更快,所以如果我只能在运行最近操作系统的现代机器上调用“原生”系统,那应该工作进行。

我有大量的用户 - 在早期版本的OS X下运行,因此这里使用的任何内容必须足够通用,以便在OS 10.6及更高版本的所有版本上运行。 QT 4.7本身似乎对它没有明确知道的操作系统版本毫无头绪;使用QSysInfo::MacVersion,它只会报告“未知操作系统版本。”

理想情况下,我想象以下形式:

int v = majorOSRevision();
int r = minorOSRevision();
int s = stepOSRevision();

OS X API中是否有这样直接,简单的调用?

2 个答案:

答案 0 :(得分:2)

您可以执行sw_vers之类的命令并阅读其输出。

示例代码,使用QProcess

<强> osxversion.h

#ifndef OSXVERSION_H
#define OSXVERSION_H

#include <QProcess>

class OSXVersion : public QProcess
{
    Q_OBJECT

    int majr;
    int minr;
    int step;

    OSXVersion();

public:

    int majorOSRevision() const { return majr; }
    int minorOSRevision() const { return minr; }
    int stepOSRevision() const { return step; }

    static OSXVersion * getVersion();

private slots:
    void dataReady();
};

#endif // OSXVERSION_H

<强> osxversion.cpp

#include "osxversion.h"

OSXVersion::OSXVersion() : QProcess(0)
{
    majr = 0;
    minr = 0;
    step = 0;
    connect(this, SIGNAL(readyRead()), this, SLOT(dataReady()));
}

OSXVersion * OSXVersion::getVersion()
{
    OSXVersion * v = new OSXVersion();
    v->start("sw_vers -productName");
    v->waitForFinished();
    return v;
}

void OSXVersion::dataReady()
{
    int * v[3] = {&majr, &minr, &step};

    QByteArray data = readAll();
    QList<QByteArray> tokens =  data.split(':');
    tokens = tokens[tokens.size() - 1].split('.');
    for(int i=0; i<tokens.size(); i++)
    {
        *(v[i]) = QString(tokens[i]).toInt();
    }
}

<强>的main.cpp

#include <QCoreApplication>
#include <QDebug>

#include "osxversion.h"

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

    OSXVersion * version = OSXVersion::getVersion();

    qDebug() << "OSX Version: "
             << version->majorOSRevision()
             << "."
             << version->minorOSRevision()
             << "."
             << version->stepOSRevision();

    delete version;

    return a.exec();
}

答案 1 :(得分:1)

OS X / macOS始终将其产品信息存储在一个确定的plist文件中,该文件位于 /System/Library/CoreServices/SystemVersion.plist

如果我们在High Sierra上查看此文件,我们可以看到以下内容

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>ProductBuildVersion</key>
    <string>17C205</string>
    <key>ProductCopyright</key>
    <string>1983-2018 Apple Inc.</string>
    <key>ProductName</key>
    <string>Mac OS X</string>
    <key>ProductUserVisibleVersion</key>
    <string>10.13.2</string>
    <key>ProductVersion</key>
    <string>10.13.2</string>
</dict>
</plist>

因为它是一个plist,根据给定的密钥使用Qt的QSettings来读取任何值

#include <QSettings>
QString getSysVersion()
{
    QSettings settings("/System/Library/CoreServices/SystemVersion.plist", QSettings::NativeFormat);
    return settings.value("ProductUserVisibleVersion").toString();
}

现在我们有QString版本,我们可以获得主要,次要和构建组件

QString version = getSysVersion();
QStringList components = version.split(".");
int maj = components[0].toInt();
int min = components[1].toInt();
int build = components[2].toInt();