diff options
author | CoprDistGit <infra@openeuler.org> | 2025-03-08 14:41:58 +0000 |
---|---|---|
committer | CoprDistGit <infra@openeuler.org> | 2025-03-08 14:41:58 +0000 |
commit | 223668fb8145dee18a01fda33ae2c9aebde53ba0 (patch) | |
tree | 30de0b76024e8c021eb7ed3a2f067b2e50bb322f | |
parent | 9882601010a78a1aeec4ff4a136f6e5666078a65 (diff) |
automatic import of ros-humble-osqp-vendoropeneuler24.03_LTS
-rw-r--r-- | .gitignore | 2 | ||||
-rw-r--r-- | 0-osqp-vendor-change-cmake-download.patch | 15 | ||||
-rw-r--r-- | osqp-vendor.spec | 107 | ||||
-rw-r--r-- | sources | 2 |
4 files changed, 126 insertions, 0 deletions
@@ -0,0 +1,2 @@ +/osqp-v0.6.2.tar.gz +/ros-humble-osqp-vendor_0.2.0.orig.tar.gz diff --git a/0-osqp-vendor-change-cmake-download.patch b/0-osqp-vendor-change-cmake-download.patch new file mode 100644 index 0000000..bc5bc6f --- /dev/null +++ b/0-osqp-vendor-change-cmake-download.patch @@ -0,0 +1,15 @@ +diff --git a/CMakeLists.txt b/CMakeLists.txt +index b17c512..ef7a27f 100644 +--- a/CMakeLists.txt ++++ b/CMakeLists.txt +@@ -21,9 +21,7 @@ macro(build_osqp) + + include(ExternalProject) + externalproject_add(osqp-${git_tag} +- GIT_REPOSITORY https://github.com/osqp/osqp.git +- GIT_TAG ${git_tag} +- GIT_SHALLOW ON ++ URL ${CMAKE_SOURCE_DIR}/osqp-${git_tag}.tar.gz + TIMEOUT 60 + # Suppress git update due to https://gitlab.kitware.com/cmake/cmake/-/issues/16419 + UPDATE_COMMAND "" diff --git a/osqp-vendor.spec b/osqp-vendor.spec new file mode 100644 index 0000000..8b6b298 --- /dev/null +++ b/osqp-vendor.spec @@ -0,0 +1,107 @@ +%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 osqp-vendor +%define ros_distro humble + +Name: ros-%{ros_distro}-%{RosPkgName} +Version: 0.2.0 +Release: 1%{?dist}%{?release_suffix} +Summary: ROS osqp-vendor package + +Url: https://github.com/oxfordcontrol/osqp +License: Apache License 2.0 +Source0: %{name}_%{version}.orig.tar.gz +Source1: osqp-v0.6.2.tar.gz + +Patch0: 0-osqp-vendor-change-cmake-download.patch + +Requires: ros-%{ros_distro}-ros-workspace + +BuildRequires: ros-%{ros_distro}-ros-environment +BuildRequires: ros-%{ros_distro}-ament-cmake +BuildRequires: git +BuildRequires: ros-%{ros_distro}-ros-workspace + +%if 0%{?with_tests} +BuildRequires: ros-%{ros_distro}-ament-lint-auto +BuildRequires: ros-%{ros_distro}-ament-lint-common +%endif + +Provides: %{name}-devel = %{version}-%{release} +Provides: %{name}-doc = %{version}-%{release} +Provides: %{name}-runtime = %{version}-%{release} + +%description + + Wrapper around osqp that ships with a CMake module + + +%prep +%autosetup -p1 +cp %{SOURCE1} . + +%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 +/opt/ros/%{ros_distro} + +%changelog +* Thu May 04 2023 Esteve Fernandez esteve.fernandez@autoware.org - 0.2.0-1 +- Autogenerated by ros-porting-tools @@ -0,0 +1,2 @@ +ed1cf6a90e1683e2e2cca6b04711dbf9 osqp-v0.6.2.tar.gz +d1ae9d1eb289c7c5a9f636be48807a52 ros-humble-osqp-vendor_0.2.0.orig.tar.gz |