forked from nasa/bplib
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCMakeLists.txt
212 lines (164 loc) · 6.04 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
##################################################################
#
# Bundle Protocol Library (BPLib) CMake build recipe
#
# This file allows BPLib to be configured and built via the CMake tool
# It also permits the BPLib module to be used in conjunction with CFE/CFS
#
##################################################################
cmake_minimum_required(VERSION 3.5)
project(BPLIB C)
option(BPLIB_INCLUDE_STORAGE "Whether or not to build the basic/example storage services as part of BPLib" ON)
option(BPLIB_INCLUDE_BPV6 "Whether or not to the BPv6 protocol implementation as part of BPLib" ON)
option(BPLIB_INCLUDE_BPV7 "Whether or not to the BPv7 protocol implementation as part of BPLib (EXPERIMENTAL)" OFF)
option(BPLIB_INCLUDE_POSIX "Whether or not to the POSIX operating system abstraction as part of BPLib (standalone builds only)" ON)
option(BPLIB_BUILD_TEST_TOOLS "Whether or not to build the test programs as part of BPLib (standalone builds only)" ON)
set(BPLIB_VERSION_STRING "3.0.99") # development
set(BPLIB_COMMON_COMPILE_OPTIONS)
# If using a GNU-style compiler then enable full warnings here.
# May want to add equivalent for other compiler flavors too
if ("${CMAKE_C_COMPILER_ID}" STREQUAL "GNU")
list(APPEND BPLIB_COMMON_COMPILE_OPTIONS -Wall -Werror -pedantic)
endif()
# source units that comprise the basic fundamentals of BPLib
# These units should always be built regardless of configuration
set(BPLIB_SRC
# library API
lib/bplib.c
# other common objects
common/crc.c
common/rb_tree.c
common/rh_hash.c
common/cbuf.c
common/lrc.c
)
# no extra link libraries at first
set(BPLIB_LINK_LIBRARIES)
set(BPLIB_PRIVATE_INCLUDE_DIRS
${CMAKE_CURRENT_SOURCE_DIR}/common
${CMAKE_CURRENT_SOURCE_DIR}/lib
)
# Add source units that comprise the protocol implementation
# This is dependent on build configuration
if (BPLIB_INCLUDE_BPV6)
list(APPEND BPLIB_SRC
# Include BPv6 implementation parts
v6/v6.c
v6/bib.c
v6/cteb.c
v6/pay.c
v6/pri.c
v6/dacs.c
v6/sdnv.c
)
list(APPEND BPLIB_PRIVATE_INCLUDE_DIRS
${CMAKE_CURRENT_SOURCE_DIR}/v6
)
endif()
if (BPLIB_INCLUDE_BPV7)
add_subdirectory(mpool)
add_subdirectory(cache)
add_subdirectory(v7)
list(REMOVE_ITEM BPLIB_SRC
lib/bplib.c
common/rb_tree.c
common/rh_hash.c
)
# v7 implementation parts
list(APPEND BPLIB_SRC
lib/v7_bplib.c
common/v7_rbtree.c
lib/v7_routing.c
lib/v7_cla_api.c
lib/v7_dataservice_api.c
$<TARGET_OBJECTS:bplib_cache>
$<TARGET_OBJECTS:bplib_v7>
$<TARGET_OBJECTS:bplib_mpool>
)
list(APPEND BPLIB_PRIVATE_INCLUDE_DIRS
$<TARGET_PROPERTY:bplib_v7,INTERFACE_INCLUDE_DIRECTORIES>
$<TARGET_PROPERTY:bplib_mpool,INTERFACE_INCLUDE_DIRECTORIES>
$<TARGET_PROPERTY:bplib_cache,INTERFACE_INCLUDE_DIRECTORIES>
)
endif()
# examples of storage implementations
# these are not strictly required to be built with bplib, as an implemenation
# may register additional or alternate implementations
if (BPLIB_INCLUDE_STORAGE)
list(APPEND BPLIB_SRC
store/file.c
store/ram.c
store/flash.c
store/flash_sim.c
)
list(APPEND BPLIB_PRIVATE_INCLUDE_DIRS
${CMAKE_CURRENT_SOURCE_DIR}/store
)
endif()
# If building as part of CFE/CFS, then the "IS_CFS_ARCH_BUILD" should be set
# this allows simply dropping this module into a CFS project
if (IS_CFS_ARCH_BUILD)
# Create the app module using the CFE/OSAL adapter layer
# Note this ignores the setting of BPLIB_INCLUDE_POSIX, as OSAL provides this service
# The CFE build system determines whether to create a shared or static object inside this routine
add_cfe_app(bplib ${BPLIB_SRC} os/cfe.c)
else()
# Building as a standalone library
# This by will usually require a POSIX OS layer
if (BPLIB_INCLUDE_POSIX)
list(APPEND BPLIB_SRC os/posix.c)
list(APPEND BPLIB_LINK_LIBRARIES rt pthread)
endif()
# Add the generic library target
# The flavor of library (shared/static) being built here depends on the BUILD_SHARED_LIBS option
# This directory may be built twice, setting this option differently to build both flavors
add_library(bplib ${BPLIB_SRC})
# compile this library as c99 (but this does not impose the same requirement on other users)
target_compile_features(bplib PRIVATE c_std_99)
# If using GNU GCC, then also enable full warning reporting
target_compile_options(bplib PRIVATE ${BPLIB_COMMON_COMPILE_OPTIONS})
if (BPLIB_INCLUDE_BPV7)
target_compile_definitions(bplib PRIVATE BPLIB_INCLUDE_BPV7)
endif()
# link with the requisite dependencies (this is mainly for POSIX, if using that adapter)
target_link_libraries(bplib ${TINYCBOR_LIBRARIES} ${BPLIB_LINK_LIBRARIES})
# Install and also export this library, so it can be found via
# "find_package()" from some other CMake build
install(TARGETS bplib
EXPORT bplib-export
LIBRARY DESTINATION lib
ARCHIVE DESTINATION lib
)
install(EXPORT bplib-export
FILE BPLibTargets.cmake
DESTINATION lib/cmake/bplib
)
install(DIRECTORY inc/
DESTINATION include/bplib
)
# Set API/ABI version info if building a shared library
if(BUILD_SHARED_LIBS)
set_target_properties(bplib PROPERTIES
SOVERSION "${BPLIB_VERSION_STRING}"
)
# If using GNU, then also add ABI version to final link
if ("${CMAKE_C_COMPILER_ID}" STREQUAL "GNU")
set_target_properties(bplib PROPERTIES
LINK_FLAGS "-Wl,--version-script=${CMAKE_CURRENT_SOURCE_DIR}/libabi.version"
)
endif()
endif()
# Build the test tools, if directed
if (BPLIB_BUILD_TEST_TOOLS)
add_subdirectory(app)
endif()
endif()
# Internal/private header files exist within the implementation directories
target_include_directories(bplib PRIVATE ${BPLIB_PRIVATE_INCLUDE_DIRS})
# The API to this library (which may be invoked/referenced from other apps)
# is stored in fsw/public_inc. Using "target_include_directories" is the
# preferred method of indicating this (vs. directory-scope "include_directories").
target_include_directories(bplib PUBLIC
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/inc>
$<INSTALL_INTERFACE:include/bplib>
)