Index: ios/chrome/browser/experimental_flags.mm |
diff --git a/ios/chrome/browser/experimental_flags.mm b/ios/chrome/browser/experimental_flags.mm |
index a1ab78ee02c8030a51de69c2f953783f9aafb398..85f454350b55968d03f54e64165c066cc57ab856 100644 |
--- a/ios/chrome/browser/experimental_flags.mm |
+++ b/ios/chrome/browser/experimental_flags.mm |
@@ -7,7 +7,12 @@ |
#include "ios/chrome/browser/experimental_flags.h" |
+#include <string> |
+ |
#include "base/command_line.h" |
+#include "base/metrics/field_trial.h" |
+#include "base/strings/string_number_conversions.h" |
+#include "components/variations/variations_associated_data.h" |
#include "ios/chrome/browser/chrome_switches.h" |
namespace experimental_flags { |
@@ -17,4 +22,25 @@ bool IsOpenFromClipboardEnabled() { |
return command_line->HasSwitch(switches::kEnableIOSOpenFromClipboard); |
} |
+size_t MemoryWedgeSizeInMB() { |
+ std::string wedge_size_string; |
+ |
+ // Get the size from the Experimental setting. |
+ base::CommandLine* command_line = base::CommandLine::ForCurrentProcess(); |
+ wedge_size_string = |
+ command_line->GetSwitchValueASCII(switches::kIOSMemoryWedgeSize); |
+ |
+ // Otherwise, get from Finch. |
Alexei Svitkine (slow)
2015/04/28 18:43:40
Nit: Finch is a codename, so we avoid using in cod
lpromero
2015/04/28 22:01:45
Done.
|
+ if (wedge_size_string.empty()) { |
+ wedge_size_string = |
+ variations::GetVariationParamValue("MemoryWedge", "wedge_size"); |
+ } |
+ |
+ // Parse the value. |
+ unsigned wedge_size_in_mb = 0; |
+ if (base::StringToUint(wedge_size_string, &wedge_size_in_mb)) |
Alexei Svitkine (slow)
2015/04/28 18:43:40
Change to StringToSizeT
lpromero
2015/04/28 22:01:45
Done.
|
+ return wedge_size_in_mb; |
+ return 0; |
+} |
+ |
} // namespace experimental_flags |