/* * Copyright (C) 2015 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 METRICS_PERSISTENT_INTEGER_H_ #define METRICS_PERSISTENT_INTEGER_H_ #include #include namespace chromeos_metrics { // PersistentIntegers is a named 64-bit integer value backed by a file. // The in-memory value acts as a write-through cache of the file value. // If the backing file doesn't exist or has bad content, the value is 0. class PersistentInteger { public: explicit PersistentInteger(const std::string& name); // Virtual only because of mock. virtual ~PersistentInteger(); // Sets the value. This writes through to the backing file. void Set(int64_t v); // Gets the value. May sync from backing file first. int64_t Get(); // Returns the name of the object. std::string Name() { return name_; } // Convenience function for Get() followed by Set(0). int64_t GetAndClear(); // Convenience function for v = Get, Set(v + x). // Virtual only because of mock. virtual void Add(int64_t x); // Sets the directory path for all persistent integers. // This is used in unittests to change where the counters are stored. static void SetMetricsDirectory(const std::string& directory); private: static const int kVersion = 1001; // Writes |value_| to the backing file, creating it if necessary. void Write(); // Reads the value from the backing file, stores it in |value_|, and returns // true if the backing file is valid. Returns false otherwise, and creates // a valid backing file as a side effect. bool Read(); int64_t value_; int32_t version_; std::string name_; std::string backing_file_name_; static std::string metrics_directory_; bool synced_; }; } // namespace chromeos_metrics #endif // METRICS_PERSISTENT_INTEGER_H_