summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/BUILD.gn777
-rw-r--r--net/net.gypi162
-rw-r--r--net/net_common.gypi31
-rw-r--r--url/BUILD.gn137
-rw-r--r--url/config.gni8
5 files changed, 525 insertions, 590 deletions
diff --git a/net/BUILD.gn b/net/BUILD.gn
index 2f30e99..1e149ba 100644
--- a/net/BUILD.gn
+++ b/net/BUILD.gn
@@ -6,7 +6,6 @@ import("//build/config/crypto.gni")
import("//build/config/features.gni")
import("//build/config/ui.gni")
import("//build/module_args/v8.gni")
-import("//url/config.gni")
import("//testing/test.gni")
import("//third_party/icu/config.gni")
import("//third_party/protobuf/proto_library.gni")
@@ -63,11 +62,8 @@ config("net_config") {
}
}
-component("net") {
- sources =
- gypi_values.net_nacl_common_sources + gypi_values.net_non_nacl_sources
-
- cflags = []
+# net_internal_config is shared with net and net_small.
+config("net_internal_config") {
defines = [
# TODO(GYP) Note that the GYP file supports linux_link_kerberos (defaults to
# 0) which implies that we run pkg_config on kerberos and link to that
@@ -78,372 +74,341 @@ component("net") {
"NET_IMPLEMENTATION",
]
- configs += [
- "//build/config:precompiled_headers",
-
- # TODO(jschuh): crbug.com/167187 fix size_t to int truncations.
- "//build/config/compiler:no_size_t_to_int_warning",
- ]
- public_configs = [ ":net_config" ]
- include_dirs = []
-
- public_deps = [
- ":net_quic_proto",
- "//crypto",
- "//crypto:platform",
- "//url",
- ]
- deps = [
- ":net_resources",
- "//base",
- "//base:prefs",
- "//base/third_party/dynamic_annotations",
- "//net/base/registry_controlled_domains",
- "//sdch",
- "//third_party/protobuf:protobuf_lite",
- "//third_party/zlib",
- "//url",
- ]
-
if (use_kerberos) {
defines += [ "USE_KERBEROS" ]
if (is_android) {
- include_dirs += [ "/usr/include/kerberosV" ]
+ include_dirs = [ "/usr/include/kerberosV" ]
}
- } else {
- sources -= [
- "http/http_auth_gssapi_posix.cc",
- "http/http_auth_gssapi_posix.h",
- "http/http_auth_handler_negotiate.cc",
- "http/http_auth_handler_negotiate.h",
- ]
}
- if (is_posix) {
- if (posix_avoid_mmap) {
- sources -= [ "disk_cache/blockfile/mapped_file_posix.cc" ]
- } else {
- sources -= [ "disk_cache/blockfile/mapped_file_avoid_mmap_posix.cc" ]
- }
+ if (enable_built_in_dns) {
+ defines += [ "ENABLE_BUILT_IN_DNS" ]
}
+}
- if (disable_file_support) {
- sources -= [
- "base/directory_lister.cc",
- "base/directory_lister.h",
- "url_request/file_protocol_handler.cc",
- "url_request/file_protocol_handler.h",
- "url_request/url_request_file_dir_job.cc",
- "url_request/url_request_file_dir_job.h",
- "url_request/url_request_file_job.cc",
- "url_request/url_request_file_job.h",
- ]
- }
+# net_shared_* are settings shared between net and net_small
+net_shared_sources =
+ gypi_values.net_nacl_common_sources + gypi_values.net_non_nacl_sources
- if (disable_ftp_support) {
- sources -= [
- "ftp/ftp_auth_cache.cc",
- "ftp/ftp_auth_cache.h",
- "ftp/ftp_ctrl_response_buffer.cc",
- "ftp/ftp_ctrl_response_buffer.h",
- "ftp/ftp_directory_listing_parser.cc",
- "ftp/ftp_directory_listing_parser.h",
- "ftp/ftp_directory_listing_parser_ls.cc",
- "ftp/ftp_directory_listing_parser_ls.h",
- "ftp/ftp_directory_listing_parser_netware.cc",
- "ftp/ftp_directory_listing_parser_netware.h",
- "ftp/ftp_directory_listing_parser_os2.cc",
- "ftp/ftp_directory_listing_parser_os2.h",
- "ftp/ftp_directory_listing_parser_vms.cc",
- "ftp/ftp_directory_listing_parser_vms.h",
- "ftp/ftp_directory_listing_parser_windows.cc",
- "ftp/ftp_directory_listing_parser_windows.h",
- "ftp/ftp_network_layer.cc",
- "ftp/ftp_network_layer.h",
- "ftp/ftp_network_session.cc",
- "ftp/ftp_network_session.h",
- "ftp/ftp_network_transaction.cc",
- "ftp/ftp_network_transaction.h",
- "ftp/ftp_request_info.h",
- "ftp/ftp_response_info.cc",
- "ftp/ftp_response_info.h",
- "ftp/ftp_server_type_histograms.cc",
- "ftp/ftp_server_type_histograms.h",
- "ftp/ftp_transaction.h",
- "ftp/ftp_transaction_factory.h",
- "ftp/ftp_util.cc",
- "ftp/ftp_util.h",
- "url_request/ftp_protocol_handler.cc",
- "url_request/ftp_protocol_handler.h",
- "url_request/url_request_ftp_job.cc",
- "url_request/url_request_ftp_job.h",
- ]
- }
+net_shared_unfiltered_sources = []
- if (enable_built_in_dns) {
- defines += [ "ENABLE_BUILT_IN_DNS" ]
- } else {
- sources -= [
- "dns/address_sorter_posix.cc",
- "dns/address_sorter_posix.h",
- "dns/dns_client.cc",
- ]
- }
+net_shared_configs = [
+ ":net_internal_config",
+ "//build/config:precompiled_headers",
- if (use_openssl) {
- sources -= [
- "base/nss_memio.c",
- "base/nss_memio.h",
- "cert/ct_log_verifier_nss.cc",
- "cert/ct_objects_extractor_nss.cc",
- "cert/jwk_serializer_nss.cc",
- "cert/scoped_nss_types.h",
- "cert/x509_util_nss.cc",
- "quic/crypto/aead_base_decrypter_nss.cc",
- "quic/crypto/aead_base_encrypter_nss.cc",
- "quic/crypto/aes_128_gcm_12_decrypter_nss.cc",
- "quic/crypto/aes_128_gcm_12_encrypter_nss.cc",
- "quic/crypto/chacha20_poly1305_decrypter_nss.cc",
- "quic/crypto/chacha20_poly1305_encrypter_nss.cc",
- "quic/crypto/channel_id_nss.cc",
- "quic/crypto/p256_key_exchange_nss.cc",
- "socket/nss_ssl_util.cc",
- "socket/nss_ssl_util.h",
- "socket/ssl_client_socket_nss.cc",
- "socket/ssl_client_socket_nss.h",
- "socket/ssl_server_socket_nss.cc",
- "socket/ssl_server_socket_nss.h",
- ]
- if (is_ios) {
- # Always removed for !ios below.
- sources -= [
- "cert/cert_verify_proc_nss.cc",
- "cert/cert_verify_proc_nss.h",
- ]
- }
- if (is_win) {
- sources -= [ "cert/sha256_legacy_support_nss_win.cc" ]
- }
- if (!use_nss_certs && !is_ios) {
- sources -= [ "cert/x509_util_nss.h" ]
- }
+ # TODO(jschuh): crbug.com/167187 fix size_t to int truncations.
+ "//build/config/compiler:no_size_t_to_int_warning",
+]
+
+net_shared_public_deps = [
+ ":net_quic_proto",
+ "//crypto",
+ "//crypto:platform",
+]
+
+net_shared_deps = [
+ ":net_resources",
+ "//base",
+ "//base:prefs",
+ "//base/third_party/dynamic_annotations",
+ "//net/base/registry_controlled_domains",
+ "//sdch",
+ "//third_party/protobuf:protobuf_lite",
+ "//third_party/zlib",
+]
+
+if (!use_kerberos) {
+ net_shared_sources -= [
+ "http/http_auth_gssapi_posix.cc",
+ "http/http_auth_gssapi_posix.h",
+ "http/http_auth_handler_negotiate.cc",
+ "http/http_auth_handler_negotiate.h",
+ ]
+}
+
+if (is_posix) {
+ if (posix_avoid_mmap) {
+ net_shared_sources -= [ "disk_cache/blockfile/mapped_file_posix.cc" ]
} else {
- sources -= [
- "cert/ct_log_verifier_openssl.cc",
- "cert/ct_objects_extractor_openssl.cc",
- "cert/jwk_serializer_openssl.cc",
- "cert/x509_util_openssl.cc",
- "cert/x509_util_openssl.h",
- "quic/crypto/aead_base_decrypter_openssl.cc",
- "quic/crypto/aead_base_encrypter_openssl.cc",
- "quic/crypto/aes_128_gcm_12_decrypter_openssl.cc",
- "quic/crypto/aes_128_gcm_12_encrypter_openssl.cc",
- "quic/crypto/chacha20_poly1305_decrypter_openssl.cc",
- "quic/crypto/chacha20_poly1305_encrypter_openssl.cc",
- "quic/crypto/channel_id_openssl.cc",
- "quic/crypto/p256_key_exchange_openssl.cc",
- "quic/crypto/scoped_evp_aead_ctx.cc",
- "quic/crypto/scoped_evp_aead_ctx.h",
- "socket/ssl_client_socket_openssl.cc",
- "socket/ssl_client_socket_openssl.h",
- "socket/ssl_server_socket_openssl.cc",
- "socket/ssl_server_socket_openssl.h",
- "ssl/openssl_ssl_util.cc",
- "ssl/openssl_ssl_util.h",
- "ssl/ssl_client_session_cache_openssl.cc",
- "ssl/ssl_client_session_cache_openssl.h",
- "ssl/ssl_platform_key.h",
- "ssl/threaded_ssl_private_key.cc",
- "ssl/threaded_ssl_private_key.h",
- ]
- if (is_mac) {
- sources -= [ "ssl/ssl_platform_key_mac.cc" ]
- }
- if (is_android) {
- sources -= [ "ssl/ssl_platform_key_android.cc" ]
- }
- if (is_win) {
- sources -= [
- "cert/sha256_legacy_support_openssl_win.cc",
- "ssl/ssl_platform_key_win.cc",
- ]
- }
- if (use_nss_certs) {
- sources -= [
- "ssl/client_key_store.cc",
- "ssl/client_key_store.h",
- "ssl/ssl_platform_key_nss.cc",
- ]
- }
+ net_shared_sources -=
+ [ "disk_cache/blockfile/mapped_file_avoid_mmap_posix.cc" ]
}
+}
- if (!use_openssl_certs) {
- sources -= [
- "base/crypto_module_openssl.cc",
- "base/keygen_handler_openssl.cc",
- "base/openssl_private_key_store.h",
- "base/openssl_private_key_store_memory.cc",
- "cert/cert_database_openssl.cc",
- "cert/cert_verify_proc_openssl.cc",
- "cert/cert_verify_proc_openssl.h",
- "cert/test_root_certs_openssl.cc",
- "cert/x509_certificate_openssl.cc",
- "ssl/openssl_client_key_store.cc",
- "ssl/openssl_client_key_store.h",
+if (!enable_built_in_dns) {
+ net_shared_sources -= [
+ "dns/address_sorter_posix.cc",
+ "dns/address_sorter_posix.h",
+ "dns/dns_client.cc",
+ ]
+}
+
+if (use_openssl) {
+ net_shared_sources -= [
+ "base/nss_memio.c",
+ "base/nss_memio.h",
+ "cert/ct_log_verifier_nss.cc",
+ "cert/ct_objects_extractor_nss.cc",
+ "cert/jwk_serializer_nss.cc",
+ "cert/scoped_nss_types.h",
+ "cert/x509_util_nss.cc",
+ "quic/crypto/aead_base_decrypter_nss.cc",
+ "quic/crypto/aead_base_encrypter_nss.cc",
+ "quic/crypto/aes_128_gcm_12_decrypter_nss.cc",
+ "quic/crypto/aes_128_gcm_12_encrypter_nss.cc",
+ "quic/crypto/chacha20_poly1305_decrypter_nss.cc",
+ "quic/crypto/chacha20_poly1305_encrypter_nss.cc",
+ "quic/crypto/channel_id_nss.cc",
+ "quic/crypto/p256_key_exchange_nss.cc",
+ "socket/nss_ssl_util.cc",
+ "socket/nss_ssl_util.h",
+ "socket/ssl_client_socket_nss.cc",
+ "socket/ssl_client_socket_nss.h",
+ "socket/ssl_server_socket_nss.cc",
+ "socket/ssl_server_socket_nss.h",
+ ]
+ if (is_ios) {
+ # Always removed for !ios below.
+ net_shared_sources -= [
+ "cert/cert_verify_proc_nss.cc",
+ "cert/cert_verify_proc_nss.h",
]
- if (is_android) {
- sources -= [ "base/openssl_private_key_store_android.cc" ]
- }
- } else {
- if (is_android) {
- # Android doesn't use these even when using OpenSSL.
- sources -= [
- "base/openssl_private_key_store_memory.cc",
- "cert/cert_database_openssl.cc",
- "cert/cert_verify_proc_openssl.cc",
- "cert/test_root_certs_openssl.cc",
- ]
- }
}
-
- if (use_glib && !is_chromeos) {
- configs += [ "//build/config/linux:gconf" ]
- deps += [ "//build/linux:gio" ]
+ if (is_win) {
+ net_shared_sources -= [ "cert/sha256_legacy_support_nss_win.cc" ]
+ }
+ if (!use_nss_certs && !is_ios) {
+ net_shared_sources -= [ "cert/x509_util_nss.h" ]
+ }
+} else {
+ net_shared_sources -= [
+ "cert/ct_log_verifier_openssl.cc",
+ "cert/ct_objects_extractor_openssl.cc",
+ "cert/jwk_serializer_openssl.cc",
+ "cert/x509_util_openssl.cc",
+ "cert/x509_util_openssl.h",
+ "quic/crypto/aead_base_decrypter_openssl.cc",
+ "quic/crypto/aead_base_encrypter_openssl.cc",
+ "quic/crypto/aes_128_gcm_12_decrypter_openssl.cc",
+ "quic/crypto/aes_128_gcm_12_encrypter_openssl.cc",
+ "quic/crypto/chacha20_poly1305_decrypter_openssl.cc",
+ "quic/crypto/chacha20_poly1305_encrypter_openssl.cc",
+ "quic/crypto/channel_id_openssl.cc",
+ "quic/crypto/p256_key_exchange_openssl.cc",
+ "quic/crypto/scoped_evp_aead_ctx.cc",
+ "quic/crypto/scoped_evp_aead_ctx.h",
+ "socket/ssl_client_socket_openssl.cc",
+ "socket/ssl_client_socket_openssl.h",
+ "socket/ssl_server_socket_openssl.cc",
+ "socket/ssl_server_socket_openssl.h",
+ "ssl/openssl_ssl_util.cc",
+ "ssl/openssl_ssl_util.h",
+ "ssl/ssl_client_session_cache_openssl.cc",
+ "ssl/ssl_client_session_cache_openssl.h",
+ "ssl/ssl_platform_key.h",
+ "ssl/threaded_ssl_private_key.cc",
+ "ssl/threaded_ssl_private_key.h",
+ ]
+ if (is_mac) {
+ net_shared_sources -= [ "ssl/ssl_platform_key_mac.cc" ]
}
-
- if (is_linux) {
- configs += [ "//build/config/linux:libresolv" ]
+ if (is_android) {
+ net_shared_sources -= [ "ssl/ssl_platform_key_android.cc" ]
}
-
- if (!use_nss_certs) {
- sources -= [
- "base/crypto_module_nss.cc",
- "base/keygen_handler_nss.cc",
- "cert/cert_database_nss.cc",
- "cert/nss_cert_database.cc",
- "cert/nss_cert_database.h",
- "cert/x509_certificate_nss.cc",
- "ssl/client_cert_store_nss.cc",
- "ssl/client_cert_store_nss.h",
- "third_party/mozilla_security_manager/nsKeygenHandler.cpp",
- "third_party/mozilla_security_manager/nsKeygenHandler.h",
- "third_party/mozilla_security_manager/nsNSSCertificateDB.cpp",
- "third_party/mozilla_security_manager/nsNSSCertificateDB.h",
- "third_party/mozilla_security_manager/nsPKCS12Blob.cpp",
- "third_party/mozilla_security_manager/nsPKCS12Blob.h",
- ]
- if (!is_ios) {
- # These files are part of the partial implementation of NSS on iOS so
- # keep them in that case (even though use_nss_certs is not set).
- sources -= [
- "cert/cert_verify_proc_nss.cc",
- "cert/cert_verify_proc_nss.h",
- "cert/test_root_certs_nss.cc",
- "cert/x509_util_nss_certs.cc",
- "cert_net/nss_ocsp.cc",
- "cert_net/nss_ocsp.h",
- ]
- }
- if (is_chromeos) {
- # These were already removed on non-ChromeOS.
- sources -= [
- "cert/nss_cert_database_chromeos.cc",
- "cert/nss_cert_database_chromeos.h",
- "cert/nss_profile_filter_chromeos.cc",
- "cert/nss_profile_filter_chromeos.h",
- ]
- }
- sources -= [
+ if (is_win) {
+ net_shared_sources -= [
+ "cert/sha256_legacy_support_openssl_win.cc",
+ "ssl/ssl_platform_key_win.cc",
+ ]
+ }
+ if (use_nss_certs) {
+ net_shared_sources -= [
"ssl/client_key_store.cc",
"ssl/client_key_store.h",
"ssl/ssl_platform_key_nss.cc",
]
- } else if (use_openssl) {
- # client_cert_store_nss.c requires NSS_CmpCertChainWCANames from NSS's
- # libssl, but our bundled copy is not built in OpenSSL ports. Pull that file
- # in directly.
- sources += [ "third_party/nss/ssl/cmpcert.c" ]
}
+}
- if (!enable_websockets) {
- sources -= [
- "websockets/websocket_basic_handshake_stream.cc",
- "websockets/websocket_basic_handshake_stream.h",
- "websockets/websocket_basic_stream.cc",
- "websockets/websocket_basic_stream.h",
- "websockets/websocket_channel.cc",
- "websockets/websocket_channel.h",
- "websockets/websocket_deflate_predictor.h",
- "websockets/websocket_deflate_predictor_impl.cc",
- "websockets/websocket_deflate_predictor_impl.h",
- "websockets/websocket_deflate_stream.cc",
- "websockets/websocket_deflate_stream.h",
- "websockets/websocket_deflater.cc",
- "websockets/websocket_deflater.h",
- "websockets/websocket_errors.cc",
- "websockets/websocket_errors.h",
- "websockets/websocket_extension.cc",
- "websockets/websocket_extension.h",
- "websockets/websocket_extension_parser.cc",
- "websockets/websocket_extension_parser.h",
- "websockets/websocket_frame.cc",
- "websockets/websocket_frame.h",
- "websockets/websocket_frame_parser.cc",
- "websockets/websocket_frame_parser.h",
- "websockets/websocket_handshake_challenge.cc",
- "websockets/websocket_handshake_challenge.h",
- "websockets/websocket_handshake_constants.cc",
- "websockets/websocket_handshake_constants.h",
- "websockets/websocket_handshake_request_info.cc",
- "websockets/websocket_handshake_request_info.h",
- "websockets/websocket_handshake_response_info.cc",
- "websockets/websocket_handshake_response_info.h",
- "websockets/websocket_handshake_stream_base.h",
- "websockets/websocket_handshake_stream_create_helper.cc",
- "websockets/websocket_handshake_stream_create_helper.h",
- "websockets/websocket_inflater.cc",
- "websockets/websocket_inflater.h",
- "websockets/websocket_mux.h",
- "websockets/websocket_stream.cc",
- "websockets/websocket_stream.h",
- ]
+if (!use_openssl_certs) {
+ net_shared_sources -= [
+ "base/crypto_module_openssl.cc",
+ "base/keygen_handler_openssl.cc",
+ "base/openssl_private_key_store.h",
+ "base/openssl_private_key_store_memory.cc",
+ "cert/cert_database_openssl.cc",
+ "cert/cert_verify_proc_openssl.cc",
+ "cert/cert_verify_proc_openssl.h",
+ "cert/test_root_certs_openssl.cc",
+ "cert/x509_certificate_openssl.cc",
+ "ssl/openssl_client_key_store.cc",
+ "ssl/openssl_client_key_store.h",
+ ]
+ if (is_android) {
+ net_shared_sources -= [ "base/openssl_private_key_store_android.cc" ]
}
-
- if (!enable_mdns) {
- sources -= [
- "dns/mdns_cache.cc",
- "dns/mdns_cache.h",
- "dns/mdns_client.cc",
- "dns/mdns_client.h",
- "dns/mdns_client_impl.cc",
- "dns/mdns_client_impl.h",
- "dns/record_parsed.cc",
- "dns/record_parsed.h",
- "dns/record_rdata.cc",
- "dns/record_rdata.h",
+} else {
+ if (is_android) {
+ # Android doesn't use these even when using OpenSSL.
+ net_shared_sources -= [
+ "base/openssl_private_key_store_memory.cc",
+ "cert/cert_database_openssl.cc",
+ "cert/cert_verify_proc_openssl.cc",
+ "cert/test_root_certs_openssl.cc",
]
}
+}
- if (is_win) {
- sources -= [
- "http/http_auth_handler_ntlm_portable.cc",
- "socket/socket_libevent.cc",
- "socket/socket_libevent.h",
- "socket/tcp_socket_libevent.cc",
- "socket/tcp_socket_libevent.h",
- "udp/udp_socket_libevent.cc",
- "udp/udp_socket_libevent.h",
- ]
- } else { # !is_win
- sources -= [
- "base/winsock_init.cc",
- "base/winsock_init.h",
- "base/winsock_util.cc",
- "base/winsock_util.h",
- "proxy/proxy_resolver_winhttp.cc",
- "proxy/proxy_resolver_winhttp.h",
+if (use_glib && !is_chromeos) {
+ net_shared_configs += [ "//build/config/linux:gconf" ]
+ net_shared_deps += [ "//build/linux:gio" ]
+}
+
+if (is_linux) {
+ net_shared_configs += [ "//build/config/linux:libresolv" ]
+}
+
+if (!use_nss_certs) {
+ net_shared_sources -= [
+ "base/crypto_module_nss.cc",
+ "base/keygen_handler_nss.cc",
+ "cert/cert_database_nss.cc",
+ "cert/nss_cert_database.cc",
+ "cert/nss_cert_database.h",
+ "cert/x509_certificate_nss.cc",
+ "ssl/client_cert_store_nss.cc",
+ "ssl/client_cert_store_nss.h",
+ "third_party/mozilla_security_manager/nsKeygenHandler.cpp",
+ "third_party/mozilla_security_manager/nsKeygenHandler.h",
+ "third_party/mozilla_security_manager/nsNSSCertificateDB.cpp",
+ "third_party/mozilla_security_manager/nsNSSCertificateDB.h",
+ "third_party/mozilla_security_manager/nsPKCS12Blob.cpp",
+ "third_party/mozilla_security_manager/nsPKCS12Blob.h",
+ ]
+ if (!is_ios) {
+ # These files are part of the partial implementation of NSS on iOS so
+ # keep them in that case (even though use_nss_certs is not set).
+ net_shared_sources -= [
+ "cert/cert_verify_proc_nss.cc",
+ "cert/cert_verify_proc_nss.h",
+ "cert/test_root_certs_nss.cc",
+ "cert/x509_util_nss_certs.cc",
+ "cert_net/nss_ocsp.cc",
+ "cert_net/nss_ocsp.h",
]
}
+ if (is_chromeos) {
+ # These were already removed on non-ChromeOS.
+ net_shared_sources -= [
+ "cert/nss_cert_database_chromeos.cc",
+ "cert/nss_cert_database_chromeos.h",
+ "cert/nss_profile_filter_chromeos.cc",
+ "cert/nss_profile_filter_chromeos.h",
+ ]
+ }
+ net_shared_sources -= [
+ "ssl/client_key_store.cc",
+ "ssl/client_key_store.h",
+ "ssl/ssl_platform_key_nss.cc",
+ ]
+} else if (use_openssl) {
+ # client_cert_store_nss.c requires NSS_CmpCertChainWCANames from NSS's
+ # libssl, but our bundled copy is not built in OpenSSL ports. Pull that file
+ # in directly.
+ net_shared_sources += [ "third_party/nss/ssl/cmpcert.c" ]
+}
+
+if (!enable_mdns) {
+ net_shared_sources -= [
+ "dns/mdns_cache.cc",
+ "dns/mdns_cache.h",
+ "dns/mdns_client.cc",
+ "dns/mdns_client.h",
+ "dns/mdns_client_impl.cc",
+ "dns/mdns_client_impl.h",
+ "dns/record_parsed.cc",
+ "dns/record_parsed.h",
+ "dns/record_rdata.cc",
+ "dns/record_rdata.h",
+ ]
+}
+
+if (is_win) {
+ net_shared_sources -= [
+ "http/http_auth_handler_ntlm_portable.cc",
+ "socket/socket_libevent.cc",
+ "socket/socket_libevent.h",
+ "socket/tcp_socket_libevent.cc",
+ "socket/tcp_socket_libevent.h",
+ "udp/udp_socket_libevent.cc",
+ "udp/udp_socket_libevent.h",
+ ]
+} else { # !is_win
+ net_shared_sources -= [
+ "base/winsock_init.cc",
+ "base/winsock_init.h",
+ "base/winsock_util.cc",
+ "base/winsock_util.h",
+ "proxy/proxy_resolver_winhttp.cc",
+ "proxy/proxy_resolver_winhttp.h",
+ ]
+}
+
+if (is_ios) {
+ # Add back some sources that were otherwise filtered out. iOS needs some Mac
+ # files.
+ net_shared_unfiltered_sources += [
+ "base/mac/url_conversions.h",
+ "base/mac/url_conversions.mm",
+ "base/network_change_notifier_mac.cc",
+ "base/network_config_watcher_mac.cc",
+ "base/network_interfaces_mac.cc",
+ "base/network_interfaces_mac.h",
+ "base/platform_mime_util_mac.mm",
+ "proxy/proxy_resolver_mac.cc",
+ "proxy/proxy_server_mac.cc",
+ ]
+
+ net_shared_sources -= [ "disk_cache/blockfile/file_posix.cc" ]
+ net_shared_deps += [
+ "//third_party/nss:nspr",
+ "//third_party/nss",
+ "//net/third_party/nss/ssl:libssl",
+ ]
+}
+
+if (is_ios || is_mac) {
+ net_shared_sources += gypi_values.net_base_mac_ios_sources
+}
+
+if (is_android) {
+ net_shared_deps += [ ":net_jni_headers" ]
+
+ # Add some Linux sources that were excluded by the filter, but which
+ # are needed.
+ net_shared_unfiltered_sources += [
+ "base/address_tracker_linux.cc",
+ "base/address_tracker_linux.h",
+ "base/network_interfaces_linux.cc",
+ "base/network_interfaces_linux.h",
+ "base/platform_mime_util_linux.cc",
+ ]
+}
+
+component("net") {
+ sources = net_shared_sources
+
+ # Add back some sources that were otherwise filtered out.
+ set_sources_assignment_filter([])
+ sources += net_shared_unfiltered_sources
+ set_sources_assignment_filter(sources_assignment_filter)
+
+ cflags = []
+ configs += net_shared_configs
+ public_configs = [ ":net_config" ]
+
+ public_deps = net_shared_public_deps + [ "//url" ]
+ deps = net_shared_deps
if (is_mac) {
libs = [
@@ -455,23 +420,6 @@ component("net") {
}
if (is_ios) {
- # Add back some sources that were otherwise filtered out. iOS needs some Mac
- # files.
- set_sources_assignment_filter([])
- sources += [
- "base/mac/url_conversions.h",
- "base/mac/url_conversions.mm",
- "base/network_change_notifier_mac.cc",
- "base/network_config_watcher_mac.cc",
- "base/network_interfaces_mac.cc",
- "base/network_interfaces_mac.h",
- "base/platform_mime_util_mac.mm",
- "proxy/proxy_resolver_mac.cc",
- "proxy/proxy_server_mac.cc",
- ]
- set_sources_assignment_filter(sources_assignment_filter)
-
- sources -= [ "disk_cache/blockfile/file_posix.cc" ]
libs = [
"CFNetwork.framework",
"MobileCoreServices.framework",
@@ -479,48 +427,62 @@ component("net") {
"SystemConfiguration.framework",
"resolv",
]
+ }
- deps += [
- "//third_party/nss:nspr",
- "//third_party/nss",
- "//net/third_party/nss/ssl:libssl",
- ]
+ if (!disable_file_support) {
+ sources += gypi_values.net_file_support_sources
}
- if (is_ios || is_mac) {
- sources += gypi_values.net_base_mac_ios_sources
+ if (!disable_ftp_support) {
+ sources += gypi_values.net_ftp_support_sources
}
- if (is_android) {
- # Add some Linux sources that were excluded by the filter, but which
- # are needed.
+ if (enable_websockets) {
+ sources += gypi_values.net_websockets_sources
+ }
+
+ # ICU support.
+ deps += [
+ "//base:i18n",
+ "//third_party/icu",
+ ]
+ sources += [
+ "base/filename_util_icu.cc",
+ "base/net_string_util_icu.cc",
+ "base/net_util_icu.cc",
+ ]
+}
+
+if (is_android) {
+ # Same as net, but with ICU, file, ftp, and websocket support stripped.
+ component("net_small") {
+ sources = net_shared_sources
+
+ # Add back some sources that were otherwise filtered out.
set_sources_assignment_filter([])
- sources += [
- "base/address_tracker_linux.cc",
- "base/address_tracker_linux.h",
- "base/network_interfaces_linux.cc",
- "base/network_interfaces_linux.h",
- "base/platform_mime_util_linux.cc",
- ]
+ sources += net_shared_unfiltered_sources
set_sources_assignment_filter(sources_assignment_filter)
- deps += [ ":net_jni_headers" ]
- }
- if (use_icu_alternatives_on_android) {
+ cflags = []
+ defines = []
+ configs += net_shared_configs
+ public_configs = [ ":net_config" ]
+
+ public_deps = net_shared_public_deps +
+ [ "//url:url_lib_use_icu_alternatives_on_android" ]
+ deps = net_shared_deps + [ ":net_jni_headers" ]
+
+ defines += [
+ "DISABLE_FILE_SUPPORT",
+ "DISABLE_FTP_SUPPORT",
+ "USE_ICU_ALTERNATIVES_ON_ANDROID=1",
+ ]
+
+ # Use ICU alternative on Android.
sources += [
"base/net_string_util_icu_alternatives_android.cc",
"base/net_string_util_icu_alternatives_android.h",
]
- } else {
- deps += [
- "//base:i18n",
- "//third_party/icu",
- ]
- sources += [
- "base/filename_util_icu.cc",
- "base/net_string_util_icu.cc",
- "base/net_util_icu.cc",
- ]
}
}
@@ -534,7 +496,10 @@ grit("net_resources") {
}
proto_library("net_quic_proto") {
- visibility = [ "//net" ] # Part of the net component.
+ visibility = [
+ ":net",
+ ":net_small",
+ ]
sources = [
"quic/proto/cached_network_parameters.proto",
@@ -1011,16 +976,12 @@ if (!is_ios && !is_android) {
]
if (is_desktop_linux) {
+ configs += [
+ "//build/config/linux:gconf",
+ "//build/config/linux:glib",
+ ]
deps += [ "//build/linux:gio" ]
}
-
- if (use_gconf) {
- configs += [ "//build/config/linux:gconf" ]
- }
-
- if (use_glib) {
- configs += [ "//build/config/linux:glib" ]
- }
}
}
@@ -1230,6 +1191,7 @@ if (is_android) {
"android/java/src/org/chromium/net/AndroidPrivateKey.java",
"android/java/src/org/chromium/net/GURLUtils.java",
"android/java/src/org/chromium/net/HttpNegotiateAuthenticator.java",
+ "android/java/src/org/chromium/net/NetStringUtil.java",
"android/java/src/org/chromium/net/NetworkChangeNotifier.java",
"android/java/src/org/chromium/net/ProxyChangeListener.java",
"android/java/src/org/chromium/net/X509Util.java",
@@ -1366,6 +1328,7 @@ test("net_unittests") {
"//crypto",
"//crypto:platform",
"//crypto:test_support",
+ "//gin",
"//net/base/registry_controlled_domains",
"//sql",
"//testing/gmock",
@@ -1374,9 +1337,6 @@ test("net_unittests") {
"//url",
]
- if (!is_ios) {
- deps += [ "//gin" ]
- }
data = [
"data/",
]
@@ -1518,8 +1478,6 @@ test("net_unittests") {
"ftp/ftp_auth_cache_unittest.cc",
"ftp/ftp_ctrl_response_buffer_unittest.cc",
"ftp/ftp_directory_listing_parser_ls_unittest.cc",
- "ftp/ftp_directory_listing_parser_netware_unittest.cc",
- "ftp/ftp_directory_listing_parser_os2_unittest.cc",
"ftp/ftp_directory_listing_parser_unittest.cc",
"ftp/ftp_directory_listing_parser_unittest.h",
"ftp/ftp_directory_listing_parser_vms_unittest.cc",
@@ -1537,10 +1495,7 @@ test("net_unittests") {
]
}
- # Always need use_v8_in_net to be 1 to run on Android, so just remove
- # net_unittest's dependency on v8 when using icu alternatives instead of
- # setting use_v8_in_net to 0.
- if (use_v8_in_net && !use_icu_alternatives_on_android) {
+ if (use_v8_in_net) {
deps += [ ":net_with_v8" ]
} else {
sources -= [
@@ -1649,14 +1604,6 @@ test("net_unittests") {
isolate_file = "net_unittests.isolate"
}
- if (use_icu_alternatives_on_android) {
- sources -= [
- "base/filename_util_unittest.cc",
- "base/net_util_icu_unittest.cc",
- ]
- deps -= [ "//base:i18n" ]
- }
-
# Symbols for crashes when running tests on swarming.
if (symbol_level > 0) {
if (is_win) {
diff --git a/net/net.gypi b/net/net.gypi
index 18d016b..bebcaee 100644
--- a/net/net.gypi
+++ b/net/net.gypi
@@ -427,8 +427,6 @@
'base/crypto_module_openssl.cc',
'base/data_url.cc',
'base/data_url.h',
- 'base/directory_lister.cc',
- 'base/directory_lister.h',
'base/dns_reloader.cc',
'base/dns_reloader.h',
'base/elements_upload_data_stream.cc',
@@ -807,33 +805,6 @@
'filter/gzip_header.h',
'filter/sdch_filter.cc',
'filter/sdch_filter.h',
- 'ftp/ftp_auth_cache.cc',
- 'ftp/ftp_auth_cache.h',
- 'ftp/ftp_ctrl_response_buffer.cc',
- 'ftp/ftp_ctrl_response_buffer.h',
- 'ftp/ftp_directory_listing_parser.cc',
- 'ftp/ftp_directory_listing_parser.h',
- 'ftp/ftp_directory_listing_parser_ls.cc',
- 'ftp/ftp_directory_listing_parser_ls.h',
- 'ftp/ftp_directory_listing_parser_vms.cc',
- 'ftp/ftp_directory_listing_parser_vms.h',
- 'ftp/ftp_directory_listing_parser_windows.cc',
- 'ftp/ftp_directory_listing_parser_windows.h',
- 'ftp/ftp_network_layer.cc',
- 'ftp/ftp_network_layer.h',
- 'ftp/ftp_network_session.cc',
- 'ftp/ftp_network_session.h',
- 'ftp/ftp_network_transaction.cc',
- 'ftp/ftp_network_transaction.h',
- 'ftp/ftp_request_info.h',
- 'ftp/ftp_response_info.cc',
- 'ftp/ftp_response_info.h',
- 'ftp/ftp_server_type_histograms.cc',
- 'ftp/ftp_server_type_histograms.h',
- 'ftp/ftp_transaction.h',
- 'ftp/ftp_transaction_factory.h',
- 'ftp/ftp_util.cc',
- 'ftp/ftp_util.h',
'http/des.cc',
'http/des.h',
'http/disk_based_cert_cache.cc',
@@ -1184,10 +1155,6 @@
'url_request/certificate_report_sender.h',
'url_request/data_protocol_handler.cc',
'url_request/data_protocol_handler.h',
- 'url_request/file_protocol_handler.cc',
- 'url_request/file_protocol_handler.h',
- 'url_request/ftp_protocol_handler.cc',
- 'url_request/ftp_protocol_handler.h',
'url_request/http_user_agent_settings.h',
'url_request/redirect_info.cc',
'url_request/redirect_info.h',
@@ -1223,14 +1190,8 @@
'url_request/url_request_data_job.h',
'url_request/url_request_error_job.cc',
'url_request/url_request_error_job.h',
- 'url_request/url_request_file_dir_job.cc',
- 'url_request/url_request_file_dir_job.h',
- 'url_request/url_request_file_job.cc',
- 'url_request/url_request_file_job.h',
'url_request/url_request_filter.cc',
'url_request/url_request_filter.h',
- 'url_request/url_request_ftp_job.cc',
- 'url_request/url_request_ftp_job.h',
'url_request/url_request_http_job.cc',
'url_request/url_request_http_job.h',
'url_request/url_request_intercepting_job_factory.cc',
@@ -1266,45 +1227,6 @@
'url_request/view_cache_helper.h',
'url_request/websocket_handshake_userdata_key.cc',
'url_request/websocket_handshake_userdata_key.h',
- 'websockets/websocket_basic_handshake_stream.cc',
- 'websockets/websocket_basic_handshake_stream.h',
- 'websockets/websocket_basic_stream.cc',
- 'websockets/websocket_basic_stream.h',
- 'websockets/websocket_channel.cc',
- 'websockets/websocket_channel.h',
- 'websockets/websocket_deflate_predictor.h',
- 'websockets/websocket_deflate_predictor_impl.cc',
- 'websockets/websocket_deflate_predictor_impl.h',
- 'websockets/websocket_deflate_stream.cc',
- 'websockets/websocket_deflate_stream.h',
- 'websockets/websocket_deflater.cc',
- 'websockets/websocket_deflater.h',
- 'websockets/websocket_errors.cc',
- 'websockets/websocket_errors.h',
- 'websockets/websocket_extension.cc',
- 'websockets/websocket_extension.h',
- 'websockets/websocket_extension_parser.cc',
- 'websockets/websocket_extension_parser.h',
- 'websockets/websocket_frame.cc',
- 'websockets/websocket_frame.h',
- 'websockets/websocket_frame_parser.cc',
- 'websockets/websocket_frame_parser.h',
- 'websockets/websocket_handshake_challenge.cc',
- 'websockets/websocket_handshake_challenge.h',
- 'websockets/websocket_handshake_constants.cc',
- 'websockets/websocket_handshake_constants.h',
- 'websockets/websocket_handshake_request_info.cc',
- 'websockets/websocket_handshake_request_info.h',
- 'websockets/websocket_handshake_response_info.cc',
- 'websockets/websocket_handshake_response_info.h',
- 'websockets/websocket_handshake_stream_base.h',
- 'websockets/websocket_handshake_stream_create_helper.cc',
- 'websockets/websocket_handshake_stream_create_helper.h',
- 'websockets/websocket_inflater.cc',
- 'websockets/websocket_inflater.h',
- 'websockets/websocket_mux.h',
- 'websockets/websocket_stream.cc',
- 'websockets/websocket_stream.h',
],
'net_extras_sources': [
'extras/sqlite/cookie_crypto_delegate.h',
@@ -1867,6 +1789,90 @@
'net_base_test_mac_ios_sources': [
'base/mac/url_conversions_unittest.mm',
],
+ 'net_file_support_sources': [
+ "base/directory_lister.cc",
+ "base/directory_lister.h",
+ "url_request/file_protocol_handler.cc",
+ "url_request/file_protocol_handler.h",
+ "url_request/url_request_file_dir_job.cc",
+ "url_request/url_request_file_dir_job.h",
+ "url_request/url_request_file_job.cc",
+ "url_request/url_request_file_job.h",
+ ],
+ 'net_ftp_support_sources': [
+ "ftp/ftp_auth_cache.cc",
+ "ftp/ftp_auth_cache.h",
+ "ftp/ftp_ctrl_response_buffer.cc",
+ "ftp/ftp_ctrl_response_buffer.h",
+ "ftp/ftp_directory_listing_parser.cc",
+ "ftp/ftp_directory_listing_parser.h",
+ "ftp/ftp_directory_listing_parser_ls.cc",
+ "ftp/ftp_directory_listing_parser_ls.h",
+ "ftp/ftp_directory_listing_parser_vms.cc",
+ "ftp/ftp_directory_listing_parser_vms.h",
+ "ftp/ftp_directory_listing_parser_windows.cc",
+ "ftp/ftp_directory_listing_parser_windows.h",
+ "ftp/ftp_network_layer.cc",
+ "ftp/ftp_network_layer.h",
+ "ftp/ftp_network_session.cc",
+ "ftp/ftp_network_session.h",
+ "ftp/ftp_network_transaction.cc",
+ "ftp/ftp_network_transaction.h",
+ "ftp/ftp_request_info.h",
+ "ftp/ftp_response_info.cc",
+ "ftp/ftp_response_info.h",
+ "ftp/ftp_server_type_histograms.cc",
+ "ftp/ftp_server_type_histograms.h",
+ "ftp/ftp_transaction.h",
+ "ftp/ftp_transaction_factory.h",
+ "ftp/ftp_util.cc",
+ "ftp/ftp_util.h",
+ "url_request/ftp_protocol_handler.cc",
+ "url_request/ftp_protocol_handler.h",
+ "url_request/url_request_ftp_job.cc",
+ "url_request/url_request_ftp_job.h",
+ ],
+ 'net_websockets_sources': [
+ "websockets/websocket_basic_handshake_stream.cc",
+ "websockets/websocket_basic_handshake_stream.h",
+ "websockets/websocket_basic_stream.cc",
+ "websockets/websocket_basic_stream.h",
+ "websockets/websocket_channel.cc",
+ "websockets/websocket_channel.h",
+ "websockets/websocket_deflate_predictor.h",
+ "websockets/websocket_deflate_predictor_impl.cc",
+ "websockets/websocket_deflate_predictor_impl.h",
+ "websockets/websocket_deflate_stream.cc",
+ "websockets/websocket_deflate_stream.h",
+ "websockets/websocket_deflater.cc",
+ "websockets/websocket_deflater.h",
+ "websockets/websocket_errors.cc",
+ "websockets/websocket_errors.h",
+ "websockets/websocket_extension.cc",
+ "websockets/websocket_extension.h",
+ "websockets/websocket_extension_parser.cc",
+ "websockets/websocket_extension_parser.h",
+ "websockets/websocket_frame.cc",
+ "websockets/websocket_frame.h",
+ "websockets/websocket_frame_parser.cc",
+ "websockets/websocket_frame_parser.h",
+ "websockets/websocket_handshake_challenge.cc",
+ "websockets/websocket_handshake_challenge.h",
+ "websockets/websocket_handshake_constants.cc",
+ "websockets/websocket_handshake_constants.h",
+ "websockets/websocket_handshake_request_info.cc",
+ "websockets/websocket_handshake_request_info.h",
+ "websockets/websocket_handshake_response_info.cc",
+ "websockets/websocket_handshake_response_info.h",
+ "websockets/websocket_handshake_stream_base.h",
+ "websockets/websocket_handshake_stream_create_helper.cc",
+ "websockets/websocket_handshake_stream_create_helper.h",
+ "websockets/websocket_inflater.cc",
+ "websockets/websocket_inflater.h",
+ "websockets/websocket_mux.h",
+ "websockets/websocket_stream.cc",
+ "websockets/websocket_stream.h",
+ ],
'net_docs_script': 'tools/net_docs/net_docs.py',
'net_docs_sources': [
'README.md',
diff --git a/net/net_common.gypi b/net/net_common.gypi
index 6aac566..38510d1d 100644
--- a/net/net_common.gypi
+++ b/net/net_common.gypi
@@ -86,31 +86,14 @@
'disk_cache/blockfile/mapped_file_avoid_mmap_posix.cc',
],
}],
- ['disable_file_support==1', {
+ ['disable_file_support!=1', {
# TODO(mmenke): Should probably get rid of the dependency on
# net_resources in this case (It's used in net_util, to format
# directory listings. Also used outside of net/).
- 'sources!': [
- 'base/directory_lister.cc',
- 'base/directory_lister.h',
- 'url_request/file_protocol_handler.cc',
- 'url_request/file_protocol_handler.h',
- 'url_request/url_request_file_dir_job.cc',
- 'url_request/url_request_file_dir_job.h',
- 'url_request/url_request_file_job.cc',
- 'url_request/url_request_file_job.h',
- ],
+ 'sources': ['<@(net_file_support_sources)']
}],
- ['disable_ftp_support==1', {
- 'sources/': [
- ['exclude', '^ftp/'],
- ],
- 'sources!': [
- 'url_request/ftp_protocol_handler.cc',
- 'url_request/ftp_protocol_handler.h',
- 'url_request/url_request_ftp_job.cc',
- 'url_request/url_request_ftp_job.h',
- ],
+ ['disable_ftp_support!=1', {
+ 'sources': ['<@(net_ftp_support_sources)']
}],
['enable_built_in_dns==1', {
'defines': [
@@ -293,10 +276,8 @@
'third_party/nss/ssl/cmpcert.c',
],
}],
- [ 'enable_websockets != 1', {
- 'sources/': [
- ['exclude', '^websockets/'],
- ],
+ [ 'enable_websockets == 1', {
+ 'sources': ['<@(net_websockets_sources)']
}],
[ 'enable_mdns != 1', {
'sources!' : [
diff --git a/url/BUILD.gn b/url/BUILD.gn
index 34dff8a..7cedd40 100644
--- a/url/BUILD.gn
+++ b/url/BUILD.gn
@@ -3,66 +3,62 @@
# found in the LICENSE file.
import("//testing/test.gni")
-import("//url/config.gni")
-# Sets the USE_ICU_ALTERNATIVES_ON_ANDROID define based on the build flag.
-config("url_icu_config") {
- if (use_icu_alternatives_on_android) {
- defines = [ "USE_ICU_ALTERNATIVES_ON_ANDROID=1" ]
- }
+if (is_android) {
+ import("//build/config/android/rules.gni")
}
+# Shared sources between url and url_lib_use_icu_alternatives_on_android.
+url_shared_sources = [
+ "gurl.cc",
+ "gurl.h",
+ "origin.cc",
+ "origin.h",
+ "scheme_host_port.cc",
+ "scheme_host_port.h",
+ "third_party/mozilla/url_parse.cc",
+ "third_party/mozilla/url_parse.h",
+ "url_canon.h",
+ "url_canon_etc.cc",
+ "url_canon_filesystemurl.cc",
+ "url_canon_fileurl.cc",
+ "url_canon_host.cc",
+ "url_canon_internal.cc",
+ "url_canon_internal.h",
+ "url_canon_internal_file.h",
+ "url_canon_ip.cc",
+ "url_canon_ip.h",
+ "url_canon_mailtourl.cc",
+ "url_canon_path.cc",
+ "url_canon_pathurl.cc",
+ "url_canon_query.cc",
+ "url_canon_relative.cc",
+ "url_canon_stdstring.cc",
+ "url_canon_stdstring.h",
+ "url_canon_stdurl.cc",
+ "url_constants.cc",
+ "url_constants.h",
+ "url_export.h",
+ "url_file.h",
+ "url_parse_file.cc",
+ "url_parse_internal.h",
+ "url_util.cc",
+ "url_util.h",
+]
+
component("url") {
+ sources = url_shared_sources + [
+ "url_canon_icu.cc",
+ "url_canon_icu.h",
+ ]
+
if (is_win) {
# Don't conflict with Windows' "url.dll".
output_name = "url_lib"
}
- sources = [
- "android/url_jni_registrar.cc",
- "android/url_jni_registrar.h",
- "gurl.cc",
- "gurl.h",
- "origin.cc",
- "origin.h",
- "scheme_host_port.cc",
- "scheme_host_port.h",
- "third_party/mozilla/url_parse.cc",
- "third_party/mozilla/url_parse.h",
- "url_canon.h",
- "url_canon_etc.cc",
- "url_canon_filesystemurl.cc",
- "url_canon_fileurl.cc",
- "url_canon_host.cc",
- "url_canon_icu.cc",
- "url_canon_icu.h",
- "url_canon_internal.cc",
- "url_canon_internal.h",
- "url_canon_internal_file.h",
- "url_canon_ip.cc",
- "url_canon_ip.h",
- "url_canon_mailtourl.cc",
- "url_canon_path.cc",
- "url_canon_pathurl.cc",
- "url_canon_query.cc",
- "url_canon_relative.cc",
- "url_canon_stdstring.cc",
- "url_canon_stdstring.h",
- "url_canon_stdurl.cc",
- "url_constants.cc",
- "url_constants.h",
- "url_export.h",
- "url_file.h",
- "url_parse_file.cc",
- "url_parse_internal.h",
- "url_util.cc",
- "url_util.h",
- ]
-
defines = [ "URL_IMPLEMENTATION" ]
configs += [
- ":url_icu_config",
-
# TODO(jschuh): crbug.com/167187 fix size_t to int truncations.
"//build/config/compiler:no_size_t_to_int_warning",
]
@@ -73,20 +69,38 @@ component("url") {
"//third_party/icu:icudata",
"//third_party/icu",
]
+}
+
+if (is_android) {
+ generate_jni("url_jni_headers") {
+ sources = [
+ "android/java/src/org/chromium/url/IDNStringUtil.java",
+ ]
+ jni_package = "url"
+ }
+
+ component("url_lib_use_icu_alternatives_on_android") {
+ sources = url_shared_sources + [
+ "android/url_jni_registrar.cc",
+ "android/url_jni_registrar.h",
+ "url_canon_icu_alternatives_android.cc",
+ "url_canon_icu_alternatives_android.h",
+ ]
- if (use_icu_alternatives_on_android) {
- sources -= [
- "url_canon_icu.cc",
- "url_canon_icu.h",
+ defines = [
+ "URL_IMPLEMENTATION",
+ "USE_ICU_ALTERNATIVES_ON_ANDROID=1",
]
- deps -= [
- "//third_party/icu:icudata",
- "//third_party/icu",
+
+ configs += [
+ # TODO(jschuh): crbug.com/167187 fix size_t to int truncations.
+ "//build/config/compiler:no_size_t_to_int_warning",
]
- sources += [
- "url_canon_icu_alternatives_android.cc",
- "url_canon_icu_alternatives_android.h",
+ deps = [
+ ":url_jni_headers",
+ "//base",
+ "//base/third_party/dynamic_annotations",
]
}
}
@@ -130,10 +144,5 @@ if (!is_android) {
"//testing/gtest",
"//third_party/icu:icuuc",
]
-
- if (use_icu_alternatives_on_android) {
- sources -= [ "url_canon_icu_unittest.cc" ]
- deps -= [ "//third_party/icu:icuuc" ]
- }
}
}
diff --git a/url/config.gni b/url/config.gni
deleted file mode 100644
index 42d335f..0000000
--- a/url/config.gni
+++ /dev/null
@@ -1,8 +0,0 @@
-# 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.
-
-declare_args() {
- # Switches to using platform functions instead of ICU on Android.
- use_icu_alternatives_on_android = false
-}