Skip to content

Commit 5810d12

Browse files
committed
Add build files 2025-07-29-1044
1 parent d2c2971 commit 5810d12

File tree

7 files changed

+401
-0
lines changed

7 files changed

+401
-0
lines changed

.github/workflows/osx_arm64.yml

Lines changed: 25 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
jobs:
2+
stage_0_job_0:
3+
name: rplidar-ros
4+
runs-on: macos-14
5+
strategy:
6+
fail-fast: false
7+
needs: []
8+
steps:
9+
- name: Checkout code
10+
uses: actions/checkout@v4
11+
- name: Build ros-humble-rplidar-ros
12+
env:
13+
ANACONDA_API_TOKEN: ${{ secrets.ANACONDA_API_TOKEN }}
14+
CURRENT_RECIPES: ros-humble-rplidar-ros
15+
BUILD_TARGET: osx-arm64
16+
run: |
17+
export CI=azure
18+
export GIT_BRANCH=$BUILD_SOURCEBRANCHNAME
19+
export FEEDSTOCK_NAME=$(basename ${BUILD_REPOSITORY_NAME})
20+
.scripts/build_unix.sh --target $BUILD_TARGET
21+
name: build_osx_arm64
22+
on:
23+
push:
24+
branches:
25+
- buildbranch_osx_arm64

buildorder.txt

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
ros-humble-rplidar-ros
Lines changed: 53 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,53 @@
1+
:: Generated by vinca http://github.com/RoboStack/vinca.
2+
:: DO NOT EDIT!
3+
setlocal EnableDelayedExpansion
4+
5+
set "PYTHONPATH=%LIBRARY_PREFIX%\lib\site-packages;%SP_DIR%"
6+
7+
:: MSVC is preferred.
8+
set CC=cl.exe
9+
set CXX=cl.exe
10+
11+
rd /s /q build
12+
mkdir build
13+
pushd build
14+
15+
:: set "CMAKE_GENERATOR=Ninja"
16+
:: We use the Visual Studio generator as a workaround for
17+
:: problems in Ninja when using long paths, see https://github.com/RoboStack/ros-humble/pull/229#issuecomment-2564856467
18+
:: Once those are solved, we can switch back to use Ninja
19+
set "CMAKE_GENERATOR=Visual Studio %VS_MAJOR% %VS_YEAR%"
20+
21+
:: PYTHON_INSTALL_DIR should be a relative path, see
22+
:: https://github.com/ament/ament_cmake/blob/2.3.2/ament_cmake_python/README.md
23+
:: So we compute the relative path of %SP_DIR% w.r.t. to LIBRARY_PREFIX,
24+
:: but it is not trivial to do this in Command Prompt scripting, so let's do it via
25+
:: python
26+
27+
:: This line is scary, but it basically assigns the output of the command inside (` and `)
28+
:: to the variable specified after DO SET
29+
:: The equivalent in bash is PYTHON_INSTALL_DIR=`python -c ...`
30+
FOR /F "tokens=* USEBACKQ" %%i IN (`python -c "import os;print(os.path.relpath(os.environ['SP_DIR'],os.environ['LIBRARY_PREFIX']).replace('\\','/'))"`) DO SET PYTHON_INSTALL_DIR=%%i
31+
32+
cmake ^
33+
-G "%CMAKE_GENERATOR%" ^
34+
-DCMAKE_INSTALL_PREFIX=%LIBRARY_PREFIX% ^
35+
-DCMAKE_BUILD_TYPE=Release ^
36+
-DCMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_SKIP=True ^
37+
-DPYTHON_EXECUTABLE=%PYTHON% ^
38+
-DPython_EXECUTABLE=%PYTHON% ^
39+
-DPython3_EXECUTABLE=%PYTHON% ^
40+
-DSETUPTOOLS_DEB_LAYOUT=OFF ^
41+
-DBUILD_SHARED_LIBS=ON ^
42+
-DBUILD_TESTING=OFF ^
43+
-DCMAKE_OBJECT_PATH_MAX=255 ^
44+
--compile-no-warning-as-error ^
45+
-DPYTHON_INSTALL_DIR=%PYTHON_INSTALL_DIR% ^
46+
^
47+
%SRC_DIR%\%PKG_NAME%\src\work\
48+
if errorlevel 1 exit 1
49+
50+
:: We explicitly pass %CPU_COUNT% to cmake --build as we are not using Ninja,
51+
:: see the comment before setting the CMAKE_GENERATOR env variable
52+
cmake --build . --config Release --parallel %CPU_COUNT% --target install
53+
if errorlevel 1 exit 1
Lines changed: 134 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,134 @@
1+
# Generated by vinca http://github.com/RoboStack/vinca.
2+
# DO NOT EDIT!
3+
4+
set -eo pipefail
5+
6+
rm -rf build
7+
mkdir build
8+
cd build
9+
10+
# necessary for correctly linking SIP files (from python_qt_bindings)
11+
export LINK=$CXX
12+
13+
if [[ "$CONDA_BUILD_CROSS_COMPILATION" != "1" ]]; then
14+
PYTHON_EXECUTABLE=$PREFIX/bin/python
15+
PKG_CONFIG_EXECUTABLE=$PREFIX/bin/pkg-config
16+
OSX_DEPLOYMENT_TARGET="10.15"
17+
else
18+
PYTHON_EXECUTABLE=$BUILD_PREFIX/bin/python
19+
PKG_CONFIG_EXECUTABLE=$BUILD_PREFIX/bin/pkg-config
20+
OSX_DEPLOYMENT_TARGET="11.0"
21+
fi
22+
23+
if [[ "${CONDA_BUILD_CROSS_COMPILATION:-}" == "1" ]]; then
24+
export QT_HOST_PATH="$BUILD_PREFIX"
25+
else
26+
export QT_HOST_PATH="$PREFIX"
27+
fi
28+
29+
echo "USING PYTHON_EXECUTABLE=${PYTHON_EXECUTABLE}"
30+
echo "USING PKG_CONFIG_EXECUTABLE=${PKG_CONFIG_EXECUTABLE}"
31+
32+
export ROS_PYTHON_VERSION=`$PYTHON_EXECUTABLE -c "import sys; print('%i.%i' % (sys.version_info[0:2]))"`
33+
echo "Using Python ${ROS_PYTHON_VERSION}"
34+
35+
# see https://github.com/conda-forge/cross-python-feedstock/issues/24
36+
if [[ "$CONDA_BUILD_CROSS_COMPILATION" == "1" ]]; then
37+
find $PREFIX/lib/cmake -type f -exec sed -i "s~\${_IMPORT_PREFIX}/lib/python${ROS_PYTHON_VERSION}/site-packages~${BUILD_PREFIX}/lib/python${ROS_PYTHON_VERSION}/site-packages~g" {} + || true
38+
find $PREFIX/share/rosidl* -type f -exec sed -i "s~${PREFIX}/lib/python${ROS_PYTHON_VERSION}/site-packages~${BUILD_PREFIX}/lib/python${ROS_PYTHON_VERSION}/site-packages~g" {} + || true
39+
find $PREFIX/share/rosidl* -type f -exec sed -i "s~\${_IMPORT_PREFIX}/lib/python${ROS_PYTHON_VERSION}/site-packages~${BUILD_PREFIX}/lib/python${ROS_PYTHON_VERSION}/site-packages~g" {} + || true
40+
find $PREFIX/lib/cmake -type f -exec sed -i "s~message(FATAL_ERROR \"The imported target~message(WARNING \"The imported target~g" {} + || true
41+
fi
42+
43+
if [[ $target_platform =~ linux.* ]]; then
44+
export CFLAGS="${CFLAGS} -D__STDC_FORMAT_MACROS=1"
45+
export CXXFLAGS="${CXXFLAGS} -D__STDC_FORMAT_MACROS=1"
46+
fi;
47+
48+
# Needed for qt-gui-cpp ..
49+
if [[ $target_platform =~ linux.* ]]; then
50+
ln -s $GCC ${BUILD_PREFIX}/bin/gcc
51+
ln -s $GXX ${BUILD_PREFIX}/bin/g++
52+
fi;
53+
54+
# PYTHON_INSTALL_DIR should be a relative path, see
55+
# https://github.com/ament/ament_cmake/blob/2.3.2/ament_cmake_python/README.md
56+
# So we compute the relative path of $SP_DIR w.r.t. to $PREFIX,
57+
# but it is not trivial to do this in bash scripting, so let's do it via python
58+
export PYTHON_INSTALL_DIR=`python -c "import os;print(os.path.relpath(os.environ['SP_DIR'],os.environ['PREFIX']))"`
59+
echo "Using PYTHON_INSTALL_DIR: $PYTHON_INSTALL_DIR"
60+
61+
if [[ $target_platform =~ emscripten.* ]]; then
62+
export CONDA_BUILD_CROSS_COMPILATION="1"
63+
PYTHON_EXECUTABLE=$BUILD_PREFIX/bin/python$PY_VER
64+
echo "set_property(GLOBAL PROPERTY TARGET_SUPPORTS_SHARED_LIBS TRUE)"> $SRC_DIR/__vinca_shared_lib_patch.cmake
65+
echo "set(CMAKE_STRIP FALSE) # used by default in pybind11 on .so modules">> $SRC_DIR/__vinca_shared_lib_patch.cmake
66+
echo "set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE BOTH) # fixes an error where numpy header files are not found correctly">> $SRC_DIR/__vinca_shared_lib_patch.cmake
67+
68+
# if [ "${PKG_NAME}" == "ros-humble-examples-rclcpp-minimal-publisher" ] || [ "${PKG_NAME}" == "ros-humble-examples-rclcpp-minimal-subscriber" ] || [ "${PKG_NAME}" == "ros-humble-rclcpp-components" ]; then
69+
# echo "set(CMAKE_SHARED_LIBRARY_CREATE_C_FLAGS \"-s ASSERTIONS=1 -s SIDE_MODULE=1 -sWASM_BIGINT -s USE_PTHREADS=0 -s DEMANGLE_SUPPORT=1 -s ALLOW_MEMORY_GROWTH=1 \")">> $SRC_DIR/__vinca_shared_lib_patch.cmake
70+
# echo "set(CMAKE_SHARED_LIBRARY_CREATE_CXX_FLAGS \"-s ASSERTIONS=1 -s SIDE_MODULE=1 -sWASM_BIGINT -s USE_PTHREADS=0 -s DEMANGLE_SUPPORT=1 -s ALLOW_MEMORY_GROWTH=1 -sASYNCIFY -O3 -s ASYNCIFY_STACK_SIZE=24576 \")">> $SRC_DIR/__vinca_shared_lib_patch.cmake
71+
# echo "set(CMAKE_EXE_LINKER_FLAGS \"-sMAIN_MODULE=1 -sASSERTIONS=1 -fexceptions -lembind -sWASM_BIGINT -s USE_PTHREADS=0 -s DEMANGLE_SUPPORT=1 -sALLOW_MEMORY_GROWTH=1 -sASYNCIFY -O3 -s ASYNCIFY_STACK_SIZE=24576 -L$SRC_DIR/build -L$PREFIX/lib\") # remove SIDE_MODULE from exe linker flags">> $SRC_DIR/__vinca_shared_lib_patch.cmake
72+
# else
73+
echo "set(CMAKE_SHARED_LIBRARY_CREATE_C_FLAGS \"-s ASSERTIONS=1 -s SIDE_MODULE=1 -sWASM_BIGINT -s USE_PTHREADS=0 -s ALLOW_MEMORY_GROWTH=1 -s DEMANGLE_SUPPORT=1 \")">> $SRC_DIR/__vinca_shared_lib_patch.cmake
74+
echo "set(CMAKE_SHARED_LIBRARY_CREATE_CXX_FLAGS \"-s ASSERTIONS=1 -s SIDE_MODULE=1 -sWASM_BIGINT -s USE_PTHREADS=0 -s ALLOW_MEMORY_GROWTH=1 -s DEMANGLE_SUPPORT=1 \")">> $SRC_DIR/__vinca_shared_lib_patch.cmake
75+
echo "set(CMAKE_EXE_LINKER_FLAGS \"-sMAIN_MODULE=1 -sASSERTIONS=1 -fexceptions -lembind -sWASM_BIGINT -s USE_PTHREADS=0 -sALLOW_MEMORY_GROWTH=1 -s DEMANGLE_SUPPORT=1 -L$SRC_DIR/build -L$PREFIX/lib\") # remove SIDE_MODULE from exe linker flags">> $SRC_DIR/__vinca_shared_lib_patch.cmake
76+
# fi
77+
78+
export BUILD_TYPE="Debug"
79+
export EXTRA_CMAKE_ARGS=" \
80+
-DPYTHON_SOABI="cpython-${ROS_PYTHON_VERSION//./}-wasm32-emscripten" \
81+
-DRMW_IMPLEMENTATION=rmw_wasm_cpp \
82+
-DCMAKE_FIND_ROOT_PATH=$PREFIX \
83+
-DCMAKE_POSITION_INDEPENDENT_CODE=TRUE \
84+
-DCMAKE_PROJECT_INCLUDE=$SRC_DIR/__vinca_shared_lib_patch.cmake \
85+
"
86+
87+
unset -f cmake
88+
export CMAKE_GEN="emcmake cmake"
89+
export CMAKE_BLD="cmake"
90+
91+
export STATIC_ROSIDL_TYPESUPPORT_C=rosidl_typesupport_introspection_c
92+
export STATIC_ROSIDL_TYPESUPPORT_CPP=rosidl_typesupport_introspection_cpp
93+
else
94+
export BUILD_TYPE="Release"
95+
export CMAKE_GEN="cmake"
96+
export CMAKE_BLD="cmake"
97+
fi;
98+
99+
if [ "${PKG_NAME}" == "ros-humble-rmw-wasm-cpp" ]; then
100+
WORK_DIR=$SRC_DIR/$PKG_NAME/src/work/rmw_wasm_cpp
101+
elif [ "${PKG_NAME}" == "ros-humble-wasm-cpp" ]; then
102+
WORK_DIR=$SRC_DIR/$PKG_NAME/src/work/wasm_cpp
103+
elif [ "${PKG_NAME}" == "dynmsg" ]; then
104+
WORK_DIR=$SRC_DIR/$PKG_NAME/src/work/dynmsg
105+
else
106+
WORK_DIR=$SRC_DIR/$PKG_NAME/src/work/
107+
fi;
108+
109+
$CMAKE_GEN \
110+
-G "Ninja" \
111+
-DCMAKE_BUILD_TYPE=$BUILD_TYPE \
112+
-DCMAKE_INSTALL_PREFIX=$PREFIX \
113+
-DCMAKE_PREFIX_PATH=$PREFIX \
114+
-DAMENT_PREFIX_PATH=$PREFIX \
115+
-DCMAKE_INSTALL_LIBDIR=lib \
116+
-DPYTHON_EXECUTABLE=$PYTHON_EXECUTABLE \
117+
-DPython_EXECUTABLE=$PYTHON_EXECUTABLE \
118+
-DPython3_EXECUTABLE=$PYTHON_EXECUTABLE \
119+
-DPython3_FIND_STRATEGY=LOCATION \
120+
-DPKG_CONFIG_EXECUTABLE=$PKG_CONFIG_EXECUTABLE \
121+
-DPYTHON_INSTALL_DIR=$PYTHON_INSTALL_DIR \
122+
-DSETUPTOOLS_DEB_LAYOUT=OFF \
123+
-DCATKIN_SKIP_TESTING=$SKIP_TESTING \
124+
-DCMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_SKIP=True \
125+
-DBUILD_SHARED_LIBS=ON \
126+
-DBUILD_TESTING=OFF \
127+
-DCMAKE_IGNORE_PREFIX_PATH="/opt/homebrew;/usr/local/homebrew" \
128+
-DCMAKE_OSX_DEPLOYMENT_TARGET=$OSX_DEPLOYMENT_TARGET \
129+
--compile-no-warning-as-error \
130+
$EXTRA_CMAKE_ARGS \
131+
\
132+
$WORK_DIR
133+
134+
$CMAKE_BLD --build . --config $BUILD_TYPE --target install
Lines changed: 89 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,89 @@
1+
diff --git a/CMakeLists.txt b/CMakeLists.txt
2+
index 48123e6..f0cecc7 100644
3+
--- a/CMakeLists.txt
4+
+++ b/CMakeLists.txt
5+
@@ -21,18 +21,25 @@ endif()
6+
set(RPLIDAR_SDK_PATH "./sdk/")
7+
8+
if(APPLE)
9+
-add_compile_definitions(_MACOS)
10+
-FILE(GLOB RPLIDAR_SDK_SRC
11+
- "${RPLIDAR_SDK_PATH}/src/arch/macOS/*.cpp"
12+
- "${RPLIDAR_SDK_PATH}/src/hal/*.cpp"
13+
- "${RPLIDAR_SDK_PATH}/src/*.cpp"
14+
-)
15+
+ add_compile_definitions(_MACOS)
16+
+ FILE(GLOB RPLIDAR_SDK_SRC
17+
+ "${RPLIDAR_SDK_PATH}/src/arch/macOS/*.cpp"
18+
+ "${RPLIDAR_SDK_PATH}/src/hal/*.cpp"
19+
+ "${RPLIDAR_SDK_PATH}/src/*.cpp"
20+
+ )
21+
+elseif(WIN32)
22+
+ add_compile_definitions(_USE_MATH_DEFINES)
23+
+ FILE(GLOB RPLIDAR_SDK_SRC
24+
+ "${RPLIDAR_SDK_PATH}/src/arch/win32/*.cpp"
25+
+ "${RPLIDAR_SDK_PATH}/src/hal/*.cpp"
26+
+ "${RPLIDAR_SDK_PATH}/src/*.cpp"
27+
+ )
28+
else()
29+
-FILE(GLOB RPLIDAR_SDK_SRC
30+
- "${RPLIDAR_SDK_PATH}/src/arch/linux/*.cpp"
31+
- "${RPLIDAR_SDK_PATH}/src/hal/*.cpp"
32+
- "${RPLIDAR_SDK_PATH}/src/*.cpp"
33+
-)
34+
+ FILE(GLOB RPLIDAR_SDK_SRC
35+
+ "${RPLIDAR_SDK_PATH}/src/arch/linux/*.cpp"
36+
+ "${RPLIDAR_SDK_PATH}/src/hal/*.cpp"
37+
+ "${RPLIDAR_SDK_PATH}/src/*.cpp"
38+
+ )
39+
endif()
40+
41+
################################################################################
42+
diff --git a/sdk/Makefile b/sdk/Makefile
43+
index 81215d9..69aec97 100644
44+
--- a/sdk/Makefile
45+
+++ b/sdk/Makefile
46+
@@ -60,6 +60,12 @@ CXXSRC += src/arch/macOS/net_serial.cpp \
47+
src/arch/macOS/timer.cpp
48+
endif
49+
50+
+ifeq ($(BUILD_TARGET_PLATFORM),Windows)
51+
+CXXSRC += src/arch/windows/net_serial.cpp \
52+
+ src/arch/windows/net_socket.cpp \
53+
+ src/arch/windows/timer.cpp
54+
+endif
55+
+
56+
all: build_sdk
57+
58+
include $(HOME_TREE)/mak_common.inc
59+
diff --git a/sdk/src/arch/macOS/net_socket.cpp b/sdk/src/arch/macOS/net_socket.cpp
60+
index f7ddfbf..153de6d 100644
61+
--- a/sdk/src/arch/macOS/net_socket.cpp
62+
+++ b/sdk/src/arch/macOS/net_socket.cpp
63+
@@ -754,6 +754,26 @@ public:
64+
65+
}
66+
67+
+ virtual u_result clearRxCache()
68+
+ {
69+
+ timeval tv;
70+
+ tv.tv_sec = 0;
71+
+ tv.tv_usec = 0;
72+
+ fd_set rdset;
73+
+ FD_ZERO(&rdset);
74+
+ FD_SET(_socket_fd, &rdset);
75+
+
76+
+ int res = -1;
77+
+ char recv_data[2];
78+
+ memset(recv_data, 0, sizeof(recv_data));
79+
+ while (true) {
80+
+ res = select(FD_SETSIZE, &rdset, nullptr, nullptr, &tv);
81+
+ if (res == 0) break;
82+
+ recv(_socket_fd, recv_data, 1, 0);
83+
+ }
84+
+ return RESULT_OK;
85+
+ }
86+
+
87+
virtual u_result recvFrom(void *buf, size_t len, size_t & recv_len, SocketAddress * sourceAddr)
88+
{
89+
struct sockaddr * addr = (sourceAddr?reinterpret_cast<struct sockaddr *>(const_cast<void *>(sourceAddr->getPlatformData())):NULL);

0 commit comments

Comments
 (0)