gravatar
alpar (Alpar Juttner)
alpar@cs.elte.hu
Backport the CMAKE related changesets from the main branch [e20fecd1945f] Add check target for CMake (#388) [e74b5db4f2c6] Put the output of chg-len.py in the version string (#389) [7d166b8b8018] Safer call of ./scripts/chg-len.py on Windows (#389) [659ba4805a48] Make CMAKE config more consistent with configure.ac (#390) [63e4468c680e] Add 'Maintainer' CMAKE build type (#388, #390) [a725503acfe9] Allow CPACK configuration on all platforms [10242c611190] Create and install lemon.pc (#393) [48e29534cf03] The deafult target doesn't build lp_test and mip_test (#388) [0fbbdd578c06] Full path for DoxygenLayout.xml in Doxyfile.in (#395) [481496e6d71f] SOURCE_BROWSER Doxygen switch is configurable from CMAKE (#395) [09282720100b] update-external-tags CMAKE target (#395)
0 5 1
default
6 files changed with 145 insertions and 9 deletions:
↑ Collapse diff ↑
Ignore white space 6 line context
1
prefix=@CMAKE_INSTALL_PREFIX@
2
exec_prefix=@CMAKE_INSTALL_PREFIX@/bin
3
libdir=@CMAKE_INSTALL_PREFIX@/lib
4
includedir=@CMAKE_INSTALL_PREFIX@/include
5

	
6
Name: @PROJECT_NAME@
7
Description: Library for Efficient Modeling and Optimization in Networks
8
Version: @PROJECT_VERSION@
9
Libs: -L${libdir} -lemon @GLPK_LIBS@ @CPLEX_LIBS@ @SOPLEX_LIBS@ @CLP_LIBS@ @CBC_LIBS@
10
Cflags: -I${includedir}
Ignore white space 4 line context
... ...
@@ -4,4 +4,7 @@
4 4
PROJECT(${PROJECT_NAME})
5 5

	
6
INCLUDE(FindPythonInterp)
7
INCLUDE(FindWget)
8

	
6 9
IF(EXISTS ${PROJECT_SOURCE_DIR}/cmake/version.cmake)
7 10
  INCLUDE(${PROJECT_SOURCE_DIR}/cmake/version.cmake)
... ...
@@ -10,4 +13,11 @@
10 13
ELSE()
11 14
  EXECUTE_PROCESS(
15
    COMMAND ${PYTHON_EXECUTABLE} ./scripts/chg-len.py
16
    WORKING_DIRECTORY ${PROJECT_SOURCE_DIR}
17
    OUTPUT_VARIABLE HG_REVISION_PATH
18
    ERROR_QUIET
19
    OUTPUT_STRIP_TRAILING_WHITESPACE
20
  )
21
  EXECUTE_PROCESS(
12 22
    COMMAND hg id -i
13 23
    WORKING_DIRECTORY ${PROJECT_SOURCE_DIR}
... ...
@@ -17,7 +27,13 @@
17 27
  )
18 28
  IF(HG_REVISION STREQUAL "")
19
    SET(HG_REVISION "hg-tip")
29
    SET(HG_REVISION_ID "hg-tip")
30
  ELSE()
31
    IF(HG_REVISION_PATH STREQUAL "")
32
      SET(HG_REVISION_ID ${HG_REVISION})
33
    ELSE()
34
      SET(HG_REVISION_ID ${HG_REVISION_PATH}.${HG_REVISION})
35
    ENDIF()
20 36
  ENDIF()
21
  SET(LEMON_VERSION ${HG_REVISION} CACHE STRING "LEMON version string.")
37
  SET(LEMON_VERSION ${HG_REVISION_ID} CACHE STRING "LEMON version string.")
22 38
ENDIF()
23 39

	
... ...
@@ -32,4 +48,67 @@
32 48
FIND_PACKAGE(COIN)
33 49

	
50
IF(DEFINED ENV{LEMON_CXX_WARNING})
51
  SET(CXX_WARNING $ENV{LEMON_CXX_WARNING})
52
ELSE()
53
  IF(CMAKE_COMPILER_IS_GNUCXX)
54
    SET(CXX_WARNING "-Wall -W -Wunused -Wformat=2 -Wctor-dtor-privacy -Wnon-virtual-dtor -Wno-char-subscripts -Wwrite-strings -Wno-char-subscripts -Wreturn-type -Wcast-qual -Wcast-align -Wsign-promo -Woverloaded-virtual -ansi -fno-strict-aliasing -Wold-style-cast -Wno-unknown-pragmas")
55
    SET(CMAKE_CXX_FLAGS_DEBUG CACHE STRING "-ggdb")
56
    SET(CMAKE_C_FLAGS_DEBUG CACHE STRING "-ggdb")
57
  ELSEIF(MSVC)
58
    # This part is unnecessary 'casue the same is set by the lemon/core.h.
59
    # Still keep it as an example.
60
    SET(CXX_WARNING "/wd4250 /wd4355 /wd4503 /wd4800 /wd4996")
61
    # Suppressed warnings:
62
    # C4250: 'class1' : inherits 'class2::member' via dominance
63
    # C4355: 'this' : used in base member initializer list
64
    # C4503: 'function' : decorated name length exceeded, name was truncated
65
    # C4800: 'type' : forcing value to bool 'true' or 'false'
66
    #        (performance warning)
67
    # C4996: 'function': was declared deprecated
68
  ELSE()
69
    SET(CXX_WARNING "-Wall -W")
70
  ENDIF()
71
ENDIF()
72
SET(LEMON_CXX_WARNING_FLAGS ${CXX_WARNING} CACHE STRING "LEMON warning flags.")
73

	
74
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${LEMON_CXX_WARNING_FLAGS}")
75

	
76
SET( CMAKE_CXX_FLAGS_MAINTAINER "-Werror -ggdb" CACHE STRING
77
    "Flags used by the C++ compiler during maintainer builds."
78
    FORCE )
79
SET( CMAKE_C_FLAGS_MAINTAINER "-Werror" CACHE STRING
80
    "Flags used by the C compiler during maintainer builds."
81
    FORCE )
82
SET( CMAKE_EXE_LINKER_FLAGS_MAINTAINER
83
    "-Wl,--warn-unresolved-symbols,--warn-once" CACHE STRING
84
    "Flags used for linking binaries during maintainer builds."
85
    FORCE )
86
SET( CMAKE_SHARED_LINKER_FLAGS_MAINTAINER
87
    "-Wl,--warn-unresolved-symbols,--warn-once" CACHE STRING
88
    "Flags used by the shared libraries linker during maintainer builds."
89
    FORCE )
90
MARK_AS_ADVANCED(
91
    CMAKE_CXX_FLAGS_MAINTAINER
92
    CMAKE_C_FLAGS_MAINTAINER
93
    CMAKE_EXE_LINKER_FLAGS_MAINTAINER
94
    CMAKE_SHARED_LINKER_FLAGS_MAINTAINER )
95

	
96
IF(CMAKE_CONFIGURATION_TYPES)
97
  LIST(APPEND CMAKE_CONFIGURATION_TYPES Maintainer)
98
  LIST(REMOVE_DUPLICATES CMAKE_CONFIGURATION_TYPES)
99
  SET(CMAKE_CONFIGURATION_TYPES "${CMAKE_CONFIGURATION_TYPES}" CACHE STRING
100
      "Add the configurations that we need"
101
      FORCE)
102
 endif()
103

	
104
IF(NOT CMAKE_BUILD_TYPE)
105
  SET(CMAKE_BUILD_TYPE "Release")
106
ENDIF()
107

	
108
SET( CMAKE_BUILD_TYPE "${CMAKE_BUILD_TYPE}" CACHE STRING
109
    "Choose the type of build, options are: None(CMAKE_CXX_FLAGS or CMAKE_C_FLAGS used) Debug Release RelWithDebInfo MinSizeRel Maintainer."
110
    FORCE )
111

	
112

	
34 113
INCLUDE(CheckTypeSize)
35 114
CHECK_TYPE_SIZE("long long" LONG_LONG)
... ...
@@ -38,4 +117,10 @@
38 117
ENABLE_TESTING()
39 118

	
119
IF(${CMAKE_BUILD_TYPE} STREQUAL "Maintainer")
120
  ADD_CUSTOM_TARGET(check ALL COMMAND ${CMAKE_CTEST_COMMAND})
121
ELSE()
122
  ADD_CUSTOM_TARGET(check COMMAND ${CMAKE_CTEST_COMMAND})
123
ENDIF()
124

	
40 125
ADD_SUBDIRECTORY(lemon)
41 126
IF(${CMAKE_SOURCE_DIR} STREQUAL ${PROJECT_SOURCE_DIR})
... ...
@@ -63,5 +148,5 @@
63 148
ENDIF()
64 149

	
65
IF(${CMAKE_SOURCE_DIR} STREQUAL ${PROJECT_SOURCE_DIR} AND WIN32)
150
IF(${CMAKE_SOURCE_DIR} STREQUAL ${PROJECT_SOURCE_DIR})
66 151
  SET(CPACK_PACKAGE_NAME ${PROJECT_NAME})
67 152
  SET(CPACK_PACKAGE_VENDOR "EGRES")
Ignore white space 6 line context
... ...
@@ -4,4 +4,6 @@
4 4
SET(abs_top_builddir ${PROJECT_BINARY_DIR})
5 5

	
6
SET(LEMON_DOC_SOURCE_BROWSER "NO" CACHE STRING "Include source into the doc (YES/NO).")
7

	
6 8
CONFIGURE_FILE(
7 9
  ${PROJECT_SOURCE_DIR}/doc/Doxyfile.in
... ...
@@ -50,2 +52,14 @@
50 52

	
51 53
ENDIF()
54

	
55
IF(WGET_FOUND)
56
ADD_CUSTOM_TARGET(update-external-tags
57
  COMMAND ${CMAKE_COMMAND} -E make_directory dl
58
  # COMMAND ${CMAKE_COMMAND} -E copy libstdc++.tag dl
59
  COMMAND ${WGET_EXECUTABLE} wget -P dl -N libstdc++.tag.tmp http://gcc.gnu.org/onlinedocs/libstdc++/latest-doxygen/libstdc++.tag
60
  COMMAND ${CMAKE_COMMAND} -E rename dl/libstdc++.tag libstdc++.tag
61
  COMMAND ${CMAKE_COMMAND} -E remove dl/libstdc++.tag
62
  COMMAND ${CMAKE_COMMAND} -E remove_directory dl
63
  WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
64
  )
65
ENDIF()
Ignore white space 6 line context
... ...
@@ -71,5 +71,5 @@
71 71
SHOW_NAMESPACES        = YES
72 72
FILE_VERSION_FILTER    = 
73
LAYOUT_FILE            = DoxygenLayout.xml
73
LAYOUT_FILE            = "@abs_top_srcdir@/doc/DoxygenLayout.xml"
74 74
#---------------------------------------------------------------------------
75 75
# configuration options related to warning and progress messages
... ...
@@ -114,5 +114,5 @@
114 114
# configuration options related to source browsing
115 115
#---------------------------------------------------------------------------
116
SOURCE_BROWSER         = NO
116
SOURCE_BROWSER         = @LEMON_DOC_SOURCE_BROWSER@
117 117
INLINE_SOURCES         = NO
118 118
STRIP_CODE_COMMENTS    = YES
... ...
@@ -225,5 +225,5 @@
225 225
# Options related to the search engine   
226 226
#---------------------------------------------------------------------------
227
TAGFILES               = "@abs_top_srcdir@/doc/libstdc++.tag = http://gcc.gnu.org/onlinedocs/libstdc++/latest-doxygen/  "
227
TAGFILES               = "@abs_top_builddir@/doc/libstdc++.tag = http://gcc.gnu.org/onlinedocs/libstdc++/latest-doxygen/  "
228 228
GENERATE_TAGFILE       = html/lemon.tag
229 229
ALLEXTERNALS           = NO
Ignore white space 6 line context
... ...
@@ -9,4 +9,10 @@
9 9
)
10 10

	
11
CONFIGURE_FILE(
12
  ${CMAKE_CURRENT_SOURCE_DIR}/lemon.pc.cmake
13
  ${CMAKE_CURRENT_BINARY_DIR}/lemon.pc
14
  @ONLY
15
)
16

	
11 17
SET(LEMON_SOURCES
12 18
  arg_parser.cc
... ...
@@ -67,2 +73,8 @@
67 73
  COMPONENT headers
68 74
)
75

	
76
INSTALL(
77
  FILES ${CMAKE_CURRENT_BINARY_DIR}/lemon.pc
78
  DESTINATION lib/pkgconfig
79
)
80

	
Ignore white space 6 line context
... ...
@@ -42,5 +42,10 @@
42 42

	
43 43
IF(LEMON_HAVE_LP)
44
  ADD_EXECUTABLE(lp_test lp_test.cc)
44
  IF(${CMAKE_BUILD_TYPE} STREQUAL "Maintainer")
45
    ADD_EXECUTABLE(lp_test lp_test.cc)
46
  ELSE()
47
    ADD_EXECUTABLE(lp_test EXCLUDE_FROM_ALL lp_test.cc)
48
  ENDIF()
49

	
45 50
  SET(LP_TEST_LIBS lemon)
46 51

	
... ...
@@ -78,5 +83,10 @@
78 83

	
79 84
IF(LEMON_HAVE_MIP)
80
  ADD_EXECUTABLE(mip_test mip_test.cc)
85
  IF(${CMAKE_BUILD_TYPE} STREQUAL "Maintainer")
86
    ADD_EXECUTABLE(mip_test mip_test.cc)
87
  ELSE()
88
    ADD_EXECUTABLE(mip_test EXCLUDE_FROM_ALL mip_test.cc)
89
  ENDIF()
90

	
81 91
  SET(MIP_TEST_LIBS lemon)
82 92

	
... ...
@@ -114,6 +124,11 @@
114 124

	
115 125
FOREACH(TEST_NAME ${TESTS})
116
  ADD_EXECUTABLE(${TEST_NAME} ${TEST_NAME}.cc)
126
  IF(${CMAKE_BUILD_TYPE} STREQUAL "Maintainer")
127
    ADD_EXECUTABLE(${TEST_NAME} ${TEST_NAME}.cc)
128
  ELSE()
129
    ADD_EXECUTABLE(${TEST_NAME} EXCLUDE_FROM_ALL ${TEST_NAME}.cc)
130
  ENDIF()
117 131
  TARGET_LINK_LIBRARIES(${TEST_NAME} lemon)
118 132
  ADD_TEST(${TEST_NAME} ${TEST_NAME})
133
  ADD_DEPENDENCIES(check ${TEST_NAME})
119 134
ENDFOREACH()
0 comments (0 inline)