mirror of
https://github.com/subsurface/subsurface.git
synced 2024-11-30 22:20:21 +00:00
cleanup: refactor subsurfacesysinfo.cpp
This used to be a copy of QSysInfo. However, once the requirement was raised to Qt5.4, this was replaced by a subclass of the original QSysInfo - which made the whole file mostly obsolete. Just use QSysInfo directly where needed. Only for windows.c, which can't call directly into Qt, keep the isWin7Or8() helper function. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
This commit is contained in:
parent
49fc05de7e
commit
d747d76762
4 changed files with 26 additions and 121 deletions
|
@ -8,7 +8,6 @@
|
||||||
#include "gettextfromc.h"
|
#include "gettextfromc.h"
|
||||||
#include "statistics.h"
|
#include "statistics.h"
|
||||||
#include "membuffer.h"
|
#include "membuffer.h"
|
||||||
#include "subsurfacesysinfo.h"
|
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
#include "errorhelper.h"
|
#include "errorhelper.h"
|
||||||
#include "planner.h"
|
#include "planner.h"
|
||||||
|
@ -40,6 +39,9 @@
|
||||||
#include <QProgressDialog> // TODO: remove with convertThumbnails()
|
#include <QProgressDialog> // TODO: remove with convertThumbnails()
|
||||||
#include <cstdarg>
|
#include <cstdarg>
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
|
#ifdef Q_OS_UNIX
|
||||||
|
#include <sys/utsname.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <libxslt/documents.h>
|
#include <libxslt/documents.h>
|
||||||
|
|
||||||
|
@ -420,11 +422,19 @@ QString getUserAgent()
|
||||||
#else
|
#else
|
||||||
QString userAgent = QString("Subsurface:%1:").arg(subsurface_canonical_version());
|
QString userAgent = QString("Subsurface:%1:").arg(subsurface_canonical_version());
|
||||||
#endif
|
#endif
|
||||||
userAgent.append(SubsurfaceSysInfo::prettyOsName().replace(':', ' ') + ":");
|
QString prettyOsName = QSysInfo::prettyProductName();
|
||||||
arch = SubsurfaceSysInfo::buildCpuArchitecture().replace(':', ' ');
|
#if defined(Q_OS_UNIX) && !defined(Q_OS_MAC) && !defined(Q_OS_ANDROID)
|
||||||
|
// QSysInfo::kernelType() returns lowercase ("linux" instead of "Linux")
|
||||||
|
struct utsname u;
|
||||||
|
if (uname(&u) == 0)
|
||||||
|
prettyOsName = QString::fromLatin1(u.sysname) + QLatin1String(" (") + prettyOsName + QLatin1Char(')');
|
||||||
|
#endif
|
||||||
|
|
||||||
|
userAgent.append(prettyOsName.replace(':', ' ') + ":");
|
||||||
|
arch = QSysInfo::buildCpuArchitecture().replace(':', ' ');
|
||||||
userAgent.append(arch);
|
userAgent.append(arch);
|
||||||
if (arch == "i386")
|
if (arch == "i386")
|
||||||
userAgent.append("/" + SubsurfaceSysInfo::currentCpuArchitecture());
|
userAgent.append("/" + QSysInfo::currentCpuArchitecture());
|
||||||
userAgent.append(":" + getUiLanguage());
|
userAgent.append(":" + getUiLanguage());
|
||||||
return userAgent;
|
return userAgent;
|
||||||
|
|
||||||
|
|
|
@ -1,73 +1,10 @@
|
||||||
// SPDX-License-Identifier: LGPL-2.1+
|
// SPDX-License-Identifier: LGPL-2.1+
|
||||||
/****************************************************************************
|
|
||||||
**
|
|
||||||
** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies).
|
|
||||||
** Copyright (C) 2014 Intel Corporation
|
|
||||||
** Contact: http://www.qt-project.org/legal
|
|
||||||
**
|
|
||||||
** This file is part of the QtCore module of the Qt Toolkit.
|
|
||||||
**
|
|
||||||
** $QT_BEGIN_LICENSE:LGPL$
|
|
||||||
** Commercial License Usage
|
|
||||||
** Licensees holding valid commercial Qt licenses may use this file in
|
|
||||||
** accordance with the commercial license agreement provided with the
|
|
||||||
** Software or, alternatively, in accordance with the terms contained in
|
|
||||||
** a written agreement between you and Digia. For licensing terms and
|
|
||||||
** conditions see http://qt.digia.com/licensing. For further information
|
|
||||||
** use the contact form at http://qt.digia.com/contact-us.
|
|
||||||
**
|
|
||||||
** GNU Lesser General Public License Usage
|
|
||||||
** Alternatively, this file may be used under the terms of the GNU Lesser
|
|
||||||
** General Public License version 2.1 as published by the Free Software
|
|
||||||
** Foundation and appearing in the file LICENSE.LGPL included in the
|
|
||||||
** packaging of this file. Please review the following information to
|
|
||||||
** ensure the GNU Lesser General Public License version 2.1 requirements
|
|
||||||
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
|
||||||
**
|
|
||||||
** In addition, as a special exception, Digia gives you certain additional
|
|
||||||
** rights. These rights are described in the Digia Qt LGPL Exception
|
|
||||||
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
|
||||||
**
|
|
||||||
** GNU General Public License Usage
|
|
||||||
** Alternatively, this file may be used under the terms of the GNU
|
|
||||||
** General Public License version 3.0 as published by the Free Software
|
|
||||||
** Foundation and appearing in the file LICENSE.GPL included in the
|
|
||||||
** packaging of this file. Please review the following information to
|
|
||||||
** ensure the GNU General Public License version 3.0 requirements will be
|
|
||||||
** met: http://www.gnu.org/copyleft/gpl.html.
|
|
||||||
**
|
|
||||||
**
|
|
||||||
** $QT_END_LICENSE$
|
|
||||||
**
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
#include "subsurfacesysinfo.h"
|
#include "subsurfacesysinfo.h"
|
||||||
#include <QString>
|
#include <QSysInfo>
|
||||||
|
|
||||||
#ifdef Q_OS_UNIX
|
|
||||||
#include <sys/utsname.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
QString SubsurfaceSysInfo::prettyOsName()
|
|
||||||
{
|
|
||||||
// Matches the pre-release version of Qt 5.4
|
|
||||||
QString pretty = prettyProductName();
|
|
||||||
#if defined(Q_OS_UNIX) && !defined(Q_OS_MAC) && !defined(Q_OS_ANDROID)
|
|
||||||
// QSysInfo::kernelType() returns lowercase ("linux" instead of "Linux")
|
|
||||||
struct utsname u;
|
|
||||||
if (uname(&u) == 0)
|
|
||||||
return QString::fromLatin1(u.sysname) + QLatin1String(" (") + pretty + QLatin1Char(')');
|
|
||||||
#endif
|
|
||||||
return pretty;
|
|
||||||
}
|
|
||||||
|
|
||||||
extern "C" {
|
|
||||||
bool isWin7Or8()
|
|
||||||
{
|
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
|
extern "C" bool isWin7Or8()
|
||||||
|
{
|
||||||
return (QSysInfo::WindowsVersion & QSysInfo::WV_NT_based) >= QSysInfo::WV_WINDOWS7;
|
return (QSysInfo::WindowsVersion & QSysInfo::WV_NT_based) >= QSysInfo::WV_WINDOWS7;
|
||||||
#else
|
}
|
||||||
return false;
|
|
||||||
#endif
|
#endif
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,55 +1,14 @@
|
||||||
// SPDX-License-Identifier: LGPL-2.1+
|
|
||||||
/****************************************************************************
|
|
||||||
**
|
|
||||||
** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies).
|
|
||||||
** Copyright (C) 2014 Intel Corporation
|
|
||||||
** Contact: http://www.qt-project.org/legal
|
|
||||||
**
|
|
||||||
** This file is part of the QtCore module of the Qt Toolkit.
|
|
||||||
**
|
|
||||||
** $QT_BEGIN_LICENSE:LGPL$
|
|
||||||
** Commercial License Usage
|
|
||||||
** Licensees holding valid commercial Qt licenses may use this file in
|
|
||||||
** accordance with the commercial license agreement provided with the
|
|
||||||
** Software or, alternatively, in accordance with the terms contained in
|
|
||||||
** a written agreement between you and Digia. For licensing terms and
|
|
||||||
** conditions see http://qt.digia.com/licensing. For further information
|
|
||||||
** use the contact form at http://qt.digia.com/contact-us.
|
|
||||||
**
|
|
||||||
** GNU Lesser General Public License Usage
|
|
||||||
** Alternatively, this file may be used under the terms of the GNU Lesser
|
|
||||||
** General Public License version 2.1 as published by the Free Software
|
|
||||||
** Foundation and appearing in the file LICENSE.LGPL included in the
|
|
||||||
** packaging of this file. Please review the following information to
|
|
||||||
** ensure the GNU Lesser General Public License version 2.1 requirements
|
|
||||||
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
|
||||||
**
|
|
||||||
** In addition, as a special exception, Digia gives you certain additional
|
|
||||||
** rights. These rights are described in the Digia Qt LGPL Exception
|
|
||||||
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
|
||||||
**
|
|
||||||
** GNU General Public License Usage
|
|
||||||
** Alternatively, this file may be used under the terms of the GNU
|
|
||||||
** General Public License version 3.0 as published by the Free Software
|
|
||||||
** Foundation and appearing in the file LICENSE.GPL included in the
|
|
||||||
** packaging of this file. Please review the following information to
|
|
||||||
** ensure the GNU General Public License version 3.0 requirements will be
|
|
||||||
** met: http://www.gnu.org/copyleft/gpl.html.
|
|
||||||
**
|
|
||||||
**
|
|
||||||
** $QT_END_LICENSE$
|
|
||||||
**
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
#ifndef SUBSURFACESYSINFO_H
|
#ifndef SUBSURFACESYSINFO_H
|
||||||
#define SUBSURFACESYSINFO_H
|
#define SUBSURFACESYSINFO_H
|
||||||
|
|
||||||
#include <QSysInfo>
|
#include <QtGlobal>
|
||||||
|
|
||||||
class SubsurfaceSysInfo : public QSysInfo {
|
#ifdef Q_OS_WIN
|
||||||
public:
|
#ifdef __cplusplus
|
||||||
static QString prettyOsName();
|
extern "C"
|
||||||
};
|
#endif
|
||||||
|
|
||||||
|
bool isWin7Or8();
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif // SUBSURFACESYSINFO_H
|
#endif // SUBSURFACESYSINFO_H
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
#include "display.h"
|
#include "display.h"
|
||||||
#include "file.h"
|
#include "file.h"
|
||||||
#include "errorhelper.h"
|
#include "errorhelper.h"
|
||||||
|
#include "subsurfacesysinfo.h"
|
||||||
#undef _WIN32_WINNT
|
#undef _WIN32_WINNT
|
||||||
#define _WIN32_WINNT 0x500
|
#define _WIN32_WINNT 0x500
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
|
@ -23,8 +24,6 @@ const char current_system_divelist_default_font[] = "Segoe UI";
|
||||||
const char *system_divelist_default_font = non_standard_system_divelist_default_font;
|
const char *system_divelist_default_font = non_standard_system_divelist_default_font;
|
||||||
double system_divelist_default_font_size = -1;
|
double system_divelist_default_font_size = -1;
|
||||||
|
|
||||||
extern bool isWin7Or8();
|
|
||||||
|
|
||||||
void subsurface_OS_pref_setup(void)
|
void subsurface_OS_pref_setup(void)
|
||||||
{
|
{
|
||||||
if (isWin7Or8())
|
if (isWin7Or8())
|
||||||
|
|
Loading…
Reference in a new issue