1
1
# vim: et ts=4 sts=4 sw=4 tw=0
2
2
3
- CMAKE_MINIMUM_REQUIRED (VERSION 2.8.5 )
3
+ CMAKE_MINIMUM_REQUIRED (VERSION 3.1 )
4
4
PROJECT (jsoncpp )
5
5
ENABLE_TESTING ()
6
6
@@ -27,20 +27,10 @@ IF(APPLE)
27
27
SET (CMAKE_MACOSX_RPATH 1 )
28
28
ENDIF ()
29
29
30
+ # Adhere to GNU filesystem layout conventions
31
+ INCLUDE (GNUInstallDirs )
32
+
30
33
SET (DEBUG_LIBNAME_SUFFIX "" CACHE STRING "Optional suffix to append to the library name for a debug build" )
31
- SET (LIB_SUFFIX "" CACHE STRING "Optional arch-dependent suffix for the library installation directory" )
32
-
33
- SET (RUNTIME_INSTALL_DIR bin
34
- CACHE PATH "Install dir for executables and dlls" )
35
- SET (ARCHIVE_INSTALL_DIR lib${LIB_SUFFIX}
36
- CACHE PATH "Install dir for static libraries" )
37
- SET (LIBRARY_INSTALL_DIR lib${LIB_SUFFIX}
38
- CACHE PATH "Install dir for shared libraries" )
39
- SET (INCLUDE_INSTALL_DIR include
40
- CACHE PATH "Install dir for headers" )
41
- SET (PACKAGE_INSTALL_DIR lib${LIB_SUFFIX}/cmake
42
- CACHE PATH "Install dir for cmake package config files" )
43
- MARK_AS_ADVANCED ( RUNTIME_INSTALL_DIR ARCHIVE_INSTALL_DIR INCLUDE_INSTALL_DIR PACKAGE_INSTALL_DIR )
44
34
45
35
# Set variable named ${VAR_NAME} to value ${VALUE}
46
36
FUNCTION (set_using_dynamic_name VAR_NAME VALUE )
@@ -69,12 +59,12 @@ ENDMACRO()
69
59
#SET( JSONCPP_VERSION_MAJOR X )
70
60
#SET( JSONCPP_VERSION_MINOR Y )
71
61
#SET( JSONCPP_VERSION_PATCH Z )
72
- SET ( JSONCPP_VERSION 1.7.7 )
62
+ SET ( JSONCPP_VERSION 1.8.3 )
73
63
jsoncpp_parse_version ( ${JSONCPP_VERSION} JSONCPP_VERSION )
74
64
#IF(NOT JSONCPP_VERSION_FOUND)
75
65
# MESSAGE(FATAL_ERROR "Failed to parse version string properly. Expect X.Y.Z")
76
66
#ENDIF(NOT JSONCPP_VERSION_FOUND)
77
- SET ( JSONCPP_SOVERSION 11 )
67
+ SET ( JSONCPP_SOVERSION 19 )
78
68
SET ( JSONCPP_USE_SECURE_MEMORY "0" CACHE STRING "-D...=1 to use memory-wiping allocator for STL" )
79
69
80
70
MESSAGE (STATUS "JsonCpp Version: ${JSONCPP_VERSION_MAJOR} .${JSONCPP_VERSION_MINOR} .${JSONCPP_VERSION_PATCH} " )
@@ -86,70 +76,79 @@ CONFIGURE_FILE( "${PROJECT_SOURCE_DIR}/version.in"
86
76
"${PROJECT_SOURCE_DIR} /version"
87
77
NEWLINE_STYLE UNIX )
88
78
89
- macro (UseCompilationWarningAsError )
90
- if ( MSVC )
79
+ MACRO (UseCompilationWarningAsError )
80
+ IF ( MSVC )
91
81
# Only enabled in debug because some old versions of VS STL generate
92
82
# warnings when compiled in release configuration.
93
- set (CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /WX " )
94
- elseif (CMAKE_CXX_COMPILER_ID STREQUAL "GNU" )
95
- set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Werror" )
96
- if (JSONCPP_WITH_STRICT_ISO )
97
- set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pedantic-errors" )
98
- endif ()
99
- endif ()
100
- endmacro ()
83
+ SET (CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /WX " )
84
+ ELSEIF (CMAKE_CXX_COMPILER_ID STREQUAL "GNU" )
85
+ SET (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Werror" )
86
+ IF (JSONCPP_WITH_STRICT_ISO )
87
+ SET (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pedantic-errors" )
88
+ ENDIF ()
89
+ ENDIF ()
90
+ ENDMACRO ()
101
91
102
92
# Include our configuration header
103
93
INCLUDE_DIRECTORIES ( ${jsoncpp_SOURCE_DIR} /include )
104
94
105
- if ( MSVC )
95
+ IF ( MSVC )
106
96
# Only enabled in debug because some old versions of VS STL generate
107
97
# unreachable code warning when compiled in release configuration.
108
- set (CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /W4 " )
109
- endif ()
110
-
111
- if (CMAKE_CXX_COMPILER_ID MATCHES "Clang" )
112
- # using regular Clang or AppleClang
113
- set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -Wall -Wconversion -Wshadow -Werror=conversion -Werror=sign-compare" )
114
- elseif (CMAKE_CXX_COMPILER_ID STREQUAL "GNU" )
115
- # using GCC
116
- set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -Wall -Wconversion -Wshadow -Wextra" )
117
- # not yet ready for -Wsign-conversion
118
-
119
- if (JSONCPP_WITH_STRICT_ISO AND NOT JSONCPP_WITH_WARNING_AS_ERROR )
120
- set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Werror=conversion -pedantic" )
121
- endif ()
122
- elseif (CMAKE_CXX_COMPILER_ID STREQUAL "Intel" )
123
- # using Intel compiler
124
- set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -Wall -Wconversion -Wshadow -Wextra -Werror=conversion" )
125
-
126
- if (JSONCPP_WITH_STRICT_ISO AND NOT JSONCPP_WITH_WARNING_AS_ERROR )
127
- set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pedantic" )
128
- endif ()
129
- endif ()
130
-
131
- find_program (CCACHE_FOUND ccache )
132
- if (CCACHE_FOUND )
133
- set_property (GLOBAL PROPERTY RULE_LAUNCH_COMPILE ccache )
134
- set_property (GLOBAL PROPERTY RULE_LAUNCH_LINK ccache )
135
- endif (CCACHE_FOUND )
98
+ SET (CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /W4 " )
99
+ ENDIF ()
100
+
101
+ # Require C++11 support, prefer ISO C++ over GNU variants,
102
+ # as relying solely on ISO C++ is more portable.
103
+ SET (CMAKE_CXX_STANDARD 11 )
104
+ SET (CMAKE_CXX_STANDARD_REQUIRED ON )
105
+ SET (CMAKE_CXX_EXTENSIONS OFF )
106
+
107
+ IF (CMAKE_CXX_COMPILER_ID MATCHES "Clang" )
108
+ # using regular Clang or AppleClang
109
+ SET (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wconversion -Wshadow -Werror=conversion -Werror=sign-compare" )
110
+ ELSEIF (CMAKE_CXX_COMPILER_ID STREQUAL "GNU" )
111
+ # using GCC
112
+ SET (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wconversion -Wshadow -Wextra" )
113
+ # not yet ready for -Wsign-conversion
114
+
115
+ IF (JSONCPP_WITH_STRICT_ISO )
116
+ SET (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pedantic" )
117
+ ENDIF ()
118
+ IF (JSONCPP_WITH_WARNING_AS_ERROR )
119
+ SET (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Werror=conversion" )
120
+ ENDIF ()
121
+ ELSEIF (CMAKE_CXX_COMPILER_ID STREQUAL "Intel" )
122
+ # using Intel compiler
123
+ SET (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wconversion -Wshadow -Wextra -Werror=conversion" )
124
+
125
+ IF (JSONCPP_WITH_STRICT_ISO AND NOT JSONCPP_WITH_WARNING_AS_ERROR )
126
+ SET (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pedantic" )
127
+ ENDIF ()
128
+ ENDIF ()
129
+
130
+ FIND_PROGRAM (CCACHE_FOUND ccache )
131
+ IF (CCACHE_FOUND )
132
+ SET_PROPERTY (GLOBAL PROPERTY RULE_LAUNCH_COMPILE ccache )
133
+ SET_PROPERTY (GLOBAL PROPERTY RULE_LAUNCH_LINK ccache )
134
+ ENDIF (CCACHE_FOUND )
136
135
137
136
IF (JSONCPP_WITH_WARNING_AS_ERROR )
138
137
UseCompilationWarningAsError ()
139
138
ENDIF ()
140
139
141
140
IF (JSONCPP_WITH_PKGCONFIG_SUPPORT )
142
- CONFIGURE_FILE (
143
- "pkg-config/jsoncpp.pc.in"
144
- "pkg-config/jsoncpp.pc"
145
- @ONLY )
146
- INSTALL (FILES "${CMAKE_CURRENT_BINARY_DIR} /pkg-config/jsoncpp.pc"
147
- DESTINATION "${CMAKE_INSTALL_PREFIX} /lib ${LIB_SUFFIX } /pkgconfig" )
141
+ CONFIGURE_FILE (
142
+ "pkg-config/jsoncpp.pc.in"
143
+ "pkg-config/jsoncpp.pc"
144
+ @ONLY )
145
+ INSTALL (FILES "${CMAKE_CURRENT_BINARY_DIR} /pkg-config/jsoncpp.pc"
146
+ DESTINATION "${CMAKE_INSTALL_LIBDIR } /pkgconfig" )
148
147
ENDIF ()
149
148
150
149
IF (JSONCPP_WITH_CMAKE_PACKAGE )
151
150
INSTALL (EXPORT jsoncpp
152
- DESTINATION ${PACKAGE_INSTALL_DIR} /jsoncpp
151
+ DESTINATION ${CMAKE_INSTALL_LIBDIR} /cmake /jsoncpp
153
152
FILE jsoncppConfig.cmake )
154
153
ENDIF ()
155
154
0 commit comments