Merge remote-tracking branch 'origin/KDE/4.10'

This commit is contained in:
Frank Reininghaus 2013-06-20 19:44:06 +02:00
commit a05db2f0d0
3 changed files with 39 additions and 4 deletions

View file

@ -50,6 +50,22 @@ void KItemListRubberBand::setEndPosition(const QPointF& pos)
if (m_endPos != pos) {
const QPointF previous = m_endPos;
m_endPos = pos;
if (m_startPos.x() == m_endPos.x()) {
if (previous.x() < m_startPos.x()) {
m_endPos.rx() = m_startPos.x() - 1.0;
} else {
m_endPos.rx() = m_startPos.x() + 1.0;
}
}
if (m_startPos.y() == m_endPos.y()) {
if (previous.y() < m_startPos.y()) {
m_endPos.ry() = m_startPos.y() - 1.0;
} else {
m_endPos.ry() = m_startPos.y() + 1.0;
}
}
emit endPositionChanged(m_endPos, previous);
}
}

View file

@ -45,6 +45,7 @@ RenameDialog::RenameDialog(QWidget *parent, const KFileItemList& items) :
m_newName(),
m_lineEdit(0),
m_items(items),
m_allExtensionsDifferent(true),
m_spinBox(0)
{
const QSize minSize = minimumSize();
@ -107,6 +108,18 @@ RenameDialog::RenameDialog(QWidget *parent, const KFileItemList& items) :
topLayout->addWidget(m_lineEdit);
if (!m_renameOneItem) {
QSet<QString> extensions;
foreach (const KFileItem& item, m_items) {
const QString extension = KMimeType::extractKnownExtension(item.url().prettyUrl().toLower());
if (extensions.contains(extension)) {
m_allExtensionsDifferent = false;
break;
}
extensions.insert(extension);
}
QLabel* infoLabel = new QLabel(i18nc("@info", "# will be replaced by ascending numbers starting with:"), page);
m_spinBox = new KIntSpinBox(0, 10000, 1, 1, page, 10);
@ -146,11 +159,16 @@ void RenameDialog::slotTextChanged(const QString& newName)
{
bool enable = !newName.isEmpty() && (newName != QLatin1String("..")) && (newName != QLatin1String("."));
if (enable && !m_renameOneItem) {
// Assure that the new name contains exactly one # (or a connected sequence of #'s)
const int count = newName.count(QLatin1Char('#'));
const int first = newName.indexOf(QLatin1Char('#'));
const int last = newName.lastIndexOf(QLatin1Char('#'));
enable = (last - first + 1 == count);
if (count == 0) {
// Renaming multiple files without '#' will only work if all extensions are different.
enable = m_allExtensionsDifferent;
} else {
// Assure that the new name contains exactly one # (or a connected sequence of #'s)
const int first = newName.indexOf(QLatin1Char('#'));
const int last = newName.lastIndexOf(QLatin1Char('#'));
enable = (last - first + 1 == count);
}
}
enableButtonOk(enable);
}

View file

@ -64,6 +64,7 @@ private:
QString m_newName;
KLineEdit* m_lineEdit;
KFileItemList m_items;
bool m_allExtensionsDifferent;
KIntSpinBox* m_spinBox;
};