diff --git a/build-generic-linux.sh b/build-generic-linux.sh new file mode 100755 index 00000000..20a095d8 --- /dev/null +++ b/build-generic-linux.sh @@ -0,0 +1,49 @@ +#!/bin/bash +SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" +PROJECT_ROOT="$SCRIPT_DIR" + +docker_name="mgconsole_build_generic_linux" +toolchain_url="https://s3-eu-west-1.amazonaws.com/deps.memgraph.io/toolchain-v4/toolchain-v4-binaries-centos-7-x86_64.tar.gz" +toolchain_tar_gz="$(basename $toolchain_url)" +memgraph_repo="https://github.com/memgraph/memgraph.git" +setup_toolchain_cmd="cd /memgraph/environment/os && \ + ./centos-7.sh check TOOLCHAIN_RUN_DEPS || \ + ./centos-7.sh install TOOLCHAIN_RUN_DEPS" +setup_memgraph_cmd="cd /memgraph/environment/os && \ + ./centos-7.sh check MEMGRAPH_BUILD_DEPS || \ + ./centos-7.sh install MEMGRAPH_BUILD_DEPS" +mgconsole_build_cmd="source /opt/toolchain-v4/activate && \ + mkdir -p /mgconsole/build && cd /mgconsole/build && \ + cmake -DCMAKE_BUILD_TYPE=Release .. && make -j" + +if [ ! "$(docker info)" ]; then + echo "ERROR: Docker is required" + exit 1 +fi + +if [ ! "$(docker ps -q -f name=$docker_name)" ]; then + if [ "$(docker ps -aq -f status=exited -f name=$docker_name)" ]; then + echo "Cleanup of the old exited mgconsole build container..." + docker rm $docker_name + fi + docker run -d --network host --name "$docker_name" centos:7 sleep infinity +fi +echo "The mgconsole build container is active!" + +docker_exec () { + cmd="$1" + docker exec -it "$docker_name" bash -c "$cmd" +} + +docker_exec "mkdir -p /mgconsole" +docker cp -q "$PROJECT_ROOT/." "$docker_name:/mgconsole/" +docker_exec "rm -rf /mgconsole/build/*" +docker_exec "yum install -y wget git" +docker_exec "[ ! -f /$toolchain_tar_gz ] && wget -O /$toolchain_tar_gz $toolchain_url" +docker_exec "[ ! -d /opt/toolchain-v4/ ] && tar -xzf /$toolchain_tar_gz -C /opt" +docker_exec "[ ! -d /memgraph/ ] && git clone $memgraph_repo" +docker_exec "$setup_toolchain_cmd" +docker_exec "$setup_memgraph_cmd" +docker_exec "$mgconsole_build_cmd" +mkdir -p "$PROJECT_ROOT/build/generic" +docker cp -q "$docker_name:/mgconsole/build/src/mgconsole" "$PROJECT_ROOT/build/generic/" diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index f6184c5d..a29dec25 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -44,7 +44,8 @@ if(MGCONSOLE_ON_WINDOWS) set(CMAKE_CXX_STANDARD_LIBRARIES "-static-libgcc -static-libstdc++ -lws2_32") set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,-Bstatic,--whole-archive -lwinpthread -Wl,--no-whole-archive") elseif(MGCONSOLE_ON_LINUX) - set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -static-libgcc -static-libstdc++") + # -no-pie -> https://stackoverflow.com/questions/46827433/g-compile-error-rodata-can-not-be-used-when-making-a-shared-object-recomp + set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -static-libgcc -static-libstdc++ -no-pie") endif() if(MGCONSOLE_ON_LINUX) @@ -63,7 +64,6 @@ ExternalProject_Add(gflags-proj CMAKE_ARGS "-DCMAKE_INSTALL_PREFIX=" "-DCMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE}" "-DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}" - "-DCMAKE_C_COMPILER=${CMAKE_C_COMPILER}" INSTALL_DIR "${PROJECT_BINARY_DIR}/gflags") ExternalProject_Get_Property(gflags-proj install_dir) @@ -121,20 +121,17 @@ target_include_directories(mgconsole ${MGCLIENT_INCLUDE_DIRS} ${REPLXX_INCLUDE_DIRS} ${CMAKE_CURRENT_BINARY_DIR}) - target_link_libraries(mgconsole PRIVATE ${GFLAGS_LIBRARY} utils ${MGCLIENT_LIBRARY} ${OPENSSL_LIBRARIES}) - if(MGCONSOLE_ON_WINDOWS) target_link_libraries(mgconsole PRIVATE shlwapi) endif() configure_file("${CMAKE_CURRENT_SOURCE_DIR}/version.hpp.in" "${CMAKE_CURRENT_BINARY_DIR}/version.hpp") - install(TARGETS mgconsole RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}) diff --git a/src/utils/CMakeLists.txt b/src/utils/CMakeLists.txt index c90cfd7c..66dfd4e6 100644 --- a/src/utils/CMakeLists.txt +++ b/src/utils/CMakeLists.txt @@ -1,11 +1,13 @@ ExternalProject_Add(replxx-proj PREFIX replxx GIT_REPOSITORY https://github.com/AmokHuginnsson/replxx.git - GIT_TAG release-0.0.3 + GIT_TAG release-0.0.4 CMAKE_ARGS "-DCMAKE_INSTALL_PREFIX=" "-DCMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE}" "-DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}" "-DCMAKE_C_COMPILER=${CMAKE_C_COMPILER}" + "-DREPLXX_BUILD_EXAMPLES=OFF" + "-DBUILD_SHARED_LIBS=OFF" INSTALL_DIR "${PROJECT_BINARY_DIR}/replxx") if(CMAKE_BUILD_TYPE_LOWERCASE STREQUAL "debug")