blob: 82861fa2f356f093164c3d120943dc001bc8e413 [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
Amin Hassani4b717432019-01-14 16:24:20 -080026template <typename T>
Alex Deymo23949d42014-02-05 15:20:59 -080027const 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;
Amin Hassani4b717432019-01-14 16:24:20 -080040 const T* result =
41 var->GetValue(RemainingTime(evaluation_monotonic_deadline_), &errmsg);
Amin Hassani03277de2020-07-28 12:32:49 -070042 if (result == nullptr && !var->IsMissingOk()) {
Alex Deymo23949d42014-02-05 15:20:59 -080043 LOG(WARNING) << "Error reading Variable " << var->GetName() << ": \""
Amin Hassani4b717432019-01-14 16:24:20 -080044 << 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.
Amin Hassani4b717432019-01-14 16:24:20 -080048 value_cache_.emplace(static_cast<BaseVariable*>(var), BoxedValue(result));
Alex Deymo23949d42014-02-05 15:20:59 -080049 return result;
50}
51
Alex Deymo63784a52014-05-28 10:46:14 -070052} // namespace chromeos_update_manager
Alex Deymo23949d42014-02-05 15:20:59 -080053
Gilad Arnold48415f12014-06-27 07:10:58 -070054#endif // UPDATE_ENGINE_UPDATE_MANAGER_EVALUATION_CONTEXT_INL_H_