1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
|
/****************************************************************************
** Copyright (C) 2001-2010 Klaralvdalens Datakonsult AB. All rights reserved.
**
** This file is part of the KD Tools library.
**
** Licensees holding valid commercial KD Tools licenses may use this file in
** accordance with the KD Tools Commercial License Agreement provided with
** the Software.
**
**
** This file may be distributed and/or modified under the terms of the
** GNU Lesser General Public License version 2 and version 3 as published by the
** Free Software Foundation and appearing in the file LICENSE.LGPL included.
**
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
**
** Contact info@kdab.com if any conditions of this licensing are not
** clear to you.
**
**********************************************************************/
#include "kdsysinfo.h"
#include <sys/utsname.h>
#include <sys/statvfs.h>
#include <QtCore/QFile>
#include <QtCore/QTextStream>
#include <QtCore/QDir>
#include <QtCore/QFileInfo>
quint64 KDSysInfo::installedMemory()
{
#ifdef Q_OS_LINUX
QFile f(QLatin1String("/proc/meminfo"));
f.open(QIODevice::ReadOnly);
QTextStream stream(&f);
while (true) {
const QString s = stream.readLine();
if( !s.startsWith(QLatin1String("MemTotal:" )))
continue;
else if (s.isEmpty())
return quint64();
const QStringList parts = s.split(QLatin1Char(' '), QString::SkipEmptyParts);
return quint64(parts.at(1).toInt() * 1024LL);
}
#else
quint64 physmem;
size_t len = sizeof physmem;
static int mib[2] = { CTL_HW, HW_MEMSIZE };
sysctl(mib, 2, &physmem, &len, 0, 0);
return quint64(physmem);
#endif
return 0;
}
QList<KDSysInfo::Volume> KDSysInfo::mountedVolumes()
{
QList<Volume> result;
QFile f(QLatin1String("/etc/mtab"));
if (!f.open(QIODevice::ReadOnly)) {
qCritical("%s: Could not open %s: %s", Q_FUNC_INFO, qPrintable(f.fileName()), qPrintable(f.errorString()));
return QList<KDSysInfo::Volume>(); //better error-handling?
}
QTextStream stream(&f);
while (true) {
const QString s = stream.readLine();
if (s.isNull())
return result;
if (!s.startsWith(QLatin1Char('/')))
continue;
const QStringList parts = s.split( QLatin1Char(' '), QString::SkipEmptyParts);
Volume v;
v.setName(parts.at(1));
v.setPath(parts.at(1));
struct statvfs data;
if (statvfs(qPrintable(v.name()), &data) == 0) {
v.setSize(quint64(static_cast<quint64>(data.f_blocks) * data.f_bsize));
v.setAvailableSpace(quint64(static_cast<quint64>(data.f_bavail) * data.f_bsize));
}
result.push_back(v);
}
return result;
}
QList<KDSysInfo::ProcessInfo> KDSysInfo::runningProcesses()
{
QList<KDSysInfo::ProcessInfo> processes;
QDir procDir(QLatin1String("/proc"));
const QFileInfoList procCont = procDir.entryInfoList(QDir::Dirs | QDir::NoDotAndDotDot | QDir::Readable);
QRegExp validator(QLatin1String("[0-9]+"));
Q_FOREACH (const QFileInfo &info, procCont) {
if (validator.exactMatch(info.fileName())) {
const QString linkPath = QDir(info.absoluteFilePath()).absoluteFilePath(QLatin1String("exe"));
const QFileInfo linkInfo(linkPath);
if (linkInfo.exists()) {
KDSysInfo::ProcessInfo processInfo;
processInfo.name = linkInfo.symLinkTarget();
processInfo.id = info.fileName().toInt();
processes.append(processInfo);
}
}
}
return processes;
}
|