| Index: chrome/BUILD.gn | 
| diff --git a/chrome/BUILD.gn b/chrome/BUILD.gn | 
| index 8ddd74bb8a7a6cf025876d731a17514a5dd8a286..fbbec51ded53c7ca6c8370e19c4bbcb41144edc0 100644 | 
| --- a/chrome/BUILD.gn | 
| +++ b/chrome/BUILD.gn | 
| @@ -11,17 +11,13 @@ import("//build/config/sanitizers/sanitizers.gni") | 
| import("//build/config/ui.gni") | 
| import("//build/config/win/console_app.gni") | 
| import("//build/config/win/manifest.gni") | 
| -import("//chrome/chrome_repack_locales.gni") | 
| +import("//chrome/chrome_paks.gni") | 
| import("//chrome/common/features.gni") | 
| import("//chrome/version.gni") | 
| import("//third_party/widevine/cdm/widevine.gni") | 
| import("//ui/base/ui_features.gni") | 
| import("//v8/gni/v8.gni") | 
|  | 
| -if (enable_resource_whitelist_generation) { | 
| -  android_resource_whitelist = "$root_gen_dir/chrome/resource_whitelist.txt" | 
| -} | 
| - | 
| if (is_android) { | 
| import("//build/config/android/rules.gni") | 
| } else if (is_mac) { | 
| @@ -36,6 +32,10 @@ if (is_android) { | 
| import("//third_party/icu/config.gni") | 
| } | 
|  | 
| +if (enable_resource_whitelist_generation) { | 
| +  chrome_resource_whitelist = "$target_gen_dir/chrome_resource_whitelist.txt" | 
| +} | 
| + | 
| if (is_win) { | 
| action("reorder_imports") { | 
| script = "//build/win/reorder-imports.py" | 
| @@ -997,7 +997,7 @@ if (is_win) { | 
| ":chrome_framework_helpers", | 
| ":chrome_framework_plugins", | 
| ":chrome_framework_resources", | 
| -      ":repack_locales_pack", | 
| +      ":packed_resources", | 
| ":widevine_cdm_library", | 
| "//build/config/sanitizers:deps", | 
| "//chrome/app/nibs:chrome_xibs", | 
| @@ -1340,100 +1340,42 @@ if (is_chrome_branded && !is_android) { | 
| } | 
| } | 
|  | 
| -group("packed_resources") { | 
| -  public_deps = [ | 
| -    ":repack_chrome_100_percent", | 
| -    ":repack_locales_pack", | 
| -  ] | 
| - | 
| -  if (is_chrome_branded && !is_mac && !is_android) { | 
| -    public_deps += [ ":default_apps" ] | 
| -  } | 
| - | 
| -  if (enable_hidpi) { | 
| -    public_deps += [ ":repack_chrome_200_percent" ] | 
| +chrome_paks("packed_resources") { | 
| +  if (is_mac) { | 
| +    output_dir = "$root_gen_dir/repack" | 
| +    copy_data_to_bundle = true | 
| +  } else { | 
| +    output_dir = root_out_dir | 
| } | 
| -} | 
| - | 
| -repack("packed_extra_resources") { | 
| -  visibility = [ "./*" ] | 
| -  sources = [ | 
| -    "$root_gen_dir/blink/public/resources/blink_resources.pak", | 
| -    "$root_gen_dir/chrome/browser_resources.pak", | 
| -    "$root_gen_dir/chrome/chrome_unscaled_resources.pak", | 
| -    "$root_gen_dir/chrome/common_resources.pak", | 
| -    "$root_gen_dir/chrome/invalidations_resources.pak", | 
| -    "$root_gen_dir/chrome/net_internals_resources.pak", | 
| -    "$root_gen_dir/chrome/password_manager_internals_resources.pak", | 
| -    "$root_gen_dir/chrome/policy_resources.pak", | 
| -    "$root_gen_dir/chrome/translate_internals_resources.pak", | 
| -    "$root_gen_dir/components/components_resources.pak", | 
| -    "$root_gen_dir/content/browser/tracing/tracing_resources.pak", | 
| -    "$root_gen_dir/content/content_resources.pak", | 
| -    "$root_gen_dir/net/net_resources.pak", | 
| -    "$root_gen_dir/ui/resources/webui_resources.pak", | 
| -  ] | 
| -  deps = [ | 
| -    "//chrome/app/theme:chrome_unscaled_resources", | 
| -    "//chrome/browser:resources", | 
| -    "//chrome/browser/resources:invalidations_resources", | 
| -    "//chrome/browser/resources:net_internals_resources", | 
| -    "//chrome/browser/resources:password_manager_internals_resources", | 
| -    "//chrome/browser/resources:policy_resources", | 
| -    "//chrome/browser/resources:translate_internals_resources", | 
| -    "//chrome/common:resources", | 
| -    "//components/resources", | 
| -    "//content:resources", | 
| -    "//content/browser/tracing:resources", | 
| -    "//net:net_resources", | 
| -    "//third_party/WebKit/public:resources", | 
| -    "//ui/resources", | 
| -  ] | 
|  | 
| -  if (is_android) { | 
| -    sources += [ "$root_gen_dir/android_webview/aw_resources.pak" ] | 
| -    deps += [ "//android_webview:generate_aw_resources" ] | 
| -  } else {  # Non-Android. | 
| -    # New paks should be added here by default. | 
| -    sources += [ | 
| -      "$root_gen_dir/blink/devtools_resources.pak", | 
| -      "$root_gen_dir/chrome/component_extension_resources.pak", | 
| -      "$root_gen_dir/chrome/options_resources.pak", | 
| -      "$root_gen_dir/chrome/quota_internals_resources.pak", | 
| -      "$root_gen_dir/chrome/settings_resources.pak", | 
| -      "$root_gen_dir/chrome/sync_file_system_internals_resources.pak", | 
| -    ] | 
| -    deps += [ | 
| -      "//chrome/browser/resources:component_extension_resources", | 
| -      "//chrome/browser/resources:options_resources", | 
| -      "//chrome/browser/resources:quota_internals_resources", | 
| -      "//chrome/browser/resources:settings_resources", | 
| -      "//chrome/browser/resources:sync_file_system_internals_resources", | 
| -      "//content/browser/devtools:devtools_resources", | 
| +  if (enable_resource_whitelist_generation) { | 
| +    repack_whitelist = chrome_resource_whitelist | 
| +    deps = [ | 
| +      "//chrome:resource_whitelist", | 
| ] | 
| } | 
| -  if (is_chromeos) { | 
| -    sources += [ "$root_gen_dir/ui/file_manager/file_manager_resources.pak" ] | 
| -    deps += [ "//ui/file_manager:resources" ] | 
| -  } | 
| -  if (enable_extensions) { | 
| -    sources += [ | 
| -      "$root_gen_dir/extensions/extensions_renderer_resources.pak", | 
| -      "$root_gen_dir/extensions/extensions_resources.pak", | 
| + | 
| +  if (is_chrome_branded && !is_mac && !is_android) { | 
| +    public_deps = [ | 
| +      ":default_apps", | 
| ] | 
| -    deps += [ "//extensions:extensions_resources" ] | 
| } | 
| +} | 
|  | 
| +chrome_extra_paks("packed_extra_resources") { | 
| if (is_mac) { | 
| -    output = "$root_gen_dir/repack/resources.pak" | 
| +    output_dir = "$root_gen_dir/repack" | 
| +    copy_data_to_bundle = true | 
| } else { | 
| -    output = "$root_out_dir/resources.pak" | 
| +    output_dir = root_out_dir | 
| } | 
|  | 
| copy_data_to_bundle = is_mac | 
| if (enable_resource_whitelist_generation) { | 
| -    repack_whitelist = android_resource_whitelist | 
| -    deps += [ ":resource_whitelist" ] | 
| +    repack_whitelist = chrome_resource_whitelist | 
| +    deps = [ | 
| +      ":resource_whitelist", | 
| +    ] | 
| } | 
| } | 
|  | 
| @@ -1450,127 +1392,6 @@ repack("browser_tests_pak") { | 
| ] | 
| } | 
|  | 
| -# Collects per-locale grit files from many sources into global per-locale files. | 
| -chrome_repack_locales("repack_locales_pack") { | 
| -  visibility = [ ":*" ] | 
| - | 
| -  input_locales = locales | 
| -  copy_data_to_bundle = is_mac | 
| - | 
| -  if (is_mac) { | 
| -    output_locales = locales_as_mac_outputs | 
| -  } else { | 
| -    output_locales = locales | 
| -  } | 
| - | 
| -  if (enable_resource_whitelist_generation) { | 
| -    repack_whitelist = android_resource_whitelist | 
| -    deps = [ | 
| -      ":resource_whitelist", | 
| -    ] | 
| -  } | 
| -} | 
| - | 
| -# Generates a rule to repack a set of resources, substituting a given string | 
| -# in for the percentage (e.g. "100", "200"). It generates the repacked files in | 
| -# the "gen" directory, and then introduces a copy rule to copy it to the root | 
| -# build directory. | 
| -# | 
| -# It's not clear why this two-step dance is necessary as opposed to just | 
| -# generating the file in the destination. However, this is what the GYP build | 
| -# does, and for maintenance purposes, this keeps the same files in the same | 
| -# place between the two builds when possible. | 
| -# | 
| -# Argument: | 
| -#   percent [required] | 
| -#      String to substitute for the percentage. | 
| -template("chrome_repack_percent") { | 
| -  percent = invoker.percent | 
| - | 
| -  repack_name = "${target_name}_repack" | 
| -  repack_output_file = "$root_gen_dir/repack/chrome_${percent}_percent.pak" | 
| - | 
| -  copy_name = target_name | 
| - | 
| -  repack(repack_name) { | 
| -    visibility = [ ":$copy_name" ] | 
| - | 
| -    # All sources should also have deps for completeness. | 
| -    sources = [ | 
| -      "$root_gen_dir/blink/public/resources/blink_image_resources_${percent}_percent.pak", | 
| -      "$root_gen_dir/chrome/renderer_resources_${percent}_percent.pak", | 
| -      "$root_gen_dir/chrome/theme_resources_${percent}_percent.pak", | 
| -      "$root_gen_dir/components/components_resources_${percent}_percent.pak", | 
| -      "$root_gen_dir/content/app/resources/content_resources_${percent}_percent.pak", | 
| -      "$root_gen_dir/ui/resources/ui_resources_${percent}_percent.pak", | 
| -    ] | 
| - | 
| -    deps = [ | 
| -      "//chrome/app/theme:theme_resources", | 
| -      "//chrome/renderer:resources", | 
| -      "//components/resources", | 
| -      "//components/strings", | 
| -      "//content/app/resources", | 
| -      "//net:net_resources", | 
| -      "//third_party/WebKit/public:image_resources", | 
| -      "//ui/resources", | 
| -    ] | 
| - | 
| -    if (use_ash) { | 
| -      sources += | 
| -          [ "$root_gen_dir/ash/resources/ash_resources_${percent}_percent.pak" ] | 
| -      deps += [ "//ash/resources" ] | 
| -    } | 
| -    if (toolkit_views) { | 
| -      sources += [ "$root_gen_dir/ui/views/resources/views_resources_${percent}_percent.pak" ] | 
| -      deps += [ "//ui/views/resources" ] | 
| -    } | 
| -    if (is_chromeos) { | 
| -      sources += [ "$root_gen_dir/ui/chromeos/resources/ui_chromeos_resources_${percent}_percent.pak" ] | 
| -      deps += [ "//ui/chromeos/resources" ] | 
| -    } | 
| -    if (enable_extensions) { | 
| -      sources += [ "$root_gen_dir/extensions/extensions_browser_resources_${percent}_percent.pak" ] | 
| -      deps += [ "//extensions:extensions_browser_resources" ] | 
| -    } | 
| -    if (enable_app_list) { | 
| -      sources += [ "$root_gen_dir/ui/app_list/resources/app_list_resources_${percent}_percent.pak" ] | 
| -      deps += [ "//ui/app_list/resources" ] | 
| -    } | 
| - | 
| -    output = repack_output_file | 
| -    copy_data_to_bundle = is_mac | 
| - | 
| -    if (enable_resource_whitelist_generation) { | 
| -      repack_whitelist = android_resource_whitelist | 
| -      deps += [ ":resource_whitelist" ] | 
| -    } | 
| -  } | 
| - | 
| -  copy(copy_name) { | 
| -    visibility = [ ":*" ] | 
| -    deps = [ | 
| -      ":$repack_name", | 
| -    ] | 
| -    sources = [ | 
| -      repack_output_file, | 
| -    ] | 
| -    outputs = [ | 
| -      "$root_build_dir/chrome_${percent}_percent.pak", | 
| -    ] | 
| -  } | 
| -} | 
| - | 
| -chrome_repack_percent("repack_chrome_100_percent") { | 
| -  percent = "100" | 
| -} | 
| - | 
| -if (enable_hidpi) { | 
| -  chrome_repack_percent("repack_chrome_200_percent") { | 
| -    percent = "200" | 
| -  } | 
| -} | 
| - | 
| # GYP version: chrome/chrome_resources.gyp:chrome_strings | 
| group("strings") { | 
| public_deps = [ | 
| @@ -1660,6 +1481,9 @@ if (is_android) { | 
|  | 
| if (enable_resource_whitelist_generation) { | 
| action("resource_whitelist") { | 
| +    assert(is_android, | 
| +           "Resource whitelist currently implemented only on Android") | 
| + | 
| deps = [ | 
| "//chrome/android:chrome", | 
| ] | 
| @@ -1670,7 +1494,7 @@ if (enable_resource_whitelist_generation) { | 
| _infile, | 
| ] | 
|  | 
| -    _outfile = android_resource_whitelist | 
| +    _outfile = chrome_resource_whitelist | 
| outputs = [ | 
| _outfile, | 
| ] | 
|  |