kdelibs/kio/kio/udsentry.cpp
Ivailo Monev 891458c94a kio: do not cache strings in KIO::UDSEntry
KIO::UDSEntry and QString are already shared data

Signed-off-by: Ivailo Monev <xakepa10@gmail.com>
2024-03-23 06:54:31 +02:00

196 lines
4.4 KiB
C++

/* This file is part of the KDE project
Copyright (C) 2000-2005 David Faure <faure@kde.org>
Copyright (C) 2007 Norbert Frese <nf2@scheinwelt.at>
Copyright (C) 2007 Thiago Macieira <thiago@kde.org>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
#include "udsentry.h"
#include <kdebug.h>
#include <kio/global.h>
#include <kio/kio_export.h>
#include <QtCore/QString>
#include <QtCore/QHash>
#include <QtCore/QList>
#include <sys/stat.h> // S_ISDIR
using namespace KIO;
/* ---------- UDSEntry ------------ */
class KIO::UDSEntryPrivate : public QSharedData
{
public:
struct Field
{
inline Field() : m_long(0) { }
QString m_str;
long long m_long;
};
typedef QHash<uint, Field> FieldHash;
FieldHash fields;
static void save(QDataStream &, const UDSEntry &);
static void load(QDataStream &, UDSEntry &);
};
QT_BEGIN_NAMESPACE
Q_DECLARE_TYPEINFO(KIO::UDSEntryPrivate::Field, Q_MOVABLE_TYPE);
QT_END_NAMESPACE
UDSEntry::UDSEntry()
: d(new UDSEntryPrivate())
{
}
UDSEntry::UDSEntry(const UDSEntry &other)
: d(other.d)
{
}
UDSEntry::~UDSEntry()
{
}
UDSEntry &UDSEntry::operator=(const UDSEntry &other)
{
d = other.d;
return *this;
}
QString UDSEntry::stringValue(uint field) const
{
return d->fields.value(field).m_str;
}
long long UDSEntry::numberValue(uint field, long long defaultValue) const
{
UDSEntryPrivate::FieldHash::ConstIterator it = d->fields.find(field);
return it != d->fields.constEnd() ? it->m_long : defaultValue;
}
bool UDSEntry::isDir() const
{
return S_ISDIR(numberValue(UDS_FILE_TYPE));
}
bool UDSEntry::isLink() const
{
return !stringValue(UDS_LINK_DEST).isEmpty();
}
void UDSEntry::insert(uint field, const QString& value)
{
UDSEntryPrivate::Field f;
f.m_str = value;
d->fields.insert(field, f);
}
void UDSEntry::insert(uint field, long long value)
{
UDSEntryPrivate::Field f;
f.m_long = value;
d->fields.insert(field, f);
}
QList<uint> UDSEntry::listFields() const
{
return d->fields.keys();
}
int UDSEntry::count() const
{
return d->fields.count();
}
bool UDSEntry::contains(uint field) const
{
return d->fields.contains(field);
}
bool UDSEntry::remove(uint field)
{
return d->fields.remove(field) > 0;
}
void UDSEntry::clear()
{
d->fields.clear();
}
QT_BEGIN_NAMESPACE
QDataStream & operator<<(QDataStream &s, const UDSEntry &a)
{
UDSEntryPrivate::save(s, a);
return s;
}
QDataStream & operator>>(QDataStream &s, UDSEntry &a)
{
UDSEntryPrivate::load(s, a);
return s;
}
QT_END_NAMESPACE
void UDSEntryPrivate::save(QDataStream &s, const UDSEntry &a)
{
const FieldHash &e = a.d->fields;
s << (quint32)e.size();
FieldHash::ConstIterator it = e.begin();
const FieldHash::ConstIterator end = e.end();
for( ; it != end; ++it) {
const quint32 uds = it.key();
s << uds;
if (uds & KIO::UDSEntry::UDS_STRING) {
s << it->m_str;
} else if (uds & KIO::UDSEntry::UDS_NUMBER) {
s << it->m_long;
} else {
Q_ASSERT_X(false, "KIO::UDSEntry", "Found a field with an invalid type");
}
}
}
void UDSEntryPrivate::load(QDataStream &s, UDSEntry &a)
{
FieldHash &e = a.d->fields;
e.clear();
quint32 size = 0;
s >> size;
for(quint32 i = 0; i < size; ++i) {
quint32 uds = 0;
s >> uds;
if (uds & KIO::UDSEntry::UDS_STRING) {
Field f;
s >> f.m_str;
e.insert(uds, f);
} else if (uds & KIO::UDSEntry::UDS_NUMBER) {
Field f;
s >> f.m_long;
e.insert(uds, f);
} else {
Q_ASSERT_X(false, "KIO::UDSEntry", "Found a field with an invalid type");
}
}
}