blob: 937adf4de11cb948bd8758d3d37aeec7d6e9802c [file] [log] [blame]
Alex Deymoaea4c1c2015-08-19 20:24:43 -07001//
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 Deymo23949d42014-02-05 15:20:59 -080016
Gilad Arnold48415f12014-06-27 07:10:58 -070017#ifndef UPDATE_ENGINE_UPDATE_MANAGER_EVALUATION_CONTEXT_INL_H_
18#define UPDATE_ENGINE_UPDATE_MANAGER_EVALUATION_CONTEXT_INL_H_
19
20#include <string>
Alex Deymo23949d42014-02-05 15:20:59 -080021
22#include <base/logging.h>
23
Alex Deymo63784a52014-05-28 10:46:14 -070024namespace chromeos_update_manager {
Alex Deymo23949d42014-02-05 15:20:59 -080025
26template<typename T>
27const T* EvaluationContext::GetValue(Variable<T>* var) {
Alex Deymocc0e5cf2014-04-23 20:20:11 -070028 if (var == nullptr) {
Alex Deymo23949d42014-02-05 15:20:59 -080029 LOG(ERROR) << "GetValue received an uninitialized variable.";
Alex Deymocc0e5cf2014-04-23 20:20:11 -070030 return nullptr;
Alex Deymo23949d42014-02-05 15:20:59 -080031 }
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;
Gilad Arnoldf9f85d62014-06-19 18:07:01 -070040 const T* result = var->GetValue(RemainingTime(evaluation_monotonic_deadline_),
41 &errmsg);
Alex Deymocc0e5cf2014-04-23 20:20:11 -070042 if (result == nullptr) {
Alex Deymo23949d42014-02-05 15:20:59 -080043 LOG(WARNING) << "Error reading Variable " << var->GetName() << ": \""
44 << errmsg << "\"";
Alex Deymo23949d42014-02-05 15:20:59 -080045 }
Alex Deymocc0e5cf2014-04-23 20:20:11 -070046 // Cache the value for the next time. The map of CachedValues keeps the
47 // ownership of the pointer until the map is destroyed.
48 value_cache_.emplace(
Yunlian Jiangcef5cd62015-05-27 15:22:32 -070049 static_cast<BaseVariable*>(var), BoxedValue(result));
Alex Deymo23949d42014-02-05 15:20:59 -080050 return result;
51}
52
Alex Deymo63784a52014-05-28 10:46:14 -070053} // namespace chromeos_update_manager
Alex Deymo23949d42014-02-05 15:20:59 -080054
Gilad Arnold48415f12014-06-27 07:10:58 -070055#endif // UPDATE_ENGINE_UPDATE_MANAGER_EVALUATION_CONTEXT_INL_H_