[iwyu] Python alternative to `apply-include-cleaner` bash script

Introducing the python variation to the `apply-include-cleaner` bash
script.
Bash script was personally very hard to read and follow.
Python provides much more pleasant interface for the kind of operations
we do like arg parsing, file manipulation and really general
maintenance cost.
Ideally we would just `git rm` the bash variation but it'd be nice to
hold both for a week~, use the python variation, fix any errors on demand and
then get rid of the bash script.

Tested by:
- Compare outputs for the `common_video` dir by running:
```
> find common_video/ -name "*.h" -o -name "*.cc" | xargs tools_webrtc/iwyu/apply_include_cleaner.py
> git diff > /tmp/iwyu_py
> git restore .
> find common_video/ -name "*.h" -o -name "*.cc" | xargs tools_webrtc/iwyu/apply-include-cleaner
> git diff > /tmp/iwyu_bash
> diff /tmp/iwyu_py /tmp/iwyu_bash
```

- To test the "print and fail on output" functionality - execute on `common_video` with `-pf` and make sure
exit code is 1
- To test the "print and fail on output but only if changes are not gtest/gmock/net_helpers" functionality - execute on `common_video`, commit, execute again but with the `-pf` flags - validate exit code is 0 although
cleaner attempted to suggest `gtest/gmock` / `gtest/gtest`

I'll look into doing this with a single `subprocess.run` invocation
instead of for looping on the list of files, but on a separate CL
to keep this one kinda straight forward.


P.S Comparing the performance of the scripts on `common_video` which included running on 59 files concluded:
- Bash script with an average wall time of 29s~
- Python script with an average wall time of 35s~

BUG=webrtc:42226242

Change-Id: I1c13b7567442c952ccdee2b6349215242830e5dc
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/384160
Reviewed-by: Jeremy Leconte <jleconte@webrtc.org>
Commit-Queue: Dor Hen <dorhen@meta.com>
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Cr-Commit-Position: refs/heads/main@{#44419}
1 file changed
tree: a48868d2c85d7649b9eb42a1e43724d79ebafe9b
  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. .git-blame-ignore-revs
  30. .gitignore
  31. .gn
  32. .mailmap
  33. .rustfmt.toml
  34. .style.yapf
  35. .vpython3
  36. AUTHORS
  37. BUILD.gn
  38. CODE_OF_CONDUCT.md
  39. codereview.settings
  40. DEPS
  41. DIR_METADATA
  42. ENG_REVIEW_OWNERS
  43. LICENSE
  44. license_template.txt
  45. native-api.md
  46. OWNERS
  47. OWNERS_INFRA
  48. PATENTS
  49. PRESUBMIT.py
  50. presubmit_test.py
  51. presubmit_test_mocks.py
  52. pylintrc
  53. pylintrc_old_style
  54. README.chromium
  55. README.md
  56. WATCHLISTS
  57. webrtc.gni
  58. webrtc_lib_link_test.cc
  59. 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