2024-12-28 23:24:32 -05: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-12-28 23:24:32 -05: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
|
|
|
from upstream_utils import Lib, has_prefix, walk_cwd_and_copy_if
|
2024-12-28 23:24:32 -05: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):
|
|
|
|
|
wpical = wpilib_root / "wpical"
|
2024-12-28 23:24:32 -05:00
|
|
|
|
|
|
|
|
# Delete old install
|
|
|
|
|
for d in [
|
|
|
|
|
"src/main/native/thirdparty/mrcal/src",
|
|
|
|
|
"src/main/native/thirdparty/mrcal/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(wpical / d, ignore_errors=True)
|
2024-12-28 23:24:32 -05:00
|
|
|
|
|
|
|
|
files = walk_cwd_and_copy_if(
|
|
|
|
|
lambda dp, f: (f.endswith(".h") or f.endswith(".hh"))
|
[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
|
|
|
and not f == "heap.h"
|
|
|
|
|
and not f == "stereo-matching-libelas.h"
|
|
|
|
|
and not has_prefix(dp, Path("test")),
|
|
|
|
|
wpical / "src/main/native/thirdparty/mrcal/include",
|
2024-12-28 23:24:32 -05:00
|
|
|
)
|
|
|
|
|
files = files + walk_cwd_and_copy_if(
|
|
|
|
|
lambda dp, f: (
|
|
|
|
|
f.endswith(".c")
|
|
|
|
|
or f.endswith(".cc")
|
|
|
|
|
or f.endswith(".cpp")
|
|
|
|
|
or f.endswith(".pl")
|
|
|
|
|
)
|
[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
|
|
|
and not f == "heap.cc"
|
|
|
|
|
and not f == "mrcal-pywrap.c"
|
|
|
|
|
and not f == "image.c"
|
|
|
|
|
and not f == "stereo.c"
|
|
|
|
|
and not f == "stereo-matching-libelas.cc"
|
|
|
|
|
and not f == "uncertainty.c"
|
|
|
|
|
and not f == "traverse-sensor-links.c"
|
|
|
|
|
and not has_prefix(dp, Path("doc"))
|
|
|
|
|
and not has_prefix(dp, Path("test")),
|
|
|
|
|
wpical / "src/main/native/thirdparty/mrcal/src",
|
2024-12-28 23:24:32 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
for f in files:
|
|
|
|
|
with open(f) as file:
|
|
|
|
|
content = file.read()
|
|
|
|
|
content = content.replace("#warning", "// #warning")
|
|
|
|
|
content = content.replace('__attribute__ ((visibility ("hidden")))', "")
|
|
|
|
|
content = content.replace("__attribute__((unused))", "")
|
|
|
|
|
with open(f, "w") as file:
|
|
|
|
|
file.write(content)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
|
name = "mrcal"
|
|
|
|
|
url = "https://github.com/dkogan/mrcal"
|
2025-07-10 15:01:15 -07:00
|
|
|
# master on 2024-11-29
|
2024-12-28 23:24:32 -05:00
|
|
|
tag = "662a539d3cbba4948c31d06a780569173b3fb6e6"
|
|
|
|
|
|
|
|
|
|
mrcal = Lib(name, url, tag, copy_upstream_src)
|
|
|
|
|
mrcal.main()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
|
main()
|