| Index: build/config/features.gni
|
| diff --git a/build/config/features.gni b/build/config/features.gni
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..93b19dd1431ca78ff2932a33f12c9d8ef7f294d9
|
| --- /dev/null
|
| +++ b/build/config/features.gni
|
| @@ -0,0 +1,204 @@
|
| +# 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.
|
| +
|
| +# This file contains Chrome-feature-related build flags (see ui.gni for
|
| +# UI-related ones). These should theoretically be moved to the build files of
|
| +# the features themselves.
|
| +#
|
| +# However, today we have many "bad" dependencies on some of these flags from,
|
| +# e.g. base, so they need to be global to match the GYP configuration. Also,
|
| +# anything that needs a grit define must be in either this file or ui.gni.
|
| +#
|
| +# PLEASE TRY TO AVOID ADDING FLAGS TO THIS FILE in cases where grit isn't
|
| +# required. See the declare_args block of BUILDCONFIG.gn for advice on how
|
| +# to set up feature flags.
|
| +
|
| +import("//build/config/chrome_build.gni")
|
| +if (is_android) {
|
| + import("//build/config/android/config.gni")
|
| +}
|
| +
|
| +declare_args() {
|
| + # Multicast DNS.
|
| + enable_mdns = is_win || is_linux
|
| +
|
| + enable_plugins = !is_android && !is_ios
|
| +
|
| + # Enables Native Client support.
|
| + # TODO(GYP): Get NaCl linking on other platforms.
|
| + # Also, see if we can always get rid of enable_nacl_untrusted and
|
| + # enable_pnacl and always build them if enable_nacl is true.
|
| + # The "is_nacl" part of the condition is needed to ensure that
|
| + # the untrusted code is built properly; arguably it should be
|
| + # guarded by "is_nacl" directly rather than enable_nacl_untrusted, but
|
| + # this will go away when Mac and Win are working and we can just use
|
| + # the commented out logic.
|
| + # Eventually we want this to be:
|
| + # enable_nacl = !is_ios && !is_android
|
| + enable_nacl = (is_linux && !is_chromeos && current_cpu == "x64") || is_nacl
|
| + enable_nacl_untrusted = enable_nacl
|
| + enable_pnacl = enable_nacl_untrusted
|
| +
|
| + # If debug_devtools is set to true, JavaScript files for DevTools are stored
|
| + # as is and loaded from disk. Otherwise, a concatenated file is stored in
|
| + # resources.pak. It is still possible to load JS files from disk by passing
|
| + # --debug-devtools cmdline switch.
|
| + debug_devtools = false
|
| +
|
| + # Enables WebRTC.
|
| + # TODO(GYP) make mac and android work.
|
| + enable_webrtc = !is_ios && !is_mac && !is_android
|
| +
|
| + # Enables the Media Router.
|
| + enable_media_router = !is_ios && !is_android
|
| +
|
| + # Enables proprietary codecs and demuxers; e.g. H264, MOV, AAC, and MP3.
|
| + # Android OS includes support for proprietary codecs regardless of building
|
| + # Chromium or Google Chrome. We also ship Google Chrome and Chromecast with
|
| + # proprietary codecs.
|
| + # TODO(GYP) The GYP build has || chromecast==1 for this:
|
| + proprietary_codecs = is_android || is_chrome_branded
|
| +
|
| + enable_configuration_policy = true
|
| +
|
| + # Enables support for background apps.
|
| + enable_background = !is_ios && !is_android
|
| +
|
| + enable_captive_portal_detection = !is_android && !is_ios
|
| +
|
| + # Enables use of the session service, which is enabled by default.
|
| + # Android stores them separately on the Java side.
|
| + enable_session_service = !is_android && !is_ios
|
| +
|
| + enable_plugin_installation = is_win || is_mac
|
| +
|
| + enable_app_list = !is_ios && !is_android
|
| +
|
| + enable_supervised_users = !is_ios
|
| +
|
| + enable_autofill_dialog = !is_ios
|
| +
|
| + enable_google_now = !is_ios && !is_android
|
| +
|
| + enable_one_click_signin = is_win || is_mac || (is_linux && !is_chromeos)
|
| +
|
| + enable_remoting = !is_ios && !is_android
|
| +
|
| + # Enable hole punching for the protected video.
|
| + enable_video_hole = is_android
|
| +
|
| + # Enables browser side Content Decryption Modules. Required for embedders
|
| + # (e.g. Android and ChromeCast) that use a browser side CDM.
|
| + enable_browser_cdms = is_android
|
| +
|
| + # Variable safe_browsing is used to control the build time configuration
|
| + # for safe browsing feature. Safe browsing can be compiled in 4 different
|
| + # levels: 0 disables it, 1 enables it fully, and 2 enables only UI and
|
| + # reporting features for use with Data Saver on Mobile, and 3 enables
|
| + # extended mobile protection via an external API. When 3 is fully deployed,
|
| + # it will replace 2.
|
| + if (is_android) {
|
| + safe_browsing_mode = 2
|
| + } else if (is_ios) {
|
| + safe_browsing_mode = 0
|
| + } else {
|
| + safe_browsing_mode = 1
|
| + }
|
| +}
|
| +
|
| +# Additional dependent variables -----------------------------------------------
|
| +
|
| +# Set the version of CLD.
|
| +# 0: Don't specify the version. This option is for the Finch testing.
|
| +# 1: Use only CLD1.
|
| +# 2: Use only CLD2.
|
| +if (is_android) {
|
| + cld_version = 1
|
| +} else {
|
| + cld_version = 2
|
| +}
|
| +
|
| +# libudev usage. This currently only affects the content layer.
|
| +use_udev = is_linux
|
| +
|
| +# Enable the spell checker.
|
| +enable_spellcheck = !is_android
|
| +
|
| +# Use the operating system's spellchecker rather than hunspell.
|
| +use_platform_spellchecker = is_android || is_mac
|
| +
|
| +enable_pepper_cdms = enable_plugins && (is_linux || is_mac || is_win)
|
| +
|
| +# Enable basic printing support and UI.
|
| +enable_basic_printing = !is_chromeos
|
| +
|
| +# Enable printing with print preview. It does not imply
|
| +# enable_basic_printing. It's possible to build Chrome with preview only.
|
| +enable_print_preview = !is_android
|
| +
|
| +# The seccomp-bpf sandbox is only supported on three architectures
|
| +# currently.
|
| +# Do not disable seccomp_bpf anywhere without talking to
|
| +# security@chromium.org!
|
| +use_seccomp_bpf = (is_linux || is_android) &&
|
| + (current_cpu == "x86" || current_cpu == "x64" ||
|
| + current_cpu == "arm" || current_cpu == "mipsel")
|
| +
|
| +# Enable notifications everywhere except iOS.
|
| +enable_notifications = !is_ios
|
| +
|
| +# TODO(brettw) this should be moved to net and only dependents get this define.
|
| +disable_ftp_support = is_ios
|
| +
|
| +enable_web_speech = !is_android && !is_ios
|
| +
|
| +use_dbus = is_linux
|
| +
|
| +enable_extensions = !is_android && !is_ios
|
| +
|
| +enable_task_manager = !is_ios && !is_android
|
| +
|
| +use_cups = is_desktop_linux || is_mac
|
| +
|
| +enable_themes = !is_android && !is_ios
|
| +
|
| +# TODO(scottmg) remove this when we've fixed printing.
|
| +win_pdf_metafile_for_printing = true
|
| +
|
| +# Whether we are using the rlz library or not. Platforms like Android send
|
| +# rlz codes for searches but do not use the library.
|
| +enable_rlz_support = is_win || is_mac || is_ios || is_chromeos
|
| +enable_rlz = is_chrome_branded && enable_rlz_support
|
| +
|
| +enable_settings_app = enable_app_list && !is_chromeos
|
| +
|
| +enable_service_discovery = enable_mdns || is_mac
|
| +
|
| +enable_wifi_bootstrapping = is_win || is_mac
|
| +
|
| +# Image loader extension is enabled on ChromeOS only.
|
| +enable_image_loader_extension = is_chromeos
|
| +
|
| +# Chrome OS: whether to also build the upcoming version of
|
| +# ChromeVox, which can then be enabled via a command-line switch.
|
| +enable_chromevox_next = false
|
| +
|
| +# Use brlapi from brltty for braille display support.
|
| +use_brlapi = is_chromeos
|
| +
|
| +# Option controlling the use of GConf (the classic GNOME configuration
|
| +# system).
|
| +# TODO(GYP) also require !embedded to enable.
|
| +use_gconf = is_linux && !is_chromeos
|
| +
|
| +# Hangout services is an extension that adds extra features to Hangouts.
|
| +# For official GYP builds, this flag is set, it will likely need to be
|
| +# parameterized in the future for a similar use.
|
| +enable_hangout_services_extension = false
|
| +
|
| +# Whether to back up data before sync.
|
| +enable_pre_sync_backup = is_win || is_mac || (is_linux && !is_chromeos)
|
| +
|
| +# WebVR support disabled until platform implementations have been added
|
| +enable_webvr = false
|
|
|