From 0ceff5b64f77f8b47369095a2ca5efbed14bb95b Mon Sep 17 00:00:00 2001 From: Duong Date: Fri, 24 Apr 2020 19:35:43 -0500 Subject: [PATCH] improve exception handling in InputFileCatalog::init --- FWCore/Catalog/src/InputFileCatalog.cc | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/FWCore/Catalog/src/InputFileCatalog.cc b/FWCore/Catalog/src/InputFileCatalog.cc index 39d0e826ffec4..d3372ef8e7290 100644 --- a/FWCore/Catalog/src/InputFileCatalog.cc +++ b/FWCore/Catalog/src/InputFileCatalog.cc @@ -49,15 +49,15 @@ namespace edm { fileLocators_.clear(); for (auto it = tmp_dataCatalogs.begin(); it != tmp_dataCatalogs.end(); ++it) { - try { + //require the first file locator to success so obvious mistakes in data catalogs, typos for example, can be catched early + if (it == tmp_dataCatalogs.begin()) { fileLocators_.push_back(std::make_unique(*it)); - } catch (cms::Exception const& e) { - //try all data catalogs but none work so throw exception - if (std::next(it) == tmp_dataCatalogs.end()) { - throw cms::Exception("TrivialFileCatalog", - "edm::InputFileCatalog: none of data catalogs are valid to make a FileLocator"); + } else { + try { + fileLocators_.push_back(std::make_unique(*it)); + } catch (cms::Exception const& e) { + continue; } - continue; } }