Use source_sets in component builds and static_library in release builds.
Static libraries don't guarantee that an exported symbol gets linked into a shared library (and in order to support Chromium's component build mode, WebRTC needs to be linked as a shared library). Source sets always pass all the object files to the linker. On the flip side, source_sets link more object files in release builds and to avoid this, this CL introduces a the GN template "rtc_library" that expands to static_library during release builds and to source_set during component builds. See: https://gn.googlesource.com/gn/+/master/docs/reference.md#func_source_set Bug: webrtc:9419 Change-Id: I4667e820c2b3fcec417becbd2034acc13e4f04fe Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/157168 Commit-Queue: Mirko Bonadei <mbonadei@webrtc.org> Reviewed-by: Karl Wiberg <kwiberg@webrtc.org> Reviewed-by: Nico Weber <thakis@chromium.org> Cr-Commit-Position: refs/heads/master@{#29525}
This commit is contained in:

committed by
Commit Bot

parent
e8b962bd3c
commit
86d053c2db
@ -10,7 +10,7 @@ import("../webrtc.gni")
|
||||
|
||||
visibility = [ ":*" ]
|
||||
|
||||
rtc_static_library("common_audio") {
|
||||
rtc_library("common_audio") {
|
||||
visibility += [ "*" ]
|
||||
sources = [
|
||||
"audio_converter.cc",
|
||||
@ -101,7 +101,7 @@ rtc_source_set("common_audio_c_arm_asm") {
|
||||
}
|
||||
}
|
||||
|
||||
rtc_source_set("common_audio_c") {
|
||||
rtc_library("common_audio_c") {
|
||||
visibility += webrtc_default_visibility
|
||||
sources = [
|
||||
"ring_buffer.c",
|
||||
@ -193,7 +193,7 @@ rtc_source_set("common_audio_c") {
|
||||
]
|
||||
}
|
||||
|
||||
rtc_source_set("common_audio_cc") {
|
||||
rtc_library("common_audio_cc") {
|
||||
sources = [
|
||||
"signal_processing/dot_product_with_scale.cc",
|
||||
"signal_processing/dot_product_with_scale.h",
|
||||
@ -225,7 +225,7 @@ rtc_source_set("fir_filter") {
|
||||
]
|
||||
}
|
||||
|
||||
rtc_source_set("fir_filter_factory") {
|
||||
rtc_library("fir_filter_factory") {
|
||||
visibility += webrtc_default_visibility
|
||||
sources = [
|
||||
"fir_filter_c.cc",
|
||||
@ -249,7 +249,7 @@ rtc_source_set("fir_filter_factory") {
|
||||
}
|
||||
|
||||
if (current_cpu == "x86" || current_cpu == "x64") {
|
||||
rtc_static_library("common_audio_sse2") {
|
||||
rtc_library("common_audio_sse2") {
|
||||
sources = [
|
||||
"fir_filter_sse.cc",
|
||||
"fir_filter_sse.h",
|
||||
@ -271,7 +271,7 @@ if (current_cpu == "x86" || current_cpu == "x64") {
|
||||
}
|
||||
|
||||
if (rtc_build_with_neon) {
|
||||
rtc_static_library("common_audio_neon") {
|
||||
rtc_library("common_audio_neon") {
|
||||
sources = [
|
||||
"fir_filter_neon.cc",
|
||||
"fir_filter_neon.h",
|
||||
@ -294,7 +294,7 @@ if (rtc_build_with_neon) {
|
||||
]
|
||||
}
|
||||
|
||||
rtc_source_set("common_audio_neon_c") {
|
||||
rtc_library("common_audio_neon_c") {
|
||||
visibility += webrtc_default_visibility
|
||||
sources = [
|
||||
"signal_processing/cross_correlation_neon.c",
|
||||
|
2
common_audio/third_party/fft4g/BUILD.gn
vendored
2
common_audio/third_party/fft4g/BUILD.gn
vendored
@ -8,7 +8,7 @@
|
||||
|
||||
import("../../../webrtc.gni")
|
||||
|
||||
rtc_source_set("fft4g") {
|
||||
rtc_library("fft4g") {
|
||||
sources = [
|
||||
"fft4g.c",
|
||||
"fft4g.h",
|
||||
|
@ -8,7 +8,7 @@
|
||||
|
||||
import("../../../webrtc.gni")
|
||||
|
||||
rtc_source_set("spl_sqrt_floor") {
|
||||
rtc_library("spl_sqrt_floor") {
|
||||
visibility = [ "../..:common_audio_c" ]
|
||||
sources = [
|
||||
"spl_sqrt_floor.h",
|
||||
|
Reference in New Issue
Block a user