summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbrettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-07-02 17:37:34 +0000
committerbrettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-07-02 17:37:34 +0000
commitfca567b91bf3e2080ec48e17b1a492af32143c36 (patch)
tree4c32f1246a7d35dfabed930efbda3c495c789986
parent2d6836f40081d7da684a608a15327be6a0e42bea (diff)
downloadchromium_src-fca567b91bf3e2080ec48e17b1a492af32143c36.zip
chromium_src-fca567b91bf3e2080ec48e17b1a492af32143c36.tar.gz
chromium_src-fca567b91bf3e2080ec48e17b1a492af32143c36.tar.bz2
Add lots of GN targets:
components/autofill components/metrics components/policy components/variations third_party/libphonenumber third_party/mt19937ar ui/gfx/ipc These are all requried to compile chrome/browser in some form or another. Fills out all grit_defines (also required for chrome/browser) and adds associated flags for them. Add the ability for generated_extensions_api to not generate a bundle. Remove mt19937ar from .gitignore (it's just checked into the tree) R=ajwong@chromium.org Review URL: https://codereview.chromium.org/365793002 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@281057 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--.gitignore1
-rw-r--r--BUILD.gn1
-rw-r--r--build/config/BUILD.gn15
-rw-r--r--build/config/features.gni8
-rw-r--r--build/config/linux/BUILD.gn8
-rw-r--r--build/json_schema_compile.gypi3
-rw-r--r--build/secondary/tools/grit/grit_rule.gni94
-rw-r--r--chrome/browser/BUILD.gn55
-rw-r--r--chrome/browser/performance_monitor/BUILD.gn10
-rw-r--r--chrome/browser/safe_browsing/BUILD.gn15
-rw-r--r--chrome/chrome_browser.gypi2
-rw-r--r--chrome/common/BUILD.gn2
-rw-r--r--chrome/common/extensions/api/BUILD.gn1
-rw-r--r--components/BUILD.gn9
-rw-r--r--components/autofill.gypi9
-rw-r--r--components/autofill/content/browser/BUILD.gn88
-rw-r--r--components/autofill/content/common/BUILD.gn23
-rw-r--r--components/autofill/content/renderer/BUILD.gn42
-rw-r--r--components/autofill/core/browser/BUILD.gn202
-rw-r--r--components/autofill/core/common/BUILD.gn55
-rw-r--r--components/metrics.gypi5
-rw-r--r--components/metrics/BUILD.gn66
-rw-r--r--components/policy.gypi12
-rw-r--r--components/policy/BUILD.gn187
-rw-r--r--components/policy/core/browser/BUILD.gn64
-rw-r--r--components/policy/core/common/BUILD.gn201
-rw-r--r--components/policy/policy_browser.gypi1
-rw-r--r--components/policy/policy_common.gypi1
-rw-r--r--components/policy/proto/BUILD.gn1
-rw-r--r--components/variations.gypi1
-rw-r--r--components/variations/BUILD.gn34
-rw-r--r--components/variations/proto/BUILD.gn13
-rw-r--r--extensions/common/api/BUILD.gn1
-rw-r--r--extensions/generated_extensions_api.gni93
-rw-r--r--net/BUILD.gn2
-rw-r--r--third_party/libphonenumber/BUILD.gn100
-rw-r--r--third_party/libphonenumber/libphonenumber.gyp3
-rw-r--r--third_party/mt19937ar/BUILD.gn10
-rw-r--r--third_party/protobuf/proto_library.gni7
-rw-r--r--ui/accessibility/BUILD.gn1
-rw-r--r--ui/gfx/ipc/BUILD.gn21
-rw-r--r--ui/gfx/ipc/gfx_ipc.gyp1
42 files changed, 1385 insertions, 83 deletions
diff --git a/.gitignore b/.gitignore
index 67f746d..b00afb7 100644
--- a/.gitignore
+++ b/.gitignore
@@ -292,7 +292,6 @@ v8.log
/third_party/mesa/src
/third_party/mingw-w64
/third_party/mkl
-/third_party/mt19937ar
/third_party/nacl_sdk_binaries/
/third_party/nss
/third_party/openmax_dl/
diff --git a/BUILD.gn b/BUILD.gn
index 2224f68..afade88 100644
--- a/BUILD.gn
+++ b/BUILD.gn
@@ -60,6 +60,7 @@ group("root") {
"//third_party/icu",
"//third_party/leveldatabase",
"//third_party/libaddressinput",
+ "//third_party/libphonenumber",
"//third_party/libpng",
"//third_party/libsrtp",
"//third_party/libusb",
diff --git a/build/config/BUILD.gn b/build/config/BUILD.gn
index 9e9c88f..b0a8ab4 100644
--- a/build/config/BUILD.gn
+++ b/build/config/BUILD.gn
@@ -32,12 +32,9 @@ config("feature_flags") {
defines = [
"CHROMIUM_BUILD",
"ENABLE_ONE_CLICK_SIGNIN",
- "ENABLE_REMOTING=1",
"ENABLE_NOTIFICATIONS",
"ENABLE_EGLIMAGE=1",
"ENABLE_BACKGROUND=1",
- "ENABLE_GOOGLE_NOW=1",
- "ENABLE_SETTINGS_APP=1",
"USE_MOJO=1",
"V8_DEPRECATION_WARNINGS", # Don't use deprecated V8 APIs anywhere.
# Temporary suppression until Blink code can be removed.
@@ -160,6 +157,9 @@ config("feature_flags") {
if (enable_app_list) {
defines += [ "ENABLE_APP_LIST=1" ]
}
+ if (enable_settings_app) {
+ defines += [ "ENABLE_SETTINGS_APP=1" ]
+ }
if (enable_managed_users) {
defines += [ "ENABLE_MANAGED_USERS=1" ]
}
@@ -172,6 +172,15 @@ config("feature_flags") {
if (enable_wifi_bootstrapping) {
defines += [ "ENABLE_WIFI_BOOTSTRAPPING=1" ]
}
+ if (enable_image_loader_extension) {
+ defines += [ "IMAGE_LOADER_EXTENSION=1" ]
+ }
+ if (enable_remoting) {
+ defines += [ "ENABLE_REMOTING=1" ]
+ }
+ if (enable_google_now) {
+ defines += [ "ENABLE_GOOGLE_NOW=1" ]
+ }
}
# Debug/release ----------------------------------------------------------------
diff --git a/build/config/features.gni b/build/config/features.gni
index 333f8d3..07fd5a9 100644
--- a/build/config/features.gni
+++ b/build/config/features.gni
@@ -128,6 +128,7 @@ enable_rlz = is_chrome_branded && (is_win || is_mac || is_ios || is_chromeos)
enable_plugin_installation = is_win || is_mac
enable_app_list = !is_ios && !is_android
+enable_settings_app = enable_app_list && !is_chromeos
enable_managed_users = !is_ios
@@ -136,3 +137,10 @@ enable_service_discovery = enable_mdns || is_mac
enable_autofill_dialog = !is_ios && !(is_android && is_android_webview_build)
enable_wifi_bootstrapping = is_win || is_mac
+
+# Image loader extension is enabled on ChromeOS only.
+enable_image_loader_extension = is_chromeos
+
+enable_remoting = !is_ios && !is_android
+
+enable_google_now = !is_ios && !is_android
diff --git a/build/config/linux/BUILD.gn b/build/config/linux/BUILD.gn
index bc5bde3..8939ad8 100644
--- a/build/config/linux/BUILD.gn
+++ b/build/config/linux/BUILD.gn
@@ -56,6 +56,10 @@ pkg_config("dbus") {
packages = [ "dbus-1" ]
}
+pkg_config("gnome_keyring") {
+ packages = [ "gnome-keyring-1" ]
+}
+
if (use_evdev_gestures) {
pkg_config("libevdev-cros") {
packages = [ "libevdev-cros" ]
@@ -95,6 +99,10 @@ config("xrandr") {
libs = [ "xrandr" ]
}
+config("xscrnsaver") {
+ libs = [ "Xss" ]
+}
+
config("libcap") {
libs = [ "cap" ]
}
diff --git a/build/json_schema_compile.gypi b/build/json_schema_compile.gypi
index 3c4e7c6..1f94b46 100644
--- a/build/json_schema_compile.gypi
+++ b/build/json_schema_compile.gypi
@@ -17,8 +17,7 @@
},
'rules': [
{
- # GN version: //build/json_schema.gni
- # (json_schema_compile template)
+ # GN version: //extensions/generated_extensions_api.gni
'rule_name': 'genapi',
'msvs_external_rule': 1,
'extension': 'json',
diff --git a/build/secondary/tools/grit/grit_rule.gni b/build/secondary/tools/grit/grit_rule.gni
index 150615c..7d42224 100644
--- a/build/secondary/tools/grit/grit_rule.gni
+++ b/build/secondary/tools/grit/grit_rule.gni
@@ -25,11 +25,30 @@
# # You can also put deps here if the grit source depends on generated
# # files.
# }
+import ("//build/config/crypto.gni")
import ("//build/config/features.gni")
import ("//build/config/ui.gni")
grit_defines = []
+# Mac and iOS want Title Case strings.
+use_titlecase_in_grd_files = is_mac || is_ios
+if (use_titlecase_in_grd_files) {
+ grit_defines += [ "-D", "use_titlecase" ]
+}
+
+if (is_chrome_branded) {
+ grit_defines += [
+ "-D", "_google_chrome",
+ "-E", "CHROMIUM_BUILD=google_chrome",
+ ]
+} else {
+ grit_defines += [
+ "-D", "_chromium",
+ "-E", "CHROMIUM_BUILD=chromium",
+ ]
+}
+
if (is_chromeos) {
grit_defines += [
"-D", "chromeos",
@@ -41,6 +60,34 @@ if (is_desktop_linux) {
grit_defines += [ "-D", "desktop_linux" ]
}
+if (toolkit_views) {
+ grit_defines += [ "-D", "toolkit_views" ]
+}
+
+if (use_aura) {
+ grit_defines += [ "-D", "use_aura" ]
+}
+
+if (use_ash) {
+ grit_defines += [ "-D", "use_ash" ]
+}
+
+if (use_nss_certs) {
+ grit_defines += [ "-D", "use_nss" ]
+}
+
+if (use_ozone) {
+ grit_defines += [ "-D", "use_ozone" ]
+}
+
+if (enable_image_loader_extension) {
+ grit_defines += [ "-D", "image_loader_extension" ]
+}
+
+if (enable_remoting) {
+ grit_defines += [ "-D", "remoting" ]
+}
+
if (is_android) {
grit_defines += [
"-t", "android",
@@ -48,26 +95,61 @@ if (is_android) {
]
}
+if (is_mac || is_ios) {
+ grit_defines += [ "-D", "scale_factors=2x" ]
+}
+
+if (is_ios) {
+ grit_defines += [
+ "-t", "ios",
+ # iOS uses a whitelist to filter resources.
+ "-w", rebase_path("//build/ios/grit_whitelist.txt", root_build_dir),
+ ]
+}
+
if (enable_extensions) {
grit_defines += [ "-D", "enable_extensions" ]
}
if (enable_plugins) {
grit_defines += [ "-D", "enable_plugins" ]
}
-if (enable_task_manager) {
- grit_defines += [ "-D", "enable_task_manager" ]
+if (enable_printing != 0) {
+ grit_defines += [ "-D", "enable_printing" ]
+ if (enable_printing == 1) {
+ grit_defines += [ "-D", "enable_full_printing" ]
+ }
+}
+if (enable_themes) {
+ grit_defines += [ "-D", "enable_themes" ]
}
if (enable_app_list) {
grit_defines += [ "-D", "enable_app_list" ]
}
-if (enable_service_discovery) {
- grit_defines += [ "-D", "enable_service_discovery" ]
+if (enable_settings_app) {
+ grit_defines += [ "-D", "enable_settings_app" ]
+}
+if (enable_google_now) {
+ grit_defines += [ "-D", "enable_google_now" ]
+}
+# Note: use_concatenated_impulse_responses is omitted. It is never used and
+# should probably be removed from GYP build.
+if (enable_webrtc) {
+ grit_defines += [ "-D", "enable_webrtc" ]
+}
+# Note: enable_hangout_services_extension is omitted. It is never set in the
+# GYP build. Need to figure out what it's for.
+if (enable_task_manager) {
+ grit_defines += [ "-D", "enable_task_manager" ]
+}
+if (enable_notifications) {
+ grit_defines += [ "-D", "enable_notifications" ]
}
if (enable_wifi_bootstrapping) {
grit_defines += [ "-D", "enable_wifi_bootstrapping" ]
}
-
-# TODO(GYP) the rest of the grit_defines from the gyp build.
+if (enable_service_discovery) {
+ grit_defines += [ "-D", "enable_service_discovery" ]
+}
grit_resource_id_file = "//tools/gritsettings/resource_ids"
grit_info_script = "//tools/grit/grit_info.py"
diff --git a/chrome/browser/BUILD.gn b/chrome/browser/BUILD.gn
index 0d54531..852cf11 100644
--- a/chrome/browser/BUILD.gn
+++ b/chrome/browser/BUILD.gn
@@ -40,7 +40,16 @@ static_library("browser") {
"//chrome/browser/search/suggestions/proto",
"//chrome/common",
"//chrome/common/net",
+ "//components/cloud_devices/common",
+ "//components/metrics:net",
+ "//components/navigation_metrics",
+ "//components/os_crypt",
+ "//components/policy:policy_component",
+ "//components/query_parser",
"//components/strings",
+ "//components/translate:translate_core_browser",
+ "//components/translate:translate_core_common",
+ "//components/user_prefs",
"//content/public/browser",
"//content/public/common",
"//crypto",
@@ -69,8 +78,6 @@ static_library("browser") {
#"../components/components.gyp:autofill_core_browser",
#"../components/components.gyp:bookmarks_browser",
#"../components/components.gyp:captive_portal",
- #"../components/components.gyp:cloud_devices_common",
- #"../components/components.gyp:component_metrics_proto",
#"../components/components.gyp:data_reduction_proxy_browser",
#"../components/components.gyp:domain_reliability",
#"../components/components.gyp:favicon_base",
@@ -82,31 +89,18 @@ static_library("browser") {
#"../components/components.gyp:history_core_common",
#"../components/components.gyp:infobars_core",
#"../components/components.gyp:invalidation",
- #"../components/components.gyp:metrics",
- #"../components/components.gyp:metrics_net",
- #"../components/components.gyp:navigation_metrics",
#"../components/components.gyp:network_time",
#"../components/components.gyp:omaha_query_params",
- #"../components/components.gyp:os_crypt",
#"../components/components.gyp:password_manager_core_browser",
#"../components/components.gyp:password_manager_core_common",
- #"../components/components.gyp:policy_component",
#"../components/components.gyp:precache_core",
- #"../components/components.gyp:query_parser",
#"../components/components.gyp:rappor",
#"../components/components.gyp:search_engines",
#"../components/components.gyp:search_provider_logos",
#"../components/components.gyp:signin_core_browser",
#"../components/components.gyp:startup_metric_utils",
#"../components/components.gyp:sync_driver",
- #"../components/components.gyp:translate_core_browser",
- #"../components/components.gyp:translate_core_common",
#"../components/components.gyp:url_fixer",
- #"../components/components.gyp:user_prefs",
- ## This depends directly on the variations target, rather than just
- ## transitively via the common target because the proto sources need to
- ## be generated before code in this target can start building.
- #"../components/components.gyp:variations",
#"../components/components.gyp:webdata_common",
#"../courgette/courgette.gyp:courgette_lib",
#"../google_apis/google_apis.gyp:google_apis",
@@ -114,6 +108,9 @@ static_library("browser") {
#"../third_party/libjingle/libjingle.gyp:libjingle",
#"../ui/message_center/message_center.gyp:message_center",
#"../ui/shell_dialogs/shell_dialogs.gyp:shell_dialogs",
+ # Note: variations dependency from GYP build is omitted because we pick it
+ # up via chrome/common, and GN doesn't have the GYP dependency bug that
+ # made it necessary to include here.
]
forward_dependent_configs_from = [
@@ -144,25 +141,29 @@ static_library("browser") {
deps += [
"//cc",
+ "//chrome/browser/performance_monitor",
+ "//components/keyed_service/content",
+ "//components/url_matcher",
"//components/visitedlink/browser",
"//components/visitedlink/common",
"//net:net_with_v8",
"//third_party/adobe/flash:flapper_version_h",
"//third_party/expat",
"//third_party/leveldatabase",
+ "//third_party/libaddressinput",
"//third_party/libyuv",
"//third_party/npapi",
"//third_party/re2",
"//third_party/smhasher:cityhash",
"//ui/gl",
"//ui/surface",
+ "//v8",
"//webkit:resources",
"//webkit/browser:storage",
"//webkit/common",
"//webkit/common:storage",
# TODO(GYP)
#"apps",
- #"browser/performance_monitor/performance_monitor.gyp:performance_monitor",
#"browser_extensions",
#"common/extensions/api/api.gyp:chrome_api",
#"debugger",
@@ -171,14 +172,12 @@ static_library("browser") {
#"sync_file_system_proto",
#"../components/components.gyp:autofill_content_browser",
#"../components/components.gyp:dom_distiller_content",
- #"../components/components.gyp:keyed_service_content",
#"../components/components.gyp:navigation_interception",
#"../components/components.gyp:password_manager_content_browser",
#"../components/components.gyp:precache_content",
#"../components/components.gyp:sessions",
#"../components/components.gyp:storage_monitor",
#"../components/components.gyp:translate_content_browser",
- #"../components/components.gyp:url_matcher",
#"../components/components.gyp:usb_service",
#"../components/components.gyp:web_modal",
#"../media/cast/cast.gyp:cast_transport",
@@ -189,11 +188,9 @@ static_library("browser") {
#"../mojo/mojo.gyp:mojo_system_impl",
## TODO(tonyg): Remove this dependency (crbug.com/280157).
#"../testing/perf/perf_test.gyp:*",
- #"../third_party/libaddressinput/libaddressinput.gyp:libaddressinput",
# Note: for this one also remove the webrtc_stub_config
#"../third_party/webrtc/modules/modules.gyp:desktop_capture",
#"../ui/web_dialogs/web_dialogs.gyp:web_dialogs",
- #"../v8/tools/gyp/v8.gyp:v8",
]
} else { # iOS
sources += rebase_path(gypi_values.chrome_browser_ios_sources,
@@ -316,8 +313,8 @@ static_library("browser") {
gypi_values.chrome_browser_basic_safe_browsing_sources,
".", "//chrome")
deps += [
- #"safe_browsing_chunk_proto", TODO(GYP)
- #"safe_browsing_report_proto", TODO(GYP)
+ "//chrome/browser/safe_browsing:chunk_proto",
+ "//chrome/browser/safe_browsing:report_proto",
]
if (safe_browsing_mode == 1) {
sources += rebase_path(
@@ -325,7 +322,7 @@ static_library("browser") {
".", "//chrome")
defines += [ "FULL_SAFE_BROWSING" ]
deps += [
- #"safe_browsing_proto", TODO(GYP)
+ "//chrome/common/safe_browsing:proto",
]
} else if (safe_browsing_mode == 2) {
defines += [ "MOBILE_SAFE_BROWSING" ]
@@ -358,14 +355,14 @@ static_library("browser") {
if (is_desktop_linux) {
sources += rebase_path(gypi_values.chrome_browser_gnome_keyring_sources,
".", "//chrome")
- #deps += [ "../build/linux/system.gyp:gnome_keyring" ] TODO(GYP)
+ configs += [ "//build/config/linux:gnome_keyring" ]
}
if (use_aura) {
sources += rebase_path(gypi_values.chrome_browser_aura_sources,
".", "//chrome")
deps += [
- #"../ui/aura/aura.gyp:aura", TODO(GYP)
- #"../ui/compositor/compositor.gyp:compositor", TODO(GYP)
+ "//ui/aura",
+ "//ui/compositor",
#"../ui/keyboard/keyboard.gyp:keyboard", TODO(GYP)
]
}
@@ -377,9 +374,7 @@ static_library("browser") {
sources += rebase_path(gypi_values.chrome_browser_x11_sources,
".", "//chrome")
if (!is_chromeos) {
- deps += [
- # "../build/linux/system.gyp:xscrnsaver", TODO(GYP)
- ]
+ configs += [ "//build/config/linux:xscrnsaver" ]
}
}
if (is_posix && !is_mac && !is_ios) {
@@ -460,11 +455,11 @@ static_library("browser") {
#"chrome_browser_jni_headers", TODO(GYP)
]
deps -= [
+ "//third_party/libaddressinput",
#"../components/components.gyp:feedback_component", TODO(GYP)
#"../components/components.gyp:storage_monitor", TODO(GYP)
#"../components/components.gyp:usb_service", TODO(GYP)
#"../components/components.gyp:web_modal", TODO(GYP)
- #"../third_party/libaddressinput/libaddressinput.gyp:libaddressinput", TODO(GYP)
]
} else {
sources += rebase_path(gypi_values.chrome_browser_non_android_sources,
diff --git a/chrome/browser/performance_monitor/BUILD.gn b/chrome/browser/performance_monitor/BUILD.gn
new file mode 100644
index 0000000..0439566
--- /dev/null
+++ b/chrome/browser/performance_monitor/BUILD.gn
@@ -0,0 +1,10 @@
+# Copyright 2014 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.
+
+import("//extensions/generated_extensions_api.gni")
+
+generated_extensions_api("performance_monitor") {
+ sources = [ "events.json" ]
+ root_namespace = "performance_monitor"
+}
diff --git a/chrome/browser/safe_browsing/BUILD.gn b/chrome/browser/safe_browsing/BUILD.gn
new file mode 100644
index 0000000..b6c750e
--- /dev/null
+++ b/chrome/browser/safe_browsing/BUILD.gn
@@ -0,0 +1,15 @@
+# Copyright 2014 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.
+
+import("//third_party/protobuf/proto_library.gni")
+
+# GYP version: chrome/chrome_browser.gypi:safe_browsing_chunk_proto
+proto_library("chunk_proto") {
+ sources = [ "chunk.proto" ]
+}
+
+# GYP version: chrome/chrome_browser.gypi:safe_browsing_report_proto
+proto_library("report_proto") {
+ sources = [ "report.proto" ]
+}
diff --git a/chrome/chrome_browser.gypi b/chrome/chrome_browser.gypi
index 6aafbf6..f433ecd 100644
--- a/chrome/chrome_browser.gypi
+++ b/chrome/chrome_browser.gypi
@@ -3448,6 +3448,7 @@
{
# Protobuf compiler / generator for the safebrowsing chunk
# protocol buffer.
+ # GN version: //chrome/browser/safe_browsing:chunk_proto
'target_name': 'safe_browsing_chunk_proto',
'type': 'static_library',
'sources': [ 'browser/safe_browsing/chunk.proto' ],
@@ -3460,6 +3461,7 @@
{
# Protobuf compiler / generator for the safebrowsing reporting
# protocol buffer.
+ # GN version: //chrome/browser/safe_browsing:report_proto
'target_name': 'safe_browsing_report_proto',
'type': 'static_library',
'sources': [ 'browser/safe_browsing/report.proto' ],
diff --git a/chrome/common/BUILD.gn b/chrome/common/BUILD.gn
index 7f9538c..fa43381 100644
--- a/chrome/common/BUILD.gn
+++ b/chrome/common/BUILD.gn
@@ -45,7 +45,7 @@ static_library("common") {
"//components/metrics",
#"//components/components.gyp:policy_component_common", TODO(GYP)
"//components/translate:translate_core_common",
- #"//components/variations", TODO(GYP)
+ "//components/variations",
"//content/public/common",
"//crypto",
"//extensions:extensions_resources",
diff --git a/chrome/common/extensions/api/BUILD.gn b/chrome/common/extensions/api/BUILD.gn
index 2432763..4734470 100644
--- a/chrome/common/extensions/api/BUILD.gn
+++ b/chrome/common/extensions/api/BUILD.gn
@@ -36,6 +36,7 @@ generated_extensions_api("api") {
impl_dir = "//chrome/browser/extensions/api"
root_namespace = "extensions::api"
+ bundle = true
deps = [
# Different APIs include some headers from chrome/common that in turn
diff --git a/components/BUILD.gn b/components/BUILD.gn
index 319d55d..b2b0c5e 100644
--- a/components/BUILD.gn
+++ b/components/BUILD.gn
@@ -8,6 +8,9 @@ group("all_components") {
visibility = "//:*" # Only for the root targets to bring in.
deps = [
+ "//components/autofill/content/browser",
+ "//components/autofill/content/common",
+ "//components/autofill/content/renderer",
"//components/cloud_devices/common",
"//components/dom_distiller/core",
"//components/favicon_base",
@@ -17,6 +20,7 @@ group("all_components") {
"//components/navigation_metrics",
"//components/onc",
"//components/os_crypt",
+ "//components/policy",
"//components/pref_registry",
"//components/query_parser",
"//components/resources:components_resources",
@@ -27,6 +31,7 @@ group("all_components") {
"//components/translate:translate_core_common",
"//components/url_matcher",
"//components/user_prefs",
+ "//components/variations",
"//components/visitedlink/browser",
"//components/visitedlink/common",
"//components/visitedlink/renderer", # Blocked on blink
@@ -44,10 +49,14 @@ group("all_components") {
if (is_android) {
deps -= [
+ "//components/autofill/content/browser", # Blocked on content/blink.
+ "//components/autofill/content/common", # Blocked on content.
+ "//components/autofill/content/renderer", # Blocked on content/blink.
"//components/cloud_devices/common", # Should work, needs checking.
"//components/dom_distiller/core", # Blocked on content.
"//components/json_schema", # Should work, needs checking.
"//components/keyed_service/content", # Blocked on content.
+ "//components/policy", # Blocked on content (indirectly via autofill).
"//components/user_prefs", # Blocked on content.
"//components/visitedlink/browser", # Blocked on content.
"//components/visitedlink/common", # Blocked on content.
diff --git a/components/autofill.gypi b/components/autofill.gypi
index eac417e..1311387 100644
--- a/components/autofill.gypi
+++ b/components/autofill.gypi
@@ -6,6 +6,7 @@
'targets': [
{
# Private target only used in components/autofill.
+ # GN version: //components/autofill/core/browser:regexes
'target_name': 'autofill_regexes',
'type': 'none',
'actions': [{
@@ -24,6 +25,7 @@
},
{
+ # GN version: //components/autofill/core/common
'target_name': 'autofill_core_common',
'type': 'static_library',
'dependencies': [
@@ -82,6 +84,7 @@
},
{
+ # GN version: //components/autofill/core/browser
'target_name': 'autofill_core_browser',
'type': 'static_library',
'include_dirs': [
@@ -245,6 +248,7 @@
},
{
+ # GN version: //components/autofill/core/browser:test_support
'target_name': 'autofill_core_test_support',
'type': 'static_library',
'dependencies': [
@@ -275,6 +279,7 @@
['OS != "ios"', {
'targets': [
{
+ # GN version: //content/autofill/content/common
'target_name': 'autofill_content_common',
'type': 'static_library',
'dependencies': [
@@ -299,6 +304,7 @@
{
# Protobuf compiler / generate rule for Autofill's risk integration.
+ # GN version: //components/autofill/content/browser:risk_proto
'target_name': 'autofill_content_risk_proto',
'type': 'static_library',
'sources': [
@@ -311,6 +317,7 @@
'includes': [ '../build/protoc.gypi' ]
},
{
+ # GN version: //components/autofill/content/browser:test_support
'target_name': 'autofill_content_test_support',
'type': 'static_library',
'dependencies': [
@@ -325,6 +332,7 @@
'include_dirs': [ '..' ],
},
{
+ # GN version: //components/autofill/content/browser
'target_name': 'autofill_content_browser',
'type': 'static_library',
'include_dirs': [
@@ -403,6 +411,7 @@
},
{
+ # GN version: //components/autofill/content/renderer
'target_name': 'autofill_content_renderer',
'type': 'static_library',
'include_dirs': [
diff --git a/components/autofill/content/browser/BUILD.gn b/components/autofill/content/browser/BUILD.gn
new file mode 100644
index 0000000..572afcd
--- /dev/null
+++ b/components/autofill/content/browser/BUILD.gn
@@ -0,0 +1,88 @@
+# Copyright 2014 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.
+
+import("//third_party/protobuf/proto_library.gni")
+
+# GYP version: components/autofill.gypi:autofill_content_browser
+static_library("browser") {
+ sources = [
+ "content_autofill_driver.cc",
+ "content_autofill_driver.h",
+ "request_autocomplete_manager.cc",
+ "request_autocomplete_manager.h",
+ "risk/fingerprint.cc",
+ "risk/fingerprint.h",
+ "wallet/form_field_error.cc",
+ "wallet/form_field_error.h",
+ "wallet/full_wallet.cc",
+ "wallet/full_wallet.h",
+ "wallet/gaia_account.cc",
+ "wallet/gaia_account.h",
+ "wallet/instrument.cc",
+ "wallet/instrument.h",
+ "wallet/required_action.cc",
+ "wallet/required_action.h",
+ "wallet/wallet_address.cc",
+ "wallet/wallet_address.h",
+ "wallet/wallet_client.cc",
+ "wallet/wallet_client.h",
+ "wallet/wallet_client_delegate.h",
+ "wallet/wallet_items.cc",
+ "wallet/wallet_items.h",
+ "wallet/wallet_service_url.cc",
+ "wallet/wallet_service_url.h",
+ "wallet/wallet_signin_helper.cc",
+ "wallet/wallet_signin_helper.h",
+ ]
+
+ deps = [
+ ":risk_proto",
+ "//base",
+ "//base:i18n",
+ "//base:prefs",
+ "//components/autofill/content/common",
+ "//components/autofill/core/browser",
+ "//components/autofill/core/browser:regexes",
+ "//components/autofill/core/common",
+ "//components/os_crypt",
+ "//components/resources",
+ "//components/strings",
+ "//content/public/browser",
+ "//content/public/common",
+ "//google_apis",
+ "//ipc",
+ "//skia",
+ "//sql",
+ "//third_party/icu",
+ "//third_party/libphonenumber",
+ "//ui/base",
+ "//ui/gfx",
+ "//ui/gfx/geometry",
+ "//url",
+ #"../third_party/libjingle/libjingle.gyp:libjingle", TODO(GYP)
+ #"user_prefs", TODO(GYP)
+ #"webdata_common", TODO(GYP)
+ ]
+}
+
+proto_library("risk_proto") {
+ sources = [
+ "risk/proto/fingerprint.proto",
+ ]
+ proto_in_dir = "risk/proto"
+ proto_out_dir = "components/autofill/content/browser/risk/proto"
+}
+
+static_library("test_support") {
+ sources = [
+ "wallet/mock_wallet_client.cc",
+ "wallet/mock_wallet_client.h",
+ "wallet/wallet_test_util.cc",
+ "wallet/wallet_test_util.h",
+ ]
+
+ deps = [
+ "//testing/gmock",
+ ]
+}
diff --git a/components/autofill/content/common/BUILD.gn b/components/autofill/content/common/BUILD.gn
new file mode 100644
index 0000000..733dfa7
--- /dev/null
+++ b/components/autofill/content/common/BUILD.gn
@@ -0,0 +1,23 @@
+# Copyright 2014 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.
+
+# GYP version: components:autofill.gypi:autofill_content_common
+static_library("common") {
+ sources = [
+ "autofill_message_generator.cc",
+ "autofill_message_generator.h",
+ "autofill_messages.h",
+ "autofill_param_traits_macros.h",
+ ]
+
+ deps = [
+ "//base",
+ "//components/autofill/core/common",
+ "//content/public/common",
+ "//ipc",
+ "//third_party/WebKit/public:blink_minimal",
+ "//ui/gfx",
+ "//ui/gfx/ipc",
+ ]
+}
diff --git a/components/autofill/content/renderer/BUILD.gn b/components/autofill/content/renderer/BUILD.gn
new file mode 100644
index 0000000..29ec170
--- /dev/null
+++ b/components/autofill/content/renderer/BUILD.gn
@@ -0,0 +1,42 @@
+# Copyright 2014 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.
+
+static_library("renderer") {
+ sources = [
+ "autofill_agent.cc",
+ "autofill_agent.h",
+ "form_autofill_util.cc",
+ "form_autofill_util.h",
+ "form_cache.cc",
+ "form_cache.h",
+ "page_click_listener.h",
+ "page_click_tracker.cc",
+ "page_click_tracker.h",
+ "password_autofill_agent.cc",
+ "password_autofill_agent.h",
+ "password_form_conversion_utils.cc",
+ "password_form_conversion_utils.h",
+ "password_generation_agent.cc",
+ "password_generation_agent.h",
+ "renderer_save_password_progress_logger.cc",
+ "renderer_save_password_progress_logger.h",
+ ]
+
+ deps = [
+ "//base",
+ "//components/autofill/content/common",
+ "//components/autofill/core/common",
+ "//components/strings",
+ "//content/public/common",
+ "//content/public/renderer",
+ "//ipc",
+ "//skia",
+ "//third_party/WebKit/public:blink",
+ ]
+
+ if (is_win) {
+ # TODO(jschuh): crbug.com/167187 fix size_t to int truncations.
+ cflags = [ "/wd4267" ]
+ }
+}
diff --git a/components/autofill/core/browser/BUILD.gn b/components/autofill/core/browser/BUILD.gn
new file mode 100644
index 0000000..c479470
--- /dev/null
+++ b/components/autofill/core/browser/BUILD.gn
@@ -0,0 +1,202 @@
+# Copyright 2014 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.
+
+if (is_android) {
+ import("//build/config/android/config.gni")
+ autofill_enable_sync = !is_android_webview_build
+} else {
+ autofill_enable_sync = true
+}
+
+config("autofill_browser_config") {
+ if (autofill_enable_sync) {
+ defines = [ "AUTOFILL_ENABLE_SYNC" ]
+ }
+}
+
+# GYP version: components/autofill.gyp:autofill_regexes
+action("regexes") {
+ visibility = "//components/autofill/*"
+ script = "//build/escape_unicode.py"
+
+ source_prereqs = [
+ "autofill_regex_constants.cc.utf8",
+ ]
+ outputs = [
+ "$target_gen_dir/autofill_regex_constants.cc",
+ ]
+
+ args = [ "-o", rebase_path(target_gen_dir, root_build_dir) ]
+ args += rebase_path(source_prereqs, root_build_dir)
+}
+
+# GYP version: components/autofill.gyp:autofill_core_browser
+static_library("browser") {
+ sources = [
+ "address.cc",
+ "address.h",
+ "address_field.cc",
+ "address_field.h",
+ "address_i18n.cc",
+ "address_i18n.h",
+ "autocomplete_history_manager.cc",
+ "autocomplete_history_manager.h",
+ "autofill-inl.h",
+ "autofill_country.cc",
+ "autofill_country.h",
+ "autofill_data_model.cc",
+ "autofill_data_model.h",
+ "autofill_download.cc",
+ "autofill_download.h",
+ "autofill_driver.h",
+ "autofill_external_delegate.cc",
+ "autofill_external_delegate.h",
+ "autofill_field.cc",
+ "autofill_field.h",
+ "autofill_ie_toolbar_import_win.cc",
+ "autofill_ie_toolbar_import_win.h",
+ "autofill_manager.cc",
+ "autofill_manager.h",
+ "autofill_client.h",
+ "autofill_manager_test_delegate.h",
+ "autofill_metrics.cc",
+ "autofill_metrics.h",
+ "autofill_popup_delegate.h",
+ "autofill_profile.cc",
+ "autofill_profile.h",
+ "autofill_regex_constants.cc.utf8",
+ "autofill_regex_constants.h",
+ "autofill_regexes.cc",
+ "autofill_regexes.h",
+ "autofill_scanner.cc",
+ "autofill_scanner.h",
+ "autofill_server_field_info.h",
+ "autofill_type.cc",
+ "autofill_type.h",
+ "autofill_xml_parser.cc",
+ "autofill_xml_parser.h",
+ "contact_info.cc",
+ "contact_info.h",
+ "credit_card.cc",
+ "credit_card.h",
+ "credit_card_field.cc",
+ "credit_card_field.h",
+ "email_field.cc",
+ "email_field.h",
+ "field_types.h",
+ "form_field.cc",
+ "form_field.h",
+ "form_group.cc",
+ "form_group.h",
+ "form_structure.cc",
+ "form_structure.h",
+ "name_field.cc",
+ "name_field.h",
+ "password_generator.cc",
+ "password_generator.h",
+ "personal_data_manager.cc",
+ "personal_data_manager.h",
+ "personal_data_manager_mac.mm",
+ "personal_data_manager_observer.h",
+ "phone_field.cc",
+ "phone_field.h",
+ "phone_number.cc",
+ "phone_number.h",
+ "phone_number_i18n.cc",
+ "phone_number_i18n.h",
+ "popup_item_ids.h",
+ "state_names.cc",
+ "state_names.h",
+ "validation.cc",
+ "validation.h",
+ "webdata/autofill_change.cc",
+ "webdata/autofill_change.h",
+ "webdata/autofill_entry.cc",
+ "webdata/autofill_entry.h",
+ "webdata/autofill_profile_syncable_service.cc",
+ "webdata/autofill_profile_syncable_service.h",
+ "webdata/autofill_table.cc",
+ "webdata/autofill_table.h",
+ "webdata/autofill_webdata.h",
+ "webdata/autofill_webdata_backend.h",
+ "webdata/autofill_webdata_backend_impl.cc",
+ "webdata/autofill_webdata_backend_impl.h",
+ "webdata/autofill_webdata_service.cc",
+ "webdata/autofill_webdata_service.h",
+ "webdata/autofill_webdata_service_observer.h",
+ ]
+
+ # Compile the generated regex file.
+ sources += get_target_outputs(":regexes")
+
+ deps = [
+ ":regexes",
+ "//base",
+ "//base:i18n",
+ "//base:prefs",
+ "//components/autofill/core/common",
+ "//components/keyed_service/core",
+ "//components/os_crypt",
+ "//components/resources",
+ "//components/strings",
+ "//google_apis",
+ "//skia",
+ "//sql",
+ "//third_party/icu",
+ "//third_party/libaddressinput",
+ "//third_party/libphonenumber",
+ "//ui/base",
+ "//ui/gfx",
+ "//ui/gfx/geometry",
+ "//url",
+ #'../third_party/fips181/fips181.gyp:fips181', TODO(GYP)
+ # TODO(GYP) also remove libjingle_stub_config below when this is added:
+ #'../third_party/libjingle/libjingle.gyp:libjingle', TODO(GYP)
+ #'pref_registry', TODO(GYP)
+ #'webdata_common', TODO(GYP)
+ ]
+
+ configs += [ "//content:libjingle_stub_config" ]
+ direct_dependent_configs = [ ":autofill_browser_config" ]
+
+ if (autofill_enable_sync) {
+ deps += [ "//sync" ]
+ } else {
+ sources -= [
+ "webdata/autofill_profile_syncable_service.cc",
+ "webdata/autofill_profile_syncable_service.h",
+ ]
+ }
+
+ if (is_win) {
+ # TODO(jschuh): crbug.com/167187 fix size_t to int truncations.
+ cflags = [ "/wd4267" ]
+ }
+}
+
+static_library("test_support") {
+ sources = [
+ "android/test_auxiliary_profile_loader_android.cc",
+ "android/test_auxiliary_profile_loader_android.h",
+ "autofill_test_utils.cc",
+ "autofill_test_utils.h",
+ "data_driven_test.cc",
+ "data_driven_test.h",
+ "test_autofill_client.cc",
+ "test_autofill_client.h",
+ "test_autofill_driver.cc",
+ "test_autofill_driver.h",
+ "test_autofill_external_delegate.cc",
+ "test_autofill_external_delegate.h",
+ "test_personal_data_manager.cc",
+ "test_personal_data_manager.h",
+ ]
+
+ deps = [
+ "//components/autofill/core/browser",
+ "//components/autofill/core/common",
+ "//skia",
+ "//testing/gtest",
+ ]
+}
diff --git a/components/autofill/core/common/BUILD.gn b/components/autofill/core/common/BUILD.gn
new file mode 100644
index 0000000..d75af87
--- /dev/null
+++ b/components/autofill/core/common/BUILD.gn
@@ -0,0 +1,55 @@
+# Copyright 2014 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.
+
+static_library("common") {
+ sources = [
+ # TODO(brettw) why are these "browser" files in the "common" target?
+ "../browser/android/auxiliary_profile_loader_android.cc",
+ "../browser/android/auxiliary_profile_loader_android.h",
+ "../browser/android/auxiliary_profiles_android.cc",
+ "../browser/android/auxiliary_profiles_android.h",
+ "../browser/android/component_jni_registrar.cc",
+ "../browser/android/component_jni_registrar.h",
+ "../browser/android/personal_data_manager_android.cc",
+ "autofill_constants.cc",
+ "autofill_constants.h",
+ "autofill_data_validation.cc",
+ "autofill_data_validation.h",
+ "autofill_pref_names.cc",
+ "autofill_pref_names.h",
+ "autofill_switches.cc",
+ "autofill_switches.h",
+ "form_data.cc",
+ "form_data.h",
+ "form_data_predictions.cc",
+ "form_data_predictions.h",
+ "form_field_data.cc",
+ "form_field_data.h",
+ "form_field_data_predictions.cc",
+ "form_field_data_predictions.h",
+ "password_autofill_util.cc",
+ "password_autofill_util.h",
+ "password_form.cc",
+ "password_form.h",
+ "password_form_fill_data.cc",
+ "password_form_fill_data.h",
+ "password_generation_util.cc",
+ "password_generation_util.h",
+ "save_password_progress_logger.cc",
+ "save_password_progress_logger.h",
+ "web_element_descriptor.cc",
+ "web_element_descriptor.h",
+ ]
+
+ deps = [
+ "//base",
+ "//ui/base",
+ "//ui/gfx",
+ "//url",
+ ]
+
+ if (is_android) {
+ # deps += [ 'autofill_jni_headers' ] TODO(GYP)
+ }
+}
diff --git a/components/metrics.gypi b/components/metrics.gypi
index a8f9d0c..f3dc749 100644
--- a/components/metrics.gypi
+++ b/components/metrics.gypi
@@ -5,6 +5,7 @@
{
'targets': [
{
+ # GN version: //components/metrics
'target_name': 'metrics',
'type': 'static_library',
'include_dirs': [
@@ -63,6 +64,7 @@
],
},
{
+ # GN version: //components/metrics:net
'target_name': 'metrics_net',
'type': 'static_library',
'include_dirs': [
@@ -80,7 +82,7 @@
{
# Protobuf compiler / generator for UMA (User Metrics Analysis).
#
- # GN version: //component/metrics/proto:proto
+ # GN version: //components/metrics/proto:proto
'target_name': 'component_metrics_proto',
'type': 'static_library',
'sources': [
@@ -103,6 +105,7 @@
{
# TODO(isherman): Remove all //chrome dependencies on this target, and
# merge the files in this target with components_unittests.
+ # GN version: //components/metrics:test_support
'target_name': 'metrics_test_support',
'type': 'static_library',
'include_dirs': [
diff --git a/components/metrics/BUILD.gn b/components/metrics/BUILD.gn
index 72fc0fe..689c0e8 100644
--- a/components/metrics/BUILD.gn
+++ b/components/metrics/BUILD.gn
@@ -2,13 +2,79 @@
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
+# GYP version: components/metrics.gypi:metrics
source_set("metrics") {
sources = [
+ "compression_utils.cc",
+ "compression_utils.h",
+ "cloned_install_detector.cc",
+ "cloned_install_detector.h",
+ "machine_id_provider.h",
+ "machine_id_provider_stub.cc",
+ "machine_id_provider_win.cc",
"metrics_hashes.cc",
"metrics_hashes.h",
+ "metrics_log.cc",
+ "metrics_log.h",
+ "metrics_log_uploader.cc",
+ "metrics_log_uploader.h",
+ "metrics_log_manager.cc",
+ "metrics_log_manager.h",
+ "metrics_pref_names.cc",
+ "metrics_pref_names.h",
+ "metrics_provider.h",
+ "metrics_reporting_scheduler.cc",
+ "metrics_reporting_scheduler.h",
+ "metrics_service.cc",
+ "metrics_service.h",
+ "metrics_service_client.h",
+ "metrics_service_observer.cc",
+ "metrics_service_observer.h",
+ "metrics_state_manager.cc",
+ "metrics_state_manager.h",
+ "metrics_switches.cc",
+ "metrics_switches.h",
+ "persisted_logs.cc",
+ "persisted_logs.h",
]
deps = [
"//base",
+ "//components/metrics/proto",
+ "//components/variations",
+ "//third_party/zlib",
]
+
+ forward_dependent_configs_from = [ "//components/metrics/proto" ]
+}
+
+# GYP version: components/metrics.gypi:metrics_net
+static_library("net") {
+ sources = [
+ "net/net_metrics_log_uploader.cc",
+ "net/net_metrics_log_uploader.h",
+ ]
+
+ deps = [
+ ":metrics",
+ "//net",
+ ]
+
+ forward_dependent_configs_from = [ ":metrics" ]
}
+
+# GYP version: components/metrics.gypi:metrics_test_support
+static_library("test_support") {
+ sources = [
+ "test_metrics_service_client.cc",
+ "test_metrics_service_client.h",
+ ]
+
+ deps = [
+ ":metrics",
+ ]
+
+ forward_dependent_configs_from = [ ":metrics" ]
+}
+
+# TODO(GYP): metrics_chromeos
diff --git a/components/policy.gypi b/components/policy.gypi
index b5dc32c..24d671f8 100644
--- a/components/policy.gypi
+++ b/components/policy.gypi
@@ -34,6 +34,7 @@
['component=="static_library"', {
'targets': [
{
+ # GN version: //components/policy:policy_component
'target_name': 'policy_component',
'type': 'none',
'dependencies': [
@@ -42,6 +43,7 @@
],
},
{
+ # GN version: //components/policy:policy_component_common
'target_name': 'policy_component_common',
'type': 'static_library',
'includes': [
@@ -49,6 +51,7 @@
],
},
{
+ # GN version: //components/policy:policy_component_browser
'target_name': 'policy_component_browser',
'type': 'static_library',
'dependencies': [
@@ -62,6 +65,7 @@
}, { # component=="static_library"
'targets': [
{
+ # GN version: //components/policy:policy_component
'target_name': 'policy_component',
'type': 'shared_library',
'includes': [
@@ -70,6 +74,7 @@
],
},
{
+ # GN version: //components/policy:policy_component_common
'target_name': 'policy_component_common',
'type': 'none',
'dependencies': [
@@ -77,6 +82,7 @@
],
},
{
+ # GN version: //components/policy:policy_component_browser
'target_name': 'policy_component_browser',
'type': 'none',
'dependencies': [
@@ -88,6 +94,7 @@
['configuration_policy==1', {
'targets': [
{
+ # GN version: //components/policy:cloud_policy_code_generate
'target_name': 'cloud_policy_code_generate',
'type': 'none',
'actions': [
@@ -127,6 +134,7 @@
},
},
{
+ # GN version: //components/policy:cloud_policy_proto_generated_compile
'target_name': 'cloud_policy_proto_generated_compile',
'type': '<(component)',
'sources': [
@@ -152,6 +160,7 @@
},
{
# This target builds the "full" protobuf, used for tests only.
+ # GN version: //components/policy:chrome_settings_proto_generated_compile
'target_name': 'chrome_settings_proto_generated_compile',
'type': 'static_library',
'sources': [
@@ -170,6 +179,7 @@
],
},
{
+ # GN version: //components/policy
'target_name': 'policy',
'type': 'static_library',
'hard_dependency': 1,
@@ -233,6 +243,7 @@
],
},
{
+ # GN version: //components/policy:test_support
'target_name': 'policy_test_support',
'type': 'none',
'hard_dependency': 1,
@@ -248,6 +259,7 @@
],
},
{
+ # GN version: //components/policy:policy_component_test_support
'target_name': 'policy_component_test_support',
'type': 'static_library',
# This must be undefined so that POLICY_EXPORT works correctly in
diff --git a/components/policy/BUILD.gn b/components/policy/BUILD.gn
new file mode 100644
index 0000000..200c584
--- /dev/null
+++ b/components/policy/BUILD.gn
@@ -0,0 +1,187 @@
+# Copyright 2014 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.
+
+import("//build/config/features.gni")
+import("//third_party/protobuf/proto_library.gni")
+import("//tools/grit/grit_rule.gni")
+
+if (is_component_build) {
+ component("policy_component") {
+ deps = [
+ "//components/policy/core/browser",
+ "//components/policy/core/common",
+ ]
+ }
+ group("policy_component_browser") {
+ deps = [ ":policy_component" ]
+ }
+ group("policy_component_common") {
+ deps = [ ":policy_component" ]
+ }
+} else { # Compile to separate libraries.
+ group("policy_component") {
+ deps = [
+ ":policy_component_browser",
+ ":policy_component_common",
+ ]
+ }
+ component("policy_component_browser") {
+ deps = [ "//components/policy/core/browser" ]
+ }
+ component("policy_component_common") {
+ deps = [ "//components/policy/core/common" ]
+ }
+}
+
+if (enable_configuration_policy) {
+ # TODO(brettw) this component should use target_gen_dir instead but the GYP
+ # build puts everything into the following directory. We do the same for now.
+ policy_gen_dir = "$root_gen_dir/policy"
+
+ # This protobuf is equivalent to chrome_settings.proto but shares messages
+ # for policies of the same type, so that less classes have to be generated
+ # and compiled.
+ cloud_policy_proto_path = "$policy_gen_dir/cloud_policy.proto"
+
+ # This is the "full" protobuf, which defines one protobuf message per
+ # policy. It is also the format currently used by the server.
+ chrome_settings_proto_path = "$policy_gen_dir/chrome_settings.proto"
+
+ constants_header_path = "$policy_gen_dir/policy_constants.h"
+ constants_source_path = "$policy_gen_dir/policy_constants.cc"
+ protobuf_decoder_path = "$policy_gen_dir/cloud_policy_generated.cc"
+
+ action("cloud_policy_code_generate") {
+ script = "tools/generate_policy_source.py"
+
+ if (is_chromeos) {
+ chromeos_flag = "1"
+ } else {
+ chromeos_flag = "0"
+ }
+
+ source_prereqs = [
+ "resources/policy_templates.json",
+ ]
+ outputs = [
+ constants_header_path,
+ constants_source_path,
+ protobuf_decoder_path,
+ chrome_settings_proto_path,
+ cloud_policy_proto_path,
+ ]
+
+ args = [
+ "--policy-constants-header=" +
+ rebase_path(constants_header_path, root_build_dir),
+ "--policy-constants-source=" +
+ rebase_path(constants_source_path, root_build_dir),
+ "--chrome-settings-protobuf=" +
+ rebase_path(chrome_settings_proto_path, root_build_dir),
+ "--cloud-policy-protobuf=" +
+ rebase_path(cloud_policy_proto_path, root_build_dir),
+ "--cloud-policy-decoder=" +
+ rebase_path(protobuf_decoder_path, root_build_dir),
+ os,
+ chromeos_flag,
+ rebase_path("resources/policy_templates.json", root_build_dir),
+ ]
+ }
+
+ proto_library("cloud_policy_proto_generated_compile") {
+ sources = [ cloud_policy_proto_path ]
+
+ proto_in_dir = policy_gen_dir
+ proto_out_dir = "policy/proto"
+ cc_generator_options = "dllexport_decl=POLICY_PROTO_EXPORT:"
+ cc_include = "components/policy/policy_proto_export.h"
+ defines = [ "POLICY_PROTO_COMPILATION" ]
+
+ deps = [
+ ":cloud_policy_code_generate",
+ ]
+ }
+
+ # This target builds the "full" protobuf, used for tests only.
+ proto_library("chrome_settings_proto_generated_compile") {
+ sources = [ chrome_settings_proto_path ]
+ proto_in_dir = policy_gen_dir
+ proto_out_dir = "policy/proto"
+
+ deps = [
+ ":cloud_policy_code_generate",
+ ":cloud_policy_proto_generated_compile",
+ ]
+ }
+
+ static_library("policy") {
+ sources = [
+ constants_header_path,
+ constants_source_path,
+ protobuf_decoder_path,
+ ]
+
+ defines = [ "POLICY_COMPONENT_IMPLEMENTATION" ]
+
+ deps = [
+ ":cloud_policy_code_generate",
+ ":cloud_policy_proto_generated_compile",
+ "//base",
+ "//third_party/protobuf:protobuf_lite",
+ ]
+ }
+
+ group("test_support") {
+ deps = [
+ ":chrome_settings_proto_generated_compile",
+ ":policy",
+ ]
+ }
+
+ static_library("policy_component_test_support") {
+ sources = [
+ "core/browser/configuration_policy_pref_store_test.cc",
+ "core/browser/configuration_policy_pref_store_test.h",
+ "core/common/cloud/mock_cloud_external_data_manager.cc",
+ "core/common/cloud/mock_cloud_external_data_manager.h",
+ "core/common/cloud/mock_cloud_policy_client.cc",
+ "core/common/cloud/mock_cloud_policy_client.h",
+ "core/common/cloud/mock_cloud_policy_store.cc",
+ "core/common/cloud/mock_cloud_policy_store.h",
+ "core/common/cloud/mock_device_management_service.cc",
+ "core/common/cloud/mock_device_management_service.h",
+ "core/common/cloud/mock_user_cloud_policy_store.cc",
+ "core/common/cloud/mock_user_cloud_policy_store.h",
+ "core/common/cloud/policy_builder.cc",
+ "core/common/cloud/policy_builder.h",
+ "core/common/configuration_policy_provider_test.cc",
+ "core/common/configuration_policy_provider_test.h",
+ "core/common/mock_configuration_policy_provider.cc",
+ "core/common/mock_configuration_policy_provider.h",
+ "core/common/mock_policy_service.cc",
+ "core/common/mock_policy_service.h",
+ "core/common/policy_test_utils.cc",
+ "core/common/policy_test_utils.h",
+ "core/common/preferences_mock_mac.cc",
+ "core/common/preferences_mock_mac.h",
+ ]
+
+ if (is_chromeos) {
+ sources -= [
+ "core/common/cloud/mock_user_cloud_policy_store.cc",
+ "core/common/cloud/mock_user_cloud_policy_store.h",
+ ]
+ }
+
+ deps = [
+ ":policy_component",
+ ":test_support",
+ "//components/policy/proto",
+ "//testing/gmock",
+ "//testing/gtest",
+ ]
+ }
+}
+
+#TODO(GYP) policy templates, chrome_manifest_bundle
diff --git a/components/policy/core/browser/BUILD.gn b/components/policy/core/browser/BUILD.gn
new file mode 100644
index 0000000..9e19d6e
--- /dev/null
+++ b/components/policy/core/browser/BUILD.gn
@@ -0,0 +1,64 @@
+# Copyright 2014 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.
+
+import("//build/config/features.gni")
+
+# GYP version: components/policy.gypi:policy_component_core_browser
+source_set("browser") {
+ sources = [
+ # Note that these sources are always included, even for builds that disable
+ # policy. Most source files should go in the conditional sources list
+ # below. url_blacklist_manager.h is used by managed mode.
+ "url_blacklist_manager.cc",
+ "url_blacklist_manager.h",
+ ]
+
+ defines = [ "POLICY_COMPONENT_IMPLEMENTATION" ]
+
+ deps = [
+ "//base",
+ "//base:prefs",
+ "//base/third_party/dynamic_annotations",
+ "//components/keyed_service/core",
+ "//components/pref_registry",
+ "//components/strings",
+ "//components/url_matcher",
+ "//net",
+ "//ui/base",
+ #'bookmarks_browser', TODO(GYP)
+ ]
+
+ if (enable_configuration_policy) {
+ sources += [
+ "autofill_policy_handler.cc",
+ "autofill_policy_handler.h",
+ "browser_policy_connector.cc",
+ "browser_policy_connector.h",
+ "browser_policy_connector_ios.h",
+ "browser_policy_connector_ios.mm",
+ "cloud/message_util.cc",
+ "cloud/message_util.h",
+ "configuration_policy_handler.cc",
+ "configuration_policy_handler.h",
+ "configuration_policy_handler_list.cc",
+ "configuration_policy_handler_list.h",
+ "configuration_policy_pref_store.cc",
+ "configuration_policy_pref_store.h",
+ "managed_bookmarks_tracker.cc",
+ "managed_bookmarks_tracker.h",
+ "policy_error_map.cc",
+ "policy_error_map.h",
+ "url_blacklist_policy_handler.cc",
+ "url_blacklist_policy_handler.h",
+ ]
+
+ deps += [
+ "//components/autofill/core/browser",
+ "//components/autofill/core/common",
+ "//components/policy",
+ "//components/policy/proto",
+ "//third_party/icu",
+ ]
+ }
+}
diff --git a/components/policy/core/common/BUILD.gn b/components/policy/core/common/BUILD.gn
new file mode 100644
index 0000000..991927b
--- /dev/null
+++ b/components/policy/core/common/BUILD.gn
@@ -0,0 +1,201 @@
+# Copyright 2014 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.
+
+import("//build/config/features.gni")
+
+source_set("common") {
+ defines = [ "POLICY_COMPONENT_IMPLEMENTATION" ]
+
+ if (enable_configuration_policy) {
+ sources = [
+ "cloud/cloud_external_data_manager.cc",
+ "cloud/cloud_external_data_manager.h",
+ "cloud/cloud_policy_client.cc",
+ "cloud/cloud_policy_client.h",
+ "cloud/cloud_policy_client_registration_helper.cc",
+ "cloud/cloud_policy_client_registration_helper.h",
+ "cloud/cloud_policy_constants.cc",
+ "cloud/cloud_policy_constants.h",
+ "cloud/cloud_policy_core.cc",
+ "cloud/cloud_policy_core.h",
+ "cloud/cloud_policy_manager.cc",
+ "cloud/cloud_policy_manager.h",
+ "cloud/cloud_policy_refresh_scheduler.cc",
+ "cloud/cloud_policy_refresh_scheduler.h",
+ "cloud/cloud_policy_service.cc",
+ "cloud/cloud_policy_service.h",
+ "cloud/cloud_policy_store.cc",
+ "cloud/cloud_policy_store.h",
+ "cloud/cloud_policy_validator.cc",
+ "cloud/cloud_policy_validator.h",
+ "cloud/component_cloud_policy_service.cc",
+ "cloud/component_cloud_policy_service.h",
+ "cloud/component_cloud_policy_store.cc",
+ "cloud/component_cloud_policy_store.h",
+ "cloud/component_cloud_policy_updater.cc",
+ "cloud/component_cloud_policy_updater.h",
+ "cloud/device_management_service.cc",
+ "cloud/device_management_service.h",
+ "cloud/enterprise_metrics.cc",
+ "cloud/enterprise_metrics.h",
+ "cloud/external_policy_data_fetcher.cc",
+ "cloud/external_policy_data_fetcher.h",
+ "cloud/external_policy_data_updater.cc",
+ "cloud/external_policy_data_updater.h",
+ "cloud/policy_header_io_helper.cc",
+ "cloud/policy_header_io_helper.h",
+ "cloud/policy_header_service.cc",
+ "cloud/policy_header_service.h",
+ "cloud/rate_limiter.cc",
+ "cloud/rate_limiter.h",
+ "cloud/resource_cache.cc",
+ "cloud/resource_cache.h",
+ "cloud/system_policy_request_context.cc",
+ "cloud/system_policy_request_context.h",
+ "cloud/user_cloud_policy_manager.cc",
+ "cloud/user_cloud_policy_manager.h",
+ "cloud/user_cloud_policy_store.cc",
+ "cloud/user_cloud_policy_store.h",
+ "cloud/user_cloud_policy_store_base.cc",
+ "cloud/user_cloud_policy_store_base.h",
+ "cloud/user_info_fetcher.cc",
+ "cloud/user_info_fetcher.h",
+ "cloud/user_policy_request_context.cc",
+ "cloud/user_policy_request_context.h",
+ "async_policy_loader.cc",
+ "async_policy_loader.h",
+ "async_policy_provider.cc",
+ "async_policy_provider.h",
+ "config_dir_policy_loader.cc",
+ "config_dir_policy_loader.h",
+ "configuration_policy_provider.cc",
+ "configuration_policy_provider.h",
+ "external_data_fetcher.cc",
+ "external_data_fetcher.h",
+ "external_data_manager.h",
+ "forwarding_policy_provider.cc",
+ "forwarding_policy_provider.h",
+ "mac_util.cc",
+ "mac_util.h",
+ "policy_bundle.cc",
+ "policy_bundle.h",
+ "policy_details.h",
+ "policy_loader_ios.h",
+ "policy_loader_ios.mm",
+ "policy_loader_mac.cc",
+ "policy_loader_mac.h",
+ "policy_loader_win.cc",
+ "policy_loader_win.h",
+ "policy_load_status.cc",
+ "policy_load_status.h",
+ "policy_map.cc",
+ "policy_map.h",
+ "policy_namespace.cc",
+ "policy_namespace.h",
+ "policy_pref_names.cc",
+ "policy_pref_names.h",
+ "policy_provider_android.cc",
+ "policy_provider_android.h",
+ "policy_provider_android_delegate.h",
+ "policy_service.cc",
+ "policy_service.h",
+ "policy_service_impl.cc",
+ "policy_service_impl.h",
+ "policy_statistics_collector.cc",
+ "policy_statistics_collector.h",
+ "policy_switches.cc",
+ "policy_switches.h",
+ "policy_types.h",
+ "preferences_mac.cc",
+ "preferences_mac.h",
+ "preg_parser_win.cc",
+ "preg_parser_win.h",
+ "registry_dict_win.cc",
+ "registry_dict_win.h",
+ "schema.cc",
+ "schema.h",
+ "schema_internal.h",
+ "schema_map.cc",
+ "schema_map.h",
+ "schema_registry.cc",
+ "schema_registry.h",
+ "../../policy_export.h",
+ ]
+
+ deps = [
+ "//base:prefs",
+ "//base/third_party/dynamic_annotations",
+ "//components/json_schema",
+ "//components/policy",
+ "//components/policy/proto",
+ "//google_apis",
+ "//net",
+ "//third_party/re2",
+ "//url",
+ ]
+
+ if (is_android) {
+ sources += [ "cloud/component_cloud_policy_service_stub.cc" ]
+ sources -= [
+ "cloud/component_cloud_policy_service.cc",
+ "cloud/component_cloud_policy_store.cc",
+ "cloud/component_cloud_policy_store.h",
+ "cloud/component_cloud_policy_updater.cc",
+ "cloud/component_cloud_policy_updater.h",
+ "cloud/external_policy_data_fetcher.cc",
+ "cloud/external_policy_data_fetcher.h",
+ "cloud/external_policy_data_updater.cc",
+ "cloud/external_policy_data_updater.h",
+ "cloud/resource_cache.cc",
+ "cloud/resource_cache.h",
+ "config_dir_policy_loader.cc",
+ "config_dir_policy_loader.h",
+ "policy_load_status.cc",
+ "policy_load_status.h",
+ ]
+ }
+ if (is_chromeos) {
+ sources += [
+ "proxy_policy_provider.cc",
+ "proxy_policy_provider.h",
+ ]
+ sources -= [
+ "cloud/cloud_policy_client_registration_helper.cc",
+ "cloud/cloud_policy_client_registration_helper.h",
+ "cloud/user_cloud_policy_manager.cc",
+ "cloud/user_cloud_policy_manager.h",
+ "cloud/user_cloud_policy_store.cc",
+ "cloud/user_cloud_policy_store.h",
+ ]
+ }
+ if (!is_ios && !is_mac) {
+ sources -= [
+ "mac_util.cc",
+ "mac_util.h",
+ ]
+ }
+ } else {
+ # Some of the policy code is always enabled, so that other parts of Chrome
+ # can always interface with the PolicyService without having to #ifdef on
+ # ENABLE_CONFIGURATION_POLICY.
+ sources = [
+ "external_data_fetcher.h",
+ "external_data_fetcher.cc",
+ "external_data_manager.h",
+ "policy_map.cc",
+ "policy_map.h",
+ "policy_namespace.cc",
+ "policy_namespace.h",
+ "policy_pref_names.cc",
+ "policy_pref_names.h",
+ "policy_service.cc",
+ "policy_service.h",
+ "policy_service_stub.cc",
+ "policy_service_stub.h",
+ ]
+ deps = [
+ "//base",
+ ]
+ }
+}
diff --git a/components/policy/policy_browser.gypi b/components/policy/policy_browser.gypi
index 9d7df97..987da77 100644
--- a/components/policy/policy_browser.gypi
+++ b/components/policy/policy_browser.gypi
@@ -31,6 +31,7 @@
'core/browser/url_blacklist_manager.h',
],
'conditions': [
+ # GN version: //components/policy/core/browser
['configuration_policy==1', {
'dependencies': [
'autofill_core_browser',
diff --git a/components/policy/policy_common.gypi b/components/policy/policy_common.gypi
index 1d7996a..6afa3d8 100644
--- a/components/policy/policy_common.gypi
+++ b/components/policy/policy_common.gypi
@@ -3,6 +3,7 @@
# found in the LICENSE file.
{
+ # GN version: //components/policy/core/common
'dependencies': [
'../base/base.gyp:base',
],
diff --git a/components/policy/proto/BUILD.gn b/components/policy/proto/BUILD.gn
index 13b7e2f..cc84042 100644
--- a/components/policy/proto/BUILD.gn
+++ b/components/policy/proto/BUILD.gn
@@ -16,6 +16,7 @@ proto_library("proto") {
sources += [ "device_management_local.proto" ]
}
+ proto_out_dir = "policy/proto"
cc_generator_options = "dllexport_decl=POLICY_PROTO_EXPORT:"
cc_include = "components/policy/policy_proto_export.h"
defines = [ "POLICY_PROTO_COMPILATION" ]
diff --git a/components/variations.gypi b/components/variations.gypi
index e560130..db46140 100644
--- a/components/variations.gypi
+++ b/components/variations.gypi
@@ -5,6 +5,7 @@
{
'targets': [
{
+ # GN version: //components/variations
'target_name': 'variations',
'type': 'static_library',
'include_dirs': [
diff --git a/components/variations/BUILD.gn b/components/variations/BUILD.gn
new file mode 100644
index 0000000..827155cf6
--- /dev/null
+++ b/components/variations/BUILD.gn
@@ -0,0 +1,34 @@
+# Copyright 2014 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.
+
+static_library("variations") {
+ sources = [
+ "active_field_trials.cc",
+ "active_field_trials.h",
+ "caching_permuted_entropy_provider.cc",
+ "caching_permuted_entropy_provider.h",
+ "entropy_provider.cc",
+ "entropy_provider.h",
+ "metrics_util.cc",
+ "metrics_util.h",
+ "pref_names.cc",
+ "pref_names.h",
+ "processed_study.cc",
+ "processed_study.h",
+ "study_filtering.cc",
+ "study_filtering.h",
+ "variations_associated_data.cc",
+ "variations_associated_data.h",
+ "variations_seed_processor.cc",
+ "variations_seed_processor.h",
+ "variations_seed_simulator.cc",
+ "variations_seed_simulator.h",
+ ]
+
+ deps = [
+ "//base",
+ "//components/variations/proto",
+ "//third_party/mt19937ar",
+ ]
+}
diff --git a/components/variations/proto/BUILD.gn b/components/variations/proto/BUILD.gn
new file mode 100644
index 0000000..5895d57
--- /dev/null
+++ b/components/variations/proto/BUILD.gn
@@ -0,0 +1,13 @@
+# Copyright 2014 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.
+
+import("//third_party/protobuf/proto_library.gni")
+
+proto_library("proto") {
+ sources = [
+ "permuted_entropy_cache.proto",
+ "study.proto",
+ "variations_seed.proto",
+ ]
+}
diff --git a/extensions/common/api/BUILD.gn b/extensions/common/api/BUILD.gn
index b4321de6..5a8c7db 100644
--- a/extensions/common/api/BUILD.gn
+++ b/extensions/common/api/BUILD.gn
@@ -18,5 +18,6 @@ generated_extensions_api("extensions_api") {
]
root_namespace = "extensions::core_api"
impl_dir = "//extensions/browser/api"
+ bundle = true
deps = [ "//skia" ]
}
diff --git a/extensions/generated_extensions_api.gni b/extensions/generated_extensions_api.gni
index c8817a6..e231157 100644
--- a/extensions/generated_extensions_api.gni
+++ b/extensions/generated_extensions_api.gni
@@ -11,20 +11,27 @@
#
# sources [required] A list of schema files to be compiled.
#
-# root_namespace [required] The namespace in which generated API code is to be
+# root_namespace [required]
+# The namespace in which generated API code is to be
# wrapped. C++ namespace syntax is accepted for nested namespace
# (e.g. "foo::bar::api").
#
-# impl_dir [required] The path containing C++ implementations of API functions.
-# This path is used as the root path when looking for
-# {schema}/{schema}_api.h headers during the API bundle generation phase.
-# Such headers, if found, are automatically included by the generated code.
+# bundle [optional, default = false]
+# Boolean indicating if the schema files should be bundled or not.
#
-# uncompiled_sources [optional] A list of schema files which should not be
-# compiled, but which should still be processed for API bundle generation.
+# impl_dir [required if bundle = true, otherwise unused]
+# The path containing C++ implementations of API functions. This path is
+# used as the root path when looking for {schema}/{schema}_api.h headers
+# during the API bundle generation phase. Such headers, if found, are
+# automatically included by the generated code.
#
-# deps [optional] If any deps are specified they will be inherited by the
-# static library target.
+# uncompiled_sources [optional, only used when bundle = true]
+# A list of schema files which should not be compiled, but which should still
+# be processed for API bundle generation.
+#
+# deps [optional]
+# If any deps are specified they will be inherited by the static library
+# target.
#
# The static libarary target also inherits the visibility and output_name
# of its invoker.
@@ -34,8 +41,8 @@ template("generated_extensions_api") {
"\"sources\" must be defined for the $target_name template.")
assert(defined(invoker.root_namespace),
"\"root_namespace\" must be defined for the $target_name template.")
- assert(defined(invoker.impl_dir),
- "\"impl_dir\" must be defined for the $target_name template.")
+
+ bundle = defined(invoker.bundle) && invoker.bundle
# Keep a copy of the target_name here since it will be trampled
# in nested targets.
@@ -49,11 +56,6 @@ template("generated_extensions_api") {
schemas = invoker.sources
root_namespace = invoker.root_namespace
- impl_dir = invoker.impl_dir
- uncompiled_schemas = []
- if (defined(invoker.uncompiled_sources)) {
- uncompiled_schemas = invoker.uncompiled_sources
- }
compiler_root = "//tools/json_schema_compiler"
compiler_script = "$compiler_root/compiler.py"
@@ -88,38 +90,51 @@ template("generated_extensions_api") {
visibility = target_visibility
}
- bundle_generator_name = target_name + "_bundle_generator"
- action(bundle_generator_name) {
- script = compiler_script
- source_prereqs = compiler_sources + schemas + uncompiled_schemas
- outputs = [
- "$target_gen_dir/generated_api.cc",
- "$target_gen_dir/generated_api.h",
- "$target_gen_dir/generated_schemas.cc",
- "$target_gen_dir/generated_schemas.h",
- ]
- args = [
- "--root=" + rebase_path("//", root_build_dir),
- "--destdir=" + rebase_path(root_gen_dir, root_build_dir),
- "--namespace=$root_namespace",
- "--generator=cpp-bundle",
- "--impl-dir=" + rebase_path(impl_dir, "//"),
- ] +
- rebase_path(schemas, root_build_dir) +
- rebase_path(uncompiled_schemas, root_build_dir)
+ if (bundle) {
+ assert(defined(invoker.impl_dir),
+ "\"impl_dir\" must be defined for the $target_name template.")
+ impl_dir = invoker.impl_dir
+
+ uncompiled_schemas = []
+ if (defined(invoker.uncompiled_sources)) {
+ uncompiled_schemas = invoker.uncompiled_sources
+ }
+
+ bundle_generator_name = target_name + "_bundle_generator"
+ action(bundle_generator_name) {
+ script = compiler_script
+ source_prereqs = compiler_sources + schemas + uncompiled_schemas
+ outputs = [
+ "$target_gen_dir/generated_api.cc",
+ "$target_gen_dir/generated_api.h",
+ "$target_gen_dir/generated_schemas.cc",
+ "$target_gen_dir/generated_schemas.h",
+ ]
+ args = [
+ "--root=" + rebase_path("//", root_build_dir),
+ "--destdir=" + rebase_path(root_gen_dir, root_build_dir),
+ "--namespace=$root_namespace",
+ "--generator=cpp-bundle",
+ "--impl-dir=" + rebase_path(impl_dir, "//"),
+ ] +
+ rebase_path(schemas, root_build_dir) +
+ rebase_path(uncompiled_schemas, root_build_dir)
+ }
}
source_set(target_name) {
- sources =
- get_target_outputs(":$schema_generator_name") +
- get_target_outputs(":$bundle_generator_name")
+ sources = get_target_outputs(":$schema_generator_name")
deps = [
":$schema_generator_name",
- ":$bundle_generator_name",
"//tools/json_schema_compiler:generated_api_util",
]
+ if (bundle) {
+ sources += get_target_outputs(":$bundle_generator_name")
+ deps += [ ":$bundle_generator_name" ]
+ }
+
if (defined(invoker.deps)) {
deps += invoker.deps
}
diff --git a/net/BUILD.gn b/net/BUILD.gn
index db3e631..2ee68d3 100644
--- a/net/BUILD.gn
+++ b/net/BUILD.gn
@@ -752,6 +752,8 @@ if (use_v8_in_net) {
"//url",
"//v8",
]
+
+ forward_dependent_configs_from = [ ":net" ]
}
}
diff --git a/third_party/libphonenumber/BUILD.gn b/third_party/libphonenumber/BUILD.gn
new file mode 100644
index 0000000..c4d244b
--- /dev/null
+++ b/third_party/libphonenumber/BUILD.gn
@@ -0,0 +1,100 @@
+# Copyright 2014 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.
+
+import("//third_party/protobuf/proto_library.gni")
+
+proto_library("proto") {
+ sources = [
+ "src/resources/phonemetadata.proto",
+ "src/resources/phonenumber.proto",
+ ]
+ proto_in_dir = "src/resources"
+ proto_out_dir = "third_party/libphonenumber/phonenumbers"
+}
+
+config("libphonenumber_config") {
+ include_dirs = [
+ "src",
+ "$root_gen_dir/protoc_out/third_party/libphonenumber",
+ ]
+ defines = [ "I18N_PHONENUMBERS_USE_ICU_REGEXP=1" ]
+ if (!is_android) {
+ defines += [ "I18N_PHONENUMBERS_NO_THREAD_SAFETY=1" ]
+ }
+}
+
+# GYP version: third_party/libphonenumber/libphonenumber.gyp:libphonenumber_without_metadata
+static_library("libphonenumber_without_metadata") {
+ sources = [
+ "src/phonenumbers/asyoutypeformatter.cc",
+ "src/phonenumbers/base/strings/string_piece.cc",
+ "src/phonenumbers/default_logger.cc",
+ "src/phonenumbers/logger.cc",
+ "src/phonenumbers/phonenumber.cc",
+ "src/phonenumbers/phonenumbermatch.cc",
+ "src/phonenumbers/phonenumbermatcher.cc",
+ "src/phonenumbers/phonenumberutil.cc",
+ "src/phonenumbers/regexp_adapter_icu.cc",
+ "src/phonenumbers/regexp_cache.cc",
+ "src/phonenumbers/string_byte_sink.cc",
+ "src/phonenumbers/stringutil.cc",
+ "src/phonenumbers/unicodestring.cc",
+ "src/phonenumbers/utf/rune.c",
+ "src/phonenumbers/utf/unicodetext.cc",
+ "src/phonenumbers/utf/unilib.cc",
+ ]
+
+ direct_dependent_configs = [ ":libphonenumber_config" ]
+
+ deps = [
+ ":proto",
+ "//third_party/icu",
+ "//third_party/protobuf:protobuf_lite",
+ ]
+
+ forward_dependent_configs_from = [ ":proto" ]
+}
+
+# Library used by clients that includes production metadata.
+# GYP version: third_party/libphonenumber/libphonenumber.gyp:libphonenumber
+static_library("libphonenumber") {
+ sources = [
+ # Comment next line and uncomment the line after, if complete metadata
+ # (with examples) is needed.
+ "src/phonenumbers/lite_metadata.cc",
+ #"src/phonenumbers/metadata.cc",
+ ]
+
+ deps = [
+ ":libphonenumber_without_metadata",
+ ]
+ forward_dependent_configs_from = deps
+}
+
+# GYP version: third_party/libphonenumber/libphonenumber.gyp:libphonenumber_unittests
+test("libphonenumber_unittests") {
+ sources = [
+ "src/phonenumbers/test_metadata.cc",
+ "src/test/phonenumbers/asyoutypeformatter_test.cc",
+ "src/test/phonenumbers/phonenumbermatch_test.cc",
+ "src/test/phonenumbers/phonenumbermatcher_test.cc",
+ "src/test/phonenumbers/phonenumberutil_test.cc",
+ "src/test/phonenumbers/regexp_adapter_test.cc",
+ "src/test/phonenumbers/stringutil_test.cc",
+ "src/test/phonenumbers/test_util.cc",
+ "src/test/phonenumbers/unicodestring_test.cc",
+ ]
+
+ include_dirs = [ "src/test" ]
+
+ deps = [
+ ":libphonenumber_without_metadata",
+ "//base",
+ "//base/test:run_all_unittests",
+ "//base/third_party/dynamic_annotations",
+ "//third_party/icu",
+ "//testing/gmock",
+ "//testing/gtest",
+ ]
+}
diff --git a/third_party/libphonenumber/libphonenumber.gyp b/third_party/libphonenumber/libphonenumber.gyp
index f002790..229440b 100644
--- a/third_party/libphonenumber/libphonenumber.gyp
+++ b/third_party/libphonenumber/libphonenumber.gyp
@@ -35,6 +35,7 @@
'targets': [{
# Build a library without metadata so that we can use it with both testing
# and production metadata. This library should not be used by clients.
+ # GN version: //third_party/libphonenumber:libphonenumber_without_metadata
'target_name': 'libphonenumber_without_metadata',
'type': 'static_library',
'dependencies': [
@@ -93,6 +94,7 @@
},
{
# Library used by clients that includes production metadata.
+ # GN version: //third_party/libphonenumber
'target_name': 'libphonenumber',
'type': 'static_library',
'dependencies': [
@@ -109,6 +111,7 @@
],
},
{
+ # GN version: //third_party/libphonenumber:libphonenumber_unittests
'target_name': 'libphonenumber_unittests',
'type': 'executable',
'sources': [
diff --git a/third_party/mt19937ar/BUILD.gn b/third_party/mt19937ar/BUILD.gn
new file mode 100644
index 0000000..35c2d9b
--- /dev/null
+++ b/third_party/mt19937ar/BUILD.gn
@@ -0,0 +1,10 @@
+# Copyright 2014 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.
+
+static_library("mt19937ar") {
+ sources = [
+ "mt19937ar.cc",
+ "mt19937ar.h",
+ ]
+}
diff --git a/third_party/protobuf/proto_library.gni b/third_party/protobuf/proto_library.gni
index 62efd78..3f4cae9 100644
--- a/third_party/protobuf/proto_library.gni
+++ b/third_party/protobuf/proto_library.gni
@@ -30,6 +30,9 @@
# String listing an extra include that should be passed.
# Example: cc_include = "foo/bar.h"
#
+# deps (optional)
+# Additional dependencies.
+#
# Parameters for compiling the generated code:
#
# defines (optional)
@@ -125,6 +128,10 @@ template("proto_library") {
]
deps = [ protoc_label ]
+
+ if (defined(invoker.deps)) {
+ deps += invoker.deps
+ }
}
source_set(target_name) {
diff --git a/ui/accessibility/BUILD.gn b/ui/accessibility/BUILD.gn
index e1c61d2..64e39c9 100644
--- a/ui/accessibility/BUILD.gn
+++ b/ui/accessibility/BUILD.gn
@@ -70,4 +70,5 @@ generated_extensions_api("ax_gen") {
sources = [ "ax_enums.idl" ]
root_namespace = ""
impl_dir = "."
+ bundle = true
}
diff --git a/ui/gfx/ipc/BUILD.gn b/ui/gfx/ipc/BUILD.gn
new file mode 100644
index 0000000..8f11fa8
--- /dev/null
+++ b/ui/gfx/ipc/BUILD.gn
@@ -0,0 +1,21 @@
+# Copyright 2014 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.
+
+component("ipc") {
+ output_name = "gfx_ipc"
+
+ sources = [
+ "gfx_param_traits.cc",
+ "gfx_param_traits.h",
+ ]
+
+ defines = [ "GFX_IPC_IMPLEMENTATION" ]
+
+ deps = [
+ "//base",
+ "//ipc",
+ "//skia",
+ "//ui/gfx",
+ ]
+}
diff --git a/ui/gfx/ipc/gfx_ipc.gyp b/ui/gfx/ipc/gfx_ipc.gyp
index 1facce5..2c527f0 100644
--- a/ui/gfx/ipc/gfx_ipc.gyp
+++ b/ui/gfx/ipc/gfx_ipc.gyp
@@ -8,6 +8,7 @@
},
'targets': [
{
+ # GN version: //ui/gfx/ipc
'target_name': 'gfx_ipc',
'type': '<(component)',
'dependencies': [