diff options
Diffstat (limited to 'third_party/libwebrtc/logging/BUILD.gn')
-rw-r--r-- | third_party/libwebrtc/logging/BUILD.gn | 611 |
1 files changed, 611 insertions, 0 deletions
diff --git a/third_party/libwebrtc/logging/BUILD.gn b/third_party/libwebrtc/logging/BUILD.gn new file mode 100644 index 0000000000..408d4ecc51 --- /dev/null +++ b/third_party/libwebrtc/logging/BUILD.gn @@ -0,0 +1,611 @@ +# Copyright (c) 2016 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("../webrtc.gni") +if (rtc_enable_protobuf) { + import("//third_party/protobuf/proto_library.gni") +} +if (is_android) { + import("//build/config/android/config.gni") + import("//build/config/android/rules.gni") +} + +group("logging") { + deps = [ + ":rtc_event_audio", + ":rtc_event_begin_end", + ":rtc_event_bwe", + ":rtc_event_log_impl_encoder", + ":rtc_event_pacing", + ":rtc_event_rtp_rtcp", + ":rtc_event_video", + ] +} + +rtc_source_set("rtc_event_log_api") { + sources = [ "rtc_event_log/encoder/rtc_event_log_encoder.h" ] + + deps = [ "../api/rtc_event_log" ] +} + +rtc_library("rtc_event_field") { + sources = [ + "rtc_event_log/events/fixed_length_encoding_parameters_v3.cc", + "rtc_event_log/events/fixed_length_encoding_parameters_v3.h", + "rtc_event_log/events/rtc_event_definition.h", + "rtc_event_log/events/rtc_event_field_encoding.cc", + "rtc_event_log/events/rtc_event_field_encoding.h", + "rtc_event_log/events/rtc_event_field_encoding_parser.cc", + "rtc_event_log/events/rtc_event_field_encoding_parser.h", + "rtc_event_log/events/rtc_event_field_extraction.cc", + "rtc_event_log/events/rtc_event_field_extraction.h", + ] + + deps = [ + ":rtc_event_number_encodings", + "../api:array_view", + "../api/rtc_event_log", + "../api/units:timestamp", + "../rtc_base:bitstream_reader", + "../rtc_base:checks", + "../rtc_base:logging", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/strings", + "//third_party/abseil-cpp/absl/types:optional", + ] +} + +rtc_library("rtc_stream_config") { + sources = [ + "rtc_event_log/rtc_stream_config.cc", + "rtc_event_log/rtc_stream_config.h", + ] + + deps = [ + "../api:rtp_headers", + "../api:rtp_parameters", + ] + absl_deps = [ "//third_party/abseil-cpp/absl/strings" ] +} + +rtc_library("rtc_event_pacing") { + sources = [ + "rtc_event_log/events/rtc_event_alr_state.cc", + "rtc_event_log/events/rtc_event_alr_state.h", + ] + + deps = [ + ":rtc_event_field", + "../api/rtc_event_log", + "../api/units:timestamp", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/memory", + "//third_party/abseil-cpp/absl/strings", + ] +} + +rtc_library("rtc_event_audio") { + sources = [ + "rtc_event_log/events/rtc_event_audio_network_adaptation.cc", + "rtc_event_log/events/rtc_event_audio_network_adaptation.h", + "rtc_event_log/events/rtc_event_audio_playout.cc", + "rtc_event_log/events/rtc_event_audio_playout.h", + "rtc_event_log/events/rtc_event_audio_receive_stream_config.cc", + "rtc_event_log/events/rtc_event_audio_receive_stream_config.h", + "rtc_event_log/events/rtc_event_audio_send_stream_config.cc", + "rtc_event_log/events/rtc_event_audio_send_stream_config.h", + "rtc_event_log/events/rtc_event_neteq_set_minimum_delay.cc", + "rtc_event_log/events/rtc_event_neteq_set_minimum_delay.h", + ] + + deps = [ + ":rtc_event_field", + ":rtc_stream_config", + "../api/rtc_event_log", + "../api/units:timestamp", + "../modules/audio_coding:audio_network_adaptor_config", + "../rtc_base:checks", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/memory", + "//third_party/abseil-cpp/absl/strings", + ] +} + +rtc_library("rtc_event_begin_end") { + sources = [ + "rtc_event_log/events/rtc_event_begin_log.cc", + "rtc_event_log/events/rtc_event_begin_log.h", + "rtc_event_log/events/rtc_event_end_log.cc", + "rtc_event_log/events/rtc_event_end_log.h", + ] + deps = [ + ":rtc_event_field", + "../api:array_view", + "../api/rtc_event_log", + "../api/units:timestamp", + ] + absl_deps = [ "//third_party/abseil-cpp/absl/strings" ] +} + +rtc_library("rtc_event_bwe") { + sources = [ + "rtc_event_log/events/rtc_event_bwe_update_delay_based.cc", + "rtc_event_log/events/rtc_event_bwe_update_delay_based.h", + "rtc_event_log/events/rtc_event_bwe_update_loss_based.cc", + "rtc_event_log/events/rtc_event_bwe_update_loss_based.h", + "rtc_event_log/events/rtc_event_probe_cluster_created.cc", + "rtc_event_log/events/rtc_event_probe_cluster_created.h", + "rtc_event_log/events/rtc_event_probe_result_failure.cc", + "rtc_event_log/events/rtc_event_probe_result_failure.h", + "rtc_event_log/events/rtc_event_probe_result_success.cc", + "rtc_event_log/events/rtc_event_probe_result_success.h", + "rtc_event_log/events/rtc_event_remote_estimate.h", + "rtc_event_log/events/rtc_event_route_change.cc", + "rtc_event_log/events/rtc_event_route_change.h", + ] + + deps = [ + ":rtc_event_field", + "../api:network_state_predictor_api", + "../api/rtc_event_log", + "../api/units:data_rate", + "../api/units:timestamp", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/memory", + "//third_party/abseil-cpp/absl/strings", + "//third_party/abseil-cpp/absl/types:optional", + ] +} + +rtc_library("rtc_event_frame_events") { + sources = [ + "rtc_event_log/events/rtc_event_frame_decoded.cc", + "rtc_event_log/events/rtc_event_frame_decoded.h", + ] + deps = [ + ":rtc_event_field", + "../api/rtc_event_log", + "../api/units:timestamp", + "../api/video:video_frame", + "../rtc_base:timeutils", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/memory", + "//third_party/abseil-cpp/absl/strings", + "//third_party/abseil-cpp/absl/types:optional", + ] +} + +rtc_library("rtc_event_generic_packet_events") { + visibility = [ "*" ] + sources = [ + "rtc_event_log/events/rtc_event_generic_ack_received.cc", + "rtc_event_log/events/rtc_event_generic_ack_received.h", + "rtc_event_log/events/rtc_event_generic_packet_received.cc", + "rtc_event_log/events/rtc_event_generic_packet_received.h", + "rtc_event_log/events/rtc_event_generic_packet_sent.cc", + "rtc_event_log/events/rtc_event_generic_packet_sent.h", + ] + deps = [ + ":rtc_event_field", + "../api/rtc_event_log", + "../api/units:timestamp", + "../rtc_base:timeutils", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/memory", + "//third_party/abseil-cpp/absl/strings", + "//third_party/abseil-cpp/absl/types:optional", + ] +} + +rtc_library("rtc_event_rtp_rtcp") { + sources = [ + "rtc_event_log/events/logged_rtp_rtcp.h", + "rtc_event_log/events/rtc_event_rtcp_packet_incoming.cc", + "rtc_event_log/events/rtc_event_rtcp_packet_incoming.h", + "rtc_event_log/events/rtc_event_rtcp_packet_outgoing.cc", + "rtc_event_log/events/rtc_event_rtcp_packet_outgoing.h", + "rtc_event_log/events/rtc_event_rtp_packet_incoming.cc", + "rtc_event_log/events/rtc_event_rtp_packet_incoming.h", + "rtc_event_log/events/rtc_event_rtp_packet_outgoing.cc", + "rtc_event_log/events/rtc_event_rtp_packet_outgoing.h", + ] + + deps = [ + ":rtc_event_field", + "../api:array_view", + "../api:rtp_headers", + "../api/rtc_event_log", + "../api/units:timestamp", + "../modules/rtp_rtcp:rtp_rtcp_format", + "../rtc_base:buffer", + "../rtc_base:checks", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/memory", + "//third_party/abseil-cpp/absl/strings", + ] +} + +rtc_library("rtc_event_video") { + sources = [ + "rtc_event_log/events/rtc_event_video_receive_stream_config.cc", + "rtc_event_log/events/rtc_event_video_receive_stream_config.h", + "rtc_event_log/events/rtc_event_video_send_stream_config.cc", + "rtc_event_log/events/rtc_event_video_send_stream_config.h", + ] + + deps = [ + ":rtc_event_field", + ":rtc_stream_config", + "../api/rtc_event_log", + "../api/units:timestamp", + "../rtc_base:checks", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/memory", + "//third_party/abseil-cpp/absl/strings", + ] +} + +rtc_library("rtc_event_number_encodings") { + sources = [ + "rtc_event_log/encoder/bit_writer.cc", + "rtc_event_log/encoder/bit_writer.h", + "rtc_event_log/encoder/rtc_event_log_encoder_common.cc", + "rtc_event_log/encoder/rtc_event_log_encoder_common.h", + "rtc_event_log/encoder/var_int.cc", + "rtc_event_log/encoder/var_int.h", + ] + + defines = [] + + deps = [ + "../rtc_base:bit_buffer", + "../rtc_base:bitstream_reader", + "../rtc_base:checks", + "../rtc_base:ignore_wundef", + "../rtc_base:macromagic", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/memory", + "//third_party/abseil-cpp/absl/strings", + "//third_party/abseil-cpp/absl/types:optional", + ] +} + +# TODO(eladalon): Break down into (1) encoder and (2) decoder; we don't need +# the decoder code in the WebRTC library, only in unit tests and tools. +rtc_library("rtc_event_log_impl_encoder") { + sources = [ + "rtc_event_log/encoder/blob_encoding.cc", + "rtc_event_log/encoder/blob_encoding.h", + "rtc_event_log/encoder/delta_encoding.cc", + "rtc_event_log/encoder/delta_encoding.h", + ] + + defines = [] + + deps = [ + ":rtc_event_number_encodings", + "../api:rtp_headers", + "../api:rtp_parameters", + "../api/transport:network_control", + "../rtc_base:bit_buffer", + "../rtc_base:bitstream_reader", + "../rtc_base:buffer", + "../rtc_base:checks", + "../rtc_base:ignore_wundef", + "../rtc_base:logging", + "../rtc_base:safe_conversions", + "../system_wrappers:field_trial", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/memory", + "//third_party/abseil-cpp/absl/strings", + "//third_party/abseil-cpp/absl/types:optional", + ] + + if (rtc_enable_protobuf) { + deps += [ + ":ice_log", + ":rtc_event_audio", + ":rtc_event_begin_end", + ":rtc_event_bwe", + ":rtc_event_field", + ":rtc_event_frame_events", + ":rtc_event_generic_packet_events", + ":rtc_event_log2_proto", + ":rtc_event_log_api", + ":rtc_event_log_proto", + ":rtc_event_pacing", + ":rtc_event_rtp_rtcp", + ":rtc_event_video", + ":rtc_stream_config", + "../api:array_view", + "../api:network_state_predictor_api", + "../modules/audio_coding:audio_network_adaptor", + "../modules/rtp_rtcp:rtp_rtcp_format", + ] + sources += [ + "rtc_event_log/encoder/rtc_event_log_encoder_legacy.cc", + "rtc_event_log/encoder/rtc_event_log_encoder_legacy.h", + "rtc_event_log/encoder/rtc_event_log_encoder_new_format.cc", + "rtc_event_log/encoder/rtc_event_log_encoder_new_format.h", + "rtc_event_log/encoder/rtc_event_log_encoder_v3.cc", + "rtc_event_log/encoder/rtc_event_log_encoder_v3.h", + ] + } +} + +# TODO(bugs.webrtc.org/6463): For backwards compatibility; delete as +# soon as downstream dependencies are updated. +rtc_source_set("rtc_event_log_impl_output") { + sources = [ "rtc_event_log/output/rtc_event_log_output_file.h" ] + deps = [ "../api:rtc_event_log_output_file" ] +} + +if (rtc_enable_protobuf) { + rtc_library("rtc_event_log_impl") { + visibility = [ + ":rtc_event_log_tests", + "../api/rtc_event_log:rtc_event_log_factory", + ] + sources = [ + "rtc_event_log/rtc_event_log_impl.cc", + "rtc_event_log/rtc_event_log_impl.h", + ] + deps = [ + ":ice_log", + ":rtc_event_log_api", + ":rtc_event_log_impl_encoder", + "../api:libjingle_logging_api", + "../api:sequence_checker", + "../api/rtc_event_log", + "../api/task_queue", + "../api/units:time_delta", + "../rtc_base:checks", + "../rtc_base:logging", + "../rtc_base:macromagic", + "../rtc_base:rtc_event", + "../rtc_base:rtc_task_queue", + "../rtc_base:safe_conversions", + "../rtc_base:safe_minmax", + "../rtc_base:timeutils", + "../rtc_base/system:no_unique_address", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/strings", + "//third_party/abseil-cpp/absl/types:optional", + ] + } +} + +rtc_library("fake_rtc_event_log") { + testonly = true + sources = [ + "rtc_event_log/fake_rtc_event_log.cc", + "rtc_event_log/fake_rtc_event_log.h", + "rtc_event_log/fake_rtc_event_log_factory.cc", + "rtc_event_log/fake_rtc_event_log_factory.h", + ] + + deps = [ + "../api/rtc_event_log", + "../rtc_base:macromagic", + "../rtc_base/synchronization:mutex", + ] +} + +if (rtc_enable_protobuf) { + proto_library("rtc_event_log_proto") { + visibility = [ "*" ] + sources = [ "rtc_event_log/rtc_event_log.proto" ] + proto_out_dir = "logging/rtc_event_log" + } + + proto_library("rtc_event_log2_proto") { + visibility = [ "*" ] + sources = [ "rtc_event_log/rtc_event_log2.proto" ] + proto_out_dir = "logging/rtc_event_log" + } + + rtc_library("rtc_event_log_parser") { + visibility = [ "*" ] + sources = [ + "rtc_event_log/logged_events.h", + "rtc_event_log/rtc_event_log_parser.cc", + "rtc_event_log/rtc_event_log_parser.h", + "rtc_event_log/rtc_event_processor.cc", + "rtc_event_log/rtc_event_processor.h", + ] + + deps = [ + ":ice_log", + ":rtc_event_audio", + ":rtc_event_begin_end", + ":rtc_event_bwe", + ":rtc_event_frame_events", + ":rtc_event_generic_packet_events", + ":rtc_event_log2_proto", + ":rtc_event_log_impl_encoder", + ":rtc_event_log_proto", + ":rtc_event_number_encodings", + ":rtc_event_pacing", + ":rtc_event_rtp_rtcp", + ":rtc_event_video", + ":rtc_stream_config", + "../api:function_view", + "../api:network_state_predictor_api", + "../api:rtp_headers", + "../api:rtp_parameters", + "../api/rtc_event_log", + "../api/units:data_rate", + "../api/units:time_delta", + "../api/units:timestamp", + "../api/video:video_frame", + "../call:video_stream_api", + "../modules:module_api_public", + "../modules/audio_coding:audio_network_adaptor", + "../modules/rtp_rtcp:rtp_rtcp_format", + "../rtc_base:checks", + "../rtc_base:copy_on_write_buffer", + "../rtc_base:ignore_wundef", + "../rtc_base:logging", + "../rtc_base:protobuf_utils", + "../rtc_base:rtc_numerics", + "../rtc_base:safe_conversions", + "../rtc_base/system:file_wrapper", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/base:core_headers", + "//third_party/abseil-cpp/absl/memory", + "//third_party/abseil-cpp/absl/strings", + "//third_party/abseil-cpp/absl/types:optional", + ] + } + + if (rtc_include_tests) { + rtc_library("rtc_event_log_tests") { + testonly = true + assert(rtc_enable_protobuf) + sources = [ + "rtc_event_log/encoder/blob_encoding_unittest.cc", + "rtc_event_log/encoder/delta_encoding_unittest.cc", + "rtc_event_log/encoder/rtc_event_log_encoder_common_unittest.cc", + "rtc_event_log/encoder/rtc_event_log_encoder_unittest.cc", + "rtc_event_log/events/rtc_event_field_encoding_unittest.cc", + "rtc_event_log/events/rtc_event_field_extraction_unittest.cc", + "rtc_event_log/rtc_event_log_impl_unittest.cc", + "rtc_event_log/rtc_event_log_unittest.cc", + "rtc_event_log/rtc_event_log_unittest_helper.cc", + "rtc_event_log/rtc_event_log_unittest_helper.h", + "rtc_event_log/rtc_event_processor_unittest.cc", + ] + deps = [ + ":ice_log", + ":rtc_event_audio", + ":rtc_event_bwe", + ":rtc_event_field", + ":rtc_event_frame_events", + ":rtc_event_generic_packet_events", + ":rtc_event_log2_proto", + ":rtc_event_log_impl", + ":rtc_event_log_impl_encoder", + ":rtc_event_log_parser", + ":rtc_event_log_proto", + ":rtc_event_number_encodings", + ":rtc_event_pacing", + ":rtc_event_rtp_rtcp", + ":rtc_event_video", + ":rtc_stream_config", + "../api:array_view", + "../api:network_state_predictor_api", + "../api:rtc_event_log_output_file", + "../api:rtp_headers", + "../api:rtp_parameters", + "../api/rtc_event_log", + "../api/rtc_event_log:rtc_event_log_factory", + "../api/task_queue:default_task_queue_factory", + "../api/units:time_delta", + "../api/units:timestamp", + "../call", + "../call:call_interfaces", + "../modules/audio_coding:audio_network_adaptor", + "../modules/rtp_rtcp:rtp_rtcp_format", + "../rtc_base:buffer", + "../rtc_base:checks", + "../rtc_base:macromagic", + "../rtc_base:random", + "../rtc_base:rtc_base_tests_utils", + "../rtc_base:timeutils", + "../system_wrappers", + "../test:fileutils", + "../test:test_support", + "../test/logging:log_writer", + "../test/time_controller", + "//testing/gtest", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/memory", + "//third_party/abseil-cpp/absl/strings", + "//third_party/abseil-cpp/absl/types:optional", + ] + } + + if (!build_with_chromium) { + rtc_executable("rtc_event_log_rtp_dump") { + testonly = true + sources = [ "rtc_event_log/rtc_event_log2rtp_dump.cc" ] + deps = [ + ":rtc_event_log_parser", + "../api:array_view", + "../api:rtp_headers", + "../api/rtc_event_log", + "../modules/rtp_rtcp", + "../modules/rtp_rtcp:rtp_rtcp_format", + "../rtc_base:checks", + "../rtc_base:protobuf_utils", + "../test:rtp_test_utils", + "//third_party/abseil-cpp/absl/flags:flag", + "//third_party/abseil-cpp/absl/flags:parse", + "//third_party/abseil-cpp/absl/flags:usage", + "//third_party/abseil-cpp/absl/memory", + "//third_party/abseil-cpp/absl/strings", + "//third_party/abseil-cpp/absl/types:optional", + ] + } + } + } +} + +rtc_library("ice_log") { + sources = [ + "rtc_event_log/events/rtc_event_dtls_transport_state.cc", + "rtc_event_log/events/rtc_event_dtls_transport_state.h", + "rtc_event_log/events/rtc_event_dtls_writable_state.cc", + "rtc_event_log/events/rtc_event_dtls_writable_state.h", + "rtc_event_log/events/rtc_event_ice_candidate_pair.cc", + "rtc_event_log/events/rtc_event_ice_candidate_pair.h", + "rtc_event_log/events/rtc_event_ice_candidate_pair_config.cc", + "rtc_event_log/events/rtc_event_ice_candidate_pair_config.h", + "rtc_event_log/ice_logger.cc", + "rtc_event_log/ice_logger.h", + ] + + deps = [ + ":rtc_event_field", + "../api:dtls_transport_interface", + "../api:libjingle_logging_api", + "../api/rtc_event_log", + "../api/units:timestamp", + ] + absl_deps = [ + "//third_party/abseil-cpp/absl/memory", + "//third_party/abseil-cpp/absl/strings", + ] +} + +if (rtc_include_tests) { + rtc_library("mocks") { + testonly = true + sources = [ + "rtc_event_log/mock/mock_rtc_event_log.cc", + "rtc_event_log/mock/mock_rtc_event_log.h", + ] + deps = [ + "../api/rtc_event_log", + "../test:test_support", + ] + } +} |