Skip to content

Commit

Permalink
improve error propagation for raster open errors (#1040)
Browse files Browse the repository at this point in the history
git-svn-id: http://svn.osgeo.org/qgis/trunk/qgis@8694 c8812cc2-4d05-0410-92ff-de0c093fc19c
  • Loading branch information
warmerdam committed Jun 30, 2008
1 parent ce706d1 commit c040a5f
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 3 deletions.
9 changes: 8 additions & 1 deletion src/app/qgisapp.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3126,6 +3126,7 @@ void QgisApp::openProject(const QString & fileName)
bool QgisApp::openLayer(const QString & fileName)
{
QFileInfo fileInfo(fileName);

// try to load it as raster
QgsMapLayer* ok = NULL;
CPLPushErrorHandler(CPLQuietErrorHandler);
Expand Down Expand Up @@ -5323,7 +5324,9 @@ bool QgisApp::addRasterLayers(QStringList const &theFileNameQStringList, bool gu
myIterator != theFileNameQStringList.end();
++myIterator)
{
if (QgsRasterLayer::isValidRasterFileName(*myIterator))
QString errMsg;

if (QgsRasterLayer::isValidRasterFileName(*myIterator,errMsg))
{
QFileInfo myFileInfo(*myIterator);
// get the directory the .adf file was in
Expand Down Expand Up @@ -5356,6 +5359,10 @@ bool QgisApp::addRasterLayers(QStringList const &theFileNameQStringList, bool gu
if(guiWarning)
{
QString msg(*myIterator + tr(" is not a supported raster data source"));

if( errMsg.size() > 0 )
msg += "\n" + errMsg;

QMessageBox::critical(this, tr("Unsupported Data Source"), msg);
}
returnValue = false;
Expand Down
16 changes: 15 additions & 1 deletion src/core/raster/qgsrasterlayer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -255,22 +255,28 @@ void QgsRasterLayer::registerGdalDrivers()


/** This helper checks to see whether the filename appears to be a valid raster file name */
bool QgsRasterLayer::isValidRasterFileName(QString const & theFileNameQString)
bool QgsRasterLayer::isValidRasterFileName(QString const & theFileNameQString,
QString & retErrMsg )
{

GDALDatasetH myDataset;
registerGdalDrivers();

CPLErrorReset();

//open the file using gdal making sure we have handled locale properly
myDataset = GDALOpen( QFile::encodeName(theFileNameQString).constData(), GA_ReadOnly );
if( myDataset == NULL )
{
if( CPLGetLastErrorNo() != CPLE_OpenFailed )
retErrMsg = CPLGetLastErrorMsg();
return false;
}
else if( GDALGetRasterCount( myDataset ) == 0 )
{
GDALClose( myDataset );
myDataset = NULL;
retErrMsg = "This raster file has no bands and is invalid as a raster layer.";
return false;
}
else
Expand All @@ -280,6 +286,14 @@ bool QgsRasterLayer::isValidRasterFileName(QString const & theFileNameQString)
}
}

bool QgsRasterLayer::isValidRasterFileName(QString const & theFileNameQString)

{
QString retErrMsg;

return isValidRasterFileName( theFileNameQString, retErrMsg);
}


//////////////////////////////////////////////////////////
//
Expand Down
7 changes: 6 additions & 1 deletion src/core/raster/qgsrasterlayer.h
Original file line number Diff line number Diff line change
Expand Up @@ -189,7 +189,12 @@ class CORE_EXPORT QgsRasterLayer : public QgsMapLayer
static void registerGdalDrivers();

/** This helper checks to see whether the filename appears to be a valid
raster file name */
raster file name. If the filename looks like it could be valid,
but some sort of error occurs in processing the file, the error is
returned in retError. */
static bool isValidRasterFileName(const QString & theFileNameQString,
QString &retError );

static bool isValidRasterFileName(const QString & theFileNameQString);

//
Expand Down

0 comments on commit c040a5f

Please sign in to comment.