summaryrefslogtreecommitdiff
path: root/navigation2.spec
diff options
context:
space:
mode:
authorCoprDistGit <infra@openeuler.org>2026-03-30 10:27:52 +0000
committerCoprDistGit <infra@openeuler.org>2026-03-30 10:27:52 +0000
commit1977dbe930ac9a009c874b54112e79ba9fd54157 (patch)
tree7bdc1b2ce9eafe751aba55de4a39e03aee00776c /navigation2.spec
parent616f5147992cbbc87f9725a20ec9b45cefa92ba4 (diff)
automatic import of navigation2openeuler24.03_LTS
Diffstat (limited to 'navigation2.spec')
-rw-r--r--navigation2.spec89
1 files changed, 80 insertions, 9 deletions
diff --git a/navigation2.spec b/navigation2.spec
index 09a4bac..d3e2e38 100644
--- a/navigation2.spec
+++ b/navigation2.spec
@@ -1,17 +1,22 @@
-%bcond_without tests
+%bcond_with tests
%bcond_without weak_deps
%define ros_distro humble
%global debug_package %{nil}
+%global __os_install_post %(echo '%{__os_install_post}' | sed -e 's!/usr/lib[^[:space:]]*/brp-python-bytecompile[[:space:]].*$!!g')
+%global __provides_exclude_from ^/opt/ros/%{ros_distro}/.*$
+%global __requires_exclude_from ^/opt/ros/%{ros_distro}/.*$
-Name: ros-%{ros_distro}-navigation2
+%define RosPkgName navigation2
+
+Name: ros-%{ros_distro}-%{RosPkgName}
Version: 1.1.20
-Release: 1%{?dist}%{?release_suffix}
-Summary: ROS2 Navigation Stack (Metapackage)
+Release: 2%{?dist}%{?release_suffix}
+Summary: ROS2 Navigation Stack
License: Apache-2.0
-URL: https://github.com/ROS-Plan/navigation2
+Source0: %{RosPkgName}-%{version}.tar.gz
Requires: ros-%{ros_distro}-nav2-amcl
Requires: ros-%{ros_distro}-nav2-behavior-tree
@@ -33,8 +38,8 @@ Requires: ros-%{ros_distro}-nav2-smoother
Requires: ros-%{ros_distro}-nav2-regulated-pure-pursuit-controller
Requires: ros-%{ros_distro}-nav2-rotation-shim-controller
Requires: ros-%{ros_distro}-nav2-route
-Requires: ros-%{ros_distro}-nav2-rviz-plugins
-Requires: ros-%{ros_distro}-nav2-simple-commander
+# Requires: ros-%{ros_distro}-nav2-rviz-plugins # skipped: needs rviz2 which is not available
+# Requires: ros-%{ros_distro}-nav2-simple-commander # skipped: LFS tarball issue on EUR
Requires: ros-%{ros_distro}-nav2-smac-planner
Requires: ros-%{ros_distro}-nav2-theta-star-planner
Requires: ros-%{ros_distro}-nav2-util
@@ -43,11 +48,77 @@ Requires: ros-%{ros_distro}-nav2-voxel-grid
Requires: ros-%{ros_distro}-nav2-waypoint-follower
Requires: ros-%{ros_distro}-ros-workspace
+BuildRequires: ros-%{ros_distro}-ament-cmake
+BuildRequires: ros-%{ros_distro}-ros-workspace
+
+%if 0%{?with_tests}
+%endif
+
+Provides: %{name}-devel = %{version}-%{release}
+Provides: %{name}-doc = %{version}-%{release}
+Provides: %{name}-runtime = %{version}-%{release}
+
%description
-ROS2 Navigation Stack - Metapackage that depends on all navigation2 sub-packages.
+ROS2 Navigation Stack
+
+%prep
+%autosetup -n %{RosPkgName}-%{version} -p1
+
+%build
+# Needed to bootstrap since the ros_workspace package does not yet exist.
+export PYTHONPATH=/opt/ros/%{ros_distro}/lib/python%{python3_version}/site-packages
+
+# In case we're installing to a non-standard location, look for a setup.sh
+# in the install tree and source it. It will set things like
+# CMAKE_PREFIX_PATH, PKG_CONFIG_PATH, and PYTHONPATH.
+if [ -f "/opt/ros/%{ros_distro}/setup.sh" ]; then . "/opt/ros/%{ros_distro}/setup.sh"; fi
+mkdir -p .obj-%{_target_platform} && cd .obj-%{_target_platform}
+%cmake3 \
+ -UINCLUDE_INSTALL_DIR \
+ -ULIB_INSTALL_DIR \
+ -USYSCONF_INSTALL_DIR \
+ -USHARE_INSTALL_PREFIX \
+ -ULIB_SUFFIX \
+ -DCMAKE_INSTALL_PREFIX="/opt/ros/%{ros_distro}" \
+ -DAMENT_PREFIX_PATH="/opt/ros/%{ros_distro}" \
+ -DCMAKE_PREFIX_PATH="/opt/ros/%{ros_distro}" \
+ -DSETUPTOOLS_DEB_LAYOUT=OFF \
+%if !0%{?with_tests}
+ -DBUILD_TESTING=OFF \
+%endif
+ ..
+
+%make_build
+
+%install
+# Needed to bootstrap since the ros_workspace package does not yet exist.
+export PYTHONPATH=/opt/ros/%{ros_distro}/lib/python%{python3_version}/site-packages
+
+# In case we're installing to a non-standard location, look for a setup.sh
+# in the install tree and source it. It will set things like
+# CMAKE_PREFIX_PATH, PKG_CONFIG_PATH, and PYTHONPATH.
+if [ -f "/opt/ros/%{ros_distro}/setup.sh" ]; then . "/opt/ros/%{ros_distro}/setup.sh"; fi
+%make_install -C .obj-%{_target_platform}
+
+%if 0%{?with_tests}
+%check
+# Needed to bootstrap since the ros_workspace package does not yet exist.
+export PYTHONPATH=/opt/ros/%{ros_distro}/lib/python%{python3_version}/site-packages
+
+# Look for a Makefile target with a name indicating that it runs tests
+TEST_TARGET=$(%__make -qp -C .obj-%{_target_platform} | sed "s/^\(test\|check\):.*/\\1/;t f;d;:f;q0")
+if [ -n "$TEST_TARGET" ]; then
+# In case we're installing to a non-standard location, look for a setup.sh
+# in the install tree and source it. It will set things like
+# CMAKE_PREFIX_PATH, PKG_CONFIG_PATH, and PYTHONPATH.
+if [ -f "/opt/ros/%{ros_distro}/setup.sh" ]; then . "/opt/ros/%{ros_distro}/setup.sh"; fi
+CTEST_OUTPUT_ON_FAILURE=1 \
+ %make_build -C .obj-%{_target_platform} $TEST_TARGET || echo "RPM TESTS FAILED"
+else echo "RPM TESTS SKIPPED"; fi
+%endif
%files
-%{_datadir}/%{name}
+/opt/ros/%{ros_distro}
%changelog
* Wed Mar 25 2026 Steve Macenski stevenmacenski@gmail.com - 1.1.20-1