blob: 6cd370b8589f94bb54021c05f5cc2b337e25ae42 [file] [log] [blame] [edit]
# Copyright 2014 The Chromium Authors
# 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("//build/config/nacl/config.gni")
import("//ppapi/buildflags/buildflags.gni")
import("//tools/grit/grit_rule.gni")
# Applied by targets internal to content.
config("content_implementation") {
defines = [ "CONTENT_IMPLEMENTATION" ]
configs = [ "//build/config/compiler:wexit_time_destructors" ]
}
assert(use_blink, "Chromium without blink shouldn't use anything in //content")
# When targets depend on, e.g. //content/public/browser, what happens? To
# facilitate the complexity here, the "public" targets are groups that forward
# to the right thing depending on the build mode. Say for additional
# illustration, the public browser sources also depend on the public common
# ones.
#
# The non-component build is easy:
# foo ->
# //content/public/browser (group) ->
# //content/public/browser:browser_sources (source set) ->
# //content/browser (source set, this is the non-public browser target)
# //content/public/common:common_sources (source set)
#
# The component build is more complicated because we want everybody to depend on
# one content shared library regardless of which public target they depend on:
# foo ->
# //content/public/browser (group) ->
# //content (shared library) ->
# //content/public/browser:browser_sources (source set) ->
# //content/browser (source set; this is the non-public browser target)
# //content/public/common:common_sources (source set)
#
# That the internal content dependencies must depend on the *_sources targets
# to avoid dependency cycles, and external dependencies must depend on the
# //content/public/browser and similar targets to avoid double-linking (these
# targets make sure the dependency goes through the content shared library
# when doing a component build).
#
# TESTS
# -----
# Tests are a challenge. The content tests need to access internals of
# content/browser, for example, but the tests themselves are outside of the
# content component (which is a shared library in the component build). To
# prevent external-to-content targets from depending on private headers,
# the non-public content/browser target is not a public dep of the content
# component. But this means there is also no public path for the content
# tests and no way to restrict that just to //content/test/* if we added one.
#
# As a result, we check deps for //content/test/* only in non-component builds
# (which should verify the dependencies are correct for both component and
# non-component cases equally). There are targets like
# //content/browser:for_content_tests that allow content/test to depend on the
# //content/browser target only in non-component builds (when there are no
# linking problems) for when check is enabled.
content_shared_components = [
"//content/gpu:gpu_sources",
"//content/public/browser:browser_sources",
"//content/public/child:child_sources",
"//content/public/common:common_sources",
"//content/public/gpu:gpu_sources",
"//content/public/renderer:render_frame_media_playback_options",
"//content/public/renderer:renderer_sources",
"//content/public/utility:utility_sources",
]
if (enable_ppapi) {
content_shared_components += [ "//content/ppapi_plugin:ppapi_plugin_sources" ]
}
if (is_component_build) {
component("content") {
public_deps =
content_shared_components + [ "//content/public/app:app_sources" ]
}
} else {
group("content") {
public_deps = content_shared_components
}
}
grit("content_resources") {
source = "content_resources.grd"
outputs = [
"grit/content_resources.h",
"grit/content_resources_map.cc",
"grit/content_resources_map.h",
"content_resources.pak",
]
if (is_chromeos_ash) {
deps = [
"//mojo/public/mojom/base:base_js__generator",
"//ui/base/mojom:mojom_js__generator",
"//url/mojom:url_mojom_gurl_js__generator",
"//url/mojom:url_mojom_origin_js__generator",
]
}
}
# This target exists to "hold" the content_export header so we can do proper
# inclusion testing of it.
source_set("export") {
# Must only be used inside of content.
visibility = [ "//content/*" ]
sources = [ "common/content_export.h" ]
}
# In the GYP build, this file is listed in several targets. In GN just have
# those targets depend on this one. This can be depended on for any
# platform for simplicity, and is a no-op on non-Windows.
source_set("sandbox_helper_win") {
if (is_win) {
sources = [
"app/sandbox_helper_win.cc",
"public/app/sandbox_helper_win.h",
]
deps = [ "//sandbox" ]
}
}