2023-10-15 05:53:56 +01:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
|
|
import os
|
|
|
|
|
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
|
2023-10-15 05:53:56 +01:00
|
|
|
|
2024-11-02 17:56:55 -07:00
|
|
|
from upstream_utils import Lib, walk_if
|
2023-10-15 05:53:56 +01: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"
|
2023-10-15 05:53:56 +01:00
|
|
|
|
|
|
|
|
# Delete old install
|
|
|
|
|
for d in [
|
|
|
|
|
"src/main/native/thirdparty/json/include",
|
|
|
|
|
]:
|
[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
|
|
|
shutil.rmtree(wpiutil / d, ignore_errors=True)
|
2023-10-15 05:53:56 +01:00
|
|
|
|
|
|
|
|
# Create lists of source and destination files
|
2024-07-16 17:20:07 -07:00
|
|
|
os.chdir("include/nlohmann")
|
[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
|
|
|
files = walk_if(Path("."), lambda dp, f: True)
|
|
|
|
|
src_include_files = [f.absolute() for f in files]
|
|
|
|
|
wpiutil_json_root = wpiutil / "src/main/native/thirdparty/json/include/wpi"
|
|
|
|
|
dest_include_files = [wpiutil_json_root / f.with_suffix(".h") for f in files]
|
2023-10-15 05:53:56 +01:00
|
|
|
|
|
|
|
|
# Copy json header files into allwpilib
|
|
|
|
|
for i in range(len(src_include_files)):
|
[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
|
|
|
dest_dir = dest_include_files[i].parent
|
|
|
|
|
if not dest_dir.exists():
|
|
|
|
|
dest_dir.mkdir(parents=True)
|
2023-10-15 05:53:56 +01:00
|
|
|
shutil.copyfile(src_include_files[i], dest_include_files[i])
|
|
|
|
|
|
|
|
|
|
for include_file in dest_include_files:
|
|
|
|
|
with open(include_file) as f:
|
|
|
|
|
content = f.read()
|
|
|
|
|
|
|
|
|
|
# Rename namespace from nlohmann to wpi
|
|
|
|
|
content = content.replace("namespace nlohmann", "namespace wpi")
|
|
|
|
|
content = content.replace("nlohmann::", "wpi::")
|
|
|
|
|
|
|
|
|
|
# Fix internal includes
|
|
|
|
|
content = content.replace(".hpp>", ".h>")
|
|
|
|
|
content = content.replace("include <nlohmann/", "include <wpi/")
|
|
|
|
|
|
|
|
|
|
# Fix include guards and other #defines
|
|
|
|
|
content = content.replace("NLOHMANN_", "WPI_")
|
|
|
|
|
|
|
|
|
|
with open(include_file, "w") as f:
|
|
|
|
|
f.write(content)
|
|
|
|
|
|
|
|
|
|
|
2024-07-16 17:20:07 -07:00
|
|
|
def main():
|
|
|
|
|
name = "json"
|
|
|
|
|
url = "https://github.com/nlohmann/json"
|
|
|
|
|
tag = "v3.11.3"
|
|
|
|
|
|
|
|
|
|
patch_options = {
|
|
|
|
|
"use_threeway": True,
|
|
|
|
|
}
|
|
|
|
|
|
2024-07-23 15:58:15 -07:00
|
|
|
json = Lib(name, url, tag, copy_upstream_src, patch_options)
|
2024-07-16 17:20:07 -07:00
|
|
|
json.main()
|
|
|
|
|
|
|
|
|
|
|
2023-10-15 05:53:56 +01:00
|
|
|
if __name__ == "__main__":
|
|
|
|
|
main()
|