cmake: a bit of packaging work 69/14569/2
authorDamjan Marion <damarion@cisco.com>
Wed, 29 Aug 2018 20:20:45 +0000 (22:20 +0200)
committerDamjan Marion <dmarion@me.com>
Thu, 30 Aug 2018 12:35:28 +0000 (12:35 +0000)
Change-Id: I40332c2348c4aab873d726532f2ac3c4abde7ec9
Signed-off-by: Damjan Marion <damarion@cisco.com>
src/CMakeLists.txt
src/cmake/library.cmake
src/cmake/pack.cmake [moved from src/cmake/deb.cmake with 75% similarity]
src/cmake/plugin.cmake
src/plugins/dpdk/CMakeLists.txt
src/vpp-api/python/CMakeLists.txt
src/vppinfra/CMakeLists.txt

index 585f8a1..3d934f2 100644 (file)
@@ -61,7 +61,6 @@ include(cmake/api.cmake)
 include(cmake/library.cmake)
 include(cmake/exec.cmake)
 include(cmake/plugin.cmake)
-include(cmake/deb.cmake)
 
 ##############################################################################
 # subdirs - order matters
@@ -74,3 +73,4 @@ foreach(
   add_subdirectory(${DIR})
 endforeach()
 
+include(cmake/pack.cmake)
index 66b4dff..0d1e97c 100644 (file)
@@ -14,7 +14,7 @@
 macro(add_vpp_library lib)
   cmake_parse_arguments(ARG
     ""
-    ""
+    "COMPONENT"
     "SOURCES;MULTIARCH_SOURCES;API_FILES;LINK_LIBRARIES;INSTALL_HEADERS;DEPENDS"
     ${ARGN}
   )
@@ -27,7 +27,14 @@ macro(add_vpp_library lib)
     target_link_libraries(${lib} ${ARG_LINK_LIBRARIES})
   endif()
   # install .so
-  install(TARGETS ${lib} DESTINATION ${VPP_LIB_DIR_NAME})
+  if(NOT ARG_COMPONENT)
+    set(ARG_COMPONENT vpp)
+  endif()
+  install(
+    TARGETS ${lib}
+    DESTINATION ${VPP_LIB_DIR_NAME}
+    COMPONENT ${ARG_COMPONENT}
+  )
 
   if(ARG_MULTIARCH_SOURCES)
     vpp_library_set_multiarch_sources(${lib} ${ARG_MULTIARCH_SOURCES})
@@ -37,7 +44,11 @@ macro(add_vpp_library lib)
     vpp_add_api_files(${lib} ${ARG_API_FILES})
     foreach(file ${ARG_API_FILES})
       get_filename_component(dir ${file} DIRECTORY)
-      install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${file}.h DESTINATION include/${lib}/${dir})
+      install(
+       FILES ${CMAKE_CURRENT_BINARY_DIR}/${file}.h
+       DESTINATION include/${lib}/${dir}
+       COMPONENT vpp-dev
+      )
     endforeach()
   endif()
 
@@ -49,7 +60,11 @@ macro(add_vpp_library lib)
   if(ARG_INSTALL_HEADERS)
     foreach(file ${ARG_INSTALL_HEADERS})
       get_filename_component(dir ${file} DIRECTORY)
-      install(FILES ${file} DESTINATION include/${lib}/${dir})
+      install(
+       FILES ${file}
+       DESTINATION include/${lib}/${dir}
+       COMPONENT vpp-dev
+      )
     endforeach()
   endif()
 endmacro()
similarity index 75%
rename from src/cmake/deb.cmake
rename to src/cmake/pack.cmake
index 09c8ac6..3288966 100644 (file)
@@ -18,13 +18,15 @@ set(CPACK_GENERATOR "DEB")
 set(CPACK_DEBIAN_PACKAGE_MAINTAINER "VPP Team")
 set(CPACK_PACKAGE_NAME "vpp")
 set(CPACK_PACKAGE_VENDOR "fd.io")
-set(CPACK_PACKAGE_VERSION "18.08")
+set(CPACK_PACKAGE_VERSION "18.10")
 set(CPACK_DEB_COMPONENT_INSTALL ON)
 set(CPACK_COMPONENTS_IGNORE_GROUPS 1)
-set(CPACK_DEBIAN_VPP_PACKAGE_NAME "vpp")
-set(CPACK_DEBIAN_VPP_FILE_NAME "vpp.deb")
-set(CPACK_DEBIAN_DEV_PACKAGE_NAME "vpp-dev")
-set(CPACK_DEBIAN_DEV_FILE_NAME "vpp-dev.deb")
-set(CPACK_DEBIAN_PLUGINS_PACKAGE_NAME "vpp-plugins")
-set(CPACK_DEBIAN_PLUGINS_FILE_NAME "vpp-plugins.deb")
+
+get_cmake_property(components COMPONENTS)
+foreach(lc ${components})
+  string(TOUPPER ${lc} uc)
+  set(CPACK_DEBIAN_${uc}_PACKAGE_NAME "${lc}")
+  set(CPACK_DEBIAN_${uc}_FILE_NAME "${lc}.deb")
+endforeach()
+
 include(CPack)
