| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/about_flags.h" | 5 #include "chrome/browser/about_flags.h" |
| 6 | 6 |
| 7 #include <iterator> | 7 #include <iterator> |
| 8 #include <map> | 8 #include <map> |
| 9 #include <set> | 9 #include <set> |
| 10 #include <utility> | 10 #include <utility> |
| (...skipping 13 matching lines...) Expand all Loading... |
| 24 #include "chrome/common/chrome_switches.h" | 24 #include "chrome/common/chrome_switches.h" |
| 25 #include "chrome/grit/chromium_strings.h" | 25 #include "chrome/grit/chromium_strings.h" |
| 26 #include "chrome/grit/generated_resources.h" | 26 #include "chrome/grit/generated_resources.h" |
| 27 #include "chrome/grit/google_chrome_strings.h" | 27 #include "chrome/grit/google_chrome_strings.h" |
| 28 #include "components/autofill/core/common/autofill_switches.h" | 28 #include "components/autofill/core/common/autofill_switches.h" |
| 29 #include "components/browser_sync/common/browser_sync_switches.h" | 29 #include "components/browser_sync/common/browser_sync_switches.h" |
| 30 #include "components/cloud_devices/common/cloud_devices_switches.h" | 30 #include "components/cloud_devices/common/cloud_devices_switches.h" |
| 31 #include "components/data_reduction_proxy/core/common/data_reduction_proxy_switc
hes.h" | 31 #include "components/data_reduction_proxy/core/common/data_reduction_proxy_switc
hes.h" |
| 32 #include "components/dom_distiller/core/dom_distiller_switches.h" | 32 #include "components/dom_distiller/core/dom_distiller_switches.h" |
| 33 #include "components/enhanced_bookmarks/enhanced_bookmark_switches.h" | 33 #include "components/enhanced_bookmarks/enhanced_bookmark_switches.h" |
| 34 #include "components/flags_ui/feature_entry_macros.h" |
| 34 #include "components/flags_ui/flags_storage.h" | 35 #include "components/flags_ui/flags_storage.h" |
| 35 #include "components/metrics/metrics_hashes.h" | 36 #include "components/metrics/metrics_hashes.h" |
| 36 #include "components/nacl/common/nacl_switches.h" | 37 #include "components/nacl/common/nacl_switches.h" |
| 37 #include "components/offline_pages/offline_page_switches.h" | 38 #include "components/offline_pages/offline_page_switches.h" |
| 38 #include "components/omnibox/browser/omnibox_switches.h" | 39 #include "components/omnibox/browser/omnibox_switches.h" |
| 39 #include "components/password_manager/core/common/password_manager_switches.h" | 40 #include "components/password_manager/core/common/password_manager_switches.h" |
| 40 #include "components/plugins/common/plugins_switches.h" | 41 #include "components/plugins/common/plugins_switches.h" |
| 41 #include "components/proximity_auth/switches.h" | 42 #include "components/proximity_auth/switches.h" |
| 42 #include "components/search/search_switches.h" | 43 #include "components/search/search_switches.h" |
| 43 #include "components/signin/core/common/signin_switches.h" | 44 #include "components/signin/core/common/signin_switches.h" |
| 44 #include "components/sync_driver/sync_driver_switches.h" | 45 #include "components/sync_driver/sync_driver_switches.h" |
| 45 #include "components/tracing/tracing_switches.h" | 46 #include "components/tracing/tracing_switches.h" |
| 46 #include "components/version_info/version_info.h" | 47 #include "components/version_info/version_info.h" |
| 47 #include "content/public/browser/user_metrics.h" | 48 #include "content/public/browser/user_metrics.h" |
| 48 #include "content/public/common/content_switches.h" | 49 #include "content/public/common/content_switches.h" |
| 50 #include "grit/components_strings.h" |
| 49 #include "media/base/media_switches.h" | 51 #include "media/base/media_switches.h" |
| 50 #include "media/midi/midi_switches.h" | 52 #include "media/midi/midi_switches.h" |
| 51 #include "ui/base/l10n/l10n_util.h" | 53 #include "ui/base/l10n/l10n_util.h" |
| 52 #include "ui/base/ui_base_switches.h" | 54 #include "ui/base/ui_base_switches.h" |
| 53 #include "ui/display/display_switches.h" | 55 #include "ui/display/display_switches.h" |
| 54 #include "ui/events/event_switches.h" | 56 #include "ui/events/event_switches.h" |
| 55 #include "ui/gfx/switches.h" | 57 #include "ui/gfx/switches.h" |
| 56 #include "ui/gl/gl_switches.h" | 58 #include "ui/gl/gl_switches.h" |
| 57 #include "ui/keyboard/keyboard_switches.h" | 59 #include "ui/keyboard/keyboard_switches.h" |
| 58 #include "ui/native_theme/native_theme_switches.h" | 60 #include "ui/native_theme/native_theme_switches.h" |
| (...skipping 17 matching lines...) Expand all Loading... |
| 76 #endif | 78 #endif |
| 77 | 79 |
| 78 #if defined(ENABLE_EXTENSIONS) | 80 #if defined(ENABLE_EXTENSIONS) |
| 79 #include "extensions/common/switches.h" | 81 #include "extensions/common/switches.h" |
| 80 #endif | 82 #endif |
| 81 | 83 |
| 82 #if defined(USE_OZONE) | 84 #if defined(USE_OZONE) |
| 83 #include "ui/ozone/public/ozone_switches.h" | 85 #include "ui/ozone/public/ozone_switches.h" |
| 84 #endif | 86 #endif |
| 85 | 87 |
| 88 using flags_ui::FeatureEntry; |
| 89 |
| 86 namespace about_flags { | 90 namespace about_flags { |
| 87 | 91 |
| 88 // Macros to simplify specifying the type. Please refer to the comments on | |
| 89 // FeatureEntry::Type in the header file, which explain the different entry | |
| 90 // types and when they should be used. | |
| 91 #define SINGLE_VALUE_TYPE_AND_VALUE(command_line_switch, switch_value) \ | |
| 92 FeatureEntry::SINGLE_VALUE, command_line_switch, switch_value, nullptr, \ | |
| 93 nullptr, nullptr, nullptr, 0 | |
| 94 #define SINGLE_VALUE_TYPE(command_line_switch) \ | |
| 95 SINGLE_VALUE_TYPE_AND_VALUE(command_line_switch, "") | |
| 96 #define SINGLE_DISABLE_VALUE_TYPE_AND_VALUE(command_line_switch, switch_value) \ | |
| 97 FeatureEntry::SINGLE_DISABLE_VALUE, command_line_switch, switch_value, \ | |
| 98 nullptr, nullptr, nullptr, nullptr, 0 | |
| 99 #define SINGLE_DISABLE_VALUE_TYPE(command_line_switch) \ | |
| 100 SINGLE_DISABLE_VALUE_TYPE_AND_VALUE(command_line_switch, "") | |
| 101 #define ENABLE_DISABLE_VALUE_TYPE_AND_VALUE(enable_switch, enable_value, \ | |
| 102 disable_switch, disable_value) \ | |
| 103 FeatureEntry::ENABLE_DISABLE_VALUE, enable_switch, enable_value, \ | |
| 104 disable_switch, disable_value, nullptr, nullptr, 3 | |
| 105 #define ENABLE_DISABLE_VALUE_TYPE(enable_switch, disable_switch) \ | |
| 106 ENABLE_DISABLE_VALUE_TYPE_AND_VALUE(enable_switch, "", disable_switch, "") | |
| 107 #define MULTI_VALUE_TYPE(choices) \ | |
| 108 FeatureEntry::MULTI_VALUE, nullptr, nullptr, nullptr, nullptr, nullptr, \ | |
| 109 choices, arraysize(choices) | |
| 110 #define FEATURE_VALUE_TYPE(feature) \ | |
| 111 FeatureEntry::FEATURE_VALUE, nullptr, nullptr, nullptr, nullptr, \ | |
| 112 feature.name, nullptr, 3 | |
| 113 | |
| 114 namespace { | 92 namespace { |
| 115 | 93 |
| 116 // Enumeration of OSs. | 94 // Enumeration of OSs. |
| 117 enum { | 95 enum { |
| 118 kOsMac = 1 << 0, | 96 kOsMac = 1 << 0, |
| 119 kOsWin = 1 << 1, | 97 kOsWin = 1 << 1, |
| 120 kOsLinux = 1 << 2, | 98 kOsLinux = 1 << 2, |
| 121 kOsCrOS = 1 << 3, | 99 kOsCrOS = 1 << 3, |
| 122 kOsAndroid = 1 << 4, | 100 kOsAndroid = 1 << 4, |
| 123 kOsCrOSOwnerOnly = 1 << 5 | 101 kOsCrOSOwnerOnly = 1 << 5 |
| (...skipping 2324 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2448 value->SetString("internal_name", name); | 2426 value->SetString("internal_name", name); |
| 2449 value->SetString("description", entry.DescriptionForChoice(i)); | 2427 value->SetString("description", entry.DescriptionForChoice(i)); |
| 2450 value->SetBoolean("selected", enabled_entries.count(name) > 0); | 2428 value->SetBoolean("selected", enabled_entries.count(name) > 0); |
| 2451 result->Append(value); | 2429 result->Append(value); |
| 2452 } | 2430 } |
| 2453 return result; | 2431 return result; |
| 2454 } | 2432 } |
| 2455 | 2433 |
| 2456 } // namespace | 2434 } // namespace |
| 2457 | 2435 |
| 2458 std::string FeatureEntry::NameForChoice(int index) const { | |
| 2459 DCHECK(type == FeatureEntry::MULTI_VALUE || | |
| 2460 type == FeatureEntry::ENABLE_DISABLE_VALUE || | |
| 2461 type == FeatureEntry::FEATURE_VALUE); | |
| 2462 DCHECK_LT(index, num_choices); | |
| 2463 return std::string(internal_name) + testing::kMultiSeparator + | |
| 2464 base::IntToString(index); | |
| 2465 } | |
| 2466 | |
| 2467 base::string16 FeatureEntry::DescriptionForChoice(int index) const { | |
| 2468 DCHECK(type == FeatureEntry::MULTI_VALUE || | |
| 2469 type == FeatureEntry::ENABLE_DISABLE_VALUE || | |
| 2470 type == FeatureEntry::FEATURE_VALUE); | |
| 2471 DCHECK_LT(index, num_choices); | |
| 2472 int description_id; | |
| 2473 if (type == FeatureEntry::ENABLE_DISABLE_VALUE || | |
| 2474 type == FeatureEntry::FEATURE_VALUE) { | |
| 2475 const int kEnableDisableDescriptionIds[] = { | |
| 2476 IDS_GENERIC_EXPERIMENT_CHOICE_DEFAULT, | |
| 2477 IDS_GENERIC_EXPERIMENT_CHOICE_ENABLED, | |
| 2478 IDS_GENERIC_EXPERIMENT_CHOICE_DISABLED, | |
| 2479 }; | |
| 2480 description_id = kEnableDisableDescriptionIds[index]; | |
| 2481 } else { | |
| 2482 description_id = choices[index].description_id; | |
| 2483 } | |
| 2484 return l10n_util::GetStringUTF16(description_id); | |
| 2485 } | |
| 2486 | |
| 2487 void ConvertFlagsToSwitches(flags_ui::FlagsStorage* flags_storage, | 2436 void ConvertFlagsToSwitches(flags_ui::FlagsStorage* flags_storage, |
| 2488 base::CommandLine* command_line, | 2437 base::CommandLine* command_line, |
| 2489 SentinelsMode sentinels) { | 2438 SentinelsMode sentinels) { |
| 2490 FlagsState::GetInstance()->ConvertFlagsToSwitches(flags_storage, | 2439 FlagsState::GetInstance()->ConvertFlagsToSwitches(flags_storage, |
| 2491 command_line, | 2440 command_line, |
| 2492 sentinels); | 2441 sentinels); |
| 2493 } | 2442 } |
| 2494 | 2443 |
| 2495 bool AreSwitchesIdenticalToCurrentCommandLine( | 2444 bool AreSwitchesIdenticalToCurrentCommandLine( |
| 2496 const base::CommandLine& new_cmdline, | 2445 const base::CommandLine& new_cmdline, |
| (...skipping 229 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2726 command_line); | 2675 command_line); |
| 2727 } | 2676 } |
| 2728 | 2677 |
| 2729 bool FlagsState::IsRestartNeededToCommitChanges() { | 2678 bool FlagsState::IsRestartNeededToCommitChanges() { |
| 2730 return needs_restart_; | 2679 return needs_restart_; |
| 2731 } | 2680 } |
| 2732 | 2681 |
| 2733 void FlagsState::SetFeatureEntryEnabled(flags_ui::FlagsStorage* flags_storage, | 2682 void FlagsState::SetFeatureEntryEnabled(flags_ui::FlagsStorage* flags_storage, |
| 2734 const std::string& internal_name, | 2683 const std::string& internal_name, |
| 2735 bool enable) { | 2684 bool enable) { |
| 2736 size_t at_index = internal_name.find(testing::kMultiSeparator); | 2685 size_t at_index = internal_name.find(flags_ui::testing::kMultiSeparator); |
| 2737 if (at_index != std::string::npos) { | 2686 if (at_index != std::string::npos) { |
| 2738 DCHECK(enable); | 2687 DCHECK(enable); |
| 2739 // We're being asked to enable a multi-choice entry. Disable the | 2688 // We're being asked to enable a multi-choice entry. Disable the |
| 2740 // currently selected choice. | 2689 // currently selected choice. |
| 2741 DCHECK_NE(at_index, 0u); | 2690 DCHECK_NE(at_index, 0u); |
| 2742 const std::string entry_name = internal_name.substr(0, at_index); | 2691 const std::string entry_name = internal_name.substr(0, at_index); |
| 2743 SetFeatureEntryEnabled(flags_storage, entry_name, false); | 2692 SetFeatureEntryEnabled(flags_storage, entry_name, false); |
| 2744 | 2693 |
| 2745 // And enable the new choice, if it is not the default first choice. | 2694 // And enable the new choice, if it is not the default first choice. |
| 2746 if (internal_name != entry_name + "@0") { | 2695 if (internal_name != entry_name + "@0") { |
| (...skipping 206 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2953 // switch to the end but doesn't remove previous ones). | 2902 // switch to the end but doesn't remove previous ones). |
| 2954 std::string switch_value = base::JoinString(features, ","); | 2903 std::string switch_value = base::JoinString(features, ","); |
| 2955 if (switch_value != original_switch_value) | 2904 if (switch_value != original_switch_value) |
| 2956 command_line->AppendSwitchASCII(switch_name, switch_value); | 2905 command_line->AppendSwitchASCII(switch_name, switch_value); |
| 2957 } | 2906 } |
| 2958 | 2907 |
| 2959 } // namespace | 2908 } // namespace |
| 2960 | 2909 |
| 2961 namespace testing { | 2910 namespace testing { |
| 2962 | 2911 |
| 2963 // WARNING: '@' is also used in the html file. If you update this constant you | |
| 2964 // also need to update the html file. | |
| 2965 const char kMultiSeparator[] = "@"; | |
| 2966 | |
| 2967 const base::HistogramBase::Sample kBadSwitchFormatHistogramId = 0; | 2912 const base::HistogramBase::Sample kBadSwitchFormatHistogramId = 0; |
| 2968 | 2913 |
| 2969 void ClearState() { | 2914 void ClearState() { |
| 2970 FlagsState::GetInstance()->Reset(); | 2915 FlagsState::GetInstance()->Reset(); |
| 2971 } | 2916 } |
| 2972 | 2917 |
| 2973 void SetFeatureEntries(const FeatureEntry* entries, size_t count) { | 2918 void SetFeatureEntries(const FeatureEntry* entries, size_t count) { |
| 2974 if (!entries) { | 2919 if (!entries) { |
| 2975 entries = kFeatureEntries; | 2920 entries = kFeatureEntries; |
| 2976 count = arraysize(kFeatureEntries); | 2921 count = arraysize(kFeatureEntries); |
| 2977 } | 2922 } |
| 2978 FlagsState::GetInstance()->SetFeatureEntries(entries, count); | 2923 FlagsState::GetInstance()->SetFeatureEntries(entries, count); |
| 2979 } | 2924 } |
| 2980 | 2925 |
| 2981 const FeatureEntry* GetFeatureEntries(size_t* count) { | 2926 const FeatureEntry* GetFeatureEntries(size_t* count) { |
| 2982 return FlagsState::GetInstance()->GetFeatureEntries(count); | 2927 return FlagsState::GetInstance()->GetFeatureEntries(count); |
| 2983 } | 2928 } |
| 2984 | 2929 |
| 2985 } // namespace testing | 2930 } // namespace testing |
| 2986 | 2931 |
| 2987 } // namespace about_flags | 2932 } // namespace about_flags |
| OLD | NEW |