Replace BasicRegatheringController with RepeatingTaskHandle

The `BasicRegatheringController` class was essentially a thin wrapper
around a recurring task. This change removes the separate class and
implements the regathering logic directly in `P2PTransportChannel` using
`webrtc::RepeatingTaskHandle` which also avoids storing a pointer to the
PortAllocatorSession outside of P2PTransportChannel.

This simplifies the code by removing an extra layer of abstraction and
reducing boilerplate.

Key changes:
* Deleted `p2p/base/regathering_controller.{h,cc}` and the unit tests
  file.
* Migrated the tests `p2p/base/p2p_transport_channel_unittest.cc` to
  ensure continued coverage of regathering scheduling and intervals.
* Updated `P2PTransportChannel` to manage the recurring regathering
  task directly using `RepeatingTaskHandle`.

This will help allow initial construction of P2PTransportChannel on the
signaling thread in the future even though ownership and logic will
continue to run on the network thread. This also retains state within
the class, avoiding having more classes pointing to the same state.

Bug: none
Change-Id: I019f573cb3e6a52f1b46e01610a748f1691aacab
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/427681
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Commit-Queue: Tomas Gunnarsson <tommi@webrtc.org>
Cr-Commit-Position: refs/heads/main@{#46282}
7 files changed
tree: a4f7fc242794bd2cc00b27d34fe4fbb3b0a6a226
  1. api/
  2. audio/
  3. build_overrides/
  4. call/
  5. common_audio/
  6. common_video/
  7. data/
  8. docs/
  9. examples/
  10. experiments/
  11. g3doc/
  12. infra/
  13. logging/
  14. media/
  15. modules/
  16. net/
  17. p2p/
  18. pc/
  19. resources/
  20. rtc_base/
  21. rtc_tools/
  22. sdk/
  23. stats/
  24. system_wrappers/
  25. test/
  26. tools_webrtc/
  27. video/
  28. .clang-format
  29. .clang-tidy
  30. .git-blame-ignore-revs
  31. .gitignore
  32. .gn
  33. .mailmap
  34. .rustfmt.toml
  35. .style.yapf
  36. .vpython3
  37. AUTHORS
  38. BUILD.gn
  39. CODE_OF_CONDUCT.md
  40. codereview.settings
  41. DEPS
  42. DIR_METADATA
  43. ENG_REVIEW_OWNERS
  44. LICENSE
  45. license_template.txt
  46. native-api.md
  47. OWNERS
  48. OWNERS_INFRA
  49. PATENTS
  50. PRESUBMIT.py
  51. presubmit_test.py
  52. presubmit_test_mocks.py
  53. pylintrc
  54. pylintrc_old_style
  55. README.chromium
  56. README.md
  57. WATCHLISTS
  58. webrtc.gni
  59. webrtc_lib_link_test.cc
  60. whitespace.txt
README.md

WebRTC is a free, open software project that provides browsers and mobile applications with Real-Time Communications (RTC) capabilities via simple APIs. The WebRTC components have been optimized to best serve this purpose.

Our mission: To enable rich, high-quality RTC applications to be developed for the browser, mobile platforms, and IoT devices, and allow them all to communicate via a common set of protocols.

The WebRTC initiative is a project supported by Google, Mozilla and Opera, amongst others.

Development

See here for instructions on how to get started developing with the native code.

Authoritative list of directories that contain the native API header files.

More info