/* * Copyright (C) 2017 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef COMBINATION_CONDITION_TRACKER_H #define COMBINATION_CONDITION_TRACKER_H #include "ConditionTracker.h" #include "src/statsd_config.pb.h" namespace android { namespace os { namespace statsd { class CombinationConditionTracker : public ConditionTracker { public: CombinationConditionTracker(int64_t id, int index, const uint64_t protoHash); ~CombinationConditionTracker(); optional init( const std::vector& allConditionConfig, const std::vector>& allConditionTrackers, const std::unordered_map& conditionIdIndexMap, std::vector& stack, std::vector& conditionCache) override; optional onConfigUpdated( const std::vector& allConditionProtos, int index, const std::vector>& allConditionTrackers, const std::unordered_map& atomMatchingTrackerMap, const std::unordered_map& conditionTrackerMap) override; void evaluateCondition(const LogEvent& event, const std::vector& eventMatcherValues, const std::vector>& mAllConditions, std::vector& conditionCache, std::vector& changedCache) override; void isConditionMet(const ConditionKey& conditionParameters, const std::vector>& allConditions, const bool isPartialLink, std::vector& conditionCache) const override; // Only one child predicate can have dimension. const std::set* getChangedToTrueDimensions( const std::vector>& allConditions) const override { for (const auto& child : mChildren) { auto result = allConditions[child]->getChangedToTrueDimensions(allConditions); if (result != nullptr) { return result; } } return nullptr; } // Only one child predicate can have dimension. const std::set* getChangedToFalseDimensions( const std::vector>& allConditions) const override { for (const auto& child : mChildren) { auto result = allConditions[child]->getChangedToFalseDimensions(allConditions); if (result != nullptr) { return result; } } return nullptr; } bool IsSimpleCondition() const override { return false; } bool IsChangedDimensionTrackable() const override { return mLogicalOperation == LogicalOperation::AND && mSlicedChildren.size() == 1; } bool equalOutputDimensions( const std::vector>& allConditions, const vector& dimensions) const override; const std::map* getSlicedDimensionMap( const std::vector>& allConditions) const override { if (mSlicedChildren.size() == 1) { return allConditions[mSlicedChildren.front()]->getSlicedDimensionMap(allConditions); } return nullptr; } private: LogicalOperation mLogicalOperation; // Store index of the children Predicates. // We don't store string name of the Children, because we want to get rid of the hash map to // map the name to object. We don't want to store smart pointers to children, because it // increases the risk of circular dependency and memory leak. std::vector mChildren; std::vector mSlicedChildren; std::vector mUnSlicedChildren; FRIEND_TEST(ConfigUpdateTest, TestUpdateConditions); }; } // namespace statsd } // namespace os } // namespace android #endif // COMBINATION_CONDITION_TRACKER_H