Skip to content
Snippets Groups Projects
Commit 9f0f37b4 authored by Michael Hart's avatar Michael Hart
Browse files

Re #13632 Added local cache of bank shared_pointers

parent 5ae90610
No related branches found
No related tags found
No related merge requests found
...@@ -65,6 +65,13 @@ private: ...@@ -65,6 +65,13 @@ private:
std::string filename); std::string filename);
void checkNumberPeaks(Mantid::DataObjects::PeaksWorkspace_sptr outWS, void checkNumberPeaks(Mantid::DataObjects::PeaksWorkspace_sptr outWS,
std::string filename); std::string filename);
/// Local cache of bank IComponents used in file
std::map<std::string, boost::shared_ptr<const Geometry::IComponent>> m_banks;
/// Retrieve cached bank (or load and cache for next time)
boost::shared_ptr<const Geometry::IComponent> getCachedBankByName(std::string bankname, const boost::shared_ptr<const Geometry::Instrument>& inst);
}; };
} // namespace Mantid } // namespace Mantid
......
...@@ -190,7 +190,7 @@ LoadIsawPeaks::ApplyCalibInfo(std::ifstream &in, std::string startChar, ...@@ -190,7 +190,7 @@ LoadIsawPeaks::ApplyCalibInfo(std::ifstream &in, std::string startChar,
} }
bankName += SbankNum; bankName += SbankNum;
boost::shared_ptr<const Geometry::IComponent> bank = boost::shared_ptr<const Geometry::IComponent> bank =
instr_old->getComponentByName(bankName); getCachedBankByName(bankName, instr_old);
if (!bank) { if (!bank) {
g_log.error() << "There is no bank " << bankName << " in the instrument" g_log.error() << "There is no bank " << bankName << " in the instrument"
...@@ -405,7 +405,8 @@ DataObjects::Peak LoadIsawPeaks::readPeak(PeaksWorkspace_sptr outWS, ...@@ -405,7 +405,8 @@ DataObjects::Peak LoadIsawPeaks::readPeak(PeaksWorkspace_sptr outWS,
int LoadIsawPeaks::findPixelID(Instrument_const_sptr inst, std::string bankName, int LoadIsawPeaks::findPixelID(Instrument_const_sptr inst, std::string bankName,
int col, int row) { int col, int row) {
boost::shared_ptr<const IComponent> parent = boost::shared_ptr<const IComponent> parent =
inst->getComponentByName(bankName); getCachedBankByName(bankName, inst);
if (parent->type().compare("RectangularDetector") == 0) { if (parent->type().compare("RectangularDetector") == 0) {
boost::shared_ptr<const RectangularDetector> RDet = boost::shared_ptr<const RectangularDetector> RDet =
boost::dynamic_pointer_cast<const RectangularDetector>(parent); boost::dynamic_pointer_cast<const RectangularDetector>(parent);
...@@ -607,5 +608,28 @@ void LoadIsawPeaks::exec() { ...@@ -607,5 +608,28 @@ void LoadIsawPeaks::exec() {
this->checkNumberPeaks(ws, getPropertyValue("Filename")); this->checkNumberPeaks(ws, getPropertyValue("Filename"));
} }
//----------------------------------------------------------------------------------------------
/** Retrieves pointer to given bank from local cache.
*
* When the bank isn't in the local cache, it is loaded and
* added to the cache for later use. Lifetime of the cache
* is bound to the lifetime of this instance of the algorithm
* (typically, the instance should be destroyed once exec()
* finishes).
*
* Note that while this is used only for banks here, it would
* work for caching any component without modification.
*
* @param bankname :: the name of the requested bank
* @param inst :: the instrument from which to load the bank if it is not yet cached
* @return A shared pointer to the request bank (empty shared pointer if not found)
*/
boost::shared_ptr<const IComponent> LoadIsawPeaks::getCachedBankByName(std::string bankname, const boost::shared_ptr<const Geometry::Instrument>& inst)
{
if (m_banks.count(bankname) == 0)
m_banks[bankname] = inst->getComponentByName(bankname);
return m_banks[bankname];
}
} // namespace Mantid } // namespace Mantid
} // namespace Crystal } // namespace Crystal
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment