#include "kstandarditemmodel.h"
-#include <KDebug>
#include "kstandarditem.h"
KStandardItemModel::KStandardItemModel(QObject* parent) :
void KStandardItemModel::insertItem(int index, KStandardItem* item)
{
- if (item && !m_indexesForItems.contains(item) && !item->m_model) {
+ if (index < 0 || index > count() || !item) {
+ delete item;
+ return;
+ }
+
+ if (!m_indexesForItems.contains(item)) {
item->m_model = this;
m_items.insert(index, item);
m_indexesForItems.insert(item, index);
+
+ // Inserting an item requires to update the indexes
+ // afterwards from m_indexesForItems.
+ for (int i = index + 1; i < m_items.count(); ++i) {
+ m_indexesForItems.insert(m_items[i], i);
+ }
+
// TODO: no hierarchical items are handled yet
onItemInserted(index);
}
}
-void KStandardItemModel::replaceItem(int index, KStandardItem* item)
+void KStandardItemModel::changeItem(int index, KStandardItem* item)
{
- if (item && index >= 0 && index < count() && !item->m_model) {
- item->m_model = this;
+ if (index < 0 || index >= count() || !item) {
+ delete item;
+ return;
+ }
- QSet<QByteArray> changedRoles;
-
- KStandardItem* oldItem= m_items[index];
- const QHash<QByteArray, QVariant> oldData = oldItem->data();
- const QHash<QByteArray, QVariant> newData = item->data();
-
- // Determine which roles have been changed
- QHashIterator<QByteArray, QVariant> it(oldData);
- while (it.hasNext()) {
- it.next();
- const QByteArray role = it.key();
- const QVariant oldValue = it.value();
- if (newData.contains(role) && newData.value(role) != oldValue) {
- changedRoles.insert(role);
- }
- }
+ item->m_model = this;
- m_indexesForItems.remove(oldItem);
- delete oldItem;
- oldItem = 0;
+ QSet<QByteArray> changedRoles;
- m_items[index] = item;
- m_indexesForItems.insert(item, index);
+ KStandardItem* oldItem = m_items[index];
+ const QHash<QByteArray, QVariant> oldData = oldItem->data();
+ const QHash<QByteArray, QVariant> newData = item->data();
- onItemReplaced(index);
- emit itemsChanged(KItemRangeList() << KItemRange(index, 1), changedRoles);
- } else {
- kWarning() << "No item available to replace on the given index" << index;
- delete item;
- item = 0;
+ // Determine which roles have been changed
+ QHashIterator<QByteArray, QVariant> it(oldData);
+ while (it.hasNext()) {
+ it.next();
+ const QByteArray role = it.key();
+ const QVariant oldValue = it.value();
+ if (newData.contains(role) && newData.value(role) != oldValue) {
+ changedRoles.insert(role);
+ }
}
+
+ m_indexesForItems.remove(oldItem);
+ delete oldItem;
+ oldItem = nullptr;
+
+ m_items[index] = item;
+ m_indexesForItems.insert(item, index);
+
+ onItemChanged(index, changedRoles);
+ emit itemsChanged(KItemRangeList() << KItemRange(index, 1), changedRoles);
}
void KStandardItemModel::removeItem(int index)
KStandardItem* item = m_items[index];
m_indexesForItems.remove(item);
m_items.removeAt(index);
- delete item;
- item = 0;
- onItemRemoved(index);
+ // Removing an item requires to update the indexes
+ // afterwards from m_indexesForItems.
+ for (int i = index; i < m_items.count(); ++i) {
+ m_indexesForItems.insert(m_items[i], i);
+ }
+
+ onItemRemoved(index, item);
+
+ item->deleteLater();
+ item = nullptr;
+
emit itemsRemoved(KItemRangeList() << KItemRange(index, 1));
+
// TODO: no hierarchical items are handled yet
}
}
+void KStandardItemModel::clear()
+{
+ int size = m_items.size();
+ m_items.clear();
+ m_indexesForItems.clear();
+
+ emit itemsRemoved(KItemRangeList() << KItemRange(0, size));
+}
+
KStandardItem* KStandardItemModel::item(int index) const
{
if (index < 0 || index >= m_items.count()) {
- return 0;
+ return nullptr;
}
return m_items[index];
}
bool KStandardItemModel::setData(int index, const QHash<QByteArray, QVariant>& values)
{
- Q_UNUSED(values);
+ Q_UNUSED(values)
if (index < 0 || index >= count()) {
return false;
}
return true;
}
-QMimeData* KStandardItemModel::createMimeData(const QSet<int>& indexes) const
+QMimeData* KStandardItemModel::createMimeData(const KItemSet& indexes) const
{
- Q_UNUSED(indexes);
- return 0;
+ Q_UNUSED(indexes)
+ return nullptr;
}
int KStandardItemModel::indexForKeyboardSearch(const QString& text, int startFromIndex) const
{
- Q_UNUSED(text);
- Q_UNUSED(startFromIndex);
+ Q_UNUSED(text)
+ Q_UNUSED(startFromIndex)
return -1;
}
bool KStandardItemModel::supportsDropping(int index) const
{
- Q_UNUSED(index);
+ Q_UNUSED(index)
return false;
}
QString KStandardItemModel::roleDescription(const QByteArray& role) const
{
- Q_UNUSED(role);
+ Q_UNUSED(role)
return QString();
}
{
QList<QPair<int, QVariant> > groups;
- const QByteArray role = sortRole();
+ const QByteArray role = sortRole().isEmpty() ? "group" : sortRole();
bool isFirstGroupValue = true;
QString groupValue;
const int maxIndex = count() - 1;
void KStandardItemModel::onItemInserted(int index)
{
- Q_UNUSED(index);
+ Q_UNUSED(index)
}
-void KStandardItemModel::onItemReplaced(int index)
+void KStandardItemModel::onItemChanged(int index, const QSet<QByteArray>& changedRoles)
{
- Q_UNUSED(index);
+ Q_UNUSED(index)
+ Q_UNUSED(changedRoles)
}
-void KStandardItemModel::onItemRemoved(int index)
+void KStandardItemModel::onItemRemoved(int index, KStandardItem* removedItem)
{
- Q_UNUSED(index);
+ Q_UNUSED(index)
+ Q_UNUSED(removedItem)
}
-
-#include "kstandarditemmodel.moc"