X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=CMakeLists.txt;h=7e273584fb7e3cca19f05a98fabd6f612db53136;hb=a7610c690a3976e296ca768977e38ceb9aafa5ff;hp=9371ce3b82161af967e5b77cd447e6af2fc8b5de;hpb=aa0b497f216ebd8bc72850bf4af5c9f35c288b65;p=ric-plt%2Flib%2Frmr.git diff --git a/CMakeLists.txt b/CMakeLists.txt index 9371ce3..7e27358 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,7 +1,6 @@ - # #================================================================================== -# Copyright (c) 2019 Nokia +# Copyright (c) 2019 Nokia # Copyright (c) 2018-2019 AT&T Intellectual Property. # # Licensed under the Apache License, Version 2.0 (the "License"); @@ -18,13 +17,21 @@ #================================================================================== # +# This CMake definition supports several -D command line options: +# +# -DDEV_PKG=1 Development package configuration +# -DBUILD_DOC=1 Man pages generated +# -DPRESERVE_PTYPE=1 Do not change the processor type when naming deb packages +# -DPACK_EXTERNALS=1 Include external libraries used to build in the run-time package +# -DSKIP_EXTERNALS=1 Do not use Nano/NNG submodules when building; uee installed packages +# -DMAN_PREFIX= Supply a path where man pages are installed (default: /usr/share/man) + project( rmr LANGUAGES C ) cmake_minimum_required( VERSION 3.5 ) - -set( major_version "1" ) +set( major_version "1" ) # should be automatically populated from git tag later, but until CI process sets a tag we use this set( minor_version "0" ) -set( patch_level "16" ) +set( patch_level "37" ) set( install_root "${CMAKE_INSTALL_PREFIX}" ) set( install_lib "lib" ) @@ -39,23 +46,114 @@ endif() # locations on all platforms. include( GNUInstallDirs ) -if( NOT BUILD_LIB ) - set( BUILD_LIB lib ) +# nano/nng install using LIBDIR as established by the gnu include; it varies from system +# to system, and we don't trust that it is always set, so we default to lib. +# +if( NOT CMAKE_INSTALL_LIBDIR ) + set( CMAKE_INSTALL_LIBDIR "lib" ) endif() -# ---------------- set version info (not perfect, but better than nothing) ---- -execute_process( - COMMAND bash -c "git rev-parse --short HEAD|awk '{printf\"%s\", $0}'" +# ---------------- extract some things from git ------------------------------ + +# commit id for the version string +execute_process( + COMMAND bash -c "git rev-parse --short HEAD|awk '{printf\"%s\", $0}'" OUTPUT_VARIABLE git_id ) -add_definitions( - -DGIT_ID=${git_id} +# version information for library names and version string +execute_process( + COMMAND bash -c "git describe --tags --abbrev=0 HEAD 2>/dev/null | awk -v tag=0.0.4095 ' { tag=$1 } END{ print tag suffix }'|sed 's/\\./;/g' " + OUTPUT_VARIABLE mmp_version_str + ERROR_QUIET OUTPUT_STRIP_TRAILING_WHITESPACE +) + +# extra indicator to show that the build was based on modified file(s) and not the true commit +# (no hope of reproducing the exact library for debugging). Used only for the internal version +# string. +execute_process( + COMMAND bash -c "git diff --shortstat|awk -v fmt=%s -v r=-rotten '{ s=r } END { printf( fmt, s ) }'" + OUTPUT_VARIABLE spoiled_str +) + +# uncomment these lines once CI starts adding a tag on merge +#set( mmp_version ${mmp_version_str} ) +#list( GET mmp_version 0 major_version ) +#list( GET mmp_version 1 minor_version ) +#list( GET mmp_version 2 patch_level ) + + +# define constants used in the version string +add_definitions( + -DGIT_ID=${git_id} -DMAJOR_VER=${major_version} -DMINOR_VER=${minor_version} -DPATCH_VER=${patch_level} ) +# ---------------- suss out pkg gen tools so we don't fail generating packages that the system cannot support -------------- + +# deb packages use underbars, and package manager(s) seem to flip the *_64 processor type +# to the old (non-standard) amd64 string, so we do it here for consistency. Set -DPRESERVE_PTYPE=1 +# to prevent the flip. RPM packages will always be given the system generated processor type string. +# +if( ${CMAKE_SYSTEM_PROCESSOR} MATCHES "x86_64" ) + if( NOT PRESERVE_PTYPE ) + set( deb_sys_name "amd64" ) + else() + set( deb_sys_name ${CMAKE_SYSTEM_PROCESSOR} ) + endif() +else() + set( deb_sys_name ${CMAKE_SYSTEM_PROCESSOR} ) +endif() +unset( PRESERVE_PTYPE CACHE ) # we don't want this to persist + +set( rpm_sys_name ${CMAKE_SYSTEM_PROCESSOR} ) + +if( DEV_PKG ) + set( deb_pkg_name "rmr-dev" ) + set( rpm_pkg_name "rmr-devel" ) +else() + set( deb_pkg_name "rmr" ) + set( rpm_pkg_name "rmr" ) +endif() + +set( pkg_label "rmr${spoiled_str}-${major_version}.${minor_version}.${patch_level}-${sys_name}" ) +set( rpm_pkg_label "${rpm_pkg_name}${spoiled_str}-${major_version}.${minor_version}.${patch_level}-${rpm_sys_name}" ) +set( deb_pkg_label "${deb_pkg_name}${spoiled_str}_${major_version}.${minor_version}.${patch_level}_${deb_sys_name}" ) +message( "+++ pkg name: ${deb_pkg_label}.deb" ) +message( "+++ pkg name: ${rpm_pkg_label}.rpm" ) + +set( out_yml /tmp/build_output.yml ) # we will record package names (we record only untainted names) +find_program( rpm NAMES rpmbuild ) # rpm package gen requires this to be installed + +set( gen_rpm 0 ) +if( "${rpm}" MATCHES "rpm-NOTFOUND" ) # cannot build rpm + set( pkg_list "DEB" ) + message( "### make package will generate only deb package; cannot find support to generate rpm packages" ) +else() + set( pkg_list "DEB;RPM" ) + set( gen_rpm 1 ) + message( "+++ make package will generate both deb and rpm packages" ) +endif() + +execute_process( + COMMAND bash -c "printf '# RMr build generated list of package paths\n---\n' >${out_yml}" +) + +execute_process( + COMMAND bash -c " echo deb: ${CMAKE_CURRENT_BINARY_DIR}/${deb_pkg_label}.deb >>${out_yml}" +) + +if( gen_rpm ) + execute_process( + COMMAND bash -c " echo rpm: ${CMAKE_CURRENT_BINARY_DIR}/${rpm_pkg_label}.rpm >>${out_yml}" + ) +endif() + +execute_process( + COMMAND bash -c "printf '...\n' >>${out_yml}" +) # ---------------- setup nano/nng things --------------------------------------- if( NOT SKIP_EXTERNALS ) @@ -121,9 +219,14 @@ if( NOT SKIP_EXTERNALS ) message( "+++ installing nano/nng with: ${nano_major}.${nano_minor} | ${nng_major}.${nng_minor}" ) else() + if( PACK_EXTERNALS ) + unset( SKIP_EXTERNALS CACHE ) # must remove so as not to trap user into a never ending failure + unset( PACK_EXTERNALS CACHE ) + message( FATAL_ERROR "ERROR: PACK_EXTERNALS can be set only if SKIP_EXTERNALS is unset (=0, or not supplied on command line)" ) + endif() set( need_ext 0 ) endif() -unset( SKIP_EXTERNALS CACHE ) # prevent it from being applied next build unless specifically set on comd line + # this gets us round a chicken/egg problem. include files don't exist until make is run @@ -140,44 +243,60 @@ set( CMAKE_POSITION_INDEPENDENT_CODE ON ) set( CMAKE_CXX_FLAGS "-g -Wall " ) # Include modules -add_subdirectory( src/common ) -add_subdirectory( src/nanomsg ) -add_subdirectory( src/nng ) +add_subdirectory( src/rmr/common ) +add_subdirectory( src/rmr/nanomsg ) +add_subdirectory( src/rmr/nng ) add_subdirectory( doc ) # this will auto skip if {X}fm is not available -# shared and static libraries built from the same object files -# Nanomsg based library (librmr ) -# library is built by pulling object files from nano and common subdirs +# shared and static libraries are built from the same object files. +# Nanomsg based library (librmr ) while nng based is librmr_nng. +# library is built by pulling object files from either the nano or nng and common subdirs # add_library( rmr_shared SHARED "$;$" ) -add_library( rmr_static STATIC "$;$" ) - -# both libraries to be named with librmr prefix -set_target_properties( rmr_shared PROPERTIES OUTPUT_NAME "rmr" ) -set_target_properties( rmr_static PROPERTIES OUTPUT_NAME "rmr" ) +set_target_properties( rmr_shared + PROPERTIES + OUTPUT_NAME "rmr" + SOVERSION ${major_version} + VERSION ${major_version}.${minor_version}.${patch_level} ) -# NNG based library (librmr_nng ) -# library is built by pulling objects from nng and common subdirs -# add_library( rmr_nng_shared SHARED "$;$" ) -add_library( rmr_nng_static STATIC "$;$" ) - - +set_target_properties( rmr_nng_shared + PROPERTIES + OUTPUT_NAME "rmr_nng" + SOVERSION ${major_version} + VERSION ${major_version}.${minor_version}.${patch_level} ) + +# we only build/export the static archive (.a) if generating a dev package +if( DEV_PKG ) + add_library( rmr_nng_static STATIC "$;$" ) + set_target_properties( rmr_nng_static + PROPERTIES + OUTPUT_NAME "rmr_nng" + SOVERSION ${major_version} + VERSION ${major_version}.${minor_version}.${patch_level} ) + + add_library( rmr_static STATIC "$;$" ) + + set_target_properties( rmr_static + PROPERTIES + OUTPUT_NAME "rmr" + SOVERSION ${major_version} + VERSION ${major_version}.${minor_version}.${patch_level} ) +endif() # if externals need to be built, then we must force them to be built first by depending on them if( need_ext ) - add_dependencies( rmr_static;rmr_shared nanomsg ) - add_dependencies( rmr_nng_shared;rmr_nng_static ext_nng ) + if( DEV_PKG ) + add_dependencies( rmr_static;rmr_shared nanomsg ) + add_dependencies( rmr_nng_shared;rmr_nng_static ext_nng ) + else() + add_dependencies( rmr_shared nanomsg ) + add_dependencies( rmr_nng_shared ext_nng ) + endif() endif() - -# both libraries to be named with librmr_nng prefix -# -set_target_properties( rmr_nng_shared PROPERTIES OUTPUT_NAME "rmr_nng" ) -set_target_properties( rmr_nng_static PROPERTIES OUTPUT_NAME "rmr_nng" ) - # if( APPLE ) message( "### apple hack: forcing hard coded library paths for nng/nano dynamic libraries" ) @@ -185,44 +304,54 @@ if( APPLE ) target_link_libraries( rmr_nng_shared ${CMAKE_CURRENT_BINARY_DIR}/lib/libnng${nng_so_suffix} ) endif() -# Define directories where package should drop things when installed -# In CMake speak archive == *.a library == *.so, so both are needed -# Headers from the common directory are forced to install by the local CM file in common. At -# the moment, there are no header files specific to either nano or nng, so to the public -# header directive is moot, but needed if some day there is one. +# Define what should be installed, and where they should go. For dev package we install +# only the RMr headers, man pages and archive (.a) files. The run-time package gets just +# the library (.so) files and nothing more. # -install( TARGETS rmr_nng_shared;rmr_nng_static;rmr_shared;rmr_static EXPORT LibraryConfig - ARCHIVE DESTINATION ${install_lib} - LIBRARY DESTINATION ${install_lib} - PUBLIC_HEADER DESTINATION ${install_inc} +if( DEV_PKG ) + set( target_list "rmr_nng_static;rmr_static" ) +else() + set( target_list "rmr_nng_shared;rmr_shared" ) +endif() + +install( TARGETS ${target_list} EXPORT LibraryConfig + LIBRARY DESTINATION ${install_lib} + ARCHIVE DESTINATION ${install_lib} + PUBLIC_HEADER DESTINATION ${install_inc} ) +unset( DEV_PKG CACHE ) # prevent from being a hiddent setting if user redoes things -# install any nano/nng libraries in to the deb as well, but ONLY if we created them. -# (sure would be nice if FILEs allowed for globbing; sadlyy it does not. +# install any nano/nng libraries in to the deb as well, but ONLY if asked for on the 'cmake ..' command +# (sure would be nice if FILEs allowed for globbing; sadlyy it does not.) # -if( need_ext ) - message( "including nano and nng libraries in the deb" ) +if( PACK_EXTERNALS ) + message( "+++ including nano and nng libraries in the deb" ) install( FILES - ${CMAKE_CURRENT_BINARY_DIR}/${BUILD_LIB}/libnanomsg${nano_so_suffix} - ${CMAKE_CURRENT_BINARY_DIR}/${BUILD_LIB}/libnanomsg${nano_so_suffix_m} - ${CMAKE_CURRENT_BINARY_DIR}/${BUILD_LIB}/libnanomsg${nano_so_suffix_mm} - ${CMAKE_CURRENT_BINARY_DIR}/${BUILD_LIB}/libnng${nng_so_suffix} - ${CMAKE_CURRENT_BINARY_DIR}/${BUILD_LIB}/libnng${nng_so_suffix_m} - ${CMAKE_CURRENT_BINARY_DIR}/${BUILD_LIB}/libnng${nng_so_suffix_mm} + ${CMAKE_CURRENT_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR}/libnanomsg${nano_so_suffix} + ${CMAKE_CURRENT_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR}/libnanomsg${nano_so_suffix_m} + ${CMAKE_CURRENT_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR}/libnanomsg${nano_so_suffix_mm} + ${CMAKE_CURRENT_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR}/libnng${nng_so_suffix} + ${CMAKE_CURRENT_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR}/libnng${nng_so_suffix_m} + ${CMAKE_CURRENT_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR}/libnng${nng_so_suffix_mm} DESTINATION ${install_lib} ) endif() +unset( SKIP_EXTERNALS CACHE ) # prevent these from being applied next build unless specifically set on comd line +unset( PACK_EXTERNALS CACHE ) IF( EXISTS "${CMAKE_ROOT}/Modules/CPack.cmake" ) include( InstallRequiredSystemLibraries ) + set( CPACK_DEBIAN_PACKAGE_NAME ${deb_pkg_name} ) + set( CPACK_RPM_PACKAGE_NAME ${rpm_pkg_name} ) + set( CPACK_set_DESTDIR "on" ) set( CPACK_PACKAGING_INSTALL_PREFIX "${install_root}" ) - set( CPACK_GENERATOR "DEB" ) + set( CPACK_GENERATOR "${pkg_list}" ) set( CPACK_PACKAGE_DESCRIPTION "Thin library for RIC xAPP messaging routed based on message type." ) set( CPACK_PACKAGE_DESCRIPTION_SUMMARY "RIC message routing library" ) @@ -231,15 +360,16 @@ IF( EXISTS "${CMAKE_ROOT}/Modules/CPack.cmake" ) set( CPACK_PACKAGE_VERSION_MAJOR "${major_version}" ) set( CPACK_PACKAGE_VERSION_MINOR "${minor_version}" ) set( CPACK_PACKAGE_VERSION_PATCH "${patch_level}" ) - set( CPACK_PACKAGE_FILE_NAME "${CMAKE_PROJECT_NAME}_${major_version}.${minor_version}.${CPACK_PACKAGE_VERSION_PATCH}" ) - set( CPACK_SOURCE_PACKAGE_FILE_NAME "vric${CMAKE_PROJECT_NAME}_${major_version}.${minor_version}.${CPACK_PACKAGE_VERSION_PATCH}" ) + set( CPACK_PACKAGE "${pkg_label}" ) # generic name for old versions of cpack + set( CPACK_DEBIAN_FILE_NAME "${deb_pkg_label}.deb" ) + set( CPACK_RPM_FILE_NAME "${rpm_pkg_label}.rpm" ) # we build and ship the libraries, so there is NO dependency - #set( CPACK_DEBIAN_PACKAGE_DEPENDS "nanomsg ( >= 1.1.4 ), nng ( >= 1.1.1 )" ) set( CPACK_DEBIAN_PACKAGE_PRIORITY "optional" ) set( CPACK_DEBIAN_PACKAGE_SECTION "ric" ) set( CPACK_DEBIAN_ARCHITECTURE ${CMAKE_SYSTEM_PROCESSOR} ) + set( CPACK_RPM_ARCHITECTURE ${CMAKE_SYSTEM_PROCESSOR} ) # this seems ingnored if included #set( CPACK_COMPONENTS_ALL Libraries ApplicationData )