Upstream version 10.39.225.0
[platform/framework/web/crosswalk.git] / src / chrome / BUILD.gn
index 982a16d..bb7a670 100644 (file)
@@ -3,6 +3,256 @@
 # found in the LICENSE file.
 
 import("//build/config/features.gni")
+import("//build/config/locales.gni")
+import("//build/config/ui.gni")
+import("//chrome/chrome_repack_locales.gni")
+import("//chrome/version.gni")
+
+if (!is_android) {
+
+# TODO(GYP) for Windows need to the the reorder-imports step which probably
+# means adding another target and renaming this to chrome_initial like in GYP.
+executable("chrome") {
+  # Because the sources list varies so significantly per-platform, generally
+  # each platform lists its own files rather than relying on filtering or
+  # removing unused files.
+  sources = [
+    "app/chrome_exe_resource.h",
+  ]
+  deps = []
+  datadeps = []
+
+  # TODO(GYP) mac_bundle_resources, xcode_settings
+
+  # TODO(GYP) order_profiling, order_text_section
+
+  if (is_win) {
+    sources += [
+      "app/chrome_exe_main_win.cc",
+      "app/client_util.cc",
+      "app/client_util.h",
+      "app/signature_validator_win.cc",
+      "app/signature_validator_win.h",
+      "//content/app/startup_helper_win.cc",
+    ]
+    deps += [ "//ui/gfx" ]
+  } else if (use_aura) {
+    # Non-Windows aura entrypoint.
+    sources += [ "app/chrome_exe_main_aura.cc" ]
+  }
+
+  if (is_linux) {
+    # TODO(GYP) manpage action
+
+    sources += [
+      "app/chrome_dll_resource.h",
+      "app/chrome_main.cc",
+      "app/chrome_main_delegate.cc",
+      "app/chrome_main_delegate.h",
+    ]
+
+    deps += [
+      # On Linux, link the dependencies (libraries) that make up actual
+      # Chromium functionality directly into the executable.
+      ":browser_dependencies",
+      ":child_dependencies",
+
+      "//base/allocator",
+      # Needed to use the master_preferences functions
+      "//chrome/installer/util",
+      "//content/public/app:both",
+    ]
+
+    # Needed for chrome_main.cc initialization of libraries.
+    configs += [ "//build/config/linux:pangocairo" ]
+
+    # TODO(GYP) ['profiling==0 and linux_disable_pie==0', {
+    #   'ldflags': [
+    #      '-pie',
+    #   ],
+    #}],
+
+    if (use_x11) {
+      configs += [
+        "//build/config/linux:x11",
+        "//build/config/linux:xext",
+      ]
+    }
+  }
+
+  if (is_mac) {
+    sources += [
+      "app/chrome_exe_main_mac.cc",
+    ]
+    # TODO(GYP) lots more stuff in the is_mac block.
+  } else {  # Non-Mac.
+    deps += [
+      ":packed_extra_resources",
+      ":packed_resources",
+
+      # Copy Flash Player files to PRODUCT_DIR if applicable. Let the .gyp
+      # file decide what to do on a per-OS basis; on Mac, internal plugins
+      # go inside the framework, so this dependency is in chrome_dll.gypi.
+      #'../third_party/adobe/flash/flash_player.gyp:flapper_binaries',  TODO(GYP)
+
+      # Copy CDM files to PRODUCT_DIR if applicable. Let the .gyp
+      # file decide what to do on a per-OS basis; on Mac, internal plugins
+      # go inside the framework, so this dependency is in chrome_dll.gypi.
+      #'../third_party/widevine/cdm/widevine_cdm.gyp:widevinecdmadapter',  TODO(GYP)
+    ]
+
+    # TODO(GYP) some stuff from GYP including chrome_multiple_dll.
+
+  }
+
+
+  if (!is_mac) {
+    # On Mac this is done in chrome_dll.gypi.
+    datadeps += [ "//pdf" ]
+
+    # TODO(GYP) pdf linux symbols
+  }
+}
+
+}  # !is_android
+
+shared_library("main_dll") {
+  configs += [ "//build/config/compiler:wexit_time_destructors" ]
+
+  deps = [
+    ":browser_dependencies",
+    "//base/allocator",
+  ]
+  if (is_win) {
+    output_name = "chrome"
+
+    sources = [
+      "app/chrome_command_ids.h",
+      "app/chrome_dll.rc",
+      "app/chrome_dll_resource.h",
+      "app/chrome_main.cc",
+      "app/chrome_main_delegate.cc",
+      "app/chrome_main_delegate.h",
+      "app/close_handle_hook_win.cc",
+      "app/close_handle_hook_win.h",
+      "app/delay_load_hook_win.cc",
+      "app/delay_load_hook_win.h",
+      "//base/win/dllmain.cc",
+    ]
+
+    deps += [
+      # On Windows, link the dependencies (libraries) that make up actual
+      # Chromium functionality into this .dll.
+      #'chrome_version_resources',  TODO(GYP)
+      "//chrome/app/theme:chrome_unscaled_resources",
+      "//content/app/resources",
+      "//crypto",
+      "//net:net_resources",
+      "//third_party/wtl",
+      "//ui/views",
+      #'<(DEPTH)/chrome_elf/chrome_elf.gyp:chrome_elf' ]  TODO(GYP)
+    ]
+    if (enable_configuration_policy) {
+      deps += [ "//components/policy" ]
+    }
+    if (cpu_arch == "x86") {
+      # Add a dependency to custom import library for user32 delay imports only
+      # in x86 builds.
+      #deps += [ 'chrome_user32_delay_imports' ]  TODO(GYP)
+    }
+
+    # TODO(GYP) incremental linking flags in debug builds
+    #'LinkIncremental': '<(msvs_large_module_debug_link_mode)',
+
+    # TODO(GYP) Lots of VCLinkerTool stuff on Windows.
+
+    # TODO(GYP) chrome_pgo_phase on Windows.
+  }
+
+  if (use_aura) {
+    deps += [ "//ui/compositor" ]
+  }
+
+  #TODO(GYP) add chrome_multiple_dll support
+  if (false) {  #chrome_multiple_dll) {
+    defines = [ "CHROME_MULTIPLE_DLL_BROWSER" ]
+    deps += [
+      "//content/public/app:browser",
+    ]
+  } else {
+    deps += [
+      ":child_dependencies",
+      "//content/public/app:both",
+    ]
+  }
+
+  if (cld_version == 0 || cld_version == 2) {
+    deps += [
+      "//third_party/cld_2",
+    ]
+  }
+
+  if (is_mac) {
+    #['OS=="mac" and component!="shared_library"', {  TODO(GYP)
+    #  'includes': [ 'chrome_dll_bundle.gypi' ],
+    #}],
+
+    # TODO(GYP) Lots of other stuff in the OS=="mac" block.
+  }
+}
+
+# GYP version: chromium_browser_dependencies variable in chrome.gyp
+group("browser_dependencies") {
+  deps = [
+    "//chrome/browser",
+    "//chrome/common",
+    "//sync",
+  ]
+  if (!is_ios) {
+    deps += [
+      "//ppapi:ppapi_host",
+    ]
+  }
+
+  if (printing_mode != 0) {
+    deps += [ "//printing" ]
+    if (printing_mode == 1) {
+      deps += [ "//chrome/service" ]
+    }
+  }
+}
+
+# GYP version: chromium_child_dependencies variable in chrome.gyp
+group("child_dependencies") {
+  deps = [
+    "//chrome/common",
+    "//sync",
+  ]
+  if (!is_ios) {
+    deps += [
+      "//chrome/browser/devtools",
+      "//chrome/plugin",
+      "//chrome/renderer",
+      "//chrome/utility",
+      "//content/public/child",
+      "//third_party/WebKit/public:blink_devtools_frontend_resources",
+    ]
+  }
+}
+
+if (is_win) {
+  # TODO(brettw) this duplicates "//chrome/common:version" which applies to
+  # Linux.
+  process_version("version_header") {
+    # TODO(brettW) this should have more reduced visibility, but chrome/browser
+    # currently depends on this.
+    #visibility = [ ":*" ]
+    source = "version.h.in"
+    # TODO(brettw) this should move to $target_gen_dir/version.h and
+    # source files including it should reference it via "chrome/version.h"
+    output = "$root_gen_dir/version.h"
+  }
+}
 
 # GYP version: chrome/chrome_resources.gyp:chrome_resources
 group("resources") {
@@ -35,8 +285,6 @@ group("extra_resources") {
     deps += [
       "//chrome/browser/resources:component_extension_resources",
       "//chrome/browser/resources:options_resources",
-      "//chrome/browser/resources:quota_internals_resources",
-      "//chrome/browser/resources:sync_file_system_internals_resources",
     ]
   }
 
@@ -49,6 +297,220 @@ group("extra_resources") {
       #'browser/resources/chromeos/chromevox/chromevox.gyp:chromevox',  TODO(GYP)
     ]
   }
+
+  if (enable_extensions) {
+    deps += [
+      "//chrome/browser/resources:quota_internals_resources",
+      "//chrome/browser/resources:sync_file_system_internals_resources",
+    ]
+  }
+}
+
+group("packed_resources") {
+  deps = [
+    ":repack_locales_pack",
+    ":repack_pseudo_locales_pack",
+    ":repack_chrome_100_percent",
+  ]
+
+  # TODO(GYP) if (is_chrome_branded) {
+  # ... copy default_apps from default_apps_list
+
+  if (enable_hidpi) {
+    deps += [ ":repack_chrome_200_percent" ]
+  }
+}
+
+repack("packed_extra_resources") {
+  visibility = [ ":*" ]
+  sources = [
+    "$root_gen_dir/chrome/browser_resources.pak",
+    "$root_gen_dir/chrome/app/theme/chrome_unscaled_resources.pak",
+    "$root_gen_dir/chrome/common_resources.pak",
+    "$root_gen_dir/chrome/browser/resources/invalidations_resources.pak",
+    "$root_gen_dir/chrome/browser/resources/memory_internals_resources.pak",
+    "$root_gen_dir/chrome/browser/resources/net_internals_resources.pak",
+    "$root_gen_dir/chrome/browser/resources/password_manager_internals_resources.pak",
+    "$root_gen_dir/chrome/browser/resources/signin_internals_resources.pak",
+    "$root_gen_dir/chrome/browser/resources/sync_internals_resources.pak",
+    "$root_gen_dir/chrome/browser/resources/translate_internals_resources.pak",
+    "$root_gen_dir/components/resources/components_resources.pak",
+    "$root_gen_dir/net/net_resources.pak",
+    "$root_gen_dir/ui/resources/webui_resources.pak",
+  ]
+  deps = [
+    "//chrome/browser:resources",
+    "//chrome/app/theme:chrome_unscaled_resources",
+    "//chrome/common:resources",
+    "//chrome/browser/resources:invalidations_resources",
+    "//chrome/browser/resources:memory_internals_resources",
+    "//chrome/browser/resources:net_internals_resources",
+    "//chrome/browser/resources:password_manager_internals_resources",
+    "//chrome/browser/resources:signin_internals_resources",
+    "//chrome/browser/resources:sync_internals_resources",
+    "//chrome/browser/resources:translate_internals_resources",
+    "//components/resources",
+    "//net:net_resources",
+    "//ui/resources",
+  ]
+
+  if (!is_ios && !is_android) {
+    # New paks should be added here by default.
+    sources += [
+      "$root_gen_dir/webkit/devtools_resources.pak",
+      "$root_gen_dir/chrome/browser/resources/component_extension_resources.pak",
+      "$root_gen_dir/chrome/browser/resources/options_resources.pak",
+      "$root_gen_dir/chrome/browser/resources/quota_internals_resources.pak",
+      "$root_gen_dir/chrome/browser/resources/sync_file_system_internals_resources.pak",
+    ]
+    deps += [
+      "//content/browser/devtools:devtools_resources",
+      "//chrome/browser/resources:component_extension_resources",
+      "//chrome/browser/resources:options_resources",
+      "//chrome/browser/resources:quota_internals_resources",
+      "//chrome/browser/resources:sync_file_system_internals_resources",
+    ]
+  }
+  if (!is_ios) {
+    sources += [
+      "$root_gen_dir/blink/public/resources/blink_resources.pak",
+      "$root_gen_dir/content/browser/tracing/tracing_resources.pak",
+      "$root_gen_dir/content/content_resources.pak",
+    ]
+  }
+  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/chrome/extensions_api_resources.pak",
+      "$root_gen_dir/extensions/extensions_renderer_resources.pak",
+      "$root_gen_dir/extensions/extensions_resources.pak",
+    ]
+    deps += [ "//chrome/common:extensions_api_resources" ]
+  }
+
+  # GYP outputs the file in the gen/repack directory. On non-Mac/iOS platforms
+  # it them copies it. This skipes the copy step and writes it to the final
+  # location.
+  if (is_mac || is_ios) {
+    output = "$root_gen_dir/repack/resources.pak"
+  } else {
+    output = "$root_out_dir/resources.pak"
+  }
+}
+
+# Collects per-locale grit files from many sources into global per-locale files.
+chrome_repack_locales("repack_locales_pack") {
+  visibility = [ ":*" ]
+
+  input_locales = locales
+
+  if (is_mac) {
+    output_locales = locales_as_mac_outputs
+  } else {
+    output_locales = locales
+  }
+}
+
+chrome_repack_locales("repack_pseudo_locales_pack") {
+  visibility = [ ":*" ]
+
+  input_locales = [ "fake-bidi" ]
+
+  if (is_mac) {
+    output_locales = [ "fake_bidi" ]  # Mac uses underscores.
+  } else {
+    output_locales = [ "fake-bidi" ]
+  }
+}
+
+# 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/components/resources/components_resources_${percent}_percent.pak",
+      "$root_gen_dir/ui/resources/ui_resources_${percent}_percent.pak",
+      "$root_gen_dir/chrome/renderer_resources_${percent}_percent.pak",
+      "$root_gen_dir/chrome/app/theme/theme_resources_${percent}_percent.pak",
+    ]
+
+    deps = [
+      "//chrome/app/theme:theme_resources",
+      "//chrome/renderer:resources",
+      "//components/strings",
+      "//net:net_resources",
+    ]
+
+    if (!is_ios) {
+      sources += [
+        "$root_gen_dir/content/app/resources/content_resources_${percent}_percent.pak",
+      ]
+      deps += [ "//content:resources" ]
+    }
+    if (use_ash) {
+      sources += [ "$root_gen_dir/ash/resources/ash_resources_${percent}_percent.pak" ]
+      deps += [ "//ash/resources" ]
+    }
+    if (use_athena) {
+      sources += [
+        "$root_gen_dir/athena/resources/athena_resources_${percent}_percent.pak",
+      ]
+      deps += [ "//athena/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",
+      ]
+    }
+
+    output = repack_output_file
+  }
+
+  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