diff options
author | saurabhb17 | 2020-02-26 16:01:28 +0530 |
---|---|---|
committer | GitHub | 2020-02-26 16:01:28 +0530 |
commit | d51317f0193609fb43e932730d78aa86a4984083 (patch) | |
tree | 6acee185a4dc19113fcbf0f9a3d6941085dedaf7 /CMakeLists.txt | |
parent | 0db48f6533517ecebfd9f0693f89deca28408b76 (diff) | |
parent | 886d9cb772e81d2e5262284bc3082664f084337f (diff) | |
download | KiCad-eSim-d51317f0193609fb43e932730d78aa86a4984083.tar.gz KiCad-eSim-d51317f0193609fb43e932730d78aa86a4984083.tar.bz2 KiCad-eSim-d51317f0193609fb43e932730d78aa86a4984083.zip |
Merge pull request #2 from FOSSEE/develop
Develop
Diffstat (limited to 'CMakeLists.txt')
-rw-r--r-- | CMakeLists.txt | 932 |
1 files changed, 932 insertions, 0 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt new file mode 100644 index 0000000..09932cc --- /dev/null +++ b/CMakeLists.txt @@ -0,0 +1,932 @@ +# +# This program source code file is part of KICAD, a free EDA CAD application. +# +# Copyright (C) 2007-2016 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 +# + +# Default to CMAKE_BUILD_TYPE = Release unless overridden on command line +# http://www.cmake.org/pipermail/cmake/2008-September/023808.html +if( DEFINED CMAKE_BUILD_TYPE ) + set( CMAKE_BUILD_TYPE ${CMAKE_BUILD_TYPE} CACHE STRING "Set to either \"Release\" or \"Debug\"" ) +else() + set( CMAKE_BUILD_TYPE Release CACHE STRING "Set to either \"Release\" or \"Debug\"" ) +endif() + +project( kicad ) + +cmake_minimum_required( VERSION 2.8.4 FATAL_ERROR ) +# because of http://public.kitware.com/Bug/view.php?id=10395 + +# Path to local CMake modules. +set( CMAKE_MODULE_PATH ${PROJECT_SOURCE_DIR}/CMakeModules ) + +# +# KiCad build options should be added below. +# +# If you add a new build option, please add it's state to the CopyVersionInfoToClipboard() +# function in common/basicframe.cpp so that build option settings can be included in bug +# reports. +# + +# The desire is to migrate designs *away from* case independence, and to create designs which use +# literally (case specific) interpreted component names. But for backwards compatibility, +# you may turn OFF this option if you really must. (Remember that with KiCad using text +# data files, typically you would be better off simply doctoring those files into +# a case literal state with a text editor and move forward into the brave new +# world of case specificity. Also, BOM generators may not work properly when you +# have this option turned OFF, the xml export's referential integrity is broken +# on library part name. Hence the default is ON now, as of 29-Jan-2014. +option( KICAD_KEEPCASE + "Use case sensitive string matching for component names (default ON)." + ON + ) + +option( USE_WX_GRAPHICS_CONTEXT + "Use wxGraphicsContext for rendering (default OFF). Warning, this is experimental" ) + +option( USE_WX_OVERLAY + "Use wxOverlay: Always ON for MAC (default OFF). Warning, this is experimental" ) + +option( KICAD_SCRIPTING + "Build the Python scripting support inside KiCad binaries (default OFF)." + ) + +option( KICAD_SCRIPTING_MODULES + "Build KiCad Python modules that can be used from scripting languages (default OFF)." + ) + +option( KICAD_SCRIPTING_WXPYTHON + "Build wxPython implementation for wx interface building in Python and py.shell (default OFF)." + ) + +option( KICAD_BUILD_STATIC + "Build dependencies as static libraries. OSX only. (default OFF)." + ) + +option( KICAD_BUILD_DYNAMIC + "Build dependencies as shared libraries. Required for wxPython support. OXS only. (default OFF)." + ) + +option( USE_OSX_DEPS_BUILDER + "Build dependencies from source instead of dependencies installed on system. OSX only. (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: +# PYTHON_EXECUTABLE can be defined when invoking cmake +# ( use -DPYTHON_EXECUTABLE=<python path>/python.exe or python2 ) +# when not defined by user, the default is python.exe under Windows and python2 for others +# python binary file should be is exec path. + +option( BUILD_GITHUB_PLUGIN "Build the GITHUB_PLUGIN for pcbnew." ON ) + + + +# 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 +LINK_DIRECTORIES( ${LINK_DIRECTORIES_PATH} ) + +if( UNIX ) + set( KICAD_USER_CONFIG_DIR $ENV{HOME} CACHE PATH "Location of user specific KiCad config files" ) +elseif( MINGW ) + set( KICAD_USER_CONFIG_DIR $ENV{APPDATA} CACHE PATH "Location of user specific KiCad config files" ) +endif() +mark_as_advanced( KICAD_USER_CONFIG_DIR ) + +# Set default data file path to CMAKE_INSTALL_PREFIX if it wasn't specified during the +# CMake configuration. The value of DEFAULT_INSTALL_PATH is expanded in config.h and +# used in the source code to define the base path for kicad search paths and environment +# variables. +if( NOT DEFAULT_INSTALL_PATH ) + set( DEFAULT_INSTALL_PATH "${CMAKE_INSTALL_PREFIX}" + CACHE + PATH + "Location of KiCad data files." ) +endif() + +message( STATUS "Kicad install dir: <${DEFAULT_INSTALL_PATH}>" ) + +# Generate build system specific header file. +include( PerformFeatureChecks ) +perform_feature_checks() + + +#================================================ +# Set flags for GCC, or treat llvm as GCC +#================================================ + +if( CMAKE_COMPILER_IS_GNUCXX OR CMAKE_CXX_COMPILER_ID MATCHES "Clang" ) + + execute_process( COMMAND ${CMAKE_C_COMPILER} -dumpversion + OUTPUT_VARIABLE GCC_VERSION + OUTPUT_STRIP_TRAILING_WHITESPACE ) + + if( CMAKE_CXX_COMPILER_ID MATCHES "Clang" ) + set( TO_LINKER -XLinker ) + else() + set( TO_LINKER -Wl ) + endif() + + # Establish -Wall early, so specialized relaxations of this may come + # subsequently on the command line, such as in pcbnew/github/CMakeLists.txt + set( CMAKE_C_FLAGS "-Wall ${CMAKE_C_FLAGS}" ) + set( CMAKE_CXX_FLAGS "-Wall ${CMAKE_CXX_FLAGS}" ) + + # The optimization level is -O1 instead of the usual -O2 level because + # boost::polygon has a function (inflate polygon) broken by the -O2 level + # with GCC 4.7.0 to 4.7.2 (works fine with with GCC 4.6 and 4.7.3). + # This lower optimization level does not have a significant change on the speed. + # See also: + # https://bugs.launchpad.net/kicad/+bug/1056926 + # https://svn.boost.org/trac/boost/ticket/7983 + if( GCC_VERSION VERSION_EQUAL 4.7.0 OR ( GCC_VERSION VERSION_GREATER 4.7.0 AND GCC_VERSION VERSION_LESS 4.7.3 ) ) + set( CMAKE_C_FLAGS_RELEASE "-O1" ) + set( CMAKE_CXX_FLAGS_RELEASE "-O1" ) + else() + set( CMAKE_C_FLAGS_RELEASE "-O2" ) + set( CMAKE_CXX_FLAGS_RELEASE "-O2" ) + endif() + + set( CMAKE_C_FLAGS_DEBUG "-g3 -ggdb3 -DDEBUG" ) + set( CMAKE_CXX_FLAGS_DEBUG "-g3 -ggdb3 -DDEBUG -Wno-deprecated-declarations" ) + + set( CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} -DNDEBUG" ) + set( CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} -DNDEBUG" ) + + if( GXX_HAS_VISIBILITY_FLAG AND NOT APPLE ) + set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fvisibility=hidden" ) + endif() + + if( GXX_HAS_VISIBILITY_INLINES_FLAG AND NOT APPLE ) + set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fvisibility-inlines-hidden" ) + endif() + + find_package( OpenMP QUIET ) + + if( OPENMP_FOUND ) + set( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${OpenMP_C_FLAGS}" ) + set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${OpenMP_CXX_FLAGS}" ) + add_definitions( -DUSE_OPENMP ) + + # MinGW does not include the OpenMP link library and FindOpenMP.cmake does not + # set it either. Not sure this is the most elegant solution but it works. + if( MINGW ) + set( OPENMP_LIBRARIES gomp ) + endif() + endif() + + if( MINGW ) + set( CMAKE_EXE_LINKER_FLAGS_RELEASE "-s" ) + + # _UNICODE definition seems needed under mingw/gcc 4.8 + # (Kicad uses unicode, and on Windows, wxWidgets >= 2.9.4 is mandatory + # and uses unicode) + if( GCC_VERSION VERSION_EQUAL 4.8.0 OR GCC_VERSION VERSION_GREATER 4.8.0 ) + add_definitions(-D_UNICODE) + endif() + + # Since version 2.8.5, Cmake uses a response file (.rsp) to + # pass the list of include paths to gcc + # unfortunately, under mingw32+msys, at least with gcc 4.8 and previous, + # this file is not always expanded and in this case include paths defined in this file + # are not taken in account ( this is the case of wxWidgets includes ) + # If it is the case, disable this response file for includes ( See Windows-GNU.cmake module ) + if( false ) #set to true to disable the include response file + if( WIN32 AND MSYS AND NOT CMAKE_CROSSCOMPILING ) + # fixme: it is needed only with MSYS+MINGW32? or always under MINGW + if( ${CMAKE_SIZEOF_VOID_P} MATCHES 4 ) + set( CMAKE_CXX_USE_RESPONSE_FILE_FOR_INCLUDES 0 ) + endif() + endif() + endif() + + # for some reasons, cmake does do use always a response file to send the list of objects + # to the archiver, and because this list can be very long, and can create issue + # when it is used in a command line, force use of a response file to store it + SET( CMAKE_CXX_USE_RESPONSE_FILE_FOR_OBJECTS 1 ) + + # The MinGW compiler can use the microsoft system snprintf as standard and it has a broken + # API with respect to the C99 standard, so make sure we force it to use its own compliant + # snprintf + add_definitions(-D__USE_MINGW_ANSI_STDIO=1) + + else() + # We build DLL/DSOs from static libraries, so create position independent + # code for all cases, since we do not have DLL/DSO specific static + # libraries. Subdirectories via add_subdirectores() reference this + # variable, and it is either set or empty, empty for Windows. + set( PIC_FLAG -fPIC ) + + set( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${PIC_FLAG}" ) + set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${PIC_FLAG}" ) + + if( NOT APPLE ) + # Thou shalt not link vaporware and tell us it's a valid DSO (apple ld doesn't support it) + set( CMAKE_SHARED_LINKER_FLAGS "${TO_LINKER},--no-undefined" ) + set( CMAKE_MODULE_LINKER_FLAGS "${TO_LINKER},--no-undefined" ) + + set( CMAKE_EXE_LINKER_FLAGS_RELEASE "-s" ) + + # Defeat ELF's ability to use the GOT to replace locally implemented functions + # with ones from another module. + # https://bugs.launchpad.net/kicad/+bug/1322354 + set( CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} ${TO_LINKER},-Bsymbolic" ) + set( CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} ${TO_LINKER},-Bsymbolic" ) + endif() + + endif() + + # quiet GCC while in boost + if( GCC_VERSION VERSION_GREATER 4.8 OR GCC_VERSION VERSION_EQUAL 4.8 ) + set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-local-typedefs" ) + endif() + set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-strict-aliasing" ) + + if( APPLE ) + + set( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -D__ASSERTMACROS__" ) + set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -D__ASSERTMACROS__" ) + + # Allows .dylib relocation in the future - needed by fixbundle + set( CMAKE_LD_FLAGS "${CMAKE_LD_FLAGS} -headerpad_max_install_names") + + if( NOT CMAKE_CXX_COMPILER ) + EXEC_PROGRAM( wx-config ARGS --cc OUTPUT_VARIABLE CMAKE_C_COMPILER ) + endif() + + if( NOT CMAKE_CXX_COMPILER ) + EXEC_PROGRAM( wx-config ARGS --cxx OUTPUT_VARIABLE CMAKE_CXX_COMPILER ) + endif() + + # There seems to be no consistent behavior when -mmacosx-min-version is + # not specified, so force user to set minimum OSX version to build for + if( NOT CMAKE_OSX_DEPLOYMENT_TARGET ) + message( FATAL_ERROR "Please specify target OS X version using -DCMAKE_OSX_DEPLOYMENT_TARGET=10.x" ) + endif() + + endif() + +endif( CMAKE_COMPILER_IS_GNUCXX OR CMAKE_CXX_COMPILER_ID MATCHES "Clang" ) + +if( KICAD_KEEPCASE ) + add_definitions( -DKICAD_KEEPCASE ) +endif() + +if( USE_WX_OVERLAY OR APPLE ) + add_definitions( -DUSE_WX_OVERLAY ) +endif() + +if( KICAD_SCRIPTING ) + add_definitions( -DKICAD_SCRIPTING ) +endif() + +if( KICAD_SCRIPTING_MODULES ) + add_definitions( -DKICAD_SCRIPTING_MODULES ) +endif() + +if( KICAD_SCRIPTING_WXPYTHON ) + add_definitions( -DKICAD_SCRIPTING_WXPYTHON ) +endif() + +if( USE_WX_GRAPHICS_CONTEXT OR APPLE ) + add_definitions( -DUSE_WX_GRAPHICS_CONTEXT ) +endif() + + +# By default images in menu items are enabled on all platforms except OSX. +if( NOT APPLE ) + set( USE_IMAGES_IN_MENUS ON CACHE BOOL "Enable images in menus" ) +else() + set( USE_IMAGES_IN_MENUS OFF CACHE BOOL "Enable images in menus" ) +endif() + + + +# KIFACE_SUFFIX is the file extension used for top level program modules which +# implement the KIFACE interface. A valid suffix starts with a period '.'. + +if( false ) + # This is the eventual situation near milestone C) of modular-kicad blueprint. + # Until then we use .kiface extension so we don't collide with python DSO. + set( KIFACE_SUFFIX ${CMAKE_SHARED_MODULE_SUFFIX} ) +else() + # Temporary situation until we can dovetail the python DSO into the kiface DSO. + set( KIFACE_SUFFIX ".kiface" ) +endif() + +# KIFACE_PREFIX is a basename prefix used for top level program modules which +# implement the KIFACE. +set( KIFACE_PREFIX "_" ) +#message( STATUS "KIFACE_SUFFIX:${KIFACE_SUFFIX} KIFACE_PREFIX:${KIFACE_PREFIX}" ) + + +#================================================ +# Locations for install targets. +#================================================ +if( NOT APPLE ) + # Everything without leading / is relative to CMAKE_INSTALL_PREFIX. + set( KICAD_BIN ${CMAKE_INSTALL_PREFIX}/bin + CACHE PATH "Location of KiCad binaries." ) + + if( WIN32 ) + set( KICAD_PLUGINS ${KICAD_BIN}/scripting/plugins + CACHE PATH "Location of KiCad plugins." ) + else() + set( KICAD_PLUGINS lib/kicad/plugins + CACHE PATH "Location of KiCad plugins." ) + endif() + + set( KICAD_DATA share/kicad + CACHE PATH "Location of KiCad data files." ) + set( KICAD_DOCS share/doc/kicad + CACHE PATH "Location of KiCad documentation files." ) + set( KICAD_DEMOS ${KICAD_DATA}/demos + CACHE PATH "Location of KiCad demo files." ) + set( KICAD_TEMPLATE ${KICAD_DATA}/template + CACHE PATH "Location of KiCad template files." ) +else() + # everything without leading / is relative to CMAKE_INSTALL_PREFIX. + # CMAKE_INSTALL_PREFIX is root of .dmg image + set( KICAD_BIN ${CMAKE_INSTALL_PREFIX} + CACHE PATH "Location of KiCad binaries." FORCE ) + + # some paths to single app bundle + set( OSX_BUNDLE_MAIN "kicad.app" ) + set( OSX_BUNDLE_BIN_DIR "Contents/MacOS" ) + set( OSX_BUNDLE_LIB_DIR "Contents/Frameworks" ) + set( OSX_BUNDLE_KIFACE_DIR "Contents/PlugIns" ) + set( OSX_BUNDLE_SUP_DIR "Contents/SharedSupport" ) + set( OSX_BUNDLE_APP_DIR "Contents/Applications" ) + set( OSX_BUNDLE_BUILD_DIR "${CMAKE_BINARY_DIR}/kicad/${OSX_BUNDLE_MAIN}" ) + set( OSX_BUNDLE_BUILD_BIN_DIR "${OSX_BUNDLE_BUILD_DIR}/${OSX_BUNDLE_BIN_DIR}" ) + set( OSX_BUNDLE_BUILD_LIB_DIR "${OSX_BUNDLE_BUILD_DIR}/${OSX_BUNDLE_LIB_DIR}" ) + set( OSX_BUNDLE_BUILD_KIFACE_DIR "${OSX_BUNDLE_BUILD_DIR}/${OSX_BUNDLE_KIFACE_DIR}" ) + set( OSX_BUNDLE_INSTALL_DIR "${KICAD_BIN}/${OSX_BUNDLE_MAIN}" ) + set( OSX_BUNDLE_INSTALL_BIN_DIR "${OSX_BUNDLE_INSTALL_DIR}/${OSX_BUNDLE_BIN_DIR}" ) + set( OSX_BUNDLE_INSTALL_LIB_DIR "${OSX_BUNDLE_INSTALL_DIR}/${OSX_BUNDLE_LIB_DIR}" ) + set( OSX_BUNDLE_INSTALL_KIFACE_DIR "${OSX_BUNDLE_INSTALL_DIR}/${OSX_BUNDLE_KIFACE_DIR}" ) + + # everything provided with the application bundle goes into + # kicad.app/Contents/SharedSupport => accessible via GetDataDir() + # everything else to the .dmg image + set( KICAD_DATA ${OSX_BUNDLE_INSTALL_DIR}/${OSX_BUNDLE_SUP_DIR} + CACHE PATH "Location of KiCad data files." FORCE ) + set( KICAD_TEMPLATE ${KICAD_DATA}/template + CACHE PATH "Location of KiCad template files." FORCE ) + set( KICAD_PLUGINS ${KICAD_DATA}/plugins + CACHE PATH "Location of KiCad plugins." FORCE ) + set( KICAD_DOCS doc + CACHE PATH "Location of KiCad documentation files." FORCE ) + set( KICAD_DEMOS demos + CACHE PATH "Location of KiCad demo files." FORCE ) + + # Override default paths for fixup_bundle + set( OSX_BUNDLE_OVERRIDE_PATHS " + function( gp_item_default_embedded_path_override item default_embedded_path_var ) + # by default, embed things right next to the main bundle executable: + set( path \"@executable_path/../../Contents/MacOS\" ) + set( overridden 0 ) + + # embed .dylibs right next to the main bundle executable: + if( item MATCHES \"\\\\.dylib$\" ) + set( path \"@executable_path/../Frameworks\" ) + set( overridden 1 ) + endif() + + set( \${default_embedded_path_var} \"\${path}\" PARENT_SCOPE ) + endfunction(gp_item_default_embedded_path_override) + " + ) +endif() + +mark_as_advanced( KICAD_BIN + KICAD_PLUGINS + KICAD_DATA + KICAD_DOCS + KICAD_DEMOS + KICAD_TEMPLATE ) + +include( Functions ) + +include( ExternalProject ) + +#================================================ +# Find libraries that are needed to build KiCad. +#================================================ +include( CheckFindPackageResult ) + +########################## +# Find wxWidgets library # +########################## +# Here you can define what libraries of wxWidgets you need for your +# application. You can figure out what libraries you need here; +# http://www.wxwidgets.org/manuals/2.8/wx_librarieslist.html + +# Turn on wxWidgets compatibility mode for some classes +add_definitions( -DWX_COMPATIBILITY ) + +# See line 41 of CMakeModules/FindwxWidgets.cmake +set( wxWidgets_CONFIG_OPTIONS ${wxWidgets_CONFIG_OPTIONS} --static=no ) + +find_package( wxWidgets 3.0.0 COMPONENTS gl aui adv html core net base xml stc REQUIRED ) + +# Include wxWidgets macros. +include( ${wxWidgets_USE_FILE} ) + +####################### +# Find OpenGL library # +####################### +find_package( OpenGL QUIET ) +check_find_package_result( OPENGL_FOUND "OpenGL" ) + +# Dick 5-Feb-2014: +# Marco: We cannot use both ExternalProject_Add() add and find_package() +# in the same CMake tree and have them both reference the same package: +# http://stackoverflow.com/questions/6351609/cmake-linking-to-library-downloaded-from-externalproject-add +# https://www.mail-archive.com/cmake@cmake.org/msg47501.html + +# Handle target used to specify if a target needs wx-widgets or other libraries +# Always defined, empty if no libraries are to be built +add_custom_target( lib-dependencies ) + +# Only download and build all dependencies from source on OSX if the user specifically requests +# it. Otherwise, respect the developers wishes to use the dependencies already installed on +# their system +if( APPLE AND USE_OSX_DEPS_BUILDER ) + + # This should be built in all cases, if swig exec is not available + # will be impossible also enable SCRIPTING being for PCBNEW required immediately + + include( download_pcre ) + include( download_swig ) + + + #set(CMAKE_FIND_LIBRARY_SUFFIXES ".a;.so;.dylib;.dll") + + if( KICAD_BUILD_STATIC AND KICAD_BUILD_DYNAMIC ) + message(FATAL_ERROR "You can't build STATIC and DYNAMIC together") + endif() + + if( KICAD_BUILD_STATIC ) + message(STATUS "KICAD_BUILD_STATIC set") + if( KICAD_SCRIPTING OR KICAD_SCRIPTING_WXPYTHON OR KICAD_SCRIPTING_MODULES ) + message(FATAL_ERROR "KICAD_SCRIPTING* is not supported with KICAD_BUILD_STATIC, please select KICAD_BUILD_DYNAMIC" ) + endif() + endif() + + if( KICAD_BUILD_DYNAMIC ) + message(STATUS "KICAD_BUILD_DYNAMIC set") + endif() + + + if( KICAD_SCRIPTING OR KICAD_SCRIPTING_WXPYTHON OR KICAD_SCRIPTING_MODULES ) + + message(STATUS "Scripting ENABLED") + include( download_wxpython ) + + set( SWIG_EXECUTABLE ${SWIG_ROOT}/bin/swig ) + set( SWIG_INCLUDE ${SWIG_ROOT}/include ) + set( PYTHON_DEST ${LIBWXPYTHON_ROOT}/wxPython/lib/python2.6/site-packages ) + + if( NOT EXISTS ${SWIG_EXECUTABLE} ) + set(KICAD_SCRIPTING CACHE OFF FORCE "Disabling KICAD_SCRIPTING") + message( STATUS "KICAD_SCRIPTING Enabled but SWIG not found, please disable and before reenabling execute: make swig") + message( FATAL_ERROR "Missing SWIG!") + endif() + message(STATUS "SWIG_EXECUTABLE: ${SWIG_EXECUTABLE}") + + set( PYTHON_DEST ${LIBWXPYTHON_ROOT}/wxPython/lib/python2.6/site-packages ) + + add_dependencies( lib-dependencies libwxpython ) + add_dependencies( lib-dependencies swig ) + else() + include( download_wxwidgets ) + add_dependencies( lib-dependencies libwx ) + endif() + + include( download_libpng ) + include( download_pkgconfig ) + set( PKG_CONFIG_EXECUTABLE "${PKGCONFIG_ROOT}/bin/pkg-config" ) + include( download_glew ) + set( GLEW_GLEW_LIBRARY "${GLEW_ROOT}/lib/libGLEW.a" ) + set( GLEW_INCLUDE_DIR "${GLEW_ROOT}/include" ) + include( download_pixman ) + set( PIXMAN_LIBRARY "${PIXMAN_ROOT}/lib/libpixman-1.a" ) + include( download_cairo ) + set( CAIRO_INCLUDE_DIR "${CAIRO_ROOT}/include/cairo" ) + set( CAIRO_LIBRARY "${CAIRO_ROOT}/lib/libcairo.a" ) + + add_dependencies( lib-dependencies boost ) + add_dependencies( lib-dependencies cairo ) + add_dependencies( lib-dependencies libpng ) + add_dependencies( lib-dependencies pixman ) + add_dependencies( lib-dependencies pkgconfig ) + + if( KICAD_BUILD_DYNAMIC AND APPLE ) + add_custom_target( osx_fix_bundles ALL DEPENDS + eeschema gerbview kicad pcbnew bitmap2component pcb_calculator pl_editor) + add_custom_command(TARGET osx_fix_bundles + POST_BUILD COMMAND ${PROJECT_SOURCE_DIR}/scripts/osx_fixbundle.sh ${PROJECT_SOURCE_DIR} + COMMENT "Migrating dylibs to bundles") + endif() +endif() + +##################### +# Find GLEW library # +##################### +if( NOT GLEW_FOUND ) + find_package( GLEW ) + check_find_package_result( GLEW_FOUND "GLEW" ) +endif() + +# Find CURL library +find_package( CURL REQUIRED ) + + +###################### +# Find Cairo library # +###################### +if( NOT CAIRO_FOUND ) + find_package( Cairo 1.8.1 QUIET ) + check_find_package_result( CAIRO_FOUND "Cairo" ) +endif() + +# Download boost and possibly build parts of it +################################################# +if( KICAD_SKIP_BOOST ) + find_package( Boost 1.54.0 REQUIRED COMPONENTS context date_time filesystem iostreams locale + program_options regex system thread ) + + if( NOT Boost_FOUND ) + 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( MinGWResourceCompiler ) + +# Find GDI+ on windows if wxGraphicsContext is available. +if( MINGW AND USE_WX_GRAPHICS_CONTEXT ) + find_package( GdiPlus ) + check_find_package_result( GDI_PLUS_FOUND "GDI+" ) +endif() + +# Assist with header file searching optimization: +# INC_BEFORE and INC_AFTER are two lists which go at the front and back of the +# header file search lists, respectively. +# INC_BEFORE is for use with "include_directories( BEFORE ...)", which _reverses_ +# the order during insertion. (So put first wanted last, which is +# ${CMAKE_SOURCE_DIR/include.) Use '.' for current source dir since +# we don't want expansion here and now, which would happen if using ${CMAKE_CURRENT_SOURCE_DIR}. +# Instead we use '.' which is applicable to any source directory below here as a result of +# this lack of expansion. +set( INC_BEFORE + . + ${CMAKE_SOURCE_DIR}/include + ) + +set( INC_AFTER + ${Boost_INCLUDE_DIR} + #include <config.h> + ${CMAKE_BINARY_DIR} + ) + + +# Find Python and other scripting resources +if( KICAD_SCRIPTING OR KICAD_SCRIPTING_MODULES ) + # force a python version < 3.0 + set( PythonInterp_FIND_VERSION 2.6 ) + set( PythonLibs_FIND_VERSION 2.6 ) + + find_package( PythonInterp ) + + check_find_package_result( PYTHONINTERP_FOUND "Python Interpreter" ) + + if( NOT PYTHON_VERSION_MAJOR EQUAL 2 ) + message( FATAL_ERROR "Python 2.x is required." ) + endif() + + # Get the correct Python site package install path from the Python interpreter found by + # FindPythonInterp unless the user specifically defined a custom path. + if( NOT PYTHON_SITE_PACKAGE_PATH ) + execute_process( COMMAND ${PYTHON_EXECUTABLE} -c "import distutils.sysconfig;print\"%s\"%distutils.sysconfig.get_python_lib(plat_specific=0, standard_lib=0, prefix='')" + OUTPUT_VARIABLE PYTHON_SITE_PACKAGE_PATH + OUTPUT_STRIP_TRAILING_WHITESPACE + ) + + if( NOT PYTHON_SITE_PACKAGE_PATH ) + message( FATAL_ERROR "Error occurred while attempting to find the Python site library path." ) + endif() + endif() + + if( NOT APPLE ) + set( PYTHON_DEST "${PYTHON_SITE_PACKAGE_PATH}" + CACHE PATH "Python module install path." + ) + else() + # relative path for python in bundle + set( PYTHON_LIB_DIR "python/site-packages" ) + # install into bundle Frameworks folder + set( PYTHON_DEST "${OSX_BUNDLE_BUILD_LIB_DIR}/${PYTHON_LIB_DIR}" + CACHE PATH "Python module install path." + ) + endif() + mark_as_advanced( PYTHON_DEST ) + message( STATUS "Python module install path: ${PYTHON_DEST}" ) + + find_package( PythonLibs 2.6 ) + + if( KICAD_SCRIPTING_WXPYTHON ) + # Check to see if the correct version of wxPython is installed based on the version of + # wxWidgets found. At least the major an minor version should match. + set( _wxpy_version "${wxWidgets_VERSION_MAJOR}.${wxWidgets_VERSION_MINOR}" ) + set( _py_cmd "import wxversion;print wxversion.checkInstalled('${_wxpy_version}')" ) + + # Add user specified Python site package path. + if( PYTHON_SITE_PACKAGE_PATH ) + set( _py_cmd + "import sys;sys.path.insert(0, \"${PYTHON_SITE_PACKAGE_PATH}\");${_py_cmd}" ) + endif() + + execute_process( COMMAND ${PYTHON_EXECUTABLE} -c "${_py_cmd}" + RESULT_VARIABLE WXPYTHON_VERSION_RESULT + OUTPUT_VARIABLE WXPYTHON_VERSION_FOUND + OUTPUT_STRIP_TRAILING_WHITESPACE + ) + + # message( STATUS "WXPYTHON_VERSION_FOUND: ${WXPYTHON_VERSION_FOUND}" ) + # message( STATUS "WXPYTHON_VERSION_RESULT: ${WXPYTHON_VERSION_RESULT}" ) + + # Check to see if any version of wxPython is installed on the system. + if( WXPYTHON_VERSION_RESULT GREATER 0 ) + message( FATAL_ERROR "wxPython does not appear to be installed on the system." ) + endif() + + if( NOT WXPYTHON_VERSION_FOUND STREQUAL "True" ) + message( FATAL_ERROR + "wxPython version ${_wxpy_version} does not appear to be installed on the system." ) + endif() + + set( WXPYTHON_VERSION ${_wxpy_version} CACHE STRING "wxPython version found." ) + message( STATUS "wxPython version ${_wxpy_version} found." ) + endif() + + #message( STATUS "PYTHON_INCLUDE_DIRS:${PYTHON_INCLUDE_DIRS}" ) + + # Infrequently needed headers go at end of search paths, append to INC_AFTER which + # although is used for all components, should be a harmless hit for something like eeschema + # so long as unused search paths are at the end like this. + set( INC_AFTER ${INC_AFTER} ${PYTHON_INCLUDE_DIRS} ${CMAKE_CURRENT_SOURCE_DIR}/scripting ) + + #message( STATUS "/ INC_AFTER:${INC_AFTER}" ) + +endif() + +if( EXISTS ${CMAKE_SOURCE_DIR}/include/config.h ) + # This file may exist ( created by an alternate process to the svn test above), + # e.g. could be created by a checkout script that produces a source tar file. + # This directive means the about box will have the svn date & revision in it, + # but the hard coded release date ( program version) will be preserved. + add_definitions( -DHAVE_SVN_REVISION ) +endif() + + +#================================================ +# Let CMake look in these directories for nested +# 'CMakeLists.txt' files to process +#================================================ + +if( APPLE ) + # Remove app bundles in ${KICAD_BIN} before installing anything new. + # Must be defined before all includes so that it is executed first. + install( CODE " + message( STATUS \"Removing existing application bundles...\" ) + # Remove links to standalone apps + file( REMOVE ${KICAD_BIN}/bitmap2component.app ) + file( REMOVE ${KICAD_BIN}/eeschema.app ) + file( REMOVE ${KICAD_BIN}/gerbview.app ) + file( REMOVE ${KICAD_BIN}/pcb_calculator.app ) + file( REMOVE ${KICAD_BIN}/pcbnew.app ) + file( REMOVE ${KICAD_BIN}/pl_editor.app ) + # Remove main bundle + file( REMOVE_RECURSE ${KICAD_BIN}/${OSX_BUNDLE_MAIN} ) + " COMPONENT Runtime + ) +endif() + +############################ +# Binaries ( CMake targets ) # +############################ + +add_subdirectory( bitmaps_png ) +add_subdirectory( common ) +add_subdirectory( 3d-viewer ) +add_subdirectory( cvpcb ) +add_subdirectory( eeschema ) +add_subdirectory( gerbview ) +add_subdirectory( lib_dxf ) +add_subdirectory( pcbnew ) +add_subdirectory( polygon ) +add_subdirectory( pagelayout_editor ) +add_subdirectory( potrace ) +add_subdirectory( bitmap2component ) +add_subdirectory( pcb_calculator ) +add_subdirectory( kicad ) # should follow pcbnew, eeschema +add_subdirectory( tools ) +add_subdirectory( utils ) +add_subdirectory( qa ) + +#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 # +############# +add_subdirectory( demos ) +add_subdirectory( template ) + +#================================================ +# Doxygen Output +#================================================ +find_package( Doxygen ) +if( DOXYGEN_FOUND ) + add_custom_target( doxygen-docs + ${CMAKE_COMMAND} -E remove_directory Documentation/doxygen + COMMAND ${DOXYGEN_EXECUTABLE} + WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} + DEPENDS Doxyfile + COMMENT "building doxygen docs into directory Documentation/doxygen/html" + ) + add_custom_target( dev-docs + ${CMAKE_COMMAND} -E remove_directory Documentation/development/doxygen + COMMAND ${DOXYGEN_EXECUTABLE} + WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/Documentation/development + DEPENDS Doxyfile + COMMENT "building developer's resource docs into directory Documentation/development/doxygen/html" + ) +else() + message( STATUS "WARNING: Doxygen not found - doxygen-docs (Source Docs) target not created" ) +endif() + +# Generate config.h. +configure_file( ${PROJECT_SOURCE_DIR}/CMakeModules/config.h.cmake + ${CMAKE_BINARY_DIR}/config.h ) + +#================================================ +# "make uninstall" rules +#================================================ +configure_file( + "${CMAKE_MODULE_PATH}/cmake_uninstall.cmake.in" + "${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake" + IMMEDIATE @ONLY ) + +add_custom_target( uninstall + "${CMAKE_COMMAND}" -P "${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake" ) + + +#================================================ +# Installation +#================================================ + +install( FILES INSTALL.txt + DESTINATION ${KICAD_DOCS} + COMPONENT resources ) + +### +# Install scripts +### +if( UNIX ) + install( DIRECTORY scripts + DESTINATION ${KICAD_DOCS} + COMPONENT resources + ) +endif() + +### +# FreeDesktop .desktop and MIME resources +### +if( UNIX AND NOT APPLE ) + + # Set paths + set( UNIX_MIME_DIR resources/linux/mime ) + set( UNIX_MIMELNK_FILES ${UNIX_MIME_DIR}/mimelnk ) + set( UNIX_MIME_FILES ${UNIX_MIME_DIR}/mime ) + set( UNIX_ICON_FILES ${UNIX_MIME_DIR}/icons ) + set( UNIX_APPLICATIONS_FILES ${UNIX_MIME_DIR}/applications ) + + # Install Mimelnk directory + install( DIRECTORY ${UNIX_MIMELNK_FILES} + DESTINATION ${CMAKE_INSTALL_PREFIX}/share + COMPONENT resources + ) + + # Install Mime directory + install( DIRECTORY ${UNIX_ICON_FILES} + DESTINATION ${CMAKE_INSTALL_PREFIX}/share + COMPONENT resources + ) + + # Install Icons + install( DIRECTORY ${UNIX_MIME_FILES} + DESTINATION ${CMAKE_INSTALL_PREFIX}/share + COMPONENT resources + ) + + # Install Applications directory (.desktop files) + install( DIRECTORY ${UNIX_APPLICATIONS_FILES} + DESTINATION ${CMAKE_INSTALL_PREFIX}/share + COMPONENT resources + ) +endif() + +#include( CTest ) + + +if( UNIX AND NOT APPLE ) + + # Create a *.deb file: + set( CPACK_GENERATOR "DEB" ) + set( CPACK_DEBIAN_PACKAGE_MAINTAINER "http://launchpad.net/kicad" ) + + set( CPACK_PACKAGE_VERSION_MAJOR 1 ) + set( CPACK_PACKAGE_VERSION_MINOR 0 ) + set( CPACK_PACKAGE_VERSION_PATCH 0 ) + #set( CPACK_PACKAGE_CONTACT Firstname Lastname <email@company.com> ) + set( CPACK_PACKAGE_DESCRIPTION_SUMMARY "KiCad built by CMake build system." ) + + include( CPack ) + +endif() |