Index: components/flags_ui/flags_state.h |
diff --git a/components/flags_ui/flags_state.h b/components/flags_ui/flags_state.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..8f2a19ffd948beb82e34246948736428956f8f7d |
--- /dev/null |
+++ b/components/flags_ui/flags_state.h |
@@ -0,0 +1,160 @@ |
+// Copyright 2015 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 COMPONENTS_FLAGS_UI_FLAGS_STATE_H_ |
+#define COMPONENTS_FLAGS_UI_FLAGS_STATE_H_ |
+ |
+#include <map> |
+#include <set> |
+#include <string> |
+ |
+#include "base/callback_forward.h" |
+#include "base/command_line.h" |
+#include "base/macros.h" |
+ |
+namespace base { |
+class ListValue; |
+} |
+ |
+namespace flags_ui { |
+ |
+struct FeatureEntry; |
+class FlagsStorage; |
+struct SwitchEntry; |
+ |
+// Enumeration of OSs. |
+enum { |
+ kOsMac = 1 << 0, |
+ kOsWin = 1 << 1, |
+ kOsLinux = 1 << 2, |
+ kOsCrOS = 1 << 3, |
+ kOsAndroid = 1 << 4, |
+ kOsCrOSOwnerOnly = 1 << 5 |
+}; |
+ |
+// A flag controlling the behavior of the |ConvertFlagsToSwitches| function - |
+// whether it should add the sentinel switches around flags. |
+enum SentinelsMode { kNoSentinels, kAddSentinels }; |
+ |
+// Differentiate between generic flags available on a per session base and flags |
+// that influence the whole machine and can be said by the admin only. This flag |
+// is relevant for ChromeOS for now only and dictates whether entries marked |
+// with the |kOsCrOSOwnerOnly| label should be enabled in the UI or not. |
+enum FlagAccess { kGeneralAccessFlagsOnly, kOwnerAccessToFlags }; |
+ |
+// Stores and encapsulates the little state that about:flags has. |
+class FlagsState { |
+ public: |
+ FlagsState(const FeatureEntry* feature_entries, size_t num_feature_entries); |
+ ~FlagsState(); |
+ |
+ void ConvertFlagsToSwitches(FlagsStorage* flags_storage, |
+ base::CommandLine* command_line, |
+ SentinelsMode sentinels, |
+ const char* enable_features_flag_name, |
+ const char* disable_features_flag_name); |
+ bool IsRestartNeededToCommitChanges(); |
+ void SetFeatureEntryEnabled(FlagsStorage* flags_storage, |
+ const std::string& internal_name, |
+ bool enable); |
+ void RemoveFlagsSwitches( |
+ std::map<std::string, base::CommandLine::StringType>* switch_list); |
+ void ResetAllFlags(FlagsStorage* flags_storage); |
+ void Reset(); |
+ |
+ // Gets the list of feature entries. Entries that are available for the |
+ // current platform are appended to |supported_entries|; all other entries are |
+ // appended to |unsupported_entries|. |
+ void GetFlagFeatureEntries( |
+ FlagsStorage* flags_storage, |
+ FlagAccess access, |
+ base::ListValue* supported_entries, |
+ base::ListValue* unsupported_entries, |
+ base::Callback<bool(const FeatureEntry&)> skip_feature_entry); |
+ |
+ // Returns the value for the current platform. This is one of the values |
+ // defined by the OS enum above. |
+ // This is exposed only for testing. |
+ static int GetCurrentPlatform(); |
+ |
+ // Compares a set of switches of the two provided command line objects and |
+ // returns true if they are the same and false otherwise. |
+ // If |out_difference| is not NULL, it's filled with set_symmetric_difference |
+ // between sets. |
+ // Only switches between --flag-switches-begin and --flag-switches-end are |
+ // compared. The embedder may use |extra_flag_sentinel_begin_flag_name| and |
+ // |extra_sentinel_end_flag_name| to specify other delimiters, if supported. |
+ static bool AreSwitchesIdenticalToCurrentCommandLine( |
+ const base::CommandLine& new_cmdline, |
+ const base::CommandLine& active_cmdline, |
+ std::set<base::CommandLine::StringType>* out_difference, |
+ const char* extra_flag_sentinel_begin_flag_name, |
+ const char* extra_flag_sentinel_end_flag_name); |
+ |
+ private: |
+ // Adds mapping to |name_to_switch_map| to set the given switch name/value. |
+ void AddSwitchMapping(const std::string& key, |
+ const std::string& switch_name, |
+ const std::string& switch_value, |
+ std::map<std::string, SwitchEntry>* name_to_switch_map); |
+ |
+ // Adds mapping to |name_to_switch_map| to toggle base::Feature |feature_name| |
+ // to state |feature_state|. |
+ void AddFeatureMapping( |
+ const std::string& key, |
+ const std::string& feature_name, |
+ bool feature_state, |
+ std::map<std::string, SwitchEntry>* name_to_switch_map); |
+ |
+ // Updates the switches in |command_line| by applying the modifications |
+ // specified in |name_to_switch_map| for each entry in |enabled_entries|. |
+ // |enable_features_flag_name| and |disable_features_flag_name| are switches |
+ // used by the embedder to enable/disable features respectively if supported. |
+ void AddSwitchesToCommandLine( |
+ const std::set<std::string>& enabled_entries, |
+ const std::map<std::string, SwitchEntry>& name_to_switch_map, |
+ SentinelsMode sentinels, |
+ base::CommandLine* command_line, |
+ const char* enable_features_flag_name, |
+ const char* disable_features_flag_name); |
+ |
+ // Updates |command_line| by merging the value of the --enable-features= or |
+ // --disable-features= list (per the |switch_name| param) with corresponding |
+ // entries in |feature_switches| that have value |feature_state|. Keeps track |
+ // of the changes by updating |appended_switches|. |
+ void MergeFeatureCommandLineSwitch( |
+ const std::map<std::string, bool>& feature_switches, |
+ const char* switch_name, |
+ bool feature_state, |
+ base::CommandLine* command_line); |
+ |
+ // Removes all entries from prefs::kEnabledLabsExperiments that are unknown, |
+ // to prevent this list to become very long as entries are added and removed. |
+ void SanitizeList(FlagsStorage* flags_storage); |
+ |
+ void GetSanitizedEnabledFlags(FlagsStorage* flags_storage, |
+ std::set<std::string>* result); |
+ |
+ // Variant of GetSanitizedEnabledFlags that also removes any flags that aren't |
+ // enabled on the current platform. |
+ void GetSanitizedEnabledFlagsForCurrentPlatform( |
+ FlagsStorage* flags_storage, |
+ std::set<std::string>* result); |
+ |
+ const FeatureEntry* feature_entries_; |
+ size_t num_feature_entries_; |
+ |
+ bool needs_restart_; |
+ std::map<std::string, std::string> flags_switches_; |
+ |
+ // Map from switch name to a set of string, that keeps track which strings |
+ // were appended to existing (list value) switches. |
+ std::map<std::string, std::set<std::string>> appended_switches_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(FlagsState); |
+}; |
+ |
+} // namespace flags_ui |
+ |
+#endif // COMPONENTS_FLAGS_UI_FLAGS_STATE_H_ |