| Alex Deymo | aea4c1c | 2015-08-19 20:24:43 -0700 | [diff] [blame] | 1 | // | 
|  | 2 | // Copyright (C) 2014 The Android Open Source Project | 
|  | 3 | // | 
|  | 4 | // Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | 5 | // you may not use this file except in compliance with the License. | 
|  | 6 | // You may obtain a copy of the License at | 
|  | 7 | // | 
|  | 8 | //      http://www.apache.org/licenses/LICENSE-2.0 | 
|  | 9 | // | 
|  | 10 | // Unless required by applicable law or agreed to in writing, software | 
|  | 11 | // distributed under the License is distributed on an "AS IS" BASIS, | 
|  | 12 | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | 13 | // See the License for the specific language governing permissions and | 
|  | 14 | // limitations under the License. | 
|  | 15 | // | 
| Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 16 |  | 
| Gilad Arnold | 48415f1 | 2014-06-27 07:10:58 -0700 | [diff] [blame] | 17 | #ifndef UPDATE_ENGINE_UPDATE_MANAGER_EVALUATION_CONTEXT_INL_H_ | 
|  | 18 | #define UPDATE_ENGINE_UPDATE_MANAGER_EVALUATION_CONTEXT_INL_H_ | 
|  | 19 |  | 
|  | 20 | #include <string> | 
| Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 21 |  | 
|  | 22 | #include <base/logging.h> | 
|  | 23 |  | 
| Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 24 | namespace chromeos_update_manager { | 
| Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 25 |  | 
| Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 26 | template <typename T> | 
| Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 27 | const T* EvaluationContext::GetValue(Variable<T>* var) { | 
| Alex Deymo | cc0e5cf | 2014-04-23 20:20:11 -0700 | [diff] [blame] | 28 | if (var == nullptr) { | 
| Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 29 | LOG(ERROR) << "GetValue received an uninitialized variable."; | 
| Alex Deymo | cc0e5cf | 2014-04-23 20:20:11 -0700 | [diff] [blame] | 30 | return nullptr; | 
| Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 31 | } | 
|  | 32 |  | 
|  | 33 | // Search for the value on the cache first. | 
|  | 34 | ValueCacheMap::iterator it = value_cache_.find(var); | 
|  | 35 | if (it != value_cache_.end()) | 
|  | 36 | return reinterpret_cast<const T*>(it->second.value()); | 
|  | 37 |  | 
|  | 38 | // Get the value from the variable if not found on the cache. | 
|  | 39 | std::string errmsg; | 
| Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 40 | const T* result = | 
|  | 41 | var->GetValue(RemainingTime(evaluation_monotonic_deadline_), &errmsg); | 
| Amin Hassani | 03277de | 2020-07-28 12:32:49 -0700 | [diff] [blame] | 42 | if (result == nullptr && !var->IsMissingOk()) { | 
| Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 43 | LOG(WARNING) << "Error reading Variable " << var->GetName() << ": \"" | 
| Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 44 | << errmsg << "\""; | 
| Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 45 | } | 
| Alex Deymo | cc0e5cf | 2014-04-23 20:20:11 -0700 | [diff] [blame] | 46 | // Cache the value for the next time. The map of CachedValues keeps the | 
|  | 47 | // ownership of the pointer until the map is destroyed. | 
| Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 48 | value_cache_.emplace(static_cast<BaseVariable*>(var), BoxedValue(result)); | 
| Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 49 | return result; | 
|  | 50 | } | 
|  | 51 |  | 
| Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 52 | }  // namespace chromeos_update_manager | 
| Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 53 |  | 
| Gilad Arnold | 48415f1 | 2014-06-27 07:10:58 -0700 | [diff] [blame] | 54 | #endif  // UPDATE_ENGINE_UPDATE_MANAGER_EVALUATION_CONTEXT_INL_H_ |