diff --git a/.gitattributes b/.gitattributes new file mode 100644 index 0000000000000000000000000000000000000000..b4415df94133b817a20c2746551d93c636808bac --- /dev/null +++ b/.gitattributes @@ -0,0 +1 @@ +ros-humble-proxsuite_0.6.5.orig.tar.gz filter=lfs diff=lfs merge=lfs -text diff --git a/files_in_srpm.txt b/files_in_srpm.txt new file mode 100644 index 0000000000000000000000000000000000000000..53aa4574ad11c3c3242694d8e34dcc00a8cff39d --- /dev/null +++ b/files_in_srpm.txt @@ -0,0 +1,2 @@ +proxsuite.spec +ros-humble-proxsuite_0.6.5.orig.tar.gz diff --git a/proxsuite.spec b/proxsuite.spec new file mode 100644 index 0000000000000000000000000000000000000000..a724e5aa70efaa83c53bde875416bfd336f3c817 --- /dev/null +++ b/proxsuite.spec @@ -0,0 +1,110 @@ +%bcond_without tests +%bcond_without weak_deps + +%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}/.*$ +%global debug_package %{nil} +%define RosPkgName proxsuite +%define ros_distro humble +%define with_tests 0 + +Name: ros-%{ros_distro}-%{RosPkgName} +Version: 0.6.5 +Release: 1%{?dist}%{?release_suffix} +Summary: The Advanced Proximal Optimization Toolbox + +Url: https://simple-robotics.github.io/proxsuite +License: BSD-2 +Source0: %{name}_%{version}.orig.tar.gz + +Requires: eigen3-devel +Requires: simde-devel +Requires: python3-numpy +Requires: python3-scipy + +BuildRequires: eigen3-devel +BuildRequires: simde-devel +BuildRequires: python3-numpy +BuildRequires: python3-scipy +BuildRequires: git +BuildRequires: doxygen +BuildRequires: cmake + +%if 0%{?with_tests} +BuildRequires: matio +%endif + +Provides: %{name}-devel = %{version}-%{release} +Provides: %{name}-doc = %{version}-%{release} +Provides: %{name}-runtime = %{version}-%{release} + +%description +The Advanced Proximal Optimization Toolbox + +%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 +* Fri May 23 2025 Justin Carpentier justin.carpentier@inria.fr - 0.6.5-1 +- Autogenerated by ros-porting-tools diff --git a/proxsuite.src.rpm b/proxsuite.src.rpm new file mode 100644 index 0000000000000000000000000000000000000000..fa5dfb6cb1ced1e405929ff984c96c83b2d497c7 Binary files /dev/null and b/proxsuite.src.rpm differ diff --git a/ros-humble-proxsuite_0.6.5.orig.tar.gz b/ros-humble-proxsuite_0.6.5.orig.tar.gz new file mode 100644 index 0000000000000000000000000000000000000000..68b9752c715d06259c027a93dae80f0aab55b217 --- /dev/null +++ b/ros-humble-proxsuite_0.6.5.orig.tar.gz @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:6664a3b55b98770043828f90f78cb6b96d90bc8a72cafa9ad47d1fbae0babd73 +size 58101913