CMake: generate .json from .api files 66/14366/3
authorNeale Ranns <neale.ranns@cisco.com>
Mon, 20 Aug 2018 14:41:52 +0000 (07:41 -0700)
committerDamjan Marion <dmarion@me.com>
Mon, 20 Aug 2018 15:05:07 +0000 (15:05 +0000)
Change-Id: Ic18aa0fb42a72b5e0ebbfbebdefc7582cb46b5ea
Signed-off-by: Neale Ranns <neale.ranns@cisco.com>
src/CMakeLists.txt
src/vlibmemory/CMakeLists.txt
src/vnet/CMakeLists.txt

index 84971c7..e6054e1 100644 (file)
@@ -136,7 +136,7 @@ endif()
 ##############################################################################
 # API
 ##############################################################################
-function(vpp_generate_api_header file)
+function(vpp_generate_api_c_header file)
   set (output_name ${CMAKE_CURRENT_BINARY_DIR}/${file}.h)
   get_filename_component(output_dir ${output_name} DIRECTORY)
   add_custom_command (OUTPUT ${output_name}
@@ -144,15 +144,32 @@ function(vpp_generate_api_header file)
     COMMAND ${CMAKE_SOURCE_DIR}/tools/vppapigen/vppapigen
     ARGS --includedir ${CMAKE_SOURCE_DIR} --input ${CMAKE_CURRENT_SOURCE_DIR}/${file} --output ${output_name}
     DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${file}
-    COMMENT "Generating API header ${file}.h"
+    COMMENT "Generating API header ${output_name}"
+  )
+endfunction()
+
+function(vpp_generate_api_json_header file)
+  set (output_name ${CMAKE_CURRENT_BINARY_DIR}/${file}.json)
+  get_filename_component(output_dir ${output_name} DIRECTORY)
+  add_custom_command (OUTPUT ${output_name}
+    COMMAND mkdir -p ${output_dir}
+    COMMAND ${CMAKE_SOURCE_DIR}/tools/vppapigen/vppapigen
+    ARGS --includedir ${CMAKE_SOURCE_DIR} --input ${CMAKE_CURRENT_SOURCE_DIR}/${file} JSON --output ${output_name}
+    DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${file}
+    COMMENT "Generating API header ${output_name}"
   )
 endfunction()
 
+function(vpp_generate_api_header file)
+    vpp_generate_api_c_header (${file})
+    vpp_generate_api_json_header (${file})
+endfunction()
+
 function(vpp_add_api_files target)
   unset(header_files)
   foreach(file ${ARGN})
     vpp_generate_api_header (${file})
-    list (APPEND header_files ${file}.h)
+    list (APPEND header_files ${file}.h ${file}.json)
   endforeach()
   add_custom_target(${target} DEPENDS ${header_files})
 endfunction()
index 3459f03..a37fc9f 100644 (file)
@@ -11,8 +11,9 @@
 # See the License for the specific language governing permissions and
 # limitations under the License.
 
-vpp_generate_api_header(memclnt.api)
-add_custom_target(vlibmemory_api_headers DEPENDS memclnt.api.h)
+vpp_add_api_files(vlibmemory_api_headers
+  memclnt.api
+)
 
 add_library (vlibmemory SHARED
   memory_api.c
index 1ae5618..ec9fc2d 100644 (file)
@@ -424,7 +424,7 @@ set(VNET_SRCS
   vxlan/vxlan.c
 )
 
-set (VNET_API_FILES
+vpp_add_api_files(vnet_api_headers
   vxlan-gpe/vxlan_gpe.api
   ip/ip.api
   ip/rd_cp.api
@@ -475,13 +475,6 @@ set (VNET_API_FILES
   bfd/bfd.api
 )
 
-set(VNET_API_HDRS)
-foreach (file ${VNET_API_FILES})
-  vpp_generate_api_header(${file})
-  list(APPEND VNET_API_HDRS ${file}.h)
-endforeach()
-add_custom_target(vnet_api_headers DEPENDS ${VNET_API_HDRS})
-
 add_library(vnet SHARED ${VNET_SRCS})
 
 vpp_library_set_multiarch_sources(vnet