让我说我有这个:
../project_dir
main.cpp
mylib.cpp
mylib.h
构建步骤将是:
g++ -c mylib.cpp -o mylib.o
g++ -shared -o libmylib.so mylib.o
g++ -L$(pwd) -Wl,-rpath='$ORIGIN' -o exec main.cpp -lmylib
exec
将是我的二进制可执行输出。当我测试时:
ldd exec
输出行是:
libmylib.so => /full/path/to/build/directory/libmylib.so (0x00007f75fdd1f000)
那个输出行是我的问题,有可能得到:
libmylib.so => ./libmylib.so
所以每当我移动可执行文件时,我都可以随身携带共享库。如果有可能,如何用cmake做到这一点?
答案 0 :(得分:5)
Juste添加你的CMakefiles.txt
set(CMAKE_INSTALL_RPATH "$ORIGIN")
set(CMAKE_BUILD_WITH_INSTALL_RPATH TRUE) # only if you want copy from the build tree
答案 1 :(得分:2)
当您启动ldd
以检查应用程序共享库依赖项时,它始终会打印绝对路径。但是,如果您将-rpath
oprtion与$ORIGIN
变量一起使用,一切都会按预期工作。您可以移动可执行文件和共享库,删除原始构建目录,您仍然可以启动应用程序。
您可以使用cmake
:
project(myapp)
cmake_minimum_required(VERSION 2.8)
set(APP_SRC main.cpp)
set(LIB_SRC mylib.cpp)
link_directories(${CMAKE_CURRENT_BINARY_DIR})
SET(CMAKE_EXE_LINKER_FLAGS
"${CMAKE_EXE_LINKER_FLAGS} -Wl,-rpath -Wl,$ORIGIN")
add_library(mylib SHARED ${LIB_SRC})
add_executable(${PROJECT_NAME} ${APP_SRC})
target_link_libraries(${PROJECT_NAME} mylib)
答案 2 :(得分:0)
我必须在$ {ORIGIN}周围加上大括号,并为要链接的库添加路径:
SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -L${CMAKE_BINARY_DIR} -lmyLibrary -Wl,-rpath -Wl,${ORIGIN}")
set(CMAKE_INSTALL_RPATH "${ORIGIN}")
set(CMAKE_BUILD_WITH_INSTALL_RPATH TRUE)