SVN commit 492900 by cgilles:
digikam from trunk : missing to check in saveAs method if user image file extension is supported by Image editor. Tom, sorry for this, but we need to backport again this fix on stable branch please (:=)))... CCMAIL: [hidden email] M +27 -6 imagewindow.cpp --- trunk/extragear/graphics/digikam/utilities/imageeditor/editor/imagewindow.cpp #492899:492900 @@ -1049,9 +1049,7 @@ // FIXME : Add 16 bits file formats and others files format like TIFF not supported by kimgio. QString mimetypes = KImageIO::mimeTypes(KImageIO::Writing).join(" "); - mimetypes.append(" image/tiff"); - kdDebug () << "mimetypes=" << mimetypes << endl; KFileDialog imageFileSaveDialog(m_urlCurrent.directory(), @@ -1076,17 +1074,40 @@ // Check if target image format have been selected from Combo List of SaveAs dialog. QString format = KImageIO::typeForMime(imageFileSaveDialog.currentMimeFilter()); - if (format.isEmpty()) + if ( format.isEmpty() ) { // Else, check if target image format have been add to target image file name using extension. + QFileInfo fi(newURL.path()); format = fi.extension(false); - - if (format.isEmpty()) + + if ( format.isEmpty() ) { - // Else, the format is empty then file format is same as that of the original file. + // If format is empty then file format is same as that of the original file. format = QImageIO::imageFormat(m_urlCurrent.path()); } + else + { + // Else, check if format from file name extension is include on file mime type list. + + QString imgExtPattern; + QStringList imgExtList = QStringList::split(" ", mimetypes); + for (QStringList::ConstIterator it = imgExtList.begin() ; it != imgExtList.end() ; it++) + { + imgExtPattern.append (KImageIO::typeForMime(*it)); + imgExtPattern.append (" "); + } + if ( imgExtPattern.contains("*.TIFF") ) imgExtPattern.append (" *.TIF"); + if ( imgExtPattern.contains("*.JPEG") ) imgExtPattern.append (" *.JPG"); + + if ( !imgExtPattern.contains( format.upper() ) ) + { + KMessageBox::error(this, i18n("Target image file format \"%1\" unsupported!") + .arg(format)); + kdWarning() << k_funcinfo << "target image file format " << format << " unsupported!" << endl; + return false; + } + } } if (!newURL.isValid()) _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
Free forum by Nabble | Edit this page |