index a044239..9f9a646 100644 (file)
@@ -14,7 +14,7 @@
 macro(add_vpp_plugin name)
   cmake_parse_arguments(PLUGIN
     ""
-    "LINK_FLAGS"
+    "LINK_FLAGS;COMPONENT"
     "SOURCES;API_FILES;MULTIARCH_SOURCES;LINK_LIBRARIES;INSTALL_HEADERS;API_TEST_SOURCES"
     ${ARGN}
   )
@@ -26,8 +26,11 @@ macro(add_vpp_plugin name)
     vpp_generate_api_header(${f} plugins)
     list(APPEND api_headers ${f}.h ${f}.json)
     set_property(GLOBAL APPEND PROPERTY VPP_API_FILES ${rpath}/${f})
-    install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${f}.h DESTINATION
-      include/vpp_plugins/${name}/${dir})
+    install(
+      FILES ${CMAKE_CURRENT_BINARY_DIR}/${f}.h
+      DESTINATION include/vpp_plugins/${name}/${dir}
+      COMPONENT vpp-dev
+    )
   endforeach()
   add_library(${plugin_name} SHARED ${PLUGIN_SOURCES} ${api_headers})
   target_compile_options(${plugin_name} PRIVATE -Wall)
@@ -47,9 +50,16 @@ macro(add_vpp_plugin name)
   if(PLUGIN_INSTALL_HEADERS)
     foreach(file ${PLUGIN_INSTALL_HEADERS})
       get_filename_component(dir ${file} DIRECTORY)
-      install(FILES ${file} DESTINATION include/vpp_plugins/${name}/${dir})
+      install(
+       FILES ${file}
+       DESTINATION include/vpp_plugins/${name}/${dir}
+       COMPONENT vpp-dev
+      )
     endforeach()
   endif()
+  if(NOT PLUGIN_COMPONENT)
+    set(PLUGIN_COMPONENT vpp-plugin-misc)
+  endif()
   if(PLUGIN_API_TEST_SOURCES)
     set(test_plugin_name ${name}_test_plugin)
     add_library(${test_plugin_name} SHARED ${PLUGIN_API_TEST_SOURCES} ${api_headers})
@@ -57,9 +67,16 @@ macro(add_vpp_plugin name)
     set_target_properties(${test_plugin_name} PROPERTIES
       PREFIX ""
       LIBRARY_OUTPUT_DIRECTORY ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}/vpp_api_test_plugins)
-    install(TARGETS ${test_plugin_name} DESTINATION ${VPP_LIB_DIR_NAME}/vpp_api_test_plugins COMPONENT
-           plugins)
+    install(
+      TARGETS ${test_plugin_name}
+      DESTINATION ${VPP_LIB_DIR_NAME}/vpp_api_test_plugins
+      COMPONENT ${PLUGIN_COMPONENT}
+    )
   endif()
-  install(TARGETS ${plugin_name} DESTINATION ${VPP_LIB_DIR_NAME}/vpp_plugins COMPONENT plugins)
+  install(
+    TARGETS ${plugin_name}
+    DESTINATION ${VPP_LIB_DIR_NAME}/vpp_plugins
+    COMPONENT ${PLUGIN_COMPONENT}
+  )
 endmacro()
 
index 72b85c1..09ebd11 100644 (file)
@@ -129,6 +129,9 @@ if(DPDK_INCLUDE_DIR AND DPDK_LIB)
 
     LINK_FLAGS
     ${DPDK_LINK_FLAGS}
+
+    COMPONENT
+    vpp-plugin-dpdk
   )
 else()
   message(WARNING "DPDK not found - dpdk disabled")
index 1b6aefa..52215cc 100644 (file)
@@ -28,5 +28,6 @@ if(PYTHONINTERP_FOUND)
          --dist-dir=${CMAKE_INSTALL_PREFIX}
       OUTPUT_QUIET
     )"
+    COMPONENT vpp-api-python
   )
 endif()
index f358339..1b2797a 100644 (file)
@@ -32,7 +32,7 @@ configure_file(
 install(
   FILES ${CMAKE_BINARY_DIR}/vppinfra/config.h
   DESTINATION include/vppinfra
-  COMPONENT dev
+  COMPONENT vpp-dev
 )
 
 ##############################################################################
@@ -198,6 +198,7 @@ add_vpp_library(vppinfra
   SOURCES ${VPPINFRA_SRCS}
   LINK_LIBRARIES m
   INSTALL_HEADERS ${VPPINFRA_HEADERS}
+  COMPONENT libvppinfra
 )
 
 ##############################################################################