blob: d8b4b8493bfba31464a29abb492ee15e2241df9b [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")
Kimmo Kinnunen08f6a6c2019-02-26 11:46:17 +020010if (rtc_enable_protobuf) {
Dan Minor9c686132018-01-15 10:20:00 -050011 import("//third_party/protobuf/proto_library.gni")
12}
skvladcc91d282016-10-03 18:31:22 -070013if (is_android) {
14 import("//build/config/android/config.gni")
15 import("//build/config/android/rules.gni")
16}
17
kjellander6ceab082016-10-28 05:44:03 -070018group("logging") {
Mirko Bonadei818d9102017-12-12 12:46:13 +010019 deps = [
Qingsi Wang970b0882018-02-01 11:04:46 -080020 ":rtc_event_audio",
Björn Tereliusc15bced2022-01-18 16:03:42 +010021 ":rtc_event_begin_end",
Qingsi Wang970b0882018-02-01 11:04:46 -080022 ":rtc_event_bwe",
Qingsi Wang970b0882018-02-01 11:04:46 -080023 ":rtc_event_log_impl_encoder",
Qingsi Wang970b0882018-02-01 11:04:46 -080024 ":rtc_event_pacing",
25 ":rtc_event_rtp_rtcp",
26 ":rtc_event_video",
kjellander6ceab082016-10-28 05:44:03 -070027 ]
kjellander6ceab082016-10-28 05:44:03 -070028}
29
skvladcc91d282016-10-03 18:31:22 -070030rtc_source_set("rtc_event_log_api") {
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +010031 sources = [ "rtc_event_log/encoder/rtc_event_log_encoder.h" ]
Qingsi Wang970b0882018-02-01 11:04:46 -080032
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +010033 deps = [ "../api/rtc_event_log" ]
Qingsi Wang970b0882018-02-01 11:04:46 -080034}
35
Björn Terelius98952d72021-09-22 19:37:22 +020036rtc_library("rtc_event_field") {
37 sources = [
Björn Tereliusfe903d52021-09-27 18:30:44 +020038 "rtc_event_log/events/fixed_length_encoding_parameters_v3.cc",
39 "rtc_event_log/events/fixed_length_encoding_parameters_v3.h",
Björn Terelius01ef37c2022-01-20 14:36:52 +010040 "rtc_event_log/events/rtc_event_definition.h",
Björn Tereliusfe903d52021-09-27 18:30:44 +020041 "rtc_event_log/events/rtc_event_field_encoding.cc",
42 "rtc_event_log/events/rtc_event_field_encoding.h",
43 "rtc_event_log/events/rtc_event_field_encoding_parser.cc",
44 "rtc_event_log/events/rtc_event_field_encoding_parser.h",
Björn Terelius98952d72021-09-22 19:37:22 +020045 "rtc_event_log/events/rtc_event_field_extraction.cc",
46 "rtc_event_log/events/rtc_event_field_extraction.h",
47 ]
48
49 deps = [
50 ":rtc_event_number_encodings",
51 "../api:array_view",
52 "../api/rtc_event_log",
Björn Tereliusc15bced2022-01-18 16:03:42 +010053 "../api/units:timestamp",
Björn Tereliusfe903d52021-09-27 18:30:44 +020054 "../rtc_base:bitstream_reader",
Björn Terelius98952d72021-09-22 19:37:22 +020055 "../rtc_base:checks",
56 "../rtc_base:logging",
Björn Terelius98952d72021-09-22 19:37:22 +020057 ]
58 absl_deps = [
Björn Terelius98952d72021-09-22 19:37:22 +020059 "//third_party/abseil-cpp/absl/strings",
60 "//third_party/abseil-cpp/absl/types:optional",
61 ]
62}
63
Mirko Bonadei86d053c2019-10-17 21:32:04 +020064rtc_library("rtc_stream_config") {
Qingsi Wang970b0882018-02-01 11:04:46 -080065 sources = [
66 "rtc_event_log/rtc_stream_config.cc",
67 "rtc_event_log/rtc_stream_config.h",
68 ]
69
70 deps = [
Niels Mölleref1052a2019-03-20 08:40:23 +010071 "../api:rtp_headers",
Niels Möller6dcd4dc2019-08-26 10:45:28 +020072 "../api:rtp_parameters",
Qingsi Wang970b0882018-02-01 11:04:46 -080073 ]
74}
75
Mirko Bonadei86d053c2019-10-17 21:32:04 +020076rtc_library("rtc_event_pacing") {
Qingsi Wang970b0882018-02-01 11:04:46 -080077 sources = [
Ilya Nikolaevskiya4259f62017-12-05 13:19:45 +010078 "rtc_event_log/events/rtc_event_alr_state.cc",
79 "rtc_event_log/events/rtc_event_alr_state.h",
Qingsi Wang970b0882018-02-01 11:04:46 -080080 ]
81
82 deps = [
Björn Tereliusc15bced2022-01-18 16:03:42 +010083 ":rtc_event_field",
Danil Chapovalov16cb1f62019-09-05 11:29:59 +020084 "../api/rtc_event_log",
Björn Tereliusada810a2021-05-24 10:19:55 +020085 "../api/units:timestamp",
Qingsi Wang970b0882018-02-01 11:04:46 -080086 ]
Björn Tereliusd12a14e2022-02-08 18:20:18 +010087 absl_deps = [
88 "//third_party/abseil-cpp/absl/memory",
89 "//third_party/abseil-cpp/absl/strings",
90 ]
Qingsi Wang970b0882018-02-01 11:04:46 -080091}
92
Mirko Bonadei86d053c2019-10-17 21:32:04 +020093rtc_library("rtc_event_audio") {
Qingsi Wang970b0882018-02-01 11:04:46 -080094 sources = [
Elad Alon652cc842017-10-02 11:27:52 +020095 "rtc_event_log/events/rtc_event_audio_network_adaptation.cc",
96 "rtc_event_log/events/rtc_event_audio_network_adaptation.h",
97 "rtc_event_log/events/rtc_event_audio_playout.cc",
98 "rtc_event_log/events/rtc_event_audio_playout.h",
99 "rtc_event_log/events/rtc_event_audio_receive_stream_config.cc",
100 "rtc_event_log/events/rtc_event_audio_receive_stream_config.h",
101 "rtc_event_log/events/rtc_event_audio_send_stream_config.cc",
102 "rtc_event_log/events/rtc_event_audio_send_stream_config.h",
Qingsi Wang970b0882018-02-01 11:04:46 -0800103 ]
104
105 deps = [
Björn Tereliusd12a14e2022-02-08 18:20:18 +0100106 ":rtc_event_field",
Qingsi Wang970b0882018-02-01 11:04:46 -0800107 ":rtc_stream_config",
Danil Chapovalov16cb1f62019-09-05 11:29:59 +0200108 "../api/rtc_event_log",
Björn Tereliusada810a2021-05-24 10:19:55 +0200109 "../api/units:timestamp",
Qingsi Wang970b0882018-02-01 11:04:46 -0800110 "../modules/audio_coding:audio_network_adaptor_config",
Elad Alon0b1b5c12018-11-09 21:50:14 +0100111 "../rtc_base:checks",
Qingsi Wang970b0882018-02-01 11:04:46 -0800112 ]
Björn Tereliusd12a14e2022-02-08 18:20:18 +0100113 absl_deps = [
114 "//third_party/abseil-cpp/absl/memory",
115 "//third_party/abseil-cpp/absl/strings",
116 ]
Qingsi Wang970b0882018-02-01 11:04:46 -0800117}
118
Björn Tereliusc15bced2022-01-18 16:03:42 +0100119rtc_library("rtc_event_begin_end") {
120 sources = [
121 "rtc_event_log/events/rtc_event_begin_log.cc",
122 "rtc_event_log/events/rtc_event_begin_log.h",
123 "rtc_event_log/events/rtc_event_end_log.cc",
124 "rtc_event_log/events/rtc_event_end_log.h",
125 ]
126 deps = [
127 ":rtc_event_field",
128 "../api:array_view",
129 "../api/rtc_event_log",
130 "../api/units:timestamp",
131 ]
132 absl_deps = [ "//third_party/abseil-cpp/absl/strings" ]
133}
134
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200135rtc_library("rtc_event_bwe") {
Qingsi Wang970b0882018-02-01 11:04:46 -0800136 sources = [
Elad Alon652cc842017-10-02 11:27:52 +0200137 "rtc_event_log/events/rtc_event_bwe_update_delay_based.cc",
138 "rtc_event_log/events/rtc_event_bwe_update_delay_based.h",
139 "rtc_event_log/events/rtc_event_bwe_update_loss_based.cc",
140 "rtc_event_log/events/rtc_event_bwe_update_loss_based.h",
Elad Alon652cc842017-10-02 11:27:52 +0200141 "rtc_event_log/events/rtc_event_probe_cluster_created.cc",
142 "rtc_event_log/events/rtc_event_probe_cluster_created.h",
143 "rtc_event_log/events/rtc_event_probe_result_failure.cc",
144 "rtc_event_log/events/rtc_event_probe_result_failure.h",
145 "rtc_event_log/events/rtc_event_probe_result_success.cc",
146 "rtc_event_log/events/rtc_event_probe_result_success.h",
Sebastian Jansson0a5ed892019-09-18 15:37:31 +0200147 "rtc_event_log/events/rtc_event_remote_estimate.h",
Sebastian Jansson166b45d2019-05-13 11:57:42 +0200148 "rtc_event_log/events/rtc_event_route_change.cc",
149 "rtc_event_log/events/rtc_event_route_change.h",
Qingsi Wang970b0882018-02-01 11:04:46 -0800150 ]
151
152 deps = [
Björn Tereliusd12a14e2022-02-08 18:20:18 +0100153 ":rtc_event_field",
Niels Möller0d863f72020-11-24 17:50:31 +0100154 "../api:network_state_predictor_api",
Danil Chapovalov16cb1f62019-09-05 11:29:59 +0200155 "../api/rtc_event_log",
Sebastian Jansson0a5ed892019-09-18 15:37:31 +0200156 "../api/units:data_rate",
Björn Tereliusada810a2021-05-24 10:19:55 +0200157 "../api/units:timestamp",
Mirko Bonadei2dcf3482020-06-05 14:30:41 +0200158 ]
159 absl_deps = [
Karl Wiberg918f50c2018-07-05 11:40:33 +0200160 "//third_party/abseil-cpp/absl/memory",
Björn Tereliusd12a14e2022-02-08 18:20:18 +0100161 "//third_party/abseil-cpp/absl/strings",
Sebastian Jansson0a5ed892019-09-18 15:37:31 +0200162 "//third_party/abseil-cpp/absl/types:optional",
Qingsi Wang970b0882018-02-01 11:04:46 -0800163 ]
164}
165
Björn Terelius00c12f62020-08-06 12:37:08 +0200166rtc_library("rtc_event_frame_events") {
167 sources = [
168 "rtc_event_log/events/rtc_event_frame_decoded.cc",
169 "rtc_event_log/events/rtc_event_frame_decoded.h",
170 ]
171 deps = [
Björn Terelius9a609702022-02-11 14:25:49 +0100172 ":rtc_event_field",
Björn Terelius00c12f62020-08-06 12:37:08 +0200173 "../api/rtc_event_log",
Björn Tereliusada810a2021-05-24 10:19:55 +0200174 "../api/units:timestamp",
Björn Terelius00c12f62020-08-06 12:37:08 +0200175 "../api/video:video_frame",
176 "../rtc_base:timeutils",
177 ]
178 absl_deps = [
179 "//third_party/abseil-cpp/absl/memory",
Björn Terelius9a609702022-02-11 14:25:49 +0100180 "//third_party/abseil-cpp/absl/strings",
Björn Terelius00c12f62020-08-06 12:37:08 +0200181 "//third_party/abseil-cpp/absl/types:optional",
182 ]
183}
184
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200185rtc_library("rtc_event_generic_packet_events") {
Piotr (Peter) Slatalaf6adac82019-02-08 10:31:35 -0800186 visibility = [ "*" ]
187 sources = [
188 "rtc_event_log/events/rtc_event_generic_ack_received.cc",
189 "rtc_event_log/events/rtc_event_generic_ack_received.h",
190 "rtc_event_log/events/rtc_event_generic_packet_received.cc",
191 "rtc_event_log/events/rtc_event_generic_packet_received.h",
192 "rtc_event_log/events/rtc_event_generic_packet_sent.cc",
193 "rtc_event_log/events/rtc_event_generic_packet_sent.h",
194 ]
195 deps = [
Björn Terelius9a609702022-02-11 14:25:49 +0100196 ":rtc_event_field",
Danil Chapovalov16cb1f62019-09-05 11:29:59 +0200197 "../api/rtc_event_log",
Björn Tereliusada810a2021-05-24 10:19:55 +0200198 "../api/units:timestamp",
Danil Chapovalovb32f2c72019-05-22 13:39:25 +0200199 "../rtc_base:timeutils",
Mirko Bonadei2dcf3482020-06-05 14:30:41 +0200200 ]
201 absl_deps = [
tzik8aa00f02019-02-18 22:28:26 +0900202 "//third_party/abseil-cpp/absl/memory",
Björn Terelius9a609702022-02-11 14:25:49 +0100203 "//third_party/abseil-cpp/absl/strings",
Danil Chapovalovb32f2c72019-05-22 13:39:25 +0200204 "//third_party/abseil-cpp/absl/types:optional",
Piotr (Peter) Slatalaf6adac82019-02-08 10:31:35 -0800205 ]
Piotr (Peter) Slatalaf6adac82019-02-08 10:31:35 -0800206}
207
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200208rtc_library("rtc_event_rtp_rtcp") {
Qingsi Wang970b0882018-02-01 11:04:46 -0800209 sources = [
Björn Terelius9a609702022-02-11 14:25:49 +0100210 "rtc_event_log/events/logged_rtp_rtcp.h",
Elad Alon652cc842017-10-02 11:27:52 +0200211 "rtc_event_log/events/rtc_event_rtcp_packet_incoming.cc",
212 "rtc_event_log/events/rtc_event_rtcp_packet_incoming.h",
213 "rtc_event_log/events/rtc_event_rtcp_packet_outgoing.cc",
214 "rtc_event_log/events/rtc_event_rtcp_packet_outgoing.h",
215 "rtc_event_log/events/rtc_event_rtp_packet_incoming.cc",
216 "rtc_event_log/events/rtc_event_rtp_packet_incoming.h",
217 "rtc_event_log/events/rtc_event_rtp_packet_outgoing.cc",
218 "rtc_event_log/events/rtc_event_rtp_packet_outgoing.h",
Qingsi Wang970b0882018-02-01 11:04:46 -0800219 ]
220
221 deps = [
Björn Terelius9a609702022-02-11 14:25:49 +0100222 ":rtc_event_field",
Qingsi Wang970b0882018-02-01 11:04:46 -0800223 "../api:array_view",
Björn Terelius9a609702022-02-11 14:25:49 +0100224 "../api:rtp_headers",
Danil Chapovalov16cb1f62019-09-05 11:29:59 +0200225 "../api/rtc_event_log",
Björn Terelius9a609702022-02-11 14:25:49 +0100226 "../api/units:timestamp",
Qingsi Wang970b0882018-02-01 11:04:46 -0800227 "../modules/rtp_rtcp:rtp_rtcp_format",
Florent Castellif9c59842022-04-19 17:07:23 +0200228 "../rtc_base:buffer",
Elad Alon0b1b5c12018-11-09 21:50:14 +0100229 "../rtc_base:checks",
Qingsi Wang970b0882018-02-01 11:04:46 -0800230 ]
Björn Terelius9a609702022-02-11 14:25:49 +0100231 absl_deps = [
232 "//third_party/abseil-cpp/absl/memory",
233 "//third_party/abseil-cpp/absl/strings",
234 ]
Qingsi Wang970b0882018-02-01 11:04:46 -0800235}
236
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200237rtc_library("rtc_event_video") {
Qingsi Wang970b0882018-02-01 11:04:46 -0800238 sources = [
Elad Alon652cc842017-10-02 11:27:52 +0200239 "rtc_event_log/events/rtc_event_video_receive_stream_config.cc",
240 "rtc_event_log/events/rtc_event_video_receive_stream_config.h",
241 "rtc_event_log/events/rtc_event_video_send_stream_config.cc",
242 "rtc_event_log/events/rtc_event_video_send_stream_config.h",
skvladcc91d282016-10-03 18:31:22 -0700243 ]
Elad Alon83ccca12017-10-04 13:18:26 +0200244
kjellander727ac1d2017-03-08 02:12:11 -0800245 deps = [
Björn Terelius9a609702022-02-11 14:25:49 +0100246 ":rtc_event_field",
Qingsi Wang970b0882018-02-01 11:04:46 -0800247 ":rtc_stream_config",
Danil Chapovalov16cb1f62019-09-05 11:29:59 +0200248 "../api/rtc_event_log",
Björn Tereliusada810a2021-05-24 10:19:55 +0200249 "../api/units:timestamp",
Elad Alon0b1b5c12018-11-09 21:50:14 +0100250 "../rtc_base:checks",
kjellander727ac1d2017-03-08 02:12:11 -0800251 ]
Björn Terelius9a609702022-02-11 14:25:49 +0100252 absl_deps = [
253 "//third_party/abseil-cpp/absl/memory",
254 "//third_party/abseil-cpp/absl/strings",
255 ]
skvladcc91d282016-10-03 18:31:22 -0700256}
257
Björn Terelius98952d72021-09-22 19:37:22 +0200258rtc_library("rtc_event_number_encodings") {
skvladcc91d282016-10-03 18:31:22 -0700259 sources = [
Björn Terelius98952d72021-09-22 19:37:22 +0200260 "rtc_event_log/encoder/bit_writer.cc",
261 "rtc_event_log/encoder/bit_writer.h",
Elad Alond95b0a22018-11-09 16:38:54 +0100262 "rtc_event_log/encoder/rtc_event_log_encoder_common.cc",
263 "rtc_event_log/encoder/rtc_event_log_encoder_common.h",
Steve Anton10542f22019-01-11 09:11:00 -0800264 "rtc_event_log/encoder/var_int.cc",
265 "rtc_event_log/encoder/var_int.h",
skvladcc91d282016-10-03 18:31:22 -0700266 ]
267
268 defines = []
269
270 deps = [
Florent Castelli7f623b02022-04-14 13:34:56 +0200271 "../rtc_base:bit_buffer",
Björn Terelius98952d72021-09-22 19:37:22 +0200272 "../rtc_base:bitstream_reader",
273 "../rtc_base:checks",
274 "../rtc_base:ignore_wundef",
275 "../rtc_base:macromagic",
Björn Terelius98952d72021-09-22 19:37:22 +0200276 ]
277 absl_deps = [
278 "//third_party/abseil-cpp/absl/memory",
279 "//third_party/abseil-cpp/absl/strings",
280 "//third_party/abseil-cpp/absl/types:optional",
281 ]
282}
283
284# TODO(eladalon): Break down into (1) encoder and (2) decoder; we don't need
285# the decoder code in the WebRTC library, only in unit tests and tools.
286rtc_library("rtc_event_log_impl_encoder") {
287 sources = [
288 "rtc_event_log/encoder/blob_encoding.cc",
289 "rtc_event_log/encoder/blob_encoding.h",
290 "rtc_event_log/encoder/delta_encoding.cc",
291 "rtc_event_log/encoder/delta_encoding.h",
292 ]
293
294 defines = []
295
296 deps = [
297 ":rtc_event_number_encodings",
Niels Mölleref1052a2019-03-20 08:40:23 +0100298 "../api:rtp_headers",
Niels Möller6dcd4dc2019-08-26 10:45:28 +0200299 "../api:rtp_parameters",
Yves Gerey3e707812018-11-28 16:47:49 +0100300 "../api/transport:network_control",
Florent Castelli7f623b02022-04-14 13:34:56 +0200301 "../rtc_base:bit_buffer",
Danil Chapovalov707e3d12021-09-07 15:19:16 +0200302 "../rtc_base:bitstream_reader",
Florent Castellif9c59842022-04-19 17:07:23 +0200303 "../rtc_base:buffer",
Patrik Höglunda8005cf2017-12-13 16:05:42 +0100304 "../rtc_base:checks",
Mirko Bonadei3663ed32019-10-19 12:03:23 +0200305 "../rtc_base:ignore_wundef",
Florent Castelli0af55ba2022-04-04 15:06:30 +0200306 "../rtc_base:logging",
Florent Castellie10a9f62022-04-04 17:04:37 +0200307 "../rtc_base:safe_conversions",
Mirko Bonadei2dcf3482020-06-05 14:30:41 +0200308 ]
309 absl_deps = [
Elad Alon50b1e6b2018-10-18 13:43:35 +0200310 "//third_party/abseil-cpp/absl/memory",
Artem Titov94b57c02019-03-21 13:35:10 +0100311 "//third_party/abseil-cpp/absl/strings",
Elad Alon73f39172018-10-23 18:24:10 +0200312 "//third_party/abseil-cpp/absl/types:optional",
skvladcc91d282016-10-03 18:31:22 -0700313 ]
314
315 if (rtc_enable_protobuf) {
Bjorn Tereliusc35096d2018-10-24 13:51:56 +0200316 deps += [
317 ":ice_log",
318 ":rtc_event_audio",
Björn Tereliusc15bced2022-01-18 16:03:42 +0100319 ":rtc_event_begin_end",
Bjorn Tereliusc35096d2018-10-24 13:51:56 +0200320 ":rtc_event_bwe",
Björn Terelius01ef37c2022-01-20 14:36:52 +0100321 ":rtc_event_field",
Björn Terelius00c12f62020-08-06 12:37:08 +0200322 ":rtc_event_frame_events",
Piotr (Peter) Slatalaf6adac82019-02-08 10:31:35 -0800323 ":rtc_event_generic_packet_events",
Bjorn Tereliusc35096d2018-10-24 13:51:56 +0200324 ":rtc_event_log2_proto",
325 ":rtc_event_log_api",
Bjorn Tereliusc35096d2018-10-24 13:51:56 +0200326 ":rtc_event_log_proto",
327 ":rtc_event_pacing",
328 ":rtc_event_rtp_rtcp",
329 ":rtc_event_video",
330 ":rtc_stream_config",
331 "../api:array_view",
Niels Möller0d863f72020-11-24 17:50:31 +0100332 "../api:network_state_predictor_api",
Bjorn Tereliusc35096d2018-10-24 13:51:56 +0200333 "../modules/audio_coding:audio_network_adaptor",
Bjorn Tereliusc35096d2018-10-24 13:51:56 +0200334 "../modules/rtp_rtcp:rtp_rtcp_format",
335 ]
336 sources += [
337 "rtc_event_log/encoder/rtc_event_log_encoder_legacy.cc",
338 "rtc_event_log/encoder/rtc_event_log_encoder_legacy.h",
339 "rtc_event_log/encoder/rtc_event_log_encoder_new_format.cc",
340 "rtc_event_log/encoder/rtc_event_log_encoder_new_format.h",
Björn Terelius01ef37c2022-01-20 14:36:52 +0100341 "rtc_event_log/encoder/rtc_event_log_encoder_v3.cc",
342 "rtc_event_log/encoder/rtc_event_log_encoder_v3.h",
Bjorn Tereliusc35096d2018-10-24 13:51:56 +0200343 ]
skvladcc91d282016-10-03 18:31:22 -0700344 }
skvladcc91d282016-10-03 18:31:22 -0700345}
346
Niels Möllerd8b9ed72019-05-08 13:53:51 +0200347# TODO(bugs.webrtc.org/6463): For backwards compatibility; delete as
348# soon as downstream dependencies are updated.
Qingsi Wang970b0882018-02-01 11:04:46 -0800349rtc_source_set("rtc_event_log_impl_output") {
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +0100350 sources = [ "rtc_event_log/output/rtc_event_log_output_file.h" ]
351 deps = [ "../api:rtc_event_log_output_file" ]
Qingsi Wang970b0882018-02-01 11:04:46 -0800352}
353
Danil Chapovalovb32f2c72019-05-22 13:39:25 +0200354if (rtc_enable_protobuf) {
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200355 rtc_library("rtc_event_log_impl") {
Danil Chapovalovb32f2c72019-05-22 13:39:25 +0200356 visibility = [ "../api/rtc_event_log:rtc_event_log_factory" ]
357 sources = [
358 "rtc_event_log/rtc_event_log_impl.cc",
359 "rtc_event_log/rtc_event_log_impl.h",
360 ]
361 deps = [
362 ":ice_log",
363 ":rtc_event_log_api",
364 ":rtc_event_log_impl_encoder",
365 "../api:libjingle_logging_api",
Artem Titovd15a5752021-02-10 14:31:24 +0100366 "../api:sequence_checker",
Danil Chapovalovb32f2c72019-05-22 13:39:25 +0200367 "../api/rtc_event_log",
368 "../api/task_queue",
369 "../rtc_base:checks",
Florent Castelli0af55ba2022-04-04 15:06:30 +0200370 "../rtc_base:logging",
Florent Castelli4467ad72022-04-04 15:18:46 +0200371 "../rtc_base:macromagic",
Florent Castelli33d31fb2022-04-04 16:57:52 +0200372 "../rtc_base:rtc_event",
Danil Chapovalovb32f2c72019-05-22 13:39:25 +0200373 "../rtc_base:rtc_task_queue",
Florent Castellie10a9f62022-04-04 17:04:37 +0200374 "../rtc_base:safe_conversions",
Danil Chapovalovb32f2c72019-05-22 13:39:25 +0200375 "../rtc_base:safe_minmax",
Florent Castellidd837e22022-04-04 17:16:15 +0200376 "../rtc_base:timeutils",
Mirko Bonadei20e4c802020-11-23 11:07:42 +0100377 "../rtc_base/system:no_unique_address",
Danil Chapovalovb32f2c72019-05-22 13:39:25 +0200378 ]
Mirko Bonadei2dcf3482020-06-05 14:30:41 +0200379 absl_deps = [ "//third_party/abseil-cpp/absl/types:optional" ]
Danil Chapovalovb32f2c72019-05-22 13:39:25 +0200380 }
381}
382
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200383rtc_library("fake_rtc_event_log") {
Qingsi Wang7685e862018-06-11 20:15:46 -0700384 testonly = true
385 sources = [
386 "rtc_event_log/fake_rtc_event_log.cc",
387 "rtc_event_log/fake_rtc_event_log.h",
388 "rtc_event_log/fake_rtc_event_log_factory.cc",
389 "rtc_event_log/fake_rtc_event_log_factory.h",
390 ]
391
392 deps = [
Danil Chapovalov83bbe912019-08-07 12:24:53 +0200393 "../api/rtc_event_log",
Artem Titov94b57c02019-03-21 13:35:10 +0100394 "../rtc_base",
Florent Castelli4467ad72022-04-04 15:18:46 +0200395 "../rtc_base:macromagic",
Danil Chapovalov4f281f12021-01-18 13:29:00 +0100396 "../rtc_base/synchronization:mutex",
Qingsi Wang7685e862018-06-11 20:15:46 -0700397 ]
398}
399
skvladcc91d282016-10-03 18:31:22 -0700400if (rtc_enable_protobuf) {
401 proto_library("rtc_event_log_proto") {
Mirko Bonadeid4746722018-11-19 12:00:51 +0100402 visibility = [ "*" ]
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +0100403 sources = [ "rtc_event_log/rtc_event_log.proto" ]
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200404 proto_out_dir = "logging/rtc_event_log"
skvladcc91d282016-10-03 18:31:22 -0700405 }
skvladcc91d282016-10-03 18:31:22 -0700406
Mirko Bonadeib3c210f2017-12-15 17:12:42 +0100407 proto_library("rtc_event_log2_proto") {
Mirko Bonadeid4746722018-11-19 12:00:51 +0100408 visibility = [ "*" ]
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +0100409 sources = [ "rtc_event_log/rtc_event_log2.proto" ]
Mirko Bonadeib3c210f2017-12-15 17:12:42 +0100410 proto_out_dir = "logging/rtc_event_log"
411 }
412
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200413 rtc_library("rtc_event_log_parser") {
Bjorn Terelius73df8832018-04-26 14:46:06 +0200414 visibility = [ "*" ]
skvladcc91d282016-10-03 18:31:22 -0700415 sources = [
Sebastian Jansson3f2b9aa2019-01-03 14:42:15 +0100416 "rtc_event_log/logged_events.h",
Sebastian Janssonb290a6d2019-01-03 14:46:23 +0100417 "rtc_event_log/rtc_event_log_parser.cc",
418 "rtc_event_log/rtc_event_log_parser.h",
Sebastian Jansson03fbf1e2019-01-08 15:31:06 +0100419 "rtc_event_log/rtc_event_processor.cc",
Bjorn Terelius60d629f2018-09-24 17:10:27 +0200420 "rtc_event_log/rtc_event_processor.h",
skvladcc91d282016-10-03 18:31:22 -0700421 ]
422
Mirko Bonadei818d9102017-12-12 12:46:13 +0100423 deps = [
Qingsi Wang8eca1ff2018-02-02 11:49:44 -0800424 ":ice_log",
Björn Terelius6f597bd2021-01-12 16:05:06 +0100425 ":rtc_event_audio",
Björn Tereliusc15bced2022-01-18 16:03:42 +0100426 ":rtc_event_begin_end",
Qingsi Wang970b0882018-02-01 11:04:46 -0800427 ":rtc_event_bwe",
Björn Terelius6f597bd2021-01-12 16:05:06 +0100428 ":rtc_event_frame_events",
429 ":rtc_event_generic_packet_events",
Mirko Bonadeib3c210f2017-12-15 17:12:42 +0100430 ":rtc_event_log2_proto",
Elad Alond95b0a22018-11-09 16:38:54 +0100431 ":rtc_event_log_impl_encoder",
skvladcc91d282016-10-03 18:31:22 -0700432 ":rtc_event_log_proto",
Björn Terelius98952d72021-09-22 19:37:22 +0200433 ":rtc_event_number_encodings",
Björn Terelius6f597bd2021-01-12 16:05:06 +0100434 ":rtc_event_pacing",
435 ":rtc_event_rtp_rtcp",
436 ":rtc_event_video",
Qingsi Wang970b0882018-02-01 11:04:46 -0800437 ":rtc_stream_config",
Artem Titov741daaf2019-03-21 14:37:36 +0100438 "../api:function_view",
Niels Möller0d863f72020-11-24 17:50:31 +0100439 "../api:network_state_predictor_api",
Niels Mölleref1052a2019-03-20 08:40:23 +0100440 "../api:rtp_headers",
Niels Möller6dcd4dc2019-08-26 10:45:28 +0200441 "../api:rtp_parameters",
Danil Chapovalov83bbe912019-08-07 12:24:53 +0200442 "../api/rtc_event_log",
Sebastian Jansson7e4341d2019-01-22 08:42:27 +0100443 "../api/units:data_rate",
444 "../api/units:time_delta",
445 "../api/units:timestamp",
Björn Terelius00c12f62020-08-06 12:37:08 +0200446 "../api/video:video_frame",
Mirko Bonadei818d9102017-12-12 12:46:13 +0100447 "../call:video_stream_api",
Danil Chapovalov7c067772019-10-07 12:56:24 +0200448 "../modules:module_api_public",
michaeltcde46b72017-04-06 05:59:10 -0700449 "../modules/audio_coding:audio_network_adaptor",
Mirko Bonadei818d9102017-12-12 12:46:13 +0100450 "../modules/rtp_rtcp:rtp_rtcp_format",
Patrik Höglunda8005cf2017-12-13 16:05:42 +0100451 "../rtc_base:checks",
Ali Tofighe00d7d02022-05-09 13:33:36 +0200452 "../rtc_base:copy_on_write_buffer",
Mirko Bonadei3663ed32019-10-19 12:03:23 +0200453 "../rtc_base:ignore_wundef",
Florent Castelli0af55ba2022-04-04 15:06:30 +0200454 "../rtc_base:logging",
Mirko Bonadei818d9102017-12-12 12:46:13 +0100455 "../rtc_base:protobuf_utils",
Sebastian Jansson7e4341d2019-01-22 08:42:27 +0100456 "../rtc_base:rtc_numerics",
Florent Castellie10a9f62022-04-04 17:04:37 +0200457 "../rtc_base:safe_conversions",
Björn Tereliusb37180f2021-03-31 13:56:57 +0200458 "../rtc_base/system:file_wrapper",
Mirko Bonadei2dcf3482020-06-05 14:30:41 +0200459 ]
460 absl_deps = [
Karl Wiberg918f50c2018-07-05 11:40:33 +0200461 "//third_party/abseil-cpp/absl/memory",
Elad Alon1ac95542018-10-02 13:20:40 +0200462 "//third_party/abseil-cpp/absl/types:optional",
skvladcc91d282016-10-03 18:31:22 -0700463 ]
skvladcc91d282016-10-03 18:31:22 -0700464 }
ehmaldonado1fd08c12017-01-17 02:37:34 -0800465
466 if (rtc_include_tests) {
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200467 rtc_library("rtc_event_log_tests") {
ehmaldonado1fd08c12017-01-17 02:37:34 -0800468 testonly = true
Elad Alon1d87b0e2017-10-03 15:01:03 +0200469 assert(rtc_enable_protobuf)
ehmaldonado1fd08c12017-01-17 02:37:34 -0800470 sources = [
Elad Aloncb21ffe2018-10-19 18:30:30 +0200471 "rtc_event_log/encoder/blob_encoding_unittest.cc",
Elad Alon50b1e6b2018-10-18 13:43:35 +0200472 "rtc_event_log/encoder/delta_encoding_unittest.cc",
Elad Alond95b0a22018-11-09 16:38:54 +0100473 "rtc_event_log/encoder/rtc_event_log_encoder_common_unittest.cc",
Elad Alon1d87b0e2017-10-03 15:01:03 +0200474 "rtc_event_log/encoder/rtc_event_log_encoder_unittest.cc",
Björn Tereliusfe903d52021-09-27 18:30:44 +0200475 "rtc_event_log/events/rtc_event_field_encoding_unittest.cc",
Björn Terelius98952d72021-09-22 19:37:22 +0200476 "rtc_event_log/events/rtc_event_field_extraction_unittest.cc",
ehmaldonado1fd08c12017-01-17 02:37:34 -0800477 "rtc_event_log/rtc_event_log_unittest.cc",
478 "rtc_event_log/rtc_event_log_unittest_helper.cc",
eladalonb5c319a2017-08-17 08:32:39 -0700479 "rtc_event_log/rtc_event_log_unittest_helper.h",
Bjorn Terelius60d629f2018-09-24 17:10:27 +0200480 "rtc_event_log/rtc_event_processor_unittest.cc",
ehmaldonado1fd08c12017-01-17 02:37:34 -0800481 ]
482 deps = [
Bjorn Tereliusf4db5422018-06-26 11:41:27 +0200483 ":ice_log",
Qingsi Wang970b0882018-02-01 11:04:46 -0800484 ":rtc_event_audio",
485 ":rtc_event_bwe",
Björn Terelius98952d72021-09-22 19:37:22 +0200486 ":rtc_event_field",
Björn Terelius00c12f62020-08-06 12:37:08 +0200487 ":rtc_event_frame_events",
Piotr (Peter) Slatala5e2aad12019-02-13 07:49:30 -0800488 ":rtc_event_generic_packet_events",
Bjorn Tereliusc35096d2018-10-24 13:51:56 +0200489 ":rtc_event_log2_proto",
Qingsi Wang970b0882018-02-01 11:04:46 -0800490 ":rtc_event_log_impl_encoder",
ehmaldonado1fd08c12017-01-17 02:37:34 -0800491 ":rtc_event_log_parser",
Mirko Bonadei818d9102017-12-12 12:46:13 +0100492 ":rtc_event_log_proto",
Björn Terelius98952d72021-09-22 19:37:22 +0200493 ":rtc_event_number_encodings",
Bjorn Tereliusf4db5422018-06-26 11:41:27 +0200494 ":rtc_event_pacing",
Qingsi Wang970b0882018-02-01 11:04:46 -0800495 ":rtc_event_rtp_rtcp",
496 ":rtc_event_video",
497 ":rtc_stream_config",
Yves Gerey3e707812018-11-28 16:47:49 +0100498 "../api:array_view",
Niels Möller0d863f72020-11-24 17:50:31 +0100499 "../api:network_state_predictor_api",
Niels Möllerd8b9ed72019-05-08 13:53:51 +0200500 "../api:rtc_event_log_output_file",
Niels Mölleref1052a2019-03-20 08:40:23 +0100501 "../api:rtp_headers",
Niels Möller6dcd4dc2019-08-26 10:45:28 +0200502 "../api:rtp_parameters",
Danil Chapovalov83bbe912019-08-07 12:24:53 +0200503 "../api/rtc_event_log",
Danil Chapovalov4ba04b72019-06-26 15:49:47 +0200504 "../api/rtc_event_log:rtc_event_log_factory",
Danil Chapovalov304ea5f2019-04-11 15:18:18 +0200505 "../api/task_queue:default_task_queue_factory",
ehmaldonado1fd08c12017-01-17 02:37:34 -0800506 "../call",
Mirko Bonadeia0e1a552017-12-04 10:50:51 +0100507 "../call:call_interfaces",
michaeltcde46b72017-04-06 05:59:10 -0700508 "../modules/audio_coding:audio_network_adaptor",
Mirko Bonadeib5728d92017-12-06 07:51:33 +0100509 "../modules/rtp_rtcp:rtp_rtcp_format",
Florent Castellif9c59842022-04-19 17:07:23 +0200510 "../rtc_base:buffer",
Patrik Höglunda8005cf2017-12-13 16:05:42 +0100511 "../rtc_base:checks",
Florent Castelli4467ad72022-04-04 15:18:46 +0200512 "../rtc_base:macromagic",
Florent Castelli71337f32022-04-14 12:41:26 +0200513 "../rtc_base:random",
ehmaldonadof6a861a2017-07-19 10:40:47 -0700514 "../rtc_base:rtc_base_tests_utils",
Florent Castellidd837e22022-04-04 17:16:15 +0200515 "../rtc_base:timeutils",
Artem Titov94b57c02019-03-21 13:35:10 +0100516 "../system_wrappers",
Patrik Höglund7696bef2018-03-15 15:05:39 +0100517 "../test:fileutils",
kjellander727ac1d2017-03-08 02:12:11 -0800518 "../test:test_support",
Björn Tereliuscc5532f2022-02-10 19:24:14 +0100519 "../test/logging:log_writer",
ehmaldonado1fd08c12017-01-17 02:37:34 -0800520 "//testing/gtest",
Mirko Bonadei2dcf3482020-06-05 14:30:41 +0200521 ]
522 absl_deps = [
Karl Wiberg918f50c2018-07-05 11:40:33 +0200523 "//third_party/abseil-cpp/absl/memory",
Yves Gerey69807e82018-10-30 22:23:02 +0100524 "//third_party/abseil-cpp/absl/types:optional",
ehmaldonado1fd08c12017-01-17 02:37:34 -0800525 ]
ehmaldonado1fd08c12017-01-17 02:37:34 -0800526 }
Mirko Bonadei9d764e82018-07-16 15:38:06 +0200527
Andrey Logvine7c79fd2021-02-01 09:56:37 +0000528 if (!build_with_chromium) {
529 rtc_executable("rtc_event_log_rtp_dump") {
530 testonly = true
531 sources = [ "rtc_event_log/rtc_event_log2rtp_dump.cc" ]
532 deps = [
533 ":rtc_event_log_parser",
534 "../api:array_view",
535 "../api:rtp_headers",
536 "../api/rtc_event_log",
537 "../modules/rtp_rtcp",
538 "../modules/rtp_rtcp:rtp_rtcp_format",
539 "../rtc_base:checks",
540 "../rtc_base:protobuf_utils",
Andrey Logvine7c79fd2021-02-01 09:56:37 +0000541 "../test:rtp_test_utils",
542 "//third_party/abseil-cpp/absl/flags:flag",
543 "//third_party/abseil-cpp/absl/flags:parse",
544 "//third_party/abseil-cpp/absl/flags:usage",
545 "//third_party/abseil-cpp/absl/memory",
546 "//third_party/abseil-cpp/absl/types:optional",
547 ]
548 }
ivoc54b6e982017-02-08 00:28:09 -0800549 }
ehmaldonado1fd08c12017-01-17 02:37:34 -0800550 }
skvladcc91d282016-10-03 18:31:22 -0700551}
Patrik Höglund731082c2018-01-03 09:08:20 +0100552
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200553rtc_library("ice_log") {
Qingsi Wang8eca1ff2018-02-02 11:49:44 -0800554 sources = [
Zach Steinc64078f2018-11-27 15:53:01 -0800555 "rtc_event_log/events/rtc_event_dtls_transport_state.cc",
556 "rtc_event_log/events/rtc_event_dtls_transport_state.h",
Zach Stein846dfdf2018-11-29 14:12:17 -0800557 "rtc_event_log/events/rtc_event_dtls_writable_state.cc",
558 "rtc_event_log/events/rtc_event_dtls_writable_state.h",
Qingsi Wang8eca1ff2018-02-02 11:49:44 -0800559 "rtc_event_log/events/rtc_event_ice_candidate_pair.cc",
560 "rtc_event_log/events/rtc_event_ice_candidate_pair.h",
561 "rtc_event_log/events/rtc_event_ice_candidate_pair_config.cc",
562 "rtc_event_log/events/rtc_event_ice_candidate_pair_config.h",
Steve Anton10542f22019-01-11 09:11:00 -0800563 "rtc_event_log/ice_logger.cc",
564 "rtc_event_log/ice_logger.h",
Qingsi Wang8eca1ff2018-02-02 11:49:44 -0800565 ]
566
567 deps = [
Björn Terelius9a609702022-02-11 14:25:49 +0100568 ":rtc_event_field",
Qingsi Wang8eca1ff2018-02-02 11:49:44 -0800569 "../api:libjingle_logging_api",
Danil Chapovalov16cb1f62019-09-05 11:29:59 +0200570 "../api:libjingle_peerconnection_api", # For api/dtls_transport_interface.h
Danil Chapovalov83bbe912019-08-07 12:24:53 +0200571 "../api/rtc_event_log",
Björn Tereliusada810a2021-05-24 10:19:55 +0200572 "../api/units:timestamp",
Qingsi Wang8eca1ff2018-02-02 11:49:44 -0800573 ]
Björn Terelius9a609702022-02-11 14:25:49 +0100574 absl_deps = [
575 "//third_party/abseil-cpp/absl/memory",
576 "//third_party/abseil-cpp/absl/strings",
577 ]
Qingsi Wang8eca1ff2018-02-02 11:49:44 -0800578}
579
Patrik Höglund731082c2018-01-03 09:08:20 +0100580if (rtc_include_tests) {
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200581 rtc_library("mocks") {
Patrik Höglund731082c2018-01-03 09:08:20 +0100582 testonly = true
583 sources = [
Danil Chapovalovdd7e2842018-03-09 15:37:03 +0000584 "rtc_event_log/mock/mock_rtc_event_log.cc",
Patrik Höglund731082c2018-01-03 09:08:20 +0100585 "rtc_event_log/mock/mock_rtc_event_log.h",
586 ]
587 deps = [
Danil Chapovalov83bbe912019-08-07 12:24:53 +0200588 "../api/rtc_event_log",
Oleh Prypinda04e062018-07-23 10:04:12 +0200589 "../test:test_support",
Patrik Höglund731082c2018-01-03 09:08:20 +0100590 ]
591 }
592}