diff options
| -rw-r--r-- | .gitignore | 1 | ||||
| -rw-r--r-- | classic-bags.spec | 118 | ||||
| -rw-r--r-- | sources | 1 | 
3 files changed, 120 insertions, 0 deletions
| @@ -0,0 +1 @@ +/ros-humble-classic-bags_0.2.0.orig.tar.gz diff --git a/classic-bags.spec b/classic-bags.spec new file mode 100644 index 0000000..20dc4e6 --- /dev/null +++ b/classic-bags.spec @@ -0,0 +1,118 @@ +%bcond_without tests +%bcond_without weak_deps + +%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}/.*$ + +%define RosPkgName      classic-bags +%define ros_distro      humble +%define with_tests 0 + +Name:           ros-%{ros_distro}-%{RosPkgName} +Version:        0.2.0 +Release:        1%{?dist}%{?release_suffix} +Summary:        A ROS 2 interface in the style of ROS 1 for reading and writing bag files + +License:        BSD 3-clause +Source0:        %{name}_%{version}.orig.tar.gz + +Requires: ros-%{ros_distro}-builtin-interfaces +Requires: ros-%{ros_distro}-rclcpp +Requires: ros-%{ros_distro}-rclpy +Requires: rosbag2_cpp +Requires: rosbag2_py +Requires: rosbag2_storage +Requires: rosidl_runtime_py + +BuildRequires: ros-%{ros_distro}-builtin-interfaces +BuildRequires: ros-%{ros_distro}-rclcpp +BuildRequires: ros-%{ros_distro}-rclpy +BuildRequires: rosbag2_cpp +BuildRequires: rosbag2_py +BuildRequires: rosbag2_storage +BuildRequires: rosidl_runtime_py +BuildRequires: ros-%{ros_distro}-ament-cmake +BuildRequires: ros-%{ros_distro}-ament-cmake-python + +%if 0%{?with_tests} +BuildRequires: ament_cmake_pytest +BuildRequires: rosbag2_storage_mcap +BuildRequires: rosbag2_storage_default_plugins +BuildRequires: ros-%{ros_distro}-std-msgs +%endif + +Provides:       %{name}-devel = %{version}-%{release} +Provides:       %{name}-doc = %{version}-%{release} +Provides:       %{name}-runtime = %{version}-%{release} + +%description +A ROS 2 interface in the style of ROS 1 for reading and writing bag files + +%prep +%autosetup -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 + +export ROS_DISTRO=%{ros_distro} +export ROS_PYTHON_VERSION=%{python3_version} + +# 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}" \ +    -DCMAKE_INSTALL_LIBDIR="/opt/ros/%{ros_distro}/lib" \ +    -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 +/opt/ros/%{ros_distro} + +%changelog +* 三 12月 04 2024 David V. Lu!! davidvlu@gmail.com - 0.2.0-1 +- Autogenerated by ros-porting-tools @@ -0,0 +1 @@ +0aa16f6b85e1c9bab99ff3dae6256e76  ros-humble-classic-bags_0.2.0.orig.tar.gz | 
