Mercurial > hg > svgui
diff layer/ImageLayer.cpp @ 464:69089c9dc42e
* Fix crash in SimpleSPARQLQuery
* Fix failure to add images from local files
author | Chris Cannam |
---|---|
date | Thu, 15 Jan 2009 18:20:40 +0000 |
parents | 22b72f0f6a4e |
children | 1fe7951a61e8 |
line wrap: on
line diff
--- a/layer/ImageLayer.cpp Fri Jan 09 14:55:12 2009 +0000 +++ b/layer/ImageLayer.cpp Thu Jan 15 18:20:40 2009 +0000 @@ -54,8 +54,8 @@ ImageLayer::~ImageLayer() { - for (FileSourceMap::iterator i = m_remoteFiles.begin(); - i != m_remoteFiles.end(); ++i) { + for (FileSourceMap::iterator i = m_fileSources.begin(); + i != m_fileSources.end(); ++i) { delete i->second; } } @@ -607,7 +607,7 @@ if (dialog.exec() == QDialog::Accepted) { - checkAddRemote(dialog.getImage()); + checkAddSource(dialog.getImage()); ImageModel::ChangeImageCommand *command = new ImageModel::ChangeImageCommand @@ -627,8 +627,9 @@ { QImage image(getLocalFilename(url)); if (image.isNull()) { - delete m_remoteFiles[url]; - m_remoteFiles.erase(url); + std::cerr << "Failed to open image from url \"" << url.toStdString() << "\" (local filename \"" << getLocalFilename(url).toStdString() << "\"" << std::endl; + delete m_fileSources[url]; + m_fileSources.erase(url); return false; } @@ -713,7 +714,7 @@ if (dialog.exec() == QDialog::Accepted) { - checkAddRemote(dialog.getImage()); + checkAddSource(dialog.getImage()); ImageModel::ChangeImageCommand *command = new ImageModel::ChangeImageCommand @@ -893,61 +894,58 @@ QString ImageLayer::getLocalFilename(QString img) const { - if (m_remoteFiles.find(img) == m_remoteFiles.end()) { - checkAddRemote(img); - if (m_remoteFiles.find(img) == m_remoteFiles.end()) { + if (m_fileSources.find(img) == m_fileSources.end()) { + checkAddSource(img); + if (m_fileSources.find(img) == m_fileSources.end()) { return img; } } - return m_remoteFiles[img]->getLocalFilename(); + return m_fileSources[img]->getLocalFilename(); } void -ImageLayer::checkAddRemote(QString img) const +ImageLayer::checkAddSource(QString img) const { - if (FileSource::isRemote(img)) { + std::cerr << "ImageLayer::checkAddSource(" << img.toStdString() << "): yes, trying..." << std::endl; - std::cerr << "ImageLayer::checkAddRemote(" << img.toStdString() << "): yes, trying..." << std::endl; + if (m_fileSources.find(img) != m_fileSources.end()) { + return; + } - if (m_remoteFiles.find(img) != m_remoteFiles.end()) { - return; - } - - ProgressDialog dialog(tr("Opening image URL..."), true, 2000); - FileSource *rf = new FileSource(img, &dialog); - if (rf->isOK()) { - std::cerr << "ok, adding it (local filename = " << rf->getLocalFilename().toStdString() << ")" << std::endl; - m_remoteFiles[img] = rf; - connect(rf, SIGNAL(ready()), this, SLOT(remoteFileReady())); - } else { - delete rf; - } + ProgressDialog dialog(tr("Opening image URL..."), true, 2000); + FileSource *rf = new FileSource(img, &dialog); + if (rf->isOK()) { + std::cerr << "ok, adding it (local filename = " << rf->getLocalFilename().toStdString() << ")" << std::endl; + m_fileSources[img] = rf; + connect(rf, SIGNAL(ready()), this, SLOT(fileSourceReady())); + } else { + delete rf; } } void -ImageLayer::checkAddRemotes() +ImageLayer::checkAddSources() { const ImageModel::PointList &points(m_model->getPoints()); for (ImageModel::PointList::const_iterator i = points.begin(); i != points.end(); ++i) { - checkAddRemote((*i).image); + checkAddSource((*i).image); } } void -ImageLayer::remoteFileReady() +ImageLayer::fileSourceReady() { -// std::cerr << "ImageLayer::remoteFileReady" << std::endl; +// std::cerr << "ImageLayer::fileSourceReady" << std::endl; FileSource *rf = dynamic_cast<FileSource *>(sender()); if (!rf) return; QString img; - for (FileSourceMap::const_iterator i = m_remoteFiles.begin(); - i != m_remoteFiles.end(); ++i) { + for (FileSourceMap::const_iterator i = m_fileSources.begin(); + i != m_fileSources.end(); ++i) { if (i->second == rf) { img = i->first; // std::cerr << "it's image \"" << img.toStdString() << "\"" << std::endl;