Remove Boost library building and other build improvements.
* Remove download and build Boost from source and all CMake boost source build dependencies. * Make FindCairo.cmake use pkg-config when it's available not just all platforms except windows. * Add version checking to FindCairo.cmake. * Change find GML version to 0.9.5.1 which is the current version in Ubuntu 14.04 LTS. * Update required Cairo version to 1.12.1.
This commit is contained in:
parent
133b8f6b96
commit
c751bf60bc
124
CMakeLists.txt
124
CMakeLists.txt
|
@ -54,14 +54,6 @@ option( KICAD_SCRIPTING_WXPYTHON
|
||||||
"Build wxPython implementation for wx interface building in Python and py.shell (default OFF)."
|
"Build wxPython implementation for wx interface building in Python and py.shell (default OFF)."
|
||||||
)
|
)
|
||||||
|
|
||||||
# WARNING: KiCad developers strongly advise you to build Boost with supplied patches,
|
|
||||||
# as it is known to work with KiCad. Other versions may contain bugs that may result
|
|
||||||
# in KiCad errors.
|
|
||||||
option( KICAD_SKIP_BOOST
|
|
||||||
"Skip building downloaded Boost library components, use Boost from your system."
|
|
||||||
)
|
|
||||||
mark_as_advanced( KICAD_SKIP_BOOST ) # Normal builders should build Boost.
|
|
||||||
|
|
||||||
# when option KICAD_SCRIPTING OR KICAD_SCRIPTING_MODULES is enabled:
|
# when option KICAD_SCRIPTING OR KICAD_SCRIPTING_MODULES is enabled:
|
||||||
# PYTHON_EXECUTABLE can be defined when invoking cmake
|
# PYTHON_EXECUTABLE can be defined when invoking cmake
|
||||||
# ( use -DPYTHON_EXECUTABLE=<python path>/python.exe or python2 )
|
# ( use -DPYTHON_EXECUTABLE=<python path>/python.exe or python2 )
|
||||||
|
@ -103,13 +95,6 @@ else()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|
||||||
# All CMake downloads go here. Suggested is up in the source tree, not in the build dir where they
|
|
||||||
# would have to be downloaded over and over again. The default is to choose a directory that is
|
|
||||||
# hidden on linux (starts with a '.') because there is a way to exclude this directory when grepping
|
|
||||||
# the source tree.
|
|
||||||
set( DOWNLOAD_DIR ${PROJECT_SOURCE_DIR}/.downloads-by-cmake
|
|
||||||
CACHE PATH "Location of KiCad downloads, suggested is a dir common to all builds, i.e. global." )
|
|
||||||
|
|
||||||
# Add option to add user directories for linker, if any
|
# Add option to add user directories for linker, if any
|
||||||
LINK_DIRECTORIES( ${LINK_DIRECTORIES_PATH} )
|
LINK_DIRECTORIES( ${LINK_DIRECTORIES_PATH} )
|
||||||
|
|
||||||
|
@ -282,7 +267,6 @@ else()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# KIFACE_SUFFIX is the file extension used for top level program modules which
|
# KIFACE_SUFFIX is the file extension used for top level program modules which
|
||||||
# implement the KIFACE interface. A valid suffix starts with a period '.'.
|
# implement the KIFACE interface. A valid suffix starts with a period '.'.
|
||||||
|
|
||||||
|
@ -396,9 +380,9 @@ include( ExternalProject )
|
||||||
#================================================
|
#================================================
|
||||||
include( CheckFindPackageResult )
|
include( CheckFindPackageResult )
|
||||||
|
|
||||||
#################################
|
#
|
||||||
# Find OpenMP support, optional #
|
# Find OpenMP support, optional
|
||||||
#################################
|
#
|
||||||
|
|
||||||
find_package( OpenMP )
|
find_package( OpenMP )
|
||||||
|
|
||||||
|
@ -414,9 +398,10 @@ if( OPENMP_FOUND )
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
##########################
|
#
|
||||||
# Find wxWidgets library #
|
# Find wxWidgets library, required
|
||||||
##########################
|
#
|
||||||
|
|
||||||
# Here you can define what libraries of wxWidgets you need for your
|
# Here you can define what libraries of wxWidgets you need for your
|
||||||
# application. You can figure out what libraries you need here;
|
# application. You can figure out what libraries you need here;
|
||||||
# http://www.wxwidgets.org/manuals/2.8/wx_librarieslist.html
|
# http://www.wxwidgets.org/manuals/2.8/wx_librarieslist.html
|
||||||
|
@ -432,11 +417,10 @@ find_package( wxWidgets 3.0.0 COMPONENTS gl aui adv html core net base xml stc R
|
||||||
# Include wxWidgets macros.
|
# Include wxWidgets macros.
|
||||||
include( ${wxWidgets_USE_FILE} )
|
include( ${wxWidgets_USE_FILE} )
|
||||||
|
|
||||||
#######################
|
#
|
||||||
# Find OpenGL library #
|
# Find OpenGL library, required
|
||||||
#######################
|
#
|
||||||
find_package( OpenGL QUIET )
|
find_package( OpenGL REQUIRED )
|
||||||
check_find_package_result( OPENGL_FOUND "OpenGL" )
|
|
||||||
|
|
||||||
# Dick 5-Feb-2014:
|
# Dick 5-Feb-2014:
|
||||||
# Marco: We cannot use both ExternalProject_Add() add and find_package()
|
# Marco: We cannot use both ExternalProject_Add() add and find_package()
|
||||||
|
@ -448,46 +432,36 @@ check_find_package_result( OPENGL_FOUND "OpenGL" )
|
||||||
# Always defined, empty if no libraries are to be built
|
# Always defined, empty if no libraries are to be built
|
||||||
add_custom_target( lib-dependencies )
|
add_custom_target( lib-dependencies )
|
||||||
|
|
||||||
# Find GLEW library
|
#
|
||||||
|
# Find GLEW library, required
|
||||||
|
#
|
||||||
if( NOT GLEW_FOUND )
|
if( NOT GLEW_FOUND )
|
||||||
find_package( GLEW )
|
find_package( GLEW REQUIRED )
|
||||||
check_find_package_result( GLEW_FOUND "GLEW" )
|
check_find_package_result( GLEW_FOUND "GLEW" )
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Find GLM library
|
#
|
||||||
find_package( GLM 0.9.5.4 REQUIRED )
|
# Find GLM library, required
|
||||||
|
#
|
||||||
|
find_package( GLM 0.9.5.1 REQUIRED )
|
||||||
|
|
||||||
# Find CURL library
|
#
|
||||||
|
# Find CURL library, required for github plugin
|
||||||
|
#
|
||||||
find_package( CURL REQUIRED )
|
find_package( CURL REQUIRED )
|
||||||
|
|
||||||
# Find Cairo library
|
#
|
||||||
if( NOT CAIRO_FOUND )
|
# Find Cairo library, required
|
||||||
find_package( Cairo 1.8.1 QUIET )
|
#
|
||||||
check_find_package_result( CAIRO_FOUND "Cairo" )
|
find_package( Cairo 1.12.1 REQUIRED )
|
||||||
endif()
|
|
||||||
|
|
||||||
# Download boost and possibly build parts of it
|
#
|
||||||
#################################################
|
# Find Boost library, required.
|
||||||
if( KICAD_SKIP_BOOST )
|
#
|
||||||
find_package( Boost 1.54.0 REQUIRED COMPONENTS context date_time filesystem iostreams locale
|
# Note: Prior to Boost 1.59, the Boost context library is not built when compiling on windows
|
||||||
program_options regex system thread )
|
# with GCC. You must patch the Boost sources.
|
||||||
|
find_package( Boost 1.54.0 REQUIRED COMPONENTS context date_time filesystem iostreams locale
|
||||||
if( NOT Boost_FOUND )
|
program_options regex system thread )
|
||||||
message( FATAL_ERROR "Boost 1.54+ libraries are required." )
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Keeps CMake from complaining about undefined boost dependencies even though Boost was
|
|
||||||
# found. Sigh!!!!!
|
|
||||||
add_custom_target( boost )
|
|
||||||
|
|
||||||
message( WARNING "
|
|
||||||
WARNING: You decided to skip building boost library.
|
|
||||||
KiCad developers strongly advise you to build the bundled boost library, as it is known to work with KiCad.
|
|
||||||
Other versions may contain bugs that may result in KiCad errors." )
|
|
||||||
else()
|
|
||||||
add_dependencies( lib-dependencies boost )
|
|
||||||
include( download_boost )
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Include MinGW resource compiler.
|
# Include MinGW resource compiler.
|
||||||
include( MinGWResourceCompiler )
|
include( MinGWResourceCompiler )
|
||||||
|
@ -665,38 +639,6 @@ add_subdirectory( qa )
|
||||||
|
|
||||||
#add_subdirectory( new )
|
#add_subdirectory( new )
|
||||||
|
|
||||||
|
|
||||||
# Make all libs and executables depend on ExternalProject_Add( boost ),
|
|
||||||
# except perhaps bitmap lib. This allows a multi-threaded build to succeed.
|
|
||||||
add_dependencies( pcbnew boost )
|
|
||||||
add_dependencies( eeschema boost )
|
|
||||||
add_dependencies( cvpcb_kiface boost )
|
|
||||||
add_dependencies( gal boost )
|
|
||||||
add_dependencies( common boost )
|
|
||||||
add_dependencies( pcbcommon boost )
|
|
||||||
add_dependencies( 3d-viewer boost )
|
|
||||||
add_dependencies( pcad2kicadpcb boost )
|
|
||||||
add_dependencies( polygon boost )
|
|
||||||
add_dependencies( pl_editor boost )
|
|
||||||
add_dependencies( pnsrouter boost )
|
|
||||||
|
|
||||||
|
|
||||||
if( KICAD_BUILD_STATIC OR KICAD_BUILD_DYNAMIC )
|
|
||||||
add_dependencies( pcbnew lib-dependencies )
|
|
||||||
add_dependencies( eeschema lib-dependencies )
|
|
||||||
add_dependencies( cvpcb_kiface lib-dependencies )
|
|
||||||
add_dependencies( common lib-dependencies )
|
|
||||||
add_dependencies( gal lib-dependencies )
|
|
||||||
add_dependencies( pcbcommon lib-dependencies )
|
|
||||||
add_dependencies( 3d-viewer lib-dependencies )
|
|
||||||
add_dependencies( pcad2kicadpcb lib-dependencies )
|
|
||||||
add_dependencies( pl_editor lib-dependencies )
|
|
||||||
add_dependencies( pnsrouter lib-dependencies )
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if( KICAD_BUILD_DYNAMIC )
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#############
|
#############
|
||||||
# Resources #
|
# Resources #
|
||||||
#############
|
#############
|
||||||
|
|
|
@ -22,12 +22,11 @@
|
||||||
# (To distribute this file outside of CMake, substitute the full
|
# (To distribute this file outside of CMake, substitute the full
|
||||||
# License text for the above reference.)
|
# License text for the above reference.)
|
||||||
|
|
||||||
if (UNIX)
|
find_package(PkgConfig)
|
||||||
find_package(PkgConfig)
|
|
||||||
if (PKG_CONFIG_FOUND)
|
if(PKG_CONFIG_FOUND)
|
||||||
pkg_check_modules(_CAIRO cairo)
|
pkg_check_modules(_CAIRO cairo)
|
||||||
endif (PKG_CONFIG_FOUND)
|
endif (PKG_CONFIG_FOUND)
|
||||||
endif (UNIX)
|
|
||||||
|
|
||||||
SET(_CAIRO_ROOT_HINTS
|
SET(_CAIRO_ROOT_HINTS
|
||||||
$ENV{CAIRO}
|
$ENV{CAIRO}
|
||||||
|
@ -54,7 +53,7 @@ FIND_PATH(CAIRO_INCLUDE_DIR
|
||||||
"include/cairo"
|
"include/cairo"
|
||||||
)
|
)
|
||||||
|
|
||||||
IF(WIN32 AND NOT CYGWIN)
|
IF(NOT PKGCONFIG_FOUND AND WIN32 AND NOT CYGWIN)
|
||||||
# MINGW should go here too
|
# MINGW should go here too
|
||||||
IF(MSVC)
|
IF(MSVC)
|
||||||
# Implementation details:
|
# Implementation details:
|
||||||
|
@ -93,7 +92,7 @@ IF(WIN32 AND NOT CYGWIN)
|
||||||
ELSEIF(MINGW)
|
ELSEIF(MINGW)
|
||||||
# same player, for MingW
|
# same player, for MingW
|
||||||
FIND_LIBRARY(CAIRO
|
FIND_LIBRARY(CAIRO
|
||||||
NAMES
|
NAMES
|
||||||
cairo
|
cairo
|
||||||
${_CAIRO_ROOT_HINTS_AND_PATHS}
|
${_CAIRO_ROOT_HINTS_AND_PATHS}
|
||||||
PATH_SUFFIXES
|
PATH_SUFFIXES
|
||||||
|
@ -113,12 +112,12 @@ IF(WIN32 AND NOT CYGWIN)
|
||||||
${_CAIRO_ROOT_HINTS_AND_PATHS}
|
${_CAIRO_ROOT_HINTS_AND_PATHS}
|
||||||
PATH_SUFFIXES
|
PATH_SUFFIXES
|
||||||
lib
|
lib
|
||||||
)
|
)
|
||||||
|
|
||||||
MARK_AS_ADVANCED(CAIRO)
|
MARK_AS_ADVANCED(CAIRO)
|
||||||
set( CAIRO_LIBRARIES ${CAIRO} )
|
set( CAIRO_LIBRARIES ${CAIRO} )
|
||||||
ENDIF(MSVC)
|
ENDIF(MSVC)
|
||||||
ELSE(WIN32 AND NOT CYGWIN)
|
ELSE()
|
||||||
|
|
||||||
FIND_LIBRARY(CAIRO_LIBRARY
|
FIND_LIBRARY(CAIRO_LIBRARY
|
||||||
NAMES
|
NAMES
|
||||||
|
@ -129,40 +128,39 @@ ELSE(WIN32 AND NOT CYGWIN)
|
||||||
PATH_SUFFIXES
|
PATH_SUFFIXES
|
||||||
"lib"
|
"lib"
|
||||||
"local/lib"
|
"local/lib"
|
||||||
)
|
)
|
||||||
|
|
||||||
MARK_AS_ADVANCED(CAIRO_LIBRARY)
|
MARK_AS_ADVANCED(CAIRO_LIBRARY)
|
||||||
|
|
||||||
# compat defines
|
# compat defines
|
||||||
SET(CAIRO_LIBRARIES ${CAIRO_LIBRARY})
|
SET(CAIRO_LIBRARIES ${CAIRO_LIBRARY})
|
||||||
|
|
||||||
ENDIF(WIN32 AND NOT CYGWIN)
|
ENDIF()
|
||||||
|
|
||||||
# if (CAIRO_INCLUDE_DIR)
|
#message( STATUS "Cairo_FIND_VERSION=${Cairo_FIND_VERSION}.")
|
||||||
# file(READ "${CAIRO_INCLUDE_DIR}/gcore/gdal_version.h" _wxgisgdal_VERSION_H_CONTENTS)
|
#message( STATUS "CAIRO_INCLUDE_DIR=${CAIRO_INCLUDE_DIR}.")
|
||||||
# string(REGEX REPLACE ".*# define[ \t]+GDAL_RELEASE_NAME[ \t]+\"([0-9A-Za-z.]+)\".*"
|
|
||||||
# "\\1" CAIRO_VERSION ${_wxgisgdal_VERSION_H_CONTENTS})
|
# Fetch version from cairo-version.h if a version was requested by find_package()
|
||||||
# set(CAIRO_VERSION ${CAIRO_VERSION} CACHE INTERNAL "The version number for wxgisgdal libraries")
|
if(CAIRO_INCLUDE_DIR AND Cairo_FIND_VERSION)
|
||||||
# endif (CAIRO_INCLUDE_DIR)
|
file(READ "${CAIRO_INCLUDE_DIR}/cairo-version.h" _CAIRO_VERSION_H_CONTENTS)
|
||||||
|
string(REGEX REPLACE "^(.*\n)?#define[ \t]+CAIRO_VERSION_MAJOR[ \t]+([0-9]+).*"
|
||||||
|
"\\2" CAIRO_VERSION_MAJOR ${_CAIRO_VERSION_H_CONTENTS})
|
||||||
|
string(REGEX REPLACE "^(.*\n)?#define[ \t]+CAIRO_VERSION_MINOR[ \t]+([0-9]+).*"
|
||||||
|
"\\2" CAIRO_VERSION_MINOR ${_CAIRO_VERSION_H_CONTENTS})
|
||||||
|
string(REGEX REPLACE "^(.*\n)?#define[ \t]+CAIRO_VERSION_MICRO[ \t]+([0-9]+).*"
|
||||||
|
"\\2" CAIRO_VERSION_MICRO ${_CAIRO_VERSION_H_CONTENTS})
|
||||||
|
set(CAIRO_VERSION ${CAIRO_VERSION_MAJOR}.${CAIRO_VERSION_MINOR}.${CAIRO_VERSION_MICRO}
|
||||||
|
CACHE INTERNAL "The version number for Cairo libraries")
|
||||||
|
endif()
|
||||||
|
|
||||||
include(FindPackageHandleStandardArgs)
|
include(FindPackageHandleStandardArgs)
|
||||||
|
|
||||||
# if (CAIRO_VERSION)
|
find_package_handle_standard_args(Cairo
|
||||||
# find_package_handle_standard_args(CAIRO
|
REQUIRED_VARS
|
||||||
# REQUIRED_VARS
|
|
||||||
# CAIRO_LIBRARIES
|
|
||||||
# CAIRO_INCLUDE_DIR
|
|
||||||
# VERSION_VAR
|
|
||||||
# CAIRO_VERSION
|
|
||||||
# FAIL_MESSAGE
|
|
||||||
# "Could NOT find CAIRO, try to set the path to CAIRO root folder in the system variable CAIRO_ROOT_DIR"
|
|
||||||
# )
|
|
||||||
# else (CAIRO_VERSION)
|
|
||||||
find_package_handle_standard_args(CAIRO "Could NOT find CAIRO, try to set the path to CAIRO root folder in the system variable CAIRO"
|
|
||||||
CAIRO_LIBRARIES
|
CAIRO_LIBRARIES
|
||||||
CAIRO_INCLUDE_DIR
|
CAIRO_INCLUDE_DIR
|
||||||
)
|
VERSION_VAR
|
||||||
# endif (CAIRO_VERSION)
|
CAIRO_VERSION
|
||||||
|
)
|
||||||
|
|
||||||
MARK_AS_ADVANCED(CAIRO_INCLUDE_DIR CAIRO_LIBRARIES)
|
MARK_AS_ADVANCED(CAIRO_INCLUDE_DIR CAIRO_LIBRARIES)
|
||||||
|
|
||||||
|
|
|
@ -1,320 +0,0 @@
|
||||||
# This program source code file is part of KICAD, a free EDA CAD application.
|
|
||||||
#
|
|
||||||
# Copyright (C) 2013 SoftPLC Corporation, Dick Hollenbeck <dick@softplc.com>
|
|
||||||
# Copyright (C) 2013 Kicad Developers, see AUTHORS.txt for contributors.
|
|
||||||
#
|
|
||||||
# This program is free software; you can redistribute it and/or
|
|
||||||
# modify it under the terms of the GNU General Public License
|
|
||||||
# as published by the Free Software Foundation; either version 2
|
|
||||||
# of the License, or (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program; if not, you may find one here:
|
|
||||||
# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
|
|
||||||
# or you may search the http://www.gnu.org website for the version 2 license,
|
|
||||||
# or you may write to the Free Software Foundation, Inc.,
|
|
||||||
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Download a particular boost version, and patch it [and build it if BUILD_GITHUB_PLUGIN].
|
|
||||||
# Assumes include( ExternalProject ) was done inline previous to this file
|
|
||||||
# and that set( DOWNLOAD_DIR ... ) was set in a higher context.
|
|
||||||
|
|
||||||
|
|
||||||
#-----<configure>----------------------------------------------------------------
|
|
||||||
|
|
||||||
set( BOOST_RELEASE 1.54.0 )
|
|
||||||
set( BOOST_MD5 15cb8c0803064faef0c4ddf5bc5ca279 ) # re-calc this on every RELEASE change
|
|
||||||
|
|
||||||
# The boost headers [and static libs if built] go here, at the top of KiCad
|
|
||||||
# source tree in boost_root.
|
|
||||||
set( BOOST_ROOT "${PROJECT_SOURCE_DIR}/boost_root" )
|
|
||||||
|
|
||||||
|
|
||||||
# Space separated list which indicates the subset of boost libraries to compile.
|
|
||||||
# Chosen libraries are based on AVHTTP requirements, and possibly
|
|
||||||
# unit_test_framework for its own worth.
|
|
||||||
# tool_manager.cpp -> coroutine -> context (_jump_fcontext) (on OSX)
|
|
||||||
|
|
||||||
set( BOOST_LIBS_BUILT
|
|
||||||
context
|
|
||||||
#coroutine
|
|
||||||
date_time
|
|
||||||
#exception
|
|
||||||
filesystem
|
|
||||||
iostreams
|
|
||||||
locale
|
|
||||||
program_options
|
|
||||||
regex
|
|
||||||
#signals
|
|
||||||
system
|
|
||||||
thread
|
|
||||||
#unit_test_framework
|
|
||||||
)
|
|
||||||
#-----</configure>---------------------------------------------------------------
|
|
||||||
|
|
||||||
if( NOT BZIP2_FOUND )
|
|
||||||
find_package( BZip2 REQUIRED )
|
|
||||||
endif()
|
|
||||||
|
|
||||||
string( REGEX REPLACE "\\." "_" BOOST_VERS "${BOOST_RELEASE}" )
|
|
||||||
set( PREFIX ${DOWNLOAD_DIR}/boost_${BOOST_VERS} )
|
|
||||||
|
|
||||||
# <SOURCE_DIR> = ${PREFIX}/src/boost
|
|
||||||
# There is a Bazaar 'boost scratch repo' in <SOURCE_DIR>/boost and after committing pristine
|
|
||||||
# download, the patch is applied. This lets you regenerate a new patch at any time
|
|
||||||
# easily, simply by editing the working tree in <SOURCE_DIR> and doing "bzr diff" in there.
|
|
||||||
|
|
||||||
# path to the boost headers in the repo.
|
|
||||||
# repo = "${headers_src}/../.bzr" = "<SOURCE_DIR>/.bzr"
|
|
||||||
set( headers_src "${PREFIX}/src/boost/boost" )
|
|
||||||
|
|
||||||
|
|
||||||
function( set_boost_lib_names libs output )
|
|
||||||
foreach( lib ${libs} )
|
|
||||||
set( fullpath_lib "${BOOST_ROOT}/lib/libboost_${lib}${CMAKE_STATIC_LIBRARY_SUFFIX}" )
|
|
||||||
list( APPEND results ${fullpath_lib} )
|
|
||||||
endforeach()
|
|
||||||
# set the results into variable represented by output into caller's scope
|
|
||||||
set( ${output} ${results} PARENT_SCOPE )
|
|
||||||
endfunction()
|
|
||||||
|
|
||||||
|
|
||||||
# (BTW "test" yields "unit_test_framework" when passed to bootstrap.sh ).
|
|
||||||
#message( STATUS "BOOST_LIBS_BUILT:${BOOST_LIBS_BUILT}" )
|
|
||||||
string( REPLACE "unit_test_framework" "test" boost_libs_list "${BOOST_LIBS_BUILT}" )
|
|
||||||
#message( STATUS "REPLACE libs_csv:${boost_libs_list}" )
|
|
||||||
|
|
||||||
# Default Toolset
|
|
||||||
set( BOOST_TOOLSET "toolset=gcc" )
|
|
||||||
|
|
||||||
if( KICAD_BUILD_STATIC OR APPLE )
|
|
||||||
set( BOOST_LINKTYPE "link=static" )
|
|
||||||
else()
|
|
||||||
unset( BOOST_LINKTYPE )
|
|
||||||
endif()
|
|
||||||
|
|
||||||
|
|
||||||
find_program(patch_bin NAMES patch patch.exe)
|
|
||||||
|
|
||||||
if( "${patch_bin}" STREQUAL "patch_bin-NOTFOUND" )
|
|
||||||
set( PATCH_STR_CMD ${PATCH_STR_CMD} )
|
|
||||||
else()
|
|
||||||
set( PATCH_STR_CMD ${patch_bin} -p0 -i )
|
|
||||||
endif()
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if( MINGW AND NOT CMAKE_HOST_UNIX ) # building for MINGW on windows not UNIX
|
|
||||||
if( MSYS )
|
|
||||||
# The Boost system does not build properly on MSYS using bootstrap.sh. Running
|
|
||||||
# bootstrap.bat with cmd.exe does. It's ugly but it works. At least for Boost
|
|
||||||
# version 1.54.
|
|
||||||
set( bootstrap cmd.exe /c "bootstrap.bat mingw" )
|
|
||||||
else()
|
|
||||||
set( bootstrap ./bootstrap.bat mingw )
|
|
||||||
endif()
|
|
||||||
|
|
||||||
foreach( lib ${boost_libs_list} )
|
|
||||||
set( b2_libs ${b2_libs} --with-${lib} )
|
|
||||||
endforeach()
|
|
||||||
unset( BOOST_CFLAGS )
|
|
||||||
|
|
||||||
else()
|
|
||||||
string( REGEX REPLACE "\\;" "," libs_csv "${boost_libs_list}" )
|
|
||||||
#message( STATUS "libs_csv:${libs_csv}" )
|
|
||||||
|
|
||||||
set( bootstrap ./bootstrap.sh --with-libraries=${libs_csv} )
|
|
||||||
# pass to *both* C and C++ compilers
|
|
||||||
set( BOOST_INCLUDE "${BOOST_ROOT}/include" )
|
|
||||||
unset( b2_libs )
|
|
||||||
endif()
|
|
||||||
|
|
||||||
|
|
||||||
if( APPLE )
|
|
||||||
set( BOOST_CXXFLAGS "cxxflags=-mmacosx-version-min=${CMAKE_OSX_DEPLOYMENT_TARGET} -fno-common" )
|
|
||||||
set( BOOST_LINKFLAGS "linkflags=-mmacosx-version-min=${CMAKE_OSX_DEPLOYMENT_TARGET} -fno-common" )
|
|
||||||
set( BOOST_TOOLSET "toolset=darwin" )
|
|
||||||
|
|
||||||
if( CMAKE_CXX_COMPILER_ID MATCHES "Clang" )
|
|
||||||
set(BOOST_CXXFLAGS "${BOOST_CXXFLAGS} -fno-lto" )
|
|
||||||
set(BOOST_LINKFLAGS "${BOOST_LINKFLAGS} -fno-lto" )
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if( CMAKE_OSX_ARCHITECTURES )
|
|
||||||
|
|
||||||
if( (CMAKE_OSX_ARCHITECTURES MATCHES "386" OR CMAKE_OSX_ARCHITECTURES MATCHES "ppc ") AND
|
|
||||||
(CMAKE_OSX_ARCHITECTURES MATCHES "64"))
|
|
||||||
message( "-- BOOST found 32/64 Address Model" )
|
|
||||||
|
|
||||||
set( BOOST_ADDRESSMODEL "address-model=32_64" )
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if( (CMAKE_OSX_ARCHITECTURES MATCHES "x86_64" OR CMAKE_OSX_ARCHITECTURES MATCHES "386") AND
|
|
||||||
(CMAKE_OSX_ARCHITECTURES MATCHES "ppc"))
|
|
||||||
message("-- BOOST found ppc/x86 Architecture")
|
|
||||||
|
|
||||||
set(BOOST_ARCHITECTURE "architecture=combined")
|
|
||||||
elseif( (CMAKE_OSX_ARCHITECTURES MATCHES "x86_64" OR CMAKE_OSX_ARCHITECTURES MATCHES "386") )
|
|
||||||
message("-- BOOST found x86 Architecture")
|
|
||||||
|
|
||||||
set(BOOST_ARCHITECTURE "architecture=x86")
|
|
||||||
elseif( (CMAKE_OSX_ARCHITECTURES MATCHES "ppc64" OR CMAKE_OSX_ARCHITECTURES MATCHES "ppc") )
|
|
||||||
message("-- BOOST found ppc Architecture")
|
|
||||||
|
|
||||||
set(BOOST_ARCHITECTURE "architecture=ppc")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set( BOOST_CFLAGS "${BOOST_CFLAGS} -arch ${CMAKE_OSX_ARCHITECTURES}" )
|
|
||||||
set( BOOST_CXXFLAGS "${BOOST_CXXFLAGS} -arch ${CMAKE_OSX_ARCHITECTURES}" )
|
|
||||||
set( BOOST_LINKFLAGS "${BOOST_LINKFLAGS} -arch ${CMAKE_OSX_ARCHITECTURES}" )
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
ExternalProject_Add( boost
|
|
||||||
PREFIX "${PREFIX}"
|
|
||||||
|
|
||||||
URL http://downloads.sourceforge.net/project/boost/boost/${BOOST_RELEASE}/boost_${BOOST_VERS}.tar.bz2
|
|
||||||
DOWNLOAD_DIR "${DOWNLOAD_DIR}"
|
|
||||||
TIMEOUT 1200 # 20 minutes
|
|
||||||
URL_MD5 ${BOOST_MD5}
|
|
||||||
# If download fails, then enable "LOG_DOWNLOAD ON" and try again.
|
|
||||||
# Upon a second failure with logging enabled, then look at these logs:
|
|
||||||
# <src>/.downloads-by-cmake$ less /tmp/product/.downloads-by-cmake/boost_1_54_0/src/boost-stamp/boost-download-out.log
|
|
||||||
# <src>/.downloads-by-cmake$ less /tmp/product/.downloads-by-cmake/boost_1_54_0/src/boost-stamp/boost-download-err.log
|
|
||||||
# If out.log does not show 100%, then try increasing TIMEOUT even more, or download the URL manually and put it
|
|
||||||
# into <src>/.downloads-by-cmake/ dir.
|
|
||||||
# LOG_DOWNLOAD ON
|
|
||||||
|
|
||||||
INSTALL_DIR "${BOOST_ROOT}"
|
|
||||||
|
|
||||||
# The patch command executes with the working directory set to <SOURCE_DIR>
|
|
||||||
# Revert the branch to pristine before applying patch sets as bzr patch
|
|
||||||
# fails when applying a patch to the branch twice and doesn't have a switch
|
|
||||||
# to ignore previously applied patches
|
|
||||||
PATCH_COMMAND bzr revert
|
|
||||||
# bzr revert is insufficient to remove "added" files:
|
|
||||||
COMMAND bzr clean-tree -q --force
|
|
||||||
|
|
||||||
COMMAND ${PATCH_STR_CMD} "${PROJECT_SOURCE_DIR}/patches/boost_minkowski.patch"
|
|
||||||
COMMAND ${PATCH_STR_CMD} "${PROJECT_SOURCE_DIR}/patches/boost_cstdint.patch"
|
|
||||||
|
|
||||||
COMMAND ${PATCH_STR_CMD} "${PROJECT_SOURCE_DIR}/patches/boost_macosx_x86.patch" #https://svn.boost.org/trac/boost/ticket/8266
|
|
||||||
# tell bzr about "added" files by last patch:
|
|
||||||
COMMAND bzr add libs/context/src/asm/jump_i386_x86_64_sysv_macho_gas.S
|
|
||||||
COMMAND bzr add libs/context/src/asm/make_i386_x86_64_sysv_macho_gas.S
|
|
||||||
|
|
||||||
COMMAND ${PATCH_STR_CMD} "${PROJECT_SOURCE_DIR}/patches/boost_macosx_x86_build.patch" #https://svn.boost.org/trac/boost/ticket/8266
|
|
||||||
COMMAND ${PATCH_STR_CMD} "${PROJECT_SOURCE_DIR}/patches/boost_macosx_older_openssl.patch" #https://svn.boost.org/trac/boost/ticket/9273
|
|
||||||
|
|
||||||
COMMAND ${PATCH_STR_CMD} "${PROJECT_SOURCE_DIR}/patches/boost_mingw.patch" #https://svn.boost.org/trac/boost/ticket/7262
|
|
||||||
COMMAND ${PATCH_STR_CMD} "${PROJECT_SOURCE_DIR}/patches/boost_mingw64_interlocked.patch"
|
|
||||||
|
|
||||||
# tell bzr about "added" files by last patch:
|
|
||||||
COMMAND bzr add libs/context/src/asm/make_i386_ms_pe_gas.S
|
|
||||||
COMMAND bzr add libs/context/src/asm/jump_i386_ms_pe_gas.S
|
|
||||||
COMMAND bzr add libs/context/src/asm/make_x86_64_ms_pe_gas.S
|
|
||||||
COMMAND bzr add libs/context/src/asm/jump_x86_64_ms_pe_gas.S
|
|
||||||
|
|
||||||
COMMAND ${PATCH_STR_CMD} "${PROJECT_SOURCE_DIR}/patches/patch_macosx_context_ppc_v2.patch" #https://svn.boost.org/trac/boost/ticket/8266
|
|
||||||
COMMAND bzr add libs/context/build/Jamfile.v2
|
|
||||||
COMMAND bzr add libs/context/build/architecture.jam
|
|
||||||
COMMAND bzr add libs/context/src/asm/jump_combined_sysv_macho_gas.S
|
|
||||||
COMMAND bzr add libs/context/src/asm/jump_ppc32_sysv_macho_gas.S
|
|
||||||
COMMAND bzr add libs/context/src/asm/jump_ppc64_sysv_macho_gas.S
|
|
||||||
COMMAND bzr add libs/context/src/asm/make_combined_sysv_macho_gas.S
|
|
||||||
COMMAND bzr add libs/context/src/asm/make_ppc32_sysv_macho_gas.S
|
|
||||||
COMMAND bzr add libs/context/src/asm/make_ppc64_sysv_macho_gas.S
|
|
||||||
|
|
||||||
# [Mis-]use this step to erase all the boost headers and libraries before
|
|
||||||
# replacing them below.
|
|
||||||
UPDATE_COMMAND ${CMAKE_COMMAND} -E remove_directory "${BOOST_ROOT}"
|
|
||||||
|
|
||||||
BINARY_DIR "${PREFIX}/src/boost/"
|
|
||||||
CONFIGURE_COMMAND ${bootstrap}
|
|
||||||
|
|
||||||
BUILD_COMMAND ./b2
|
|
||||||
variant=release
|
|
||||||
threading=multi
|
|
||||||
${BOOST_CFLAGS}
|
|
||||||
${BOOST_TOOLSET}
|
|
||||||
${BOOST_CXXFLAGS}
|
|
||||||
${BOOST_LINKFLAGS}
|
|
||||||
${BOOST_ADDRESSMODEL}
|
|
||||||
${BOOST_ARCHITECTURE}
|
|
||||||
${b2_libs}
|
|
||||||
${BOOST_LINKTYPE}
|
|
||||||
--prefix=<INSTALL_DIR>
|
|
||||||
install
|
|
||||||
|
|
||||||
INSTALL_COMMAND ""
|
|
||||||
)
|
|
||||||
|
|
||||||
if( MINGW )
|
|
||||||
execute_process( COMMAND ${CMAKE_C_COMPILER} -dumpversion
|
|
||||||
OUTPUT_VARIABLE GCC_VERSION
|
|
||||||
OUTPUT_STRIP_TRAILING_WHITESPACE )
|
|
||||||
|
|
||||||
string( REGEX REPLACE "([0-9]+)\\.([0-9]+)\\.[0-9]+.*" "\\1\\2" BOOST_GCC_VERSION ${GCC_VERSION} )
|
|
||||||
#message( STATUS "BOOST_GCC_VERSION: ${BOOST_GCC_VERSION}" )
|
|
||||||
|
|
||||||
string( REGEX REPLACE "([0-9]+)\\.([0-9]+)\\.([0-9])" "\\1_\\2" BOOST_LIB_VERSION ${BOOST_RELEASE} )
|
|
||||||
#message( STATUS "BOOST_LIB_VERSION: ${BOOST_LIB_VERSION}" )
|
|
||||||
|
|
||||||
# adjust the names of the libraries to suit the build. There's no
|
|
||||||
# symbolic links provided on the MinGW build to allow us to use
|
|
||||||
# generic names for the libs
|
|
||||||
foreach( lib ${BOOST_LIBS_BUILT} )
|
|
||||||
set( mingw_boost_libs ${mingw_boost_libs} ${lib}-mgw${BOOST_GCC_VERSION}-mt-${BOOST_LIB_VERSION} )
|
|
||||||
endforeach()
|
|
||||||
|
|
||||||
set( BOOST_LIBS_BUILT ${mingw_boost_libs} )
|
|
||||||
set( BOOST_INCLUDE "${BOOST_ROOT}/include/boost-${BOOST_LIB_VERSION}" )
|
|
||||||
unset( mingw_boost_libs )
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set( boost_libs "" )
|
|
||||||
set_boost_lib_names( "${BOOST_LIBS_BUILT}" boost_libs )
|
|
||||||
|
|
||||||
set( Boost_LIBRARIES ${boost_libs} )
|
|
||||||
set( Boost_INCLUDE_DIR "${BOOST_INCLUDE}" )
|
|
||||||
|
|
||||||
mark_as_advanced( Boost_LIBRARIES Boost_INCLUDE_DIR )
|
|
||||||
|
|
||||||
#message( STATUS "BOOST_ROOT:${BOOST_ROOT} BOOST_LIBRARIES:${BOOST_LIBRARIES}" )
|
|
||||||
#message( STATUS "Boost_INCLUDE_DIR: ${Boost_INCLUDE_DIR}" )
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
ExternalProject_Add_Step( boost bzr_commit_boost
|
|
||||||
COMMAND bzr ci -q -m pristine <SOURCE_DIR>
|
|
||||||
COMMENT "committing pristine boost files to 'boost scratch repo'"
|
|
||||||
DEPENDERS patch
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
ExternalProject_Add_Step( boost bzr_add_boost
|
|
||||||
# add only the headers to the scratch repo, repo = "../.bzr" from ${headers_src}
|
|
||||||
COMMAND bzr add -q ${PREFIX}/src/boost
|
|
||||||
COMMENT "adding pristine boost files to 'boost scratch repo'"
|
|
||||||
DEPENDERS bzr_commit_boost
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
ExternalProject_Add_Step( boost bzr_init_boost
|
|
||||||
COMMAND bzr init -q <SOURCE_DIR>
|
|
||||||
#creates a .bzrignore file in boost root dir, to avoid copying useless files
|
|
||||||
#moreover these files have a very very long name, and sometimes
|
|
||||||
#have a too long full file name to be handled by DOS commands
|
|
||||||
COMMAND echo "*.htm*" > ${PREFIX}/src/boost/.bzrignore
|
|
||||||
COMMENT "creating 'boost scratch repo' specifically for boost to track boost patches"
|
|
||||||
DEPENDERS bzr_add_boost
|
|
||||||
DEPENDEES download
|
|
||||||
)
|
|
||||||
|
|
|
@ -23,9 +23,8 @@
|
||||||
# These are additions to any inherited from pcbnew dir:
|
# These are additions to any inherited from pcbnew dir:
|
||||||
include_directories( . )
|
include_directories( . )
|
||||||
|
|
||||||
# Tell AVHTTP we have SSL.
|
|
||||||
set( GITHUB_PLUGIN_SRCS
|
set( GITHUB_PLUGIN_SRCS
|
||||||
github_plugin.cpp
|
github_plugin.cpp
|
||||||
github_getliblist.cpp
|
github_getliblist.cpp
|
||||||
html_link_parser.cpp
|
html_link_parser.cpp
|
||||||
)
|
)
|
||||||
|
@ -43,5 +42,3 @@ if( MINGW )
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_dependencies( github_plugin boost )
|
|
||||||
|
|
||||||
|
|
|
@ -18,8 +18,6 @@ add_executable( idfrect idf_rect.cpp )
|
||||||
add_executable( dxf2idf dxf2idfmain.cpp dxf2idf.cpp )
|
add_executable( dxf2idf dxf2idfmain.cpp dxf2idf.cpp )
|
||||||
add_executable( idf2vrml idf2vrml.cpp )
|
add_executable( idf2vrml idf2vrml.cpp )
|
||||||
|
|
||||||
add_dependencies( idf2vrml boost )
|
|
||||||
|
|
||||||
target_link_libraries( dxf2idf lib_dxf idf3 ${wxWidgets_LIBRARIES} )
|
target_link_libraries( dxf2idf lib_dxf idf3 ${wxWidgets_LIBRARIES} )
|
||||||
|
|
||||||
target_link_libraries( idf2vrml idf3 ${OPENGL_LIBRARIES} ${wxWidgets_LIBRARIES} )
|
target_link_libraries( idf2vrml idf3 ${OPENGL_LIBRARIES} ${wxWidgets_LIBRARIES} )
|
||||||
|
|
Loading…
Reference in New Issue