┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/renamedialog.cpp32
-rw-r--r--src/tests/renamedialogtest.cpp11
2 files changed, 29 insertions, 14 deletions
diff --git a/src/renamedialog.cpp b/src/renamedialog.cpp
index fa5bf60e0..3e9b39327 100644
--- a/src/renamedialog.cpp
+++ b/src/renamedialog.cpp
@@ -128,24 +128,30 @@ void RenameDialog::slotButtonClicked(int button)
QString RenameDialog::extensionString(const QString& name)
{
QString extension;
- bool foundExtension = false; // true if at least one valid file extension
- // like "gif", "txt", ... has been found
- QStringList strings = name.split('.');
+ const QStringList strings = name.split('.');
const int size = strings.size();
- for (int i = 1; i < size; ++i) {
+ for (int i = size - 1; i >= 0; --i) {
const QString& str = strings.at(i);
- if (!foundExtension) {
- // Sub strings like "9", "12", "99", ... which contain only
- // numbers don't count as extension. Usually they are version
- // numbers like in "cmake-2.4.5".
- bool ok = false;
- str.toInt(&ok);
- foundExtension = !ok;
+
+ // Sub strings like "9", "12", "99", ... which contain only
+ // numbers don't count as extension. Usually they are version
+ // numbers like in "cmake-2.4.5".
+ bool isNumeric = false;
+ str.toInt(&isNumeric);
+ if (isNumeric) {
+ break;
}
- if (foundExtension) {
- extension += '.' + str;
+
+ // Extensions may not contain a space and the maximum length
+ // should not exceed 4 characters. This prevents that strings like
+ // "Open office.org writer documentation.pdf" get ".org writer documentation.pdf"
+ // as extension.
+ if (str.contains(' ') || (str.length() > 4)) {
+ break;
}
+
+ extension.insert(0, '.' + str);
}
return extension;
diff --git a/src/tests/renamedialogtest.cpp b/src/tests/renamedialogtest.cpp
index aeca0a0c4..dc2adffd9 100644
--- a/src/tests/renamedialogtest.cpp
+++ b/src/tests/renamedialogtest.cpp
@@ -40,7 +40,16 @@ void RenameDialogTest::testExtensionString()
QCOMPARE(result, QString(".gif"));
result = RenameDialog::extensionString("Image.tar.1.12.gz");
- QCOMPARE(result, QString(".tar.1.12.gz"));
+ QCOMPARE(result, QString(".gz"));
+
+ result = RenameDialog::extensionString("Open office.org writer documentation.pdf");
+ QCOMPARE(result, QString(".pdf"));
+
+ result = RenameDialog::extensionString("Test.toolongextension.pdf");
+ QCOMPARE(result, QString(".pdf"));
+
+ result = RenameDialog::extensionString("Test.x x.pdf");
+ QCOMPARE(result, QString(".pdf"));
}
#include "renamedialogtest.moc"