blob: 7b31309795833c7381838dd23c2ba18aa18336c9 [file] [log] [blame]
skvladcc91d282016-10-03 18:31:22 -07001# Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
2#
3# Use of this source code is governed by a BSD-style license
4# that can be found in the LICENSE file in the root of the source
5# tree. An additional intellectual property rights grant can be found
6# in the file PATENTS. All contributing project authors may
7# be found in the AUTHORS file in the root of the source tree.
8
mbonadei9aa3f0a2017-01-24 06:58:22 -08009import("../webrtc.gni")
skvladcc91d282016-10-03 18:31:22 -070010import("//third_party/protobuf/proto_library.gni")
11if (is_android) {
12 import("//build/config/android/config.gni")
13 import("//build/config/android/rules.gni")
14}
15
kjellander6ceab082016-10-28 05:44:03 -070016group("logging") {
17 public_deps = [
18 ":rtc_event_log_impl",
19 ]
20 if (rtc_enable_protobuf) {
21 public_deps += [ ":rtc_event_log_parser" ]
22 }
23}
24
skvladcc91d282016-10-03 18:31:22 -070025rtc_source_set("rtc_event_log_api") {
26 sources = [
Elad Alon652cc842017-10-02 11:27:52 +020027 "rtc_event_log/events/rtc_event.h",
Ilya Nikolaevskiya4259f62017-12-05 13:19:45 +010028 "rtc_event_log/events/rtc_event_alr_state.cc",
29 "rtc_event_log/events/rtc_event_alr_state.h",
Elad Alon652cc842017-10-02 11:27:52 +020030 "rtc_event_log/events/rtc_event_audio_network_adaptation.cc",
31 "rtc_event_log/events/rtc_event_audio_network_adaptation.h",
32 "rtc_event_log/events/rtc_event_audio_playout.cc",
33 "rtc_event_log/events/rtc_event_audio_playout.h",
34 "rtc_event_log/events/rtc_event_audio_receive_stream_config.cc",
35 "rtc_event_log/events/rtc_event_audio_receive_stream_config.h",
36 "rtc_event_log/events/rtc_event_audio_send_stream_config.cc",
37 "rtc_event_log/events/rtc_event_audio_send_stream_config.h",
38 "rtc_event_log/events/rtc_event_bwe_update_delay_based.cc",
39 "rtc_event_log/events/rtc_event_bwe_update_delay_based.h",
40 "rtc_event_log/events/rtc_event_bwe_update_loss_based.cc",
41 "rtc_event_log/events/rtc_event_bwe_update_loss_based.h",
42 "rtc_event_log/events/rtc_event_logging_started.cc",
43 "rtc_event_log/events/rtc_event_logging_started.h",
44 "rtc_event_log/events/rtc_event_logging_stopped.cc",
45 "rtc_event_log/events/rtc_event_logging_stopped.h",
46 "rtc_event_log/events/rtc_event_probe_cluster_created.cc",
47 "rtc_event_log/events/rtc_event_probe_cluster_created.h",
48 "rtc_event_log/events/rtc_event_probe_result_failure.cc",
49 "rtc_event_log/events/rtc_event_probe_result_failure.h",
50 "rtc_event_log/events/rtc_event_probe_result_success.cc",
51 "rtc_event_log/events/rtc_event_probe_result_success.h",
52 "rtc_event_log/events/rtc_event_rtcp_packet_incoming.cc",
53 "rtc_event_log/events/rtc_event_rtcp_packet_incoming.h",
54 "rtc_event_log/events/rtc_event_rtcp_packet_outgoing.cc",
55 "rtc_event_log/events/rtc_event_rtcp_packet_outgoing.h",
56 "rtc_event_log/events/rtc_event_rtp_packet_incoming.cc",
57 "rtc_event_log/events/rtc_event_rtp_packet_incoming.h",
58 "rtc_event_log/events/rtc_event_rtp_packet_outgoing.cc",
59 "rtc_event_log/events/rtc_event_rtp_packet_outgoing.h",
60 "rtc_event_log/events/rtc_event_video_receive_stream_config.cc",
61 "rtc_event_log/events/rtc_event_video_receive_stream_config.h",
62 "rtc_event_log/events/rtc_event_video_send_stream_config.cc",
63 "rtc_event_log/events/rtc_event_video_send_stream_config.h",
Elad Alon83ccca12017-10-04 13:18:26 +020064 "rtc_event_log/output/rtc_event_log_output_file.cc",
65 "rtc_event_log/output/rtc_event_log_output_file.h",
skvladcc91d282016-10-03 18:31:22 -070066 "rtc_event_log/rtc_event_log.h",
zhihuang38ede132017-06-15 12:52:32 -070067 "rtc_event_log/rtc_event_log_factory_interface.h",
eladalon4bb3b9c2017-09-11 07:25:26 -070068 "rtc_event_log/rtc_stream_config.cc",
69 "rtc_event_log/rtc_stream_config.h",
skvladcc91d282016-10-03 18:31:22 -070070 ]
Elad Alon83ccca12017-10-04 13:18:26 +020071
kjellander727ac1d2017-03-08 02:12:11 -080072 deps = [
perkj77cd58e2017-05-30 03:52:10 -070073 "..:webrtc_common",
Bjorn Terelius440216f2017-09-29 21:01:42 +020074 "../api:array_view",
Elad Alon80810732017-10-06 13:07:32 +020075 "../api:libjingle_logging_api",
Stefan Holmer1acbd682017-09-01 15:29:28 +020076 "../api:libjingle_peerconnection_api",
aleloi440b6d92017-08-22 05:43:23 -070077 "../call:video_stream_api",
Elad Alon078a7812017-10-02 13:33:31 +020078 "../modules/audio_coding:audio_network_adaptor_config",
79 "../modules/remote_bitrate_estimator:remote_bitrate_estimator",
80 "../modules/rtp_rtcp:rtp_rtcp_format",
ehmaldonadof6a861a2017-07-19 10:40:47 -070081 "../rtc_base:rtc_base_approved",
Elad Alon83ccca12017-10-04 13:18:26 +020082 "../system_wrappers",
kjellander727ac1d2017-03-08 02:12:11 -080083 ]
Elad Alon83ccca12017-10-04 13:18:26 +020084
85 # TODO(eladalon): Remove this.
86 if (!build_with_chromium && is_clang) {
87 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
88 suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
89 }
skvladcc91d282016-10-03 18:31:22 -070090}
91
92rtc_static_library("rtc_event_log_impl") {
93 sources = [
Elad Alon1d87b0e2017-10-03 15:01:03 +020094 "rtc_event_log/encoder/rtc_event_log_encoder.h",
95 "rtc_event_log/encoder/rtc_event_log_encoder_legacy.cc",
96 "rtc_event_log/encoder/rtc_event_log_encoder_legacy.h",
skvladcc91d282016-10-03 18:31:22 -070097 "rtc_event_log/rtc_event_log.cc",
zhihuang38ede132017-06-15 12:52:32 -070098 "rtc_event_log/rtc_event_log_factory.cc",
99 "rtc_event_log/rtc_event_log_factory.h",
skvladcc91d282016-10-03 18:31:22 -0700100 ]
101
102 defines = []
103
104 deps = [
105 ":rtc_event_log_api",
106 "..:webrtc_common",
minyue4b7c9522017-01-24 04:54:59 -0800107 "../modules/audio_coding:audio_network_adaptor",
michaelt97653702017-04-11 00:49:44 -0700108 "../modules/remote_bitrate_estimator:remote_bitrate_estimator",
Mirko Bonadeib5728d92017-12-06 07:51:33 +0100109 "../modules/rtp_rtcp:rtp_rtcp_format",
ehmaldonadof6a861a2017-07-19 10:40:47 -0700110 "../rtc_base:protobuf_utils",
111 "../rtc_base:rtc_base_approved",
eladalon248fd4f2017-09-06 05:18:15 -0700112 "../rtc_base:rtc_task_queue",
113 "../rtc_base:sequenced_task_checker",
kjellander727ac1d2017-03-08 02:12:11 -0800114 "../system_wrappers",
skvladcc91d282016-10-03 18:31:22 -0700115 ]
116
117 if (rtc_enable_protobuf) {
118 defines += [ "ENABLE_RTC_EVENT_LOG" ]
119 deps += [ ":rtc_event_log_proto" ]
120 }
Elad Alon83ccca12017-10-04 13:18:26 +0200121
122 # TODO(eladalon): Remove this.
kjellandere40a7ee2016-10-16 23:56:12 -0700123 if (!build_with_chromium && is_clang) {
124 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
skvladcc91d282016-10-03 18:31:22 -0700125 suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
126 }
127}
128
skvladcc91d282016-10-03 18:31:22 -0700129if (rtc_enable_protobuf) {
130 proto_library("rtc_event_log_proto") {
131 sources = [
132 "rtc_event_log/rtc_event_log.proto",
133 ]
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200134 proto_out_dir = "logging/rtc_event_log"
skvladcc91d282016-10-03 18:31:22 -0700135 }
skvladcc91d282016-10-03 18:31:22 -0700136
skvladcc91d282016-10-03 18:31:22 -0700137 rtc_static_library("rtc_event_log_parser") {
138 sources = [
139 "rtc_event_log/rtc_event_log_parser.cc",
140 "rtc_event_log/rtc_event_log_parser.h",
141 ]
142
143 public_deps = [
kjellander727ac1d2017-03-08 02:12:11 -0800144 ":rtc_event_log_api",
skvladcc91d282016-10-03 18:31:22 -0700145 ":rtc_event_log_proto",
146 "..:webrtc_common",
michaeltcde46b72017-04-06 05:59:10 -0700147 "../modules/audio_coding:audio_network_adaptor",
michaelt97653702017-04-11 00:49:44 -0700148 "../modules/remote_bitrate_estimator:remote_bitrate_estimator",
Mirko Bonadeib5728d92017-12-06 07:51:33 +0100149 "../modules/rtp_rtcp",
kjellander727ac1d2017-03-08 02:12:11 -0800150 "../system_wrappers",
skvladcc91d282016-10-03 18:31:22 -0700151 ]
152
kjellandere40a7ee2016-10-16 23:56:12 -0700153 if (!build_with_chromium && is_clang) {
154 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
skvladcc91d282016-10-03 18:31:22 -0700155 suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
156 }
kjellander727ac1d2017-03-08 02:12:11 -0800157 deps = [
aleloi440b6d92017-08-22 05:43:23 -0700158 "../call:video_stream_api",
Mirko Bonadeib5728d92017-12-06 07:51:33 +0100159 "../modules/rtp_rtcp:rtp_rtcp_format",
ehmaldonadof6a861a2017-07-19 10:40:47 -0700160 "../rtc_base:protobuf_utils",
161 "../rtc_base:rtc_base_approved",
kjellander727ac1d2017-03-08 02:12:11 -0800162 ]
skvladcc91d282016-10-03 18:31:22 -0700163 }
ehmaldonado1fd08c12017-01-17 02:37:34 -0800164
165 if (rtc_include_tests) {
166 rtc_source_set("rtc_event_log_tests") {
167 testonly = true
Elad Alon1d87b0e2017-10-03 15:01:03 +0200168 assert(rtc_enable_protobuf)
169 defines = [ "ENABLE_RTC_EVENT_LOG" ]
Elad Alon8233bfe2017-10-05 15:27:29 +0200170 if (rtc_use_memcheck) {
171 defines += [ "WEBRTC_USE_MEMCHECK" ]
172 }
ehmaldonado1fd08c12017-01-17 02:37:34 -0800173 sources = [
Elad Alon1d87b0e2017-10-03 15:01:03 +0200174 "rtc_event_log/encoder/rtc_event_log_encoder_unittest.cc",
Elad Alon83ccca12017-10-04 13:18:26 +0200175 "rtc_event_log/output/rtc_event_log_output_file_unittest.cc",
ehmaldonado1fd08c12017-01-17 02:37:34 -0800176 "rtc_event_log/rtc_event_log_unittest.cc",
177 "rtc_event_log/rtc_event_log_unittest_helper.cc",
eladalonb5c319a2017-08-17 08:32:39 -0700178 "rtc_event_log/rtc_event_log_unittest_helper.h",
ehmaldonado1fd08c12017-01-17 02:37:34 -0800179 ]
180 deps = [
181 ":rtc_event_log_impl",
182 ":rtc_event_log_parser",
Mirko Bonadeia0e1a552017-12-04 10:50:51 +0100183 "../api:libjingle_peerconnection_api",
ehmaldonado1fd08c12017-01-17 02:37:34 -0800184 "../call",
Mirko Bonadeia0e1a552017-12-04 10:50:51 +0100185 "../call:call_interfaces",
michaeltcde46b72017-04-06 05:59:10 -0700186 "../modules/audio_coding:audio_network_adaptor",
michaelt97653702017-04-11 00:49:44 -0700187 "../modules/remote_bitrate_estimator:remote_bitrate_estimator",
Mirko Bonadeib5728d92017-12-06 07:51:33 +0100188 "../modules/rtp_rtcp:rtp_rtcp_format",
ehmaldonadof6a861a2017-07-19 10:40:47 -0700189 "../rtc_base:rtc_base_approved",
190 "../rtc_base:rtc_base_tests_utils",
ehmaldonado1fd08c12017-01-17 02:37:34 -0800191 "../system_wrappers:metrics_default",
kjellander727ac1d2017-03-08 02:12:11 -0800192 "../test:test_support",
ehmaldonado1fd08c12017-01-17 02:37:34 -0800193 "//testing/gmock",
194 "//testing/gtest",
195 ]
196 if (!build_with_chromium && is_clang) {
197 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
198 suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
199 }
200 }
ivoc54b6e982017-02-08 00:28:09 -0800201 rtc_test("rtc_event_log2rtp_dump") {
202 testonly = true
203 sources = [
204 "rtc_event_log/rtc_event_log2rtp_dump.cc",
205 ]
206 deps = [
207 ":rtc_event_log_api",
208 ":rtc_event_log_impl",
209 ":rtc_event_log_parser",
Mirko Bonadeib5728d92017-12-06 07:51:33 +0100210 "../modules/rtp_rtcp:rtp_rtcp_format",
ehmaldonadof6a861a2017-07-19 10:40:47 -0700211 "../rtc_base:rtc_base_approved",
ivoc54b6e982017-02-08 00:28:09 -0800212 "../system_wrappers:field_trial_default",
213 "../system_wrappers:metrics_default",
214 "../test:rtp_test_utils",
ivoc54b6e982017-02-08 00:28:09 -0800215 ]
216 if (!build_with_chromium && is_clang) {
217 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
218 suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
219 }
220 }
ehmaldonado1fd08c12017-01-17 02:37:34 -0800221 }
tereliusd4ed7f52017-02-08 04:22:53 -0800222 if (rtc_include_tests) {
223 rtc_executable("rtc_event_log2text") {
224 testonly = true
225 sources = [
226 "rtc_event_log/rtc_event_log2text.cc",
227 ]
228 deps = [
229 ":rtc_event_log_api",
230 ":rtc_event_log_impl",
231 ":rtc_event_log_parser",
Stefan Holmer1acbd682017-09-01 15:29:28 +0200232 "../call:video_stream_api",
Mirko Bonadeib5728d92017-12-06 07:51:33 +0100233 "../modules/rtp_rtcp:rtp_rtcp_format",
ehmaldonadof6a861a2017-07-19 10:40:47 -0700234 "../rtc_base:rtc_base_approved",
tereliusbb46b952017-02-08 09:37:30 -0800235
236 # TODO(kwiberg): Remove this dependency.
kwiberg087bd342017-02-10 08:15:44 -0800237 "../api/audio_codecs:audio_codecs_api",
Elad Alona96fd7f2017-09-15 16:13:21 +0200238 "../modules/audio_coding:audio_network_adaptor_config",
Mirko Bonadeib5728d92017-12-06 07:51:33 +0100239 "../modules/rtp_rtcp",
tereliusd4ed7f52017-02-08 04:22:53 -0800240 ]
241 if (!build_with_chromium && is_clang) {
242 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
243 suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
244 }
245 }
246 }
tereliusee37e862017-04-28 07:48:17 -0700247 if (rtc_include_tests) {
248 rtc_executable("rtc_event_log2stats") {
249 testonly = true
250 sources = [
251 "rtc_event_log/rtc_event_log2stats.cc",
252 ]
253 deps = [
254 ":rtc_event_log_api",
255 ":rtc_event_log_impl",
256 ":rtc_event_log_proto",
ehmaldonadof6a861a2017-07-19 10:40:47 -0700257 "../rtc_base:rtc_base_approved",
tereliusee37e862017-04-28 07:48:17 -0700258 ]
259 if (!build_with_chromium && is_clang) {
260 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
261 suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
262 }
263 }
264 }
skvladcc91d282016-10-03 18:31:22 -0700265}