summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCoprDistGit <infra@openeuler.org>2025-03-08 14:41:58 +0000
committerCoprDistGit <infra@openeuler.org>2025-03-08 14:41:58 +0000
commit223668fb8145dee18a01fda33ae2c9aebde53ba0 (patch)
tree30de0b76024e8c021eb7ed3a2f067b2e50bb322f
parent9882601010a78a1aeec4ff4a136f6e5666078a65 (diff)
automatic import of ros-humble-osqp-vendoropeneuler24.03_LTS
-rw-r--r--.gitignore2
-rw-r--r--0-osqp-vendor-change-cmake-download.patch15
-rw-r--r--osqp-vendor.spec107
-rw-r--r--sources2
4 files changed, 126 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore
index e69de29..54d7c8f 100644
--- a/.gitignore
+++ b/.gitignore
@@ -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
diff --git a/sources b/sources
new file mode 100644
index 0000000..c2af687
--- /dev/null
+++ b/sources
@@ -0,0 +1,2 @@
+ed1cf6a90e1683e2e2cca6b04711dbf9 osqp-v0.6.2.tar.gz
+d1ae9d1eb289c7c5a9f636be48807a52 ros-humble-osqp-vendor_0.2.0.orig.tar.gz