Initial GN work for WebRTC
This CL makes it possible to build the 'webrtc_base' target using GN. The majority of our GYP stuff in webrtc/build/common.gypi has been translated into the configs of webrtc/BUILD.gn. The webrtc/base/base.gyp file is translated into webrtc/base/BUILD.gn. This CL depends on https://codereview.chromium.org/322373002/ for the jsoncpp BUILD.gn file and the ssl config. To build inside Chromium, https://codereview.chromium.org/321313006/ needs to be landed first. BUG=webrtc:3441 TEST= Successful compilation of WebRTC as standalone: gn gen out/Default --args="build_with_chromium=false" && ninja -C out/Default gn gen out/Default --args="build_with_chromium=false is_clang=true" && ninja -C out/Default I also ran: gn gen out/Default --args="build_with_chromium=false have_dbus_glib=true" but it fails to compile: something is probably wrong with with pkg-config for that. For Chromium, I symlinked src/third_party/webrtc to the webrtc subfolder of the WebRTC checkout and applied the following patches: https://codereview.chromium.org/322373002 (for jsoncpp and ssl config) https://codereview.chromium.org/321313006 (enable building WebRTC) Then I built successfully using: gn gen out/Default && ninja -C out/Default webrtc_base R=brettw@chromium.org TBR=niklas.enbom@webrtc.org Review URL: https://webrtc-codereview.appspot.com/17669004 git-svn-id: http://webrtc.googlecode.com/svn/trunk@6461 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
parent
2ca2188906
commit
851a09e71a
1
.gitignore
vendored
1
.gitignore
vendored
@ -90,6 +90,7 @@
|
|||||||
/tools/android-dummy-test
|
/tools/android-dummy-test
|
||||||
/tools/clang
|
/tools/clang
|
||||||
/tools/find_depot_tools
|
/tools/find_depot_tools
|
||||||
|
/tools/generate_library_loader
|
||||||
/tools/gn
|
/tools/gn
|
||||||
/tools/grit
|
/tools/grit
|
||||||
/tools/gritsettings
|
/tools/gritsettings
|
||||||
|
11
BUILD.gn
11
BUILD.gn
@ -8,16 +8,7 @@
|
|||||||
|
|
||||||
# This file is copied and modified from Chromium (src/BUILD.gn).
|
# This file is copied and modified from Chromium (src/BUILD.gn).
|
||||||
group("root") {
|
group("root") {
|
||||||
external = true
|
|
||||||
|
|
||||||
deps = [
|
deps = [
|
||||||
|
"//webrtc",
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
# A standard (non-group) target is required in the build to load any of the
|
|
||||||
# configurations, which is in turn required to load all of the build parameters
|
|
||||||
# (in build/config/BUILD.gn).
|
|
||||||
executable("dummy") {
|
|
||||||
external = true
|
|
||||||
}
|
|
||||||
|
|
||||||
|
3
DEPS
3
DEPS
@ -122,6 +122,9 @@ deps = {
|
|||||||
"tools/clang":
|
"tools/clang":
|
||||||
Var("chromium_trunk") + "/src/tools/clang@" + Var("chromium_revision"),
|
Var("chromium_trunk") + "/src/tools/clang@" + Var("chromium_revision"),
|
||||||
|
|
||||||
|
"tools/generate_library_loader":
|
||||||
|
Var("chromium_trunk") + "/src/tools/generate_library_loader@" + Var("chromium_revision"),
|
||||||
|
|
||||||
"tools/gn":
|
"tools/gn":
|
||||||
Var("chromium_trunk") + "/src/tools/gn@" + Var("chromium_revision"),
|
Var("chromium_trunk") + "/src/tools/gn@" + Var("chromium_revision"),
|
||||||
|
|
||||||
|
174
webrtc/BUILD.gn
Normal file
174
webrtc/BUILD.gn
Normal file
@ -0,0 +1,174 @@
|
|||||||
|
# Copyright (c) 2014 The WebRTC project authors. All Rights Reserved.
|
||||||
|
#
|
||||||
|
# Use of this source code is governed by a BSD-style license
|
||||||
|
# that can be found in the LICENSE file in the root of the source
|
||||||
|
# tree. An additional intellectual property rights grant can be found
|
||||||
|
# in the file PATENTS. All contributing project authors may
|
||||||
|
# be found in the AUTHORS file in the root of the source tree.
|
||||||
|
|
||||||
|
import("//build/config/arm.gni")
|
||||||
|
import("//build/config/crypto.gni")
|
||||||
|
import("//build/config/linux/pkg_config.gni")
|
||||||
|
import("build/webrtc.gni")
|
||||||
|
|
||||||
|
# Contains the defines and includes in common.gypi that are duplicated both as
|
||||||
|
# target_defaults and direct_dependent_settings.
|
||||||
|
config("common_inherited_config") {
|
||||||
|
defines = []
|
||||||
|
if (build_with_mozilla) {
|
||||||
|
defines += [ "WEBRTC_MOZILLA_BUILD" ]
|
||||||
|
}
|
||||||
|
if (build_with_chromium) {
|
||||||
|
defines = [
|
||||||
|
"WEBRTC_CHROMIUM_BUILD",
|
||||||
|
"LOGGING_INSIDE_WEBRTC",
|
||||||
|
]
|
||||||
|
include_dirs = [
|
||||||
|
# overrides must be included first as that is the mechanism for
|
||||||
|
# selecting the override headers in Chromium.
|
||||||
|
"overrides",
|
||||||
|
# Allow includes to be prefixed with webrtc/ in case it is not an
|
||||||
|
# immediate subdirectory of the top-level.
|
||||||
|
"..",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
if (is_posix) {
|
||||||
|
defines += [ "WEBRTC_POSIX" ]
|
||||||
|
}
|
||||||
|
if (is_ios) {
|
||||||
|
defines += [
|
||||||
|
"WEBRTC_MAC",
|
||||||
|
"WEBRTC_IOS",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
if (is_linux) {
|
||||||
|
defines += [ "WEBRTC_LINUX" ]
|
||||||
|
}
|
||||||
|
if (is_mac) {
|
||||||
|
defines += [ "WEBRTC_MAC" ]
|
||||||
|
}
|
||||||
|
if (is_win) {
|
||||||
|
defines += [ "WEBRTC_WIN" ]
|
||||||
|
}
|
||||||
|
if (is_android) {
|
||||||
|
defines += [
|
||||||
|
"WEBRTC_LINUX",
|
||||||
|
"WEBRTC_ANDROID",
|
||||||
|
]
|
||||||
|
if (enable_android_opensl) {
|
||||||
|
defines += [ "WEBRTC_ANDROID_OPENSLES" ]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_config("dbus-glib") {
|
||||||
|
packages = [ "dbus-glib-1" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
config("common_config") {
|
||||||
|
if (restrict_webrtc_logging) {
|
||||||
|
defines = [ "WEBRTC_RESTRICT_LOGGING" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (have_dbus_glib) {
|
||||||
|
defines += [ "HAVE_DBUS_GLIB" ]
|
||||||
|
# TODO(kjellander): Investigate this, it seems like include <dbus/dbus.h>
|
||||||
|
# is still not found even if the execution of
|
||||||
|
# build/config/linux/pkg-config.py dbus-glib-1 returns correct include
|
||||||
|
# dirs on Linux.
|
||||||
|
all_dependent_configs = [ "dbus-glib" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (enable_video) {
|
||||||
|
defines += [ "WEBRTC_MODULE_UTILITY_VIDEO" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!build_with_chromium) {
|
||||||
|
if (is_posix) {
|
||||||
|
# -Wextra is currently disabled in Chromium"s common.gypi. Enable
|
||||||
|
# for targets that can handle it. For Android/arm64 right now
|
||||||
|
# there will be an "enumeral and non-enumeral type in conditional
|
||||||
|
# expression" warning in android_tools/ndk_experimental"s version
|
||||||
|
# of stlport.
|
||||||
|
# See: https://code.google.com/p/chromium/issues/detail?id=379699
|
||||||
|
if (cpu_arch != "arm64" || !is_android) {
|
||||||
|
cflags = [
|
||||||
|
"-Wextra",
|
||||||
|
# We need to repeat some flags from Chromium"s common.gypi
|
||||||
|
# here that get overridden by -Wextra.
|
||||||
|
"-Wno-unused-parameter",
|
||||||
|
"-Wno-missing-field-initializers",
|
||||||
|
"-Wno-strict-overflow",
|
||||||
|
]
|
||||||
|
cflags_cc = [
|
||||||
|
"-Wnon-virtual-dtor",
|
||||||
|
# This is enabled for clang; enable for gcc as well.
|
||||||
|
"-Woverloaded-virtual",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_clang) {
|
||||||
|
cflags += [ "-Wthread-safety" ]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cpu_arch == "arm") {
|
||||||
|
defines += [ "WEBRTC_ARCH_ARM" ]
|
||||||
|
if (arm_version == 7) {
|
||||||
|
defines += [ "WEBRTC_ARCH_ARM_V7" ]
|
||||||
|
if (arm_use_neon) {
|
||||||
|
defines += [ "WEBRTC_ARCH_ARM_NEON" ]
|
||||||
|
} else {
|
||||||
|
defines += [ "WEBRTC_DETECT_ARM_NEON" ]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cpu_arch == "mipsel") {
|
||||||
|
defines += [ "MIPS32_LE" ]
|
||||||
|
if (mips_fpu) {
|
||||||
|
defines += [ "MIPS_FPU_LE" ]
|
||||||
|
cflags += [ "-mhard-float" ]
|
||||||
|
} else {
|
||||||
|
cflags += [ "-msoft-float" ]
|
||||||
|
}
|
||||||
|
if (mips_arch_variant == "mips32r2") {
|
||||||
|
defines += [ "MIPS32_R2_LE" ]
|
||||||
|
cflags += [ "-mips32r2" ]
|
||||||
|
cflags_cc += [ "-mips32r2" ]
|
||||||
|
}
|
||||||
|
if (mips_dsp_rev == 1) {
|
||||||
|
defines += [ "MIPS_DSP_R1_LE" ]
|
||||||
|
cflags += [ "-mdsp" ]
|
||||||
|
cflags_cc += [ "-mdsp" ]
|
||||||
|
} else if (mips_dsp_rev == 2) {
|
||||||
|
defines += [
|
||||||
|
"MIPS_DSP_R1_LE",
|
||||||
|
"MIPS_DSP_R2_LE",
|
||||||
|
]
|
||||||
|
cflags += [ "-mdspr2" ]
|
||||||
|
cflags_cc += [ "-mdspr2" ]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# TODO(kjellander): Handle warnings on Windows where WebRTC differ from the
|
||||||
|
# default warnings set in build/config/compiler/BUILD.gn.
|
||||||
|
|
||||||
|
if (is_android && is_clang) {
|
||||||
|
# The Android NDK doesn"t provide optimized versions of these
|
||||||
|
# functions. Ensure they are disabled for all compilers.
|
||||||
|
cflags += [
|
||||||
|
"-fno-builtin-cos",
|
||||||
|
"-fno-builtin-sin",
|
||||||
|
"-fno-builtin-cosf",
|
||||||
|
"-fno-builtin-sinf",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static_library("webrtc") {
|
||||||
|
deps = [
|
||||||
|
"base:webrtc_base",
|
||||||
|
]
|
||||||
|
}
|
723
webrtc/base/BUILD.gn
Normal file
723
webrtc/base/BUILD.gn
Normal file
@ -0,0 +1,723 @@
|
|||||||
|
# Copyright (c) 2014 The WebRTC project authors. All Rights Reserved.
|
||||||
|
#
|
||||||
|
# Use of this source code is governed by a BSD-style license
|
||||||
|
# that can be found in the LICENSE file in the root of the source
|
||||||
|
# tree. An additional intellectual property rights grant can be found
|
||||||
|
# in the file PATENTS. All contributing project authors may
|
||||||
|
# be found in the AUTHORS file in the root of the source tree.
|
||||||
|
|
||||||
|
import("//build/config/crypto.gni")
|
||||||
|
import("../build/webrtc.gni")
|
||||||
|
|
||||||
|
config("webrtc_base_config") {
|
||||||
|
include_dirs = [
|
||||||
|
"//third_party/jsoncpp/overrides/include",
|
||||||
|
"//third_party/jsoncpp/source/include",
|
||||||
|
]
|
||||||
|
|
||||||
|
defines = [
|
||||||
|
"FEATURE_ENABLE_SSL",
|
||||||
|
"GTEST_RELATIVE_PATH",
|
||||||
|
]
|
||||||
|
|
||||||
|
# TODO(henrike): issue 3307, make webrtc_base build without disabling
|
||||||
|
# these flags.
|
||||||
|
cflags_cc = [ "-Wno-non-virtual-dtor" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
config("webrtc_base_chromium_config") {
|
||||||
|
defines = [
|
||||||
|
"NO_MAIN_THREAD_WRAPPING",
|
||||||
|
"SSL_USE_NSS",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
config("openssl_config") {
|
||||||
|
defines = [
|
||||||
|
"SSL_USE_OPENSSL",
|
||||||
|
"HAVE_OPENSSL_SSL_H",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
config("no_openssl_config") {
|
||||||
|
defines = [
|
||||||
|
"SSL_USE_NSS",
|
||||||
|
"HAVE_NSS_SSL_H",
|
||||||
|
"SSL_USE_NSS_RNG",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
config("android_config") {
|
||||||
|
defines = [ "HAVE_OPENSSL_SSL_H" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
config("no_android_config") {
|
||||||
|
defines = [
|
||||||
|
"HAVE_NSS_SSL_H",
|
||||||
|
"SSL_USE_NSS_RNG",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
config("ios_config") {
|
||||||
|
ldflags = [
|
||||||
|
#"Foundation.framework", # Already included in //build/config:default_libs.
|
||||||
|
"Security.framework",
|
||||||
|
"SystemConfiguration.framework",
|
||||||
|
#"UIKit.framework", # Already included in //build/config:default_libs.
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
config("mac_config") {
|
||||||
|
ldflags = [
|
||||||
|
"Cocoa.framework",
|
||||||
|
#"Foundation.framework", # Already included in //build/config:default_libs.
|
||||||
|
#"IOKit.framework", # Already included in //build/config:default_libs.
|
||||||
|
#"Security.framework", # Already included in //build/config:default_libs.
|
||||||
|
"SystemConfiguration.framework",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
config("mac_x86_config") {
|
||||||
|
libs = [
|
||||||
|
#"Carbon.framework", # Already included in //build/config:default_libs.
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
config("linux_system_ssl_config") {
|
||||||
|
visibility = ":*" # Only targets in this file can depend on this.
|
||||||
|
|
||||||
|
# TODO(kjellander): Find out how to convert GYP include_dirs+ (i.e. insert
|
||||||
|
# first in the include path?).
|
||||||
|
include_dirs = [ "//net/third_party/nss/ssl" ]
|
||||||
|
|
||||||
|
configs = [ "//third_party/nss:system_nss_no_ssl_config" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
# Provides the same functionality as the build/linux/system.gyp:ssl GYP target.
|
||||||
|
# This cannot be in build/linux/BUILD.gn since targets in build/ are not allowed
|
||||||
|
# to depend on targets outside of it. This could be replaced by the Chromium
|
||||||
|
# //crypto:platform target, but as WebRTC currently don't sync src/crypto from
|
||||||
|
# Chromium, it is not possible today.
|
||||||
|
config("linux_system_ssl") {
|
||||||
|
if (use_openssl) {
|
||||||
|
deps = [ "//third_party/openssl" ]
|
||||||
|
} else {
|
||||||
|
deps = [ "//net/third_party/nss/ssl:libssl" ]
|
||||||
|
|
||||||
|
direct_dependent_configs = [
|
||||||
|
":linux_system_ssl_config",
|
||||||
|
]
|
||||||
|
|
||||||
|
if (is_clang) {
|
||||||
|
cflags = [
|
||||||
|
# There is a broken header guard in /usr/include/nss/secmod.h:
|
||||||
|
# https://bugzilla.mozilla.org/show_bug.cgi?id=884072
|
||||||
|
"-Wno-header-guard",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static_library("webrtc_base") {
|
||||||
|
cflags = []
|
||||||
|
cflags_cc = []
|
||||||
|
|
||||||
|
configs -= [ "//build/config/compiler:chromium_code" ]
|
||||||
|
configs += [ "//build/config/compiler:no_chromium_code" ]
|
||||||
|
configs += [
|
||||||
|
"..:common_inherited_config",
|
||||||
|
"..:common_config",
|
||||||
|
":webrtc_base_config",
|
||||||
|
]
|
||||||
|
|
||||||
|
direct_dependent_configs = [
|
||||||
|
"..:common_inherited_config",
|
||||||
|
":webrtc_base_config",
|
||||||
|
]
|
||||||
|
|
||||||
|
defines = [
|
||||||
|
"LOGGING=1",
|
||||||
|
"USE_WEBRTC_DEV_BRANCH",
|
||||||
|
]
|
||||||
|
|
||||||
|
sources = [
|
||||||
|
"asyncfile.cc",
|
||||||
|
"asyncfile.h",
|
||||||
|
"asynchttprequest.cc",
|
||||||
|
"asynchttprequest.h",
|
||||||
|
"asyncinvoker.cc",
|
||||||
|
"asyncinvoker.h",
|
||||||
|
"asyncinvoker-inl.h",
|
||||||
|
"asyncpacketsocket.h",
|
||||||
|
"asyncresolverinterface.h",
|
||||||
|
"asyncsocket.cc",
|
||||||
|
"asyncsocket.h",
|
||||||
|
"asynctcpsocket.cc",
|
||||||
|
"asynctcpsocket.h",
|
||||||
|
"asyncudpsocket.cc",
|
||||||
|
"asyncudpsocket.h",
|
||||||
|
"atomicops.h",
|
||||||
|
"autodetectproxy.cc",
|
||||||
|
"autodetectproxy.h",
|
||||||
|
"bandwidthsmoother.cc",
|
||||||
|
"bandwidthsmoother.h",
|
||||||
|
"base64.cc",
|
||||||
|
"base64.h",
|
||||||
|
"basicdefs.h",
|
||||||
|
"basictypes.h",
|
||||||
|
"bind.h",
|
||||||
|
"bind.h.pump",
|
||||||
|
"buffer.h",
|
||||||
|
"bytebuffer.cc",
|
||||||
|
"bytebuffer.h",
|
||||||
|
"byteorder.h",
|
||||||
|
"callback.h",
|
||||||
|
"callback.h.pump",
|
||||||
|
"checks.cc",
|
||||||
|
"checks.h",
|
||||||
|
"common.cc",
|
||||||
|
"common.h",
|
||||||
|
"constructormagic.h",
|
||||||
|
"cpumonitor.cc",
|
||||||
|
"cpumonitor.h",
|
||||||
|
"crc32.cc",
|
||||||
|
"crc32.h",
|
||||||
|
"criticalsection.h",
|
||||||
|
"cryptstring.h",
|
||||||
|
"dbus.cc",
|
||||||
|
"dbus.h",
|
||||||
|
"diskcache.cc",
|
||||||
|
"diskcache.h",
|
||||||
|
"event.cc",
|
||||||
|
"event.h",
|
||||||
|
"filelock.cc",
|
||||||
|
"filelock.h",
|
||||||
|
"fileutils.cc",
|
||||||
|
"fileutils.h",
|
||||||
|
"fileutils_mock.h",
|
||||||
|
"firewallsocketserver.cc",
|
||||||
|
"firewallsocketserver.h",
|
||||||
|
"flags.cc",
|
||||||
|
"flags.h",
|
||||||
|
"genericslot.h",
|
||||||
|
"genericslot.h.pump",
|
||||||
|
"gunit_prod.h",
|
||||||
|
"helpers.cc",
|
||||||
|
"helpers.h",
|
||||||
|
"httpbase.cc",
|
||||||
|
"httpbase.h",
|
||||||
|
"httpclient.cc",
|
||||||
|
"httpclient.h",
|
||||||
|
"httpcommon-inl.h",
|
||||||
|
"httpcommon.cc",
|
||||||
|
"httpcommon.h",
|
||||||
|
"httprequest.cc",
|
||||||
|
"httprequest.h",
|
||||||
|
"httpserver.cc",
|
||||||
|
"httpserver.h",
|
||||||
|
"ifaddrs-android.cc",
|
||||||
|
"ifaddrs-android.h",
|
||||||
|
"iosfilesystem.mm",
|
||||||
|
"ipaddress.cc",
|
||||||
|
"ipaddress.h",
|
||||||
|
"json.cc",
|
||||||
|
"json.h",
|
||||||
|
"latebindingsymboltable.cc",
|
||||||
|
"latebindingsymboltable.cc.def",
|
||||||
|
"latebindingsymboltable.h",
|
||||||
|
"latebindingsymboltable.h.def",
|
||||||
|
"libdbusglibsymboltable.cc",
|
||||||
|
"libdbusglibsymboltable.h",
|
||||||
|
"linux.cc",
|
||||||
|
"linux.h",
|
||||||
|
"linuxfdwalk.c",
|
||||||
|
"linuxfdwalk.h",
|
||||||
|
"linuxwindowpicker.cc",
|
||||||
|
"linuxwindowpicker.h",
|
||||||
|
"linked_ptr.h",
|
||||||
|
"logging.cc",
|
||||||
|
"logging.h",
|
||||||
|
"macasyncsocket.cc",
|
||||||
|
"macasyncsocket.h",
|
||||||
|
"maccocoasocketserver.h",
|
||||||
|
"maccocoasocketserver.mm",
|
||||||
|
"maccocoathreadhelper.h",
|
||||||
|
"maccocoathreadhelper.mm",
|
||||||
|
"macconversion.cc",
|
||||||
|
"macconversion.h",
|
||||||
|
"macsocketserver.cc",
|
||||||
|
"macsocketserver.h",
|
||||||
|
"macutils.cc",
|
||||||
|
"macutils.h",
|
||||||
|
"macwindowpicker.cc",
|
||||||
|
"macwindowpicker.h",
|
||||||
|
"mathutils.h",
|
||||||
|
"md5.cc",
|
||||||
|
"md5.h",
|
||||||
|
"md5digest.h",
|
||||||
|
"messagedigest.cc",
|
||||||
|
"messagedigest.h",
|
||||||
|
"messagehandler.cc",
|
||||||
|
"messagehandler.h",
|
||||||
|
"messagequeue.cc",
|
||||||
|
"messagequeue.h",
|
||||||
|
"multipart.cc",
|
||||||
|
"multipart.h",
|
||||||
|
"natserver.cc",
|
||||||
|
"natserver.h",
|
||||||
|
"natsocketfactory.cc",
|
||||||
|
"natsocketfactory.h",
|
||||||
|
"nattypes.cc",
|
||||||
|
"nattypes.h",
|
||||||
|
"nethelpers.cc",
|
||||||
|
"nethelpers.h",
|
||||||
|
"network.cc",
|
||||||
|
"network.h",
|
||||||
|
"nssidentity.cc",
|
||||||
|
"nssidentity.h",
|
||||||
|
"nssstreamadapter.cc",
|
||||||
|
"nssstreamadapter.h",
|
||||||
|
"nullsocketserver.h",
|
||||||
|
"openssl.h",
|
||||||
|
"openssladapter.cc",
|
||||||
|
"openssladapter.h",
|
||||||
|
"openssldigest.cc",
|
||||||
|
"openssldigest.h",
|
||||||
|
"opensslidentity.cc",
|
||||||
|
"opensslidentity.h",
|
||||||
|
"opensslstreamadapter.cc",
|
||||||
|
"opensslstreamadapter.h",
|
||||||
|
"optionsfile.cc",
|
||||||
|
"optionsfile.h",
|
||||||
|
"pathutils.cc",
|
||||||
|
"pathutils.h",
|
||||||
|
"physicalsocketserver.cc",
|
||||||
|
"physicalsocketserver.h",
|
||||||
|
"posix.cc",
|
||||||
|
"posix.h",
|
||||||
|
"profiler.cc",
|
||||||
|
"profiler.h",
|
||||||
|
"proxydetect.cc",
|
||||||
|
"proxydetect.h",
|
||||||
|
"proxyinfo.cc",
|
||||||
|
"proxyinfo.h",
|
||||||
|
"proxyserver.cc",
|
||||||
|
"proxyserver.h",
|
||||||
|
"ratelimiter.cc",
|
||||||
|
"ratelimiter.h",
|
||||||
|
"ratetracker.cc",
|
||||||
|
"ratetracker.h",
|
||||||
|
"refcount.h",
|
||||||
|
"referencecountedsingletonfactory.h",
|
||||||
|
"rollingaccumulator.h",
|
||||||
|
"schanneladapter.cc",
|
||||||
|
"schanneladapter.h",
|
||||||
|
"scoped_autorelease_pool.h",
|
||||||
|
"scoped_autorelease_pool.mm",
|
||||||
|
"scoped_ptr.h",
|
||||||
|
"scoped_ref_ptr.h",
|
||||||
|
"scopedptrcollection.h",
|
||||||
|
"sec_buffer.h",
|
||||||
|
"sha1.cc",
|
||||||
|
"sha1.h",
|
||||||
|
"sha1digest.h",
|
||||||
|
"sharedexclusivelock.cc",
|
||||||
|
"sharedexclusivelock.h",
|
||||||
|
"signalthread.cc",
|
||||||
|
"signalthread.h",
|
||||||
|
"sigslot.h",
|
||||||
|
"sigslotrepeater.h",
|
||||||
|
"socket.h",
|
||||||
|
"socketadapters.cc",
|
||||||
|
"socketadapters.h",
|
||||||
|
"socketaddress.cc",
|
||||||
|
"socketaddress.h",
|
||||||
|
"socketaddresspair.cc",
|
||||||
|
"socketaddresspair.h",
|
||||||
|
"socketfactory.h",
|
||||||
|
"socketpool.cc",
|
||||||
|
"socketpool.h",
|
||||||
|
"socketserver.h",
|
||||||
|
"socketstream.cc",
|
||||||
|
"socketstream.h",
|
||||||
|
"ssladapter.cc",
|
||||||
|
"ssladapter.h",
|
||||||
|
"sslconfig.h",
|
||||||
|
"sslfingerprint.cc",
|
||||||
|
"sslfingerprint.h",
|
||||||
|
"sslidentity.cc",
|
||||||
|
"sslidentity.h",
|
||||||
|
"sslroots.h",
|
||||||
|
"sslsocketfactory.cc",
|
||||||
|
"sslsocketfactory.h",
|
||||||
|
"sslstreamadapter.cc",
|
||||||
|
"sslstreamadapter.h",
|
||||||
|
"sslstreamadapterhelper.cc",
|
||||||
|
"sslstreamadapterhelper.h",
|
||||||
|
"stream.cc",
|
||||||
|
"stream.h",
|
||||||
|
"stringdigest.h",
|
||||||
|
"stringencode.cc",
|
||||||
|
"stringencode.h",
|
||||||
|
"stringutils.cc",
|
||||||
|
"stringutils.h",
|
||||||
|
"systeminfo.cc",
|
||||||
|
"systeminfo.h",
|
||||||
|
"task.cc",
|
||||||
|
"task.h",
|
||||||
|
"taskparent.cc",
|
||||||
|
"taskparent.h",
|
||||||
|
"taskrunner.cc",
|
||||||
|
"taskrunner.h",
|
||||||
|
"testclient.cc",
|
||||||
|
"testclient.h",
|
||||||
|
"thread.cc",
|
||||||
|
"thread.h",
|
||||||
|
"timeutils.cc",
|
||||||
|
"timeutils.h",
|
||||||
|
"timing.cc",
|
||||||
|
"timing.h",
|
||||||
|
"transformadapter.cc",
|
||||||
|
"transformadapter.h",
|
||||||
|
"unixfilesystem.cc",
|
||||||
|
"unixfilesystem.h",
|
||||||
|
"urlencode.cc",
|
||||||
|
"urlencode.h",
|
||||||
|
"versionparsing.cc",
|
||||||
|
"versionparsing.h",
|
||||||
|
"virtualsocketserver.cc",
|
||||||
|
"virtualsocketserver.h",
|
||||||
|
"win32.cc",
|
||||||
|
"win32.h",
|
||||||
|
"win32filesystem.cc",
|
||||||
|
"win32filesystem.h",
|
||||||
|
"win32regkey.cc",
|
||||||
|
"win32regkey.h",
|
||||||
|
"win32securityerrors.cc",
|
||||||
|
"win32socketinit.cc",
|
||||||
|
"win32socketinit.h",
|
||||||
|
"win32socketserver.cc",
|
||||||
|
"win32socketserver.h",
|
||||||
|
"win32window.cc",
|
||||||
|
"win32window.h",
|
||||||
|
"win32windowpicker.cc",
|
||||||
|
"win32windowpicker.h",
|
||||||
|
"window.h",
|
||||||
|
"windowpicker.h",
|
||||||
|
"windowpickerfactory.h",
|
||||||
|
"winfirewall.cc",
|
||||||
|
"winfirewall.h",
|
||||||
|
"winping.cc",
|
||||||
|
"winping.h",
|
||||||
|
"worker.cc",
|
||||||
|
"worker.h",
|
||||||
|
]
|
||||||
|
|
||||||
|
if (build_with_chromium) {
|
||||||
|
sources += [
|
||||||
|
"../overrides/webrtc/base/basictypes.h",
|
||||||
|
"../overrides/webrtc/base/constructormagic.h",
|
||||||
|
"../overrides/webrtc/base/logging.cc",
|
||||||
|
"../overrides/webrtc/base/logging.h",
|
||||||
|
]
|
||||||
|
if (is_win) {
|
||||||
|
sources += [ "../overrides/webrtc/base/win32socketinit.cc" ]
|
||||||
|
}
|
||||||
|
sources -= [
|
||||||
|
"asyncinvoker.cc",
|
||||||
|
"asyncinvoker.h",
|
||||||
|
"asyncinvoker-inl.h",
|
||||||
|
"asyncresolverinterface.h",
|
||||||
|
"atomicops.h",
|
||||||
|
"bandwidthsmoother.cc",
|
||||||
|
"bandwidthsmoother.h",
|
||||||
|
"basictypes.h",
|
||||||
|
"bind.h",
|
||||||
|
"bind.h.pump",
|
||||||
|
"buffer.h",
|
||||||
|
"callback.h",
|
||||||
|
"callback.h.pump",
|
||||||
|
"constructormagic.h",
|
||||||
|
"dbus.cc",
|
||||||
|
"dbus.h",
|
||||||
|
"filelock.cc",
|
||||||
|
"filelock.h",
|
||||||
|
"fileutils_mock.h",
|
||||||
|
"genericslot.h",
|
||||||
|
"genericslot.h.pump",
|
||||||
|
"httpserver.cc",
|
||||||
|
"httpserver.h",
|
||||||
|
"json.cc",
|
||||||
|
"json.h",
|
||||||
|
"latebindingsymboltable.cc",
|
||||||
|
"latebindingsymboltable.cc.def",
|
||||||
|
"latebindingsymboltable.h",
|
||||||
|
"latebindingsymboltable.h.def",
|
||||||
|
"libdbusglibsymboltable.cc",
|
||||||
|
"libdbusglibsymboltable.h",
|
||||||
|
"linuxfdwalk.c",
|
||||||
|
"linuxfdwalk.h",
|
||||||
|
"linuxwindowpicker.cc",
|
||||||
|
"linuxwindowpicker.h",
|
||||||
|
"logging.cc",
|
||||||
|
"logging.h",
|
||||||
|
#"macasyncsocket.cc",
|
||||||
|
#"macasyncsocket.h",
|
||||||
|
#"maccocoasocketserver.h",
|
||||||
|
#"maccocoasocketserver.mm",
|
||||||
|
#"macsocketserver.cc",
|
||||||
|
#"macsocketserver.h",
|
||||||
|
#"macwindowpicker.cc",
|
||||||
|
#"macwindowpicker.h",
|
||||||
|
"mathutils.h",
|
||||||
|
"multipart.cc",
|
||||||
|
"multipart.h",
|
||||||
|
"natserver.cc",
|
||||||
|
"natserver.h",
|
||||||
|
"natsocketfactory.cc",
|
||||||
|
"natsocketfactory.h",
|
||||||
|
"nattypes.cc",
|
||||||
|
"nattypes.h",
|
||||||
|
"openssl.h",
|
||||||
|
"optionsfile.cc",
|
||||||
|
"optionsfile.h",
|
||||||
|
"posix.cc",
|
||||||
|
"posix.h",
|
||||||
|
"profiler.cc",
|
||||||
|
"profiler.h",
|
||||||
|
"proxyserver.cc",
|
||||||
|
"proxyserver.h",
|
||||||
|
"refcount.h",
|
||||||
|
"referencecountedsingletonfactory.h",
|
||||||
|
"rollingaccumulator.h",
|
||||||
|
#"safe_conversions.h",
|
||||||
|
#"safe_conversions_impl.h",
|
||||||
|
"scopedptrcollection.h",
|
||||||
|
"scoped_ref_ptr.h",
|
||||||
|
"sec_buffer.h",
|
||||||
|
"sharedexclusivelock.cc",
|
||||||
|
"sharedexclusivelock.h",
|
||||||
|
"sslconfig.h",
|
||||||
|
"sslroots.h",
|
||||||
|
"stringdigest.h",
|
||||||
|
#"testbase64.h",
|
||||||
|
"testclient.cc",
|
||||||
|
"testclient.h",
|
||||||
|
#"testutils.h",
|
||||||
|
"transformadapter.cc",
|
||||||
|
"transformadapter.h",
|
||||||
|
"versionparsing.cc",
|
||||||
|
"versionparsing.h",
|
||||||
|
"virtualsocketserver.cc",
|
||||||
|
"virtualsocketserver.h",
|
||||||
|
#"win32regkey.cc",
|
||||||
|
#"win32regkey.h",
|
||||||
|
#"win32socketinit.cc",
|
||||||
|
#"win32socketinit.h",
|
||||||
|
#"win32socketserver.cc",
|
||||||
|
#"win32socketserver.h",
|
||||||
|
#"win32toolhelp.h",
|
||||||
|
"window.h",
|
||||||
|
"windowpickerfactory.h",
|
||||||
|
"windowpicker.h",
|
||||||
|
]
|
||||||
|
|
||||||
|
include_dirs = [
|
||||||
|
"../overrides",
|
||||||
|
"../../openssl/openssl/include",
|
||||||
|
]
|
||||||
|
|
||||||
|
direct_dependent_configs += [ ":webrtc_base_chromium_config" ]
|
||||||
|
} else {
|
||||||
|
if (is_win) {
|
||||||
|
sources += [
|
||||||
|
"diskcache_win32.cc",
|
||||||
|
"diskcache_win32.h",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
deps = [ "//third_party/jsoncpp" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
# TODO(henrike): issue 3307, make webrtc_base build without disabling
|
||||||
|
# these flags.
|
||||||
|
cflags += [
|
||||||
|
"-Wno-extra",
|
||||||
|
"-Wno-all",
|
||||||
|
]
|
||||||
|
cflags_cc += [ "-Wno-non-virtual-dtor" ]
|
||||||
|
|
||||||
|
if (use_openssl) {
|
||||||
|
direct_dependent_configs += [ ":openssl_config" ]
|
||||||
|
|
||||||
|
deps = [ "//third_party/openssl" ]
|
||||||
|
} else {
|
||||||
|
direct_dependent_configs += [ ":no_openssl_config" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_android) {
|
||||||
|
direct_dependent_configs += [ ":android_config" ]
|
||||||
|
|
||||||
|
libs = [
|
||||||
|
"log",
|
||||||
|
"GLESv2"
|
||||||
|
]
|
||||||
|
} else {
|
||||||
|
direct_dependent_configs += [ ":no_android_config" ]
|
||||||
|
|
||||||
|
sources -= [
|
||||||
|
"ifaddrs-android.cc",
|
||||||
|
"ifaddrs-android.h",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_ios) {
|
||||||
|
all_dependent_configs += [ ":ios_config" ]
|
||||||
|
|
||||||
|
deps = [ "//net/third_party/nss/ssl:libssl" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_linux) {
|
||||||
|
libs = [
|
||||||
|
"crypto",
|
||||||
|
"dl",
|
||||||
|
"rt",
|
||||||
|
"Xext",
|
||||||
|
"X11",
|
||||||
|
"Xcomposite",
|
||||||
|
"Xrender",
|
||||||
|
]
|
||||||
|
configs += [ "//third_party/nss:system_nss_no_ssl_config" ]
|
||||||
|
} else {
|
||||||
|
sources -= [
|
||||||
|
"dbus.cc",
|
||||||
|
"dbus.h",
|
||||||
|
"libdbusglibsymboltable.cc",
|
||||||
|
"libdbusglibsymboltable.h",
|
||||||
|
"linuxfdwalk.c",
|
||||||
|
"linuxfdwalk.h",
|
||||||
|
"linuxwindowpicker.cc",
|
||||||
|
"linuxwindowpicker.h",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_mac) {
|
||||||
|
all_dependent_configs = [ ":mac_config" ]
|
||||||
|
|
||||||
|
libs = [
|
||||||
|
"crypto", # $(SDKROOT)/usr/lib/libcrypto.dylib
|
||||||
|
"ssl", # $(SDKROOT)/usr/lib/libssl.dylib
|
||||||
|
]
|
||||||
|
if (cpu_arch == "x86") {
|
||||||
|
all_dependent_configs += [ ":mac_x86_config" ]
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
sources -= [
|
||||||
|
"macasyncsocket.cc",
|
||||||
|
"macasyncsocket.h",
|
||||||
|
"maccocoasocketserver.h",
|
||||||
|
#"maccocoasocketserver.mm", # Seems to be excluded by default with GN.
|
||||||
|
"macconversion.cc",
|
||||||
|
"macconversion.h",
|
||||||
|
"macsocketserver.cc",
|
||||||
|
"macsocketserver.h",
|
||||||
|
"macutils.cc",
|
||||||
|
"macutils.h",
|
||||||
|
"macwindowpicker.cc",
|
||||||
|
"macwindowpicker.h",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_win) {
|
||||||
|
libs = [
|
||||||
|
"crypt32.lib",
|
||||||
|
"iphlpapi.lib",
|
||||||
|
"secur32.lib",
|
||||||
|
]
|
||||||
|
|
||||||
|
cflags += [
|
||||||
|
# Suppress warnings about WIN32_LEAN_AND_MEAN.
|
||||||
|
"/wd4005",
|
||||||
|
"/wd4703",
|
||||||
|
]
|
||||||
|
|
||||||
|
defines += [ "_CRT_NONSTDC_NO_DEPRECATE" ]
|
||||||
|
} else {
|
||||||
|
sources -= [
|
||||||
|
"schanneladapter.cc",
|
||||||
|
"schanneladapter.h",
|
||||||
|
"winping.cc",
|
||||||
|
"winping.h",
|
||||||
|
"winfirewall.cc",
|
||||||
|
"winfirewall.h",
|
||||||
|
# The files below were covered by a regex exclude in GYP.
|
||||||
|
"win32.cc",
|
||||||
|
"win32.h",
|
||||||
|
"win32filesystem.cc",
|
||||||
|
"win32filesystem.h",
|
||||||
|
"win32regkey.cc",
|
||||||
|
"win32regkey.h",
|
||||||
|
"win32securityerrors.cc",
|
||||||
|
"win32socketinit.cc",
|
||||||
|
"win32socketinit.h",
|
||||||
|
"win32socketserver.cc",
|
||||||
|
"win32socketserver.h",
|
||||||
|
"win32window.cc",
|
||||||
|
"win32window.h",
|
||||||
|
"win32windowpicker.cc",
|
||||||
|
"win32windowpicker.h",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_posix) {
|
||||||
|
if (is_debug) {
|
||||||
|
defines += [ "_DEBUG" ]
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
sources -= [
|
||||||
|
"latebindingsymboltable.cc",
|
||||||
|
"latebindingsymboltable.h",
|
||||||
|
"posix.cc",
|
||||||
|
"posix.h",
|
||||||
|
"unixfilesystem.cc",
|
||||||
|
"unixfilesystem.h",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_ios || (is_mac && cpu_arch != "x86")) {
|
||||||
|
defines += [ "CARBON_DEPRECATED=YES" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_ios || !is_posix) {
|
||||||
|
sources -= [
|
||||||
|
"openssl.h",
|
||||||
|
"openssladapter.cc",
|
||||||
|
"openssladapter.h",
|
||||||
|
"openssldigest.cc",
|
||||||
|
"openssldigest.h",
|
||||||
|
"opensslidentity.cc",
|
||||||
|
"opensslidentity.h",
|
||||||
|
"opensslstreamadapter.cc",
|
||||||
|
"opensslstreamadapter.h",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!is_linux && !is_android) {
|
||||||
|
sources -= [
|
||||||
|
"linux.cc",
|
||||||
|
"linux.h",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_mac || is_ios || is_win) {
|
||||||
|
deps += [
|
||||||
|
"//net/third_party/nss/ssl:libssl",
|
||||||
|
"//third_party/nss:nspr",
|
||||||
|
"//third_party/nss:nss",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_posix && !is_mac && !is_ios && !is_android) {
|
||||||
|
configs += [ ":linux_system_ssl" ]
|
||||||
|
}
|
||||||
|
}
|
57
webrtc/build/webrtc.gni
Normal file
57
webrtc/build/webrtc.gni
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
# Copyright (c) 2014 The WebRTC project authors. All Rights Reserved.
|
||||||
|
#
|
||||||
|
# Use of this source code is governed by a BSD-style license
|
||||||
|
# that can be found in the LICENSE file in the root of the source
|
||||||
|
# tree. An additional intellectual property rights grant can be found
|
||||||
|
# in the file PATENTS. All contributing project authors may
|
||||||
|
# be found in the AUTHORS file in the root of the source tree.
|
||||||
|
|
||||||
|
declare_args() {
|
||||||
|
# Assume Chromium build for now, since that's the priority case for getting GN
|
||||||
|
# up and running with WebRTC.
|
||||||
|
build_with_chromium = true
|
||||||
|
build_with_libjingle = true
|
||||||
|
|
||||||
|
if (build_with_libjingle) {
|
||||||
|
include_tests = false
|
||||||
|
restrict_webrtc_logging = true
|
||||||
|
} else {
|
||||||
|
include_tests = true
|
||||||
|
restrict_webrtc_logging = false
|
||||||
|
}
|
||||||
|
|
||||||
|
# Adds video support to dependencies shared by voice and video engine.
|
||||||
|
# This should normally be enabled; the intended use is to disable only
|
||||||
|
# when building voice engine exclusively.
|
||||||
|
enable_video = true
|
||||||
|
|
||||||
|
# Selects fixed-point code where possible.
|
||||||
|
prefer_fixed_point = false
|
||||||
|
|
||||||
|
build_libjpeg = true
|
||||||
|
# Enables the use of protocol buffers for debug recordings.
|
||||||
|
enable_protobuf = true
|
||||||
|
|
||||||
|
# Disable by default.
|
||||||
|
have_dbus_glib = false
|
||||||
|
|
||||||
|
# Enable to use the Mozilla internal settings.
|
||||||
|
build_with_mozilla = false
|
||||||
|
|
||||||
|
# Define MIPS architecture variant, MIPS DSP variant and MIPS FPU
|
||||||
|
# This may be subject to change in accordance to Chromium's MIPS flags
|
||||||
|
mips_arch_variant = "mips32r1"
|
||||||
|
mips_dsp_rev = 0
|
||||||
|
mips_fpu = true
|
||||||
|
|
||||||
|
enable_android_opensl = true
|
||||||
|
|
||||||
|
if (is_ios) {
|
||||||
|
build_libjpeg = false
|
||||||
|
enable_protobuf = false
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cpu_arch == "arm") {
|
||||||
|
prefer_fixed_point = true
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user