| // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef CHROMEOS_SYSTEM_NAME_VALUE_PAIRS_PARSER_H_ |
| #define CHROMEOS_SYSTEM_NAME_VALUE_PAIRS_PARSER_H_ |
| |
| #include <map> |
| #include <string> |
| |
| #include "base/macros.h" |
| #include "chromeos/chromeos_export.h" |
| |
| namespace base { |
| class FilePath; |
| } |
| |
| namespace chromeos { |
| namespace system { |
| |
| // The parser is used to get machine info as name-value pairs. Defined |
| // here to be accessible by tests. |
| class CHROMEOS_EXPORT NameValuePairsParser { |
| public: |
| typedef std::map<std::string, std::string> NameValueMap; |
| |
| // The obtained info will be written into the given map. |
| explicit NameValuePairsParser(NameValueMap* map); |
| |
| void AddNameValuePair(const std::string& key, const std::string& value); |
| |
| // Executes tool and inserts (key, <output>) into map_. |
| // The program name (argv[0]) should be an absolute path. The function |
| // checks if the program exists before executing it as some programs |
| // don't exist on Linux desktop; returns false in that case. |
| bool GetSingleValueFromTool(int argc, const char* argv[], |
| const std::string& key); |
| |
| // Parses name-value pairs from the file. |
| // Returns false if there was any error in the file. Valid pairs will still be |
| // added to the map. |
| bool GetNameValuePairsFromFile(const base::FilePath& file_path, |
| const std::string& eq, |
| const std::string& delim); |
| |
| // These will parse strings with output in the format: |
| // <key><EQ><value><DELIM>[<key><EQ><value>][...] |
| // e.g. ParseNameValuePairs("key1=value1 key2=value2", "=", " ") |
| // Returns false if there was any error in in_string. Valid pairs will still |
| // be added to the map. |
| bool ParseNameValuePairs(const std::string& in_string, |
| const std::string& eq, |
| const std::string& delim); |
| |
| // This version allows for values which end with a comment |
| // beginning with comment_delim. |
| // e.g. "key2=value2 # Explanation of value\n" |
| // Returns false if there was any error in in_string. Valid pairs will still |
| // be added to the map. |
| bool ParseNameValuePairsWithComments(const std::string& in_string, |
| const std::string& eq, |
| const std::string& delim, |
| const std::string& comment_delim); |
| |
| // Same as ParseNameValuePairsWithComments(), but uses the output of the given |
| // tool as the input to parse. |
| bool ParseNameValuePairsFromTool( |
| int argc, |
| const char* argv[], |
| const std::string& eq, |
| const std::string& delim, |
| const std::string& comment_delim); |
| |
| private: |
| NameValueMap* map_; |
| |
| DISALLOW_COPY_AND_ASSIGN(NameValuePairsParser); |
| }; |
| |
| } // namespace system |
| } // namespace chromeos |
| |
| #endif // CHROMEOS_SYSTEM_NAME_VALUE_PAIRS_PARSER_H_ |