2024-01-25 22:21:37 -08:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
|
|
import shutil
|
[upstream_utils] Use pathlib instead of os.path (#7983)
A noteworthy change is the replacement of the `dp.startswith(os.path.join(".", "subdir"))` pattern. pathlib doesn't offer something with similar semantics besides `match` and `full_match`, so there's now a helper function that replicates the behavior.
Other notable changes include the addition of type annotations to ensure code correctness, using == to check file names instead of `endswith` for clarity (`endswith` is still used to check extensions), manual walking and copying being refactored in googletest, json, memory, nanopb, protobuf, and sleipnir to use `walk_cwd_and_copy_if`, and matching functions being shortened to the point where they can just be inlined into the lambda.
Co-authored-by: Tyler Veness <calcmogul@gmail.com>
Co-authored-by: David Vo <auscompgeek@users.noreply.github.com>
2025-05-29 22:05:22 +00:00
|
|
|
from pathlib import Path
|
2024-01-25 22:21:37 -08:00
|
|
|
|
2024-07-20 07:01:06 -07:00
|
|
|
from upstream_utils import Lib
|
2024-01-25 22:21:37 -08:00
|
|
|
|
|
|
|
|
|
[upstream_utils] Use pathlib instead of os.path (#7983)
A noteworthy change is the replacement of the `dp.startswith(os.path.join(".", "subdir"))` pattern. pathlib doesn't offer something with similar semantics besides `match` and `full_match`, so there's now a helper function that replicates the behavior.
Other notable changes include the addition of type annotations to ensure code correctness, using == to check file names instead of `endswith` for clarity (`endswith` is still used to check extensions), manual walking and copying being refactored in googletest, json, memory, nanopb, protobuf, and sleipnir to use `walk_cwd_and_copy_if`, and matching functions being shortened to the point where they can just be inlined into the lambda.
Co-authored-by: Tyler Veness <calcmogul@gmail.com>
Co-authored-by: David Vo <auscompgeek@users.noreply.github.com>
2025-05-29 22:05:22 +00:00
|
|
|
def copy_upstream_src(wpilib_root: Path):
|
|
|
|
|
wpiutil = wpilib_root / "wpiutil"
|
2024-01-25 22:21:37 -08:00
|
|
|
|
|
|
|
|
# Copy expected header into allwpilib
|
2025-11-07 19:57:55 -05:00
|
|
|
dest_filename = (
|
|
|
|
|
wpiutil / "src/main/native/thirdparty/expected/include/wpi/util/expected"
|
|
|
|
|
)
|
2024-07-16 17:20:07 -07:00
|
|
|
shutil.copyfile("include/tl/expected.hpp", dest_filename)
|
2024-01-25 22:21:37 -08:00
|
|
|
|
2024-09-07 19:59:20 -07:00
|
|
|
# Rename namespace from tl to wpi, and detail to detail_expected
|
2024-01-25 22:21:37 -08:00
|
|
|
with open(dest_filename) as f:
|
|
|
|
|
content = f.read()
|
2025-11-07 19:58:22 -05:00
|
|
|
content = content.replace("namespace tl", "namespace wpi::util")
|
|
|
|
|
content = content.replace("tl::", "wpi::util::")
|
2024-01-25 22:21:37 -08:00
|
|
|
content = content.replace("TL_", "WPI_")
|
2024-09-07 19:59:20 -07:00
|
|
|
content = content.replace("namespace detail", "namespace detail_expected")
|
|
|
|
|
content = content.replace("detail::", "detail_expected::")
|
2024-01-25 22:21:37 -08:00
|
|
|
with open(dest_filename, "w") as f:
|
|
|
|
|
f.write(content)
|
|
|
|
|
|
|
|
|
|
|
2024-07-16 17:20:07 -07:00
|
|
|
def main():
|
|
|
|
|
name = "expected"
|
|
|
|
|
url = "https://github.com/TartanLlama/expected"
|
|
|
|
|
# master on 2024-01-25
|
|
|
|
|
tag = "3f0ca7b19253129700a073abfa6d8638d9f7c80c"
|
|
|
|
|
|
2024-07-23 15:58:15 -07:00
|
|
|
expected = Lib(name, url, tag, copy_upstream_src)
|
2024-07-16 17:20:07 -07:00
|
|
|
expected.main()
|
|
|
|
|
|
|
|
|
|
|
2024-01-25 22:21:37 -08:00
|
|
|
if __name__ == "__main__":
|
|
|
|
|
main()
|