
This is a reland of f5e261aaf65cdf2eb903cdf40d651846be44f447 This CL disables RTC_NO_UNIQUE_ADDRESS on MSan builds since there have been some issues. Original change's description: > Introduce RTC_NO_UNIQUE_ADDRESS. > > This macro introduces the possibility to suggest the compiler that a > data member doesn't need an address different from other non static > data members. > > The usage of a macro is to maintain portability since at the moment > the attribute [[no_unique_address]] is only supported by clang > with at least -std=c++11 but it should be supported by all the > compilers starting from C++20. > > Bug: webrtc:11495 > Change-Id: I9f12b67b4422a2749649eaa6b004a67d5fd572d8 > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/173331 > Commit-Queue: Mirko Bonadei <mbonadei@webrtc.org> > Reviewed-by: Karl Wiberg <kwiberg@webrtc.org> > Cr-Commit-Position: refs/heads/master@{#32246} Bug: webrtc:11495, webrtc:12218 Change-Id: I4e6c7cc37d3daffad2407c9a2acfa897fa5b426a Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/189968 Commit-Queue: Mirko Bonadei <mbonadei@webrtc.org> Reviewed-by: Karl Wiberg <kwiberg@webrtc.org> Cr-Commit-Position: refs/heads/master@{#32668}
90 lines
2.2 KiB
Plaintext
90 lines
2.2 KiB
Plaintext
# Copyright (c) 2019 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")
|
|
|
|
rtc_library("repeating_task") {
|
|
sources = [
|
|
"repeating_task.cc",
|
|
"repeating_task.h",
|
|
]
|
|
deps = [
|
|
":to_queued_task",
|
|
"..:logging",
|
|
"..:thread_checker",
|
|
"..:timeutils",
|
|
"../../api/task_queue",
|
|
"../../api/units:time_delta",
|
|
"../../api/units:timestamp",
|
|
"../../system_wrappers:system_wrappers",
|
|
"../synchronization:sequence_checker",
|
|
]
|
|
absl_deps = [ "//third_party/abseil-cpp/absl/memory" ]
|
|
}
|
|
|
|
rtc_library("pending_task_safety_flag") {
|
|
sources = [
|
|
"pending_task_safety_flag.cc",
|
|
"pending_task_safety_flag.h",
|
|
]
|
|
deps = [
|
|
"..:checks",
|
|
"..:refcount",
|
|
"..:thread_checker",
|
|
"../../api:scoped_refptr",
|
|
"../synchronization:sequence_checker",
|
|
"../system:no_unique_address",
|
|
]
|
|
}
|
|
|
|
rtc_source_set("to_queued_task") {
|
|
sources = [ "to_queued_task.h" ]
|
|
deps = [
|
|
":pending_task_safety_flag",
|
|
"../../api/task_queue",
|
|
]
|
|
}
|
|
|
|
if (rtc_include_tests) {
|
|
rtc_library("pending_task_safety_flag_unittests") {
|
|
testonly = true
|
|
sources = [ "pending_task_safety_flag_unittest.cc" ]
|
|
deps = [
|
|
":pending_task_safety_flag",
|
|
":to_queued_task",
|
|
"..:rtc_base_approved",
|
|
"..:rtc_task_queue",
|
|
"..:task_queue_for_test",
|
|
"../../test:test_support",
|
|
]
|
|
}
|
|
|
|
rtc_library("repeating_task_unittests") {
|
|
testonly = true
|
|
sources = [ "repeating_task_unittest.cc" ]
|
|
deps = [
|
|
":repeating_task",
|
|
"..:rtc_base_approved",
|
|
"..:rtc_task_queue",
|
|
"..:task_queue_for_test",
|
|
"../../test:test_support",
|
|
]
|
|
}
|
|
|
|
rtc_library("to_queued_task_unittests") {
|
|
testonly = true
|
|
sources = [ "to_queued_task_unittest.cc" ]
|
|
deps = [
|
|
":to_queued_task",
|
|
"../../api/task_queue",
|
|
"../../test:test_support",
|
|
]
|
|
absl_deps = [ "//third_party/abseil-cpp/absl/memory" ]
|
|
}
|
|
}
|