mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-04-03 20:47:37 +03:00
Introduce Group::aboutToMove() and moved() signals.
Emit them instead of remove/add when groups are moved within a database.
This commit is contained in:
parent
6340ed8993
commit
bddc29101c
10 changed files with 239 additions and 37 deletions
|
@ -1,8 +1,7 @@
|
|||
/****************************************************************************
|
||||
**
|
||||
** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
|
||||
** All rights reserved.
|
||||
** Contact: Nokia Corporation (qt-info@nokia.com)
|
||||
** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies).
|
||||
** Contact: http://www.qt-project.org/
|
||||
**
|
||||
** This file is part of the test suite of the Qt Toolkit.
|
||||
**
|
||||
|
@ -94,6 +93,12 @@ ModelTest::ModelTest ( QAbstractItemModel *_model, QObject *parent ) : QObject (
|
|||
connect ( model, SIGNAL ( rowsRemoved ( const QModelIndex &, int, int ) ),
|
||||
this, SLOT ( rowsRemoved ( const QModelIndex &, int, int ) ) );
|
||||
|
||||
connect ( model, SIGNAL (rowsAboutToBeMoved(QModelIndex,int,int,QModelIndex,int)),
|
||||
this, SLOT (rowsAboutToBeMoved(QModelIndex,int,int,QModelIndex,int)) );
|
||||
connect ( model, SIGNAL (rowsMoved(QModelIndex,int,int,QModelIndex,int)),
|
||||
this, SLOT (rowsMoved(QModelIndex,int,int,QModelIndex,int)) );
|
||||
|
||||
|
||||
runAllTests();
|
||||
}
|
||||
|
||||
|
@ -559,3 +564,50 @@ void ModelTest::rowsRemoved ( const QModelIndex & parent, int start, int end )
|
|||
QVERIFY( c.last == model->data ( model->index ( start - 1, 0, c.parent ) ) );
|
||||
QVERIFY( c.next == model->data ( model->index ( start, 0, c.parent ) ) );
|
||||
}
|
||||
|
||||
void ModelTest::rowsAboutToBeMoved( const QModelIndex &srcParent, int start, int end, const QModelIndex &destParent, int destinationRow )
|
||||
{
|
||||
Changing cs;
|
||||
cs.parent = srcParent;
|
||||
cs.oldSize = model->rowCount ( srcParent );
|
||||
cs.last = model->data ( model->index ( start - 1, 0, srcParent ) );
|
||||
cs.next = model->data ( model->index ( end + 1, 0, srcParent ) );
|
||||
remove.push ( cs );
|
||||
Changing cd;
|
||||
cd.parent = destParent;
|
||||
cd.oldSize = model->rowCount ( destParent );
|
||||
cd.last = model->data ( model->index ( destinationRow - 1, 0, destParent ) );
|
||||
cd.next = model->data ( model->index ( destinationRow, 0, destParent ) );
|
||||
insert.push ( cd );
|
||||
}
|
||||
|
||||
void ModelTest::rowsMoved( const QModelIndex &srcParent, int start, int end, const QModelIndex &destParent, int destinationRow )
|
||||
{
|
||||
Changing cd = insert.pop();
|
||||
Q_ASSERT ( cd.parent == destParent );
|
||||
if (srcParent == destParent) {
|
||||
Q_ASSERT ( cd.oldSize == model->rowCount ( destParent ) );
|
||||
|
||||
// TODO: Find out what I can assert here about last and next.
|
||||
// Q_ASSERT ( cd.last == model->data ( model->index ( destinationRow - 1, 0, cd.parent ) ) );
|
||||
// Q_ASSERT ( cd.next == model->data ( model->index ( destinationRow + (end - start + 1), 0, cd.parent ) ) );
|
||||
}
|
||||
else {
|
||||
Q_ASSERT ( cd.oldSize + ( end - start + 1 ) == model->rowCount ( destParent ) );
|
||||
|
||||
Q_ASSERT ( cd.last == model->data ( model->index ( destinationRow - 1, 0, cd.parent ) ) );
|
||||
Q_ASSERT ( cd.next == model->data ( model->index ( destinationRow + (end - start + 1), 0, cd.parent ) ) );
|
||||
}
|
||||
|
||||
Changing cs = remove.pop();
|
||||
Q_ASSERT ( cs.parent == srcParent );
|
||||
if (srcParent == destParent) {
|
||||
Q_ASSERT ( cs.oldSize == model->rowCount ( srcParent ) );
|
||||
}
|
||||
else {
|
||||
Q_ASSERT ( cs.oldSize - ( end - start + 1 ) == model->rowCount ( srcParent ) );
|
||||
|
||||
Q_ASSERT ( cs.last == model->data ( model->index ( start - 1, 0, srcParent ) ) );
|
||||
Q_ASSERT ( cs.next == model->data ( model->index ( start, 0, srcParent ) ) );
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue