Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(200)

Unified Diff: components/prefs/command_line_pref_store.h

Issue 2419733005: Extract a base class from CommandLinePrefStore (Closed)
Patch Set: Extract a base class from CommandLinePrefStore Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « components/prefs/BUILD.gn ('k') | components/prefs/command_line_pref_store.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: components/prefs/command_line_pref_store.h
diff --git a/components/prefs/command_line_pref_store.h b/components/prefs/command_line_pref_store.h
new file mode 100644
index 0000000000000000000000000000000000000000..fff3fe112ff759299d7d394ac5f7e98b80dede1f
--- /dev/null
+++ b/components/prefs/command_line_pref_store.h
@@ -0,0 +1,65 @@
+// Copyright (c) 2016 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_PREFS_COMMAND_LINE_PREF_STORE_H_
+#define COMPONENTS_PREFS_COMMAND_LINE_PREF_STORE_H_
+
+#include "base/command_line.h"
+#include "base/macros.h"
+#include "base/values.h"
+#include "components/prefs/value_map_pref_store.h"
+
+// Base class for a PrefStore that maps command line switches to preferences.
+// Subclasses should call the Apply...Switches() methods with their own maps.
Bernhard Bauer 2016/10/17 14:46:38 OK, sorry. Now this comment isn't quite accurate a
Menglin 2016/10/17 16:27:52 yeah i should've changed this in the last upload.
+class COMPONENTS_PREFS_EXPORT CommandLinePrefStore : public ValueMapPrefStore {
+ public:
+ struct SwitchToPreferenceMapEntry {
+ const char* switch_name;
+ const char* preference_path;
+ };
+
+ // |set_value| indicates what the preference should be set to if the switch
+ // is present.
+ struct BooleanSwitchToPreferenceMapEntry {
+ const char* switch_name;
+ const char* preference_path;
+ bool set_value;
+ };
+
+ // Apply command-line switches to the corresponding preferences of the switch
+ // map, where the value associated with the switch is a string.
+ void ApplyStringSwitches(
+ const SwitchToPreferenceMapEntry string_switch_map[], size_t size);
+
+ // Apply command-line switches to the corresponding preferences of the switch
+ // map, where the value associated with the switch is a path.
+ void ApplyPathSwitches(const SwitchToPreferenceMapEntry path_switch_map[],
+ size_t size);
+
+ // Apply command-line switches to the corresponding preferences of the switch
+ // map, where the value associated with the switch is an integer.
+ void ApplyIntegerSwitches(
+ const SwitchToPreferenceMapEntry integer_switch_map[], size_t size);
+
+ // Apply command-line switches to the corresponding preferences of the
+ // boolean switch map.
+ void ApplyBooleanSwitches(
+ const BooleanSwitchToPreferenceMapEntry boolean_switch_map[],
+ size_t size);
+
+
+ protected:
+ explicit CommandLinePrefStore(const base::CommandLine* command_line);
+ ~CommandLinePrefStore() override;
+
+ const base::CommandLine* command_line() { return command_line_; }
+
+ private:
+ // Weak reference.
+ const base::CommandLine* command_line_;
+
+ DISALLOW_COPY_AND_ASSIGN(CommandLinePrefStore);
+};
+
+#endif // COMPONENTS_PREFS_COMMAND_LINE_PREF_STORE_H_
« no previous file with comments | « components/prefs/BUILD.gn ('k') | components/prefs/command_line_pref_store.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698