diff --git a/ql/index.hpp b/ql/index.hpp index 6419700ff6..57da0ff14e 100644 --- a/ql/index.hpp +++ b/ql/index.hpp @@ -101,7 +101,7 @@ namespace QuantLib { bool forceOverwrite = false) { checkNativeFixingsAllowed(); std::string tag = name(); - TimeSeries h = IndexManager::instance().getHistory(tag); + TimeSeries& h = IndexManager::instance().getHistoryRef(tag); bool noInvalidFixing = true, noDuplicatedFixing = true; Date invalidDate, duplicatedDate; Real nullValue = Null(); @@ -128,7 +128,6 @@ namespace QuantLib { invalidValue = *(vBegin++); } } - IndexManager::instance().setHistory(tag, h); QL_REQUIRE(noInvalidFixing, "At least one invalid fixing provided: " << invalidDate.weekday() << " " << invalidDate << ", " << invalidValue); diff --git a/ql/indexes/indexmanager.cpp b/ql/indexes/indexmanager.cpp index 19f4c4f77d..39bb14d0b2 100644 --- a/ql/indexes/indexmanager.cpp +++ b/ql/indexes/indexmanager.cpp @@ -29,6 +29,10 @@ namespace QuantLib { return data_[name].value(); } + TimeSeries& IndexManager::getHistoryRef(const std::string& name) { + return data_[name].ref(); + } + void IndexManager::setHistory(const std::string& name, TimeSeries history) { data_[name] = std::move(history); } diff --git a/ql/indexes/indexmanager.hpp b/ql/indexes/indexmanager.hpp index 0115aabfe9..2e18fbc3ed 100644 --- a/ql/indexes/indexmanager.hpp +++ b/ql/indexes/indexmanager.hpp @@ -45,6 +45,8 @@ namespace QuantLib { bool hasHistory(const std::string& name) const; //! returns the (possibly empty) history of the index fixings const TimeSeries& getHistory(const std::string& name) const; + //! returns a ref to the (possibly empty) history of the index fixings + TimeSeries& getHistoryRef(const std::string& name); //! stores the historical fixings of the index void setHistory(const std::string& name, TimeSeries history); //! observer notifying of changes in the index fixings diff --git a/ql/utilities/observablevalue.hpp b/ql/utilities/observablevalue.hpp index aa54ce7846..a35fa972bb 100644 --- a/ql/utilities/observablevalue.hpp +++ b/ql/utilities/observablevalue.hpp @@ -57,6 +57,8 @@ namespace QuantLib { operator ext::shared_ptr() const; //! explicit inspector const T& value() const; + //! explicit reference + T& ref(); private: T value_; ext::shared_ptr observable_; @@ -118,6 +120,10 @@ namespace QuantLib { return value_; } + template + T& ObservableValue::ref() { + return value_; + } } #endif