aboutsummaryrefslogtreecommitdiffstats
path: root/cmake/dists
diff options
context:
space:
mode:
authortobigun <tobigun@b956fd51-792f-4845-bead-9b4dfca2ff2c>2009-05-11 19:59:01 +0000
committertobigun <tobigun@b956fd51-792f-4845-bead-9b4dfca2ff2c>2009-05-11 19:59:01 +0000
commit3bac1f9c6c02cbe30f4fbed37366482fcc687e03 (patch)
tree3549fe136d4843db1856c190060d73dc7325ef4f /cmake/dists
parent17deba0bcda7f39696bad713bc2c0bc49ec4fb59 (diff)
downloadusdx-3bac1f9c6c02cbe30f4fbed37366482fcc687e03.tar.gz
usdx-3bac1f9c6c02cbe30f4fbed37366482fcc687e03.tar.xz
usdx-3bac1f9c6c02cbe30f4fbed37366482fcc687e03.zip
- Package flags (FLAGS / LIBRARY_FLAGS)
- -k"-U sdl_main" for Mac OS X defined as SDL package LIBRARY_FLAG - plugins moved to game/plugins - BUILD_PLUGINS option added to disable plugin creation (if linking of libraries fails) - PASCAL_FLAGS_... added git-svn-id: svn://svn.code.sf.net/p/ultrastardx/svn/branches/experimental@1722 b956fd51-792f-4845-bead-9b4dfca2ff2c
Diffstat (limited to '')
-rw-r--r--cmake/dists/cmake/Modules/FindPPC.cmake315
-rw-r--r--cmake/dists/cmake/Modules/UsePascal.cmake100
-rw-r--r--cmake/dists/gentoo/ultrastardx-9999.ebuild24
3 files changed, 298 insertions, 141 deletions
diff --git a/cmake/dists/cmake/Modules/FindPPC.cmake b/cmake/dists/cmake/Modules/FindPPC.cmake
index 3f82b720..2c4f2da3 100644
--- a/cmake/dists/cmake/Modules/FindPPC.cmake
+++ b/cmake/dists/cmake/Modules/FindPPC.cmake
@@ -7,195 +7,282 @@
# - Find Pascal compiler
#
# This module defines
-# PPC_FOUND, If false, do not try to use PPC.
-
-##
-# Find FreePascal executable
-##
-
-set(PPC_BIN_PATH
- "$ENV{SystemDrive}/fpc/*/bin/*"
- "$ENV{ProgramFiles}/fpc/*/bin/*"
- "$ENV{SystemDrive}/lazarus/fpc/*/bin/*"
- "$ENV{ProgramFiles}/lazarus/fpc/*/bin/*"
-)
-find_program(PPC fpc PATHS ${PPC_BIN_PATH})
+# PPC_FOUND: If false, do not try to use PPC.
+# PASCAL_COMPILER_TYPE: Either FPC or DELPHI (latter not yet supported)
+# PASCAL_COMPILER_WORKS: True if the compiler works
+# PASCAL_FLAGS_...: Some default flags for several build types
+# PASCAL_FLAGS
+# PASCAL_LIBRARY_FLAGS
+# PASCAL_FLAGS_DEBUG
+# PASCAL_FLAGS_RELEASE
+# PASCAL_FLAGS_RELWITHDEBINFO
+# PASCAL_FLAGS_MINSIZEREL
+# PASCAL_LIBRARY_BUILD_WORKS: Compiler/linker combination is able to build libraries.
+# PASCAL_LIBRARY_SUFFIX: Library suffix (e.g. .dll or .so)
+# PASCAL_LIBRARY_PREFIX: Library prefix (e.g. lib)
+# FPC_PLATFORM: Target platform (OS): linux, freebsd, openbsd, netbsd, darwin, win32, ...
+# FPC_PROCESSOR: Target processor (CPU): i386, x86_64, powerpc, arm
+# FPC_CPLATFORM: Compiler platform (OS)
+# FPC_CPROCESSOR: Compiler processor (CPU)
+# FPC_TARGET: String "FPC_PROCESSOR-FPC_PLATFORM"
##
# Get FPC compiler info
##
-set(PPC_CHECK_DIR ${CMAKE_BINARY_DIR}/ppc_check)
+set(current_pkg PPC)
+set(ppc_check_dir ${CMAKE_BINARY_DIR}/ppc_check)
-# - creates file with code in PPC_CHECK_DIR and compiles it with
+# - creates file with code in ppc_check_dir and compiles it with
# the given flags. The result will be stored in result_var.
-# If NO_CLEAN is given, the PPC_CHECK_DIR will not be removed
+# If NO_CLEAN is given, the ppc_check_dir will not be removed
# after the check.
#
-# PPC_CHECK(file code flags result_var NO_CLEAN)
+# ppc_check(file code flags result_var NO_CLEAN)
#
-function(PPC_CHECK file code flags result_var)
+function(ppc_check file code flags result_var)
# create compiler check directory
- file(MAKE_DIRECTORY ${PPC_CHECK_DIR})
+ file(MAKE_DIRECTORY ${ppc_check_dir})
- file(WRITE ${PPC_CHECK_DIR}/${file} "${code}")
+ file(WRITE ${ppc_check_dir}/${file} "${code}")
execute_process(
- COMMAND ${PPC} ${flags} ${file}
- WORKING_DIRECTORY ${PPC_CHECK_DIR}
+ COMMAND ${PASCAL_COMPILER} ${flags} ${file}
+ WORKING_DIRECTORY ${ppc_check_dir}
RESULT_VARIABLE check_result
- ERROR_QUIET
- OUTPUT_QUIET)
+ ERROR_VARIABLE check_output
+ OUTPUT_VARIABLE check_output
+ )
# remove compiler check directory
list(FIND ARGN "NO_CLEAN" no_clean)
-
if(no_clean EQUAL -1)
- file(REMOVE_RECURSE ${PPC_CHECK_DIR})
- endif(no_clean EQUAL -1)
+ file(REMOVE_RECURSE ${ppc_check_dir})
+ endif()
+
+ list(FIND ARGN "SHOW_ERROR" show_error)
+ if(show_error GREATER -1)
+ if(check_result AND NOT ${current_pkg}_FIND_QUIETLY)
+ message("${check_output}")
+ endif()
+ endif()
set(${result_var} ${check_result} PARENT_SCOPE)
-endfunction(PPC_CHECK)
+endfunction(ppc_check)
# use a foreach statement so we can leave this section with break()
# if an error occurs.
foreach(once 1)
- set(PPC_WORKS)
- set(PPC_ERROR)
+ # clear error message
+ set(ppc_error)
+
+ # skip tests if compiler was previously found
+ if(PASCAL_COMPILER_WORKS)
+ break()
+ endif(PASCAL_COMPILER_WORKS)
- if(NOT PPC)
- set(PPC_ERROR "Executable not found")
+ # Find FreePascal executable
+ set(ppc_bin_path
+ "$ENV{SystemDrive}/fpc/*/bin/*"
+ "$ENV{ProgramFiles}/fpc/*/bin/*"
+ "$ENV{SystemDrive}/lazarus/fpc/*/bin/*"
+ "$ENV{ProgramFiles}/lazarus/fpc/*/bin/*"
+ )
+ find_program(PASCAL_COMPILER fpc PATHS ${ppc_bin_path})
+ if(NOT PASCAL_COMPILER)
+ set(ppc_error "Executable not found")
break()
- endif(NOT PPC)
+ endif(NOT PASCAL_COMPILER)
+
+ if(NOT ${current_pkg}_FIND_QUIETLY)
+ message(STATUS "Check for working Pascal compiler: ${PASCAL_COMPILER}")
+ endif(NOT ${current_pkg}_FIND_QUIETLY)
# retrieve FPC version
- execute_process(COMMAND ${PPC} -iV
+ execute_process(COMMAND ${PASCAL_COMPILER} -iV
OUTPUT_VARIABLE FPC_VERSION
OUTPUT_STRIP_TRAILING_WHITESPACE)
# check version
- if(PPC_FIND_VERSION_EXACT)
- if(NOT FPC_VERSION VERSION_EQUAL PPC_FIND_VERSION)
- set(PPC_ERROR "Required =${PPC_FIND_VERSION} but found ${FPC_VERSION}")
+ if(${current_pkg}_FIND_VERSION_EXACT)
+ if(NOT FPC_VERSION VERSION_EQUAL ${current_pkg}_FIND_VERSION)
+ set(ppc_error "Required =${${current_pkg}_FIND_VERSION} but found ${FPC_VERSION}")
break()
- endif(NOT FPC_VERSION VERSION_EQUAL PPC_FIND_VERSION)
- endif(PPC_FIND_VERSION_EXACT)
- if(PPC_FIND_VERSION)
- if(FPC_VERSION VERSION_LESS PPC_FIND_VERSION)
- set(PPC_ERROR "Required >=${PPC_FIND_VERSION} but found ${FPC_VERSION}")
+ endif(NOT FPC_VERSION VERSION_EQUAL ${current_pkg}_FIND_VERSION)
+ endif(${current_pkg}_FIND_VERSION_EXACT)
+ if(${current_pkg}_FIND_VERSION)
+ if(FPC_VERSION VERSION_LESS ${current_pkg}_FIND_VERSION)
+ set(ppc_error "Required >=${${current_pkg}_FIND_VERSION} but found ${FPC_VERSION}")
break()
- endif(FPC_VERSION VERSION_LESS PPC_FIND_VERSION)
- endif(PPC_FIND_VERSION)
+ endif(FPC_VERSION VERSION_LESS ${current_pkg}_FIND_VERSION)
+ endif(${current_pkg}_FIND_VERSION)
# retrieve FPC platform info
- execute_process(COMMAND ${PPC} -iTO
+ execute_process(COMMAND ${PASCAL_COMPILER} -iTO
OUTPUT_VARIABLE FPC_PLATFORM
OUTPUT_STRIP_TRAILING_WHITESPACE)
- execute_process(COMMAND ${PPC} -iTP
+ execute_process(COMMAND ${PASCAL_COMPILER} -iTP
OUTPUT_VARIABLE FPC_PROCESSOR
OUTPUT_STRIP_TRAILING_WHITESPACE)
- execute_process(COMMAND ${PPC} -iSO
+ execute_process(COMMAND ${PASCAL_COMPILER} -iSO
OUTPUT_VARIABLE FPC_CPLATFORM
OUTPUT_STRIP_TRAILING_WHITESPACE)
- execute_process(COMMAND ${PPC} -iSP
+ execute_process(COMMAND ${PASCAL_COMPILER} -iSP
OUTPUT_VARIABLE FPC_CPROCESSOR
OUTPUT_STRIP_TRAILING_WHITESPACE)
set(FPC_TARGET "${FPC_PROCESSOR}-${FPC_PLATFORM}")
-
- #-v -l verbose/banner
- #-n ignore fpc.cfg
- #-Fi -I include-dir
- #-k
- #-Fl linker-dir
- #-Fo -Fu object-/unit-dir
- #-Xt -Xc
- #-Ciort range checks
- #-Cs -Ch stack/heap size
- #-Cg -fPIC PIC code
- #-E
- #-g -gv -gw(2/3) -gh -gl -pg
- #-O
- #-T -Xd -XP cross-compiling
- #-d -u define/undefine
- #-Xs strip
- #-B build all modules
- #-Dd -Dv description + DLL-version
-
- #PFLAGS_BASE_DEFAULT := -Si -Sg- -Sc- -v0Binwe
- #PFLAGS_DEBUG_DEFAULT := -Xs- -g -gl -dDEBUG_MODE
- #PFLAGS_RELEASE_DEFAULT := -Xs- -O2
-
##
# Compiler checks
##
- set(default_flags "")
+ set(check_flags "-l -v0ie")
# check whether FPC works and can compile a program
- ppc_check(simple.pas "program simple;\nbegin\nend."
- "${default_flags}" check_result)
+ ppc_check(simple.pas "program simple;\nbegin\nend."
+ "${check_flags}" check_result SHOW_ERROR)
if(check_result)
- set(PPC_ERROR "Cannot compile simple test-program")
+ set(ppc_error "Cannot compile simple test-program")
break()
endif(check_result)
# check if FPC can link with standard libraries
ppc_check(link.pas "program link;\nuses SysUtils;\nbegin\nWriteLn('Test');\nend."
- "${default_flags}" check_result)
+ "${check_flags}" check_result SHOW_ERROR)
if(check_result)
- set(PPC_ERROR "Cannot link with standard libraries")
+ set(ppc_error "Cannot link with standard libraries")
break()
endif(check_result)
- # check whether FPC's linker knows (or at least doesn't crash with)
- # "-z noexecstack"
+ # check whether FPC's linker knows (or at least doesn't crash with) "-z noexecstack".
# FPC does not set the NX-flag on stack memory. Binaries generated with FPC
# might crash on platforms that require the stack to be non-executable.
# So we will try to find a workaround here.
# See http://bugs.freepascal.org/view.php?id=11563
- set(noexecstack_flags -k"-z noexecstack")
ppc_check(noexecstack.pas "program noexecstack;\nbegin\nend."
- "${default_flags} ${noexecstack_flags}" check_result)
- if(check_result)
- set(noexecstack_flags)
- endif(check_result)
+ "${check_flags};-k-z noexecstack" check_result)
+ if(NOT check_result)
+ set(noexecstack_flag "-k\"-z noexecstack\"")
+ endif(NOT check_result)
- # check prefixes and suffixes
+ # check if compiler is able to build libraries
+ set(lib_build_works TRUE)
ppc_check(testlib.pas "library link;\nbegin\nend."
- "${default_flags}" check_result
+ "${check_flags}" check_result
NO_CLEAN)
- # find generated library
- find_library(PPC_TEST_LIBPATH testlib
- PATHS ${PPC_CHECK_DIR}
- NO_DEFAULT_PATH)
- # do not show library name in GUI
- mark_as_advanced(PPC_TEST_LIBPATH)
- # extract prefix and suffix from library name
- if(PPC_TEST_LIBPATH)
- get_filename_component(PPC_LIBRARY_SUFFIX ${PPC_TEST_LIBPATH} EXT CACHE)
- get_filename_component(libfilename ${PPC_TEST_LIBPATH} NAME_WE)
- string(REGEX REPLACE "^(.*)testlib.*" "\\1" PPC_LIBRARY_PREFIX ${libfilename})
- endif(PPC_TEST_LIBPATH)
- # remove library test directory
- file(REMOVE_RECURSE ${PPC_CHECK_DIR})
if(check_result)
- set(PPC_ERROR "Cannot link with standard libraries")
- break()
- endif(check_result)
+ # The linker (ld) cannot link the library. Ubuntu with ld 2.19.1
+ # is known to fail here because of a bug so do not break here.
+ if(NOT ${current_pkg}_FIND_QUIETLY)
+ message(STATUS "Pascal compiler cannot build shared libraries!")
+ endif(NOT ${current_pkg}_FIND_QUIETLY)
+ set(lib_build_works FALSE)
+ else(check_result)
+ # find generated library
+ find_library(PASCAL_TESTLIB_PATH testlib
+ PATHS ${ppc_check_dir}
+ NO_DEFAULT_PATH)
+ # do not show library name in GUI
+ mark_as_advanced(PASCAL_TESTLIB_PATH)
+ # extract prefix and suffix from library name
+ if(PASCAL_TESTLIB_PATH)
+ get_filename_component(lib_suffix ${PASCAL_TESTLIB_PATH} EXT)
+ get_filename_component(testlib_filename ${PASCAL_TESTLIB_PATH} NAME_WE)
+ string(REGEX REPLACE "^(.*)testlib.*" "\\1" lib_prefix ${testlib_filename})
+ mark_as_advanced(PASCAL_LIBRARY_PREFIX PASCAL_LIBRARY_SUFFIX)
+ endif(PASCAL_TESTLIB_PATH)
- ##
- # Check results
- ##
+ # set cache entries
+ set(PASCAL_LIBRARY_SUFFIX ${lib_suffix} CACHE STRING "Pascal library suffix.")
+ set(PASCAL_LIBRARY_PREFIX ${lib_prefix} CACHE STRING "Pascal library prefix.")
+ endif(check_result)
+ # remove test directory
+ file(REMOVE_RECURSE ${ppc_check_dir})
- #set(PFLAGS ${noexecstack_flags} "-B" "-FE../bin" "-Cs2000000" "-vwi" "-O2" "-Fl/opt/local/lib" ${hwengine_project})
+ # cache results
+ set(PASCAL_COMPILER_WORKS TRUE CACHE INTERNAL "")
+ set(PASCAL_LIBRARY_BUILD_WORKS ${lib_build_works} CACHE INTERNAL "")
+ set(PASCAL_COMPILER_TYPE FPC CACHE INTERNAL "")
- set(PPC_WORKS TRUE)
+ if(NOT ${current_pkg}_FIND_QUIETLY)
+ message(STATUS "Check for working Pascal compiler: ${PASCAL_COMPILER} -- works")
+ endif(NOT ${current_pkg}_FIND_QUIETLY)
endforeach(once)
-# handle the QUIETLY and REQUIRED arguments and set PPC_FOUND to TRUE if
-# all listed variables are TRUE
-INCLUDE(FindPackageHandleStandardArgs)
-FIND_PACKAGE_HANDLE_STANDARD_ARGS(PPC "Could NOT find PPC: ${PPC_ERROR}!" PPC PPC_WORKS)
+##
+# Set Flags
+##
+
+# default flags.
+# Notes:
+# - The flags defined in fpc.cfg are evaluated first in a first pass.
+# This also applies those flags that are enabled by defining -dDEBUG or -dRELEASE.
+# In a second pass all command line options are evaluated.
+# This way all flags defined in fpc.cfg can be undefined with -<flag>-
+# - FPC strips binaries by default. Stripping binaries is considered bad style,
+# for example Gentoo reacts to stripped binaries with a quality warning.
+# In addition the cmake installer strips the binaries if required.
+# Disable stripping with -Xs-.
+set(PASCAL_FLAGS
+ "-Xs- -v0Binwe ${noexecstack_flag}"
+ CACHE STRING "Flags used by the Pascal compiler during all build types.")
+separate_arguments(PASCAL_FLAGS)
+
+# default library flags. Some Linux distribution's security policies require -fPIC,
+# otherwise linking will fail.
+if(UNIX)
+ # FPC supports PIC for Darwin and Linux/x86_64 but Linux/i386 is broken with 2.2.2.
+ # See http://community.freepascal.org:10000/bboards/message?message_id=314214&forum_id=24092
+ if(NOT FPC_PLATFORM STREQUAL linux OR NOT FPC_PROCESSOR STREQUAL i386)
+ set(PIC_flag "-fPIC")
+ endif()
+endif(UNIX)
+set(PASCAL_LIBRARY_FLAGS
+ "${PIC_flag}"
+ CACHE STRING "Flags used by the Pascal compiler during library builds.")
+separate_arguments(PASCAL_LIBRARY_FLAGS)
+
+# Some debug flags to keep in mind: -gv -gw(2/3) -gh -pg
+set(debug_info_flags "-g -gl")
+
+# default debug flags. Define DEBUG but remove some ill-suited flags set in fpc.cfg (-Crtoi).
+set(PASCAL_FLAGS_DEBUG
+ "-dDEBUG -Cr-t-o-i- ${debug_info_flags}"
+ CACHE STRING "Flags used by the Pascal compiler during debug builds.")
+separate_arguments(PASCAL_FLAGS_DEBUG)
+
+set(release_base_flags "-dRELEASE -vn-")
+
+# default release flags. Define RELEASE but remove some ill-suited flags set in fpc.cfg (-Xs)
+# Enable optimization, reduce verbosity by disabling notes.
+set(PASCAL_FLAGS_RELEASE
+ "${release_base_flags} -O2"
+ CACHE STRING "Flags used by the Pascal compiler during release builds.")
+separate_arguments(PASCAL_FLAGS_RELEASE)
+
+set(PASCAL_FLAGS_RELWITHDEBINFO
+ "${release_base_flags} -O2 ${debug_info_flags}"
+ CACHE STRING "Flags used by the Pascal compiler during Release with Debug Info builds.")
+separate_arguments(PASCAL_FLAGS_RELWITHDEBINFO)
+
+set(PASCAL_FLAGS_MINSIZEREL
+ "${release_base_flags} -Os"
+ CACHE STRING "Flags used by the Pascal compiler during release minsize builds.")
+separate_arguments(PASCAL_FLAGS_MINSIZEREL)
+
+##
+# set PPC_FOUND and show error messages
+##
-mark_as_advanced(PPC)
+set(fail_message "No working Pascal compiler found: ${ppc_error}!")
+if(PASCAL_COMPILER_WORKS)
+ set(${current_pkg}_FOUND TRUE)
+else(PASCAL_COMPILER_WORKS)
+ if(${current_pkg}_FIND_REQUIRED)
+ message(FATAL_ERROR "${fail_message}")
+ else(${current_pkg}_FIND_REQUIRED)
+ if(NOT ${current_pkg}_FIND_QUIETLY)
+ message(STATUS "${fail_message}")
+ endif(NOT ${current_pkg}_FIND_QUIETLY)
+ endif(${current_pkg}_FIND_REQUIRED)
+endif(PASCAL_COMPILER_WORKS)
diff --git a/cmake/dists/cmake/Modules/UsePascal.cmake b/cmake/dists/cmake/Modules/UsePascal.cmake
index e3c3612b..7a7ade08 100644
--- a/cmake/dists/cmake/Modules/UsePascal.cmake
+++ b/cmake/dists/cmake/Modules/UsePascal.cmake
@@ -11,12 +11,19 @@
# (mostly used for header files).
# This information will be appended to a module generated by
# add_pascal_module() if a package is specified with the PACKAGE
-# option.
+# option.
+# You can pass additional compiler flags with
+# <COMPILER>_FLAGS (for all module types) and
+# <COMPILER>_LIBRARY_FLAGS (for libraries only)
+# where <COMPILER> must be either FPC or DELPHI.
# PASCAL_ADD_PACKAGE(
# <name>
# [UNITS file1 [...]]
# [INCLUDES file1 [...]]
# [OBJECT_DIRS dir1 [...]]
+# [<COMPILER>_FLAGS ...]
+# [<COMPILER>_LIBRARY_FLAGS]
+# )
#
# - Builds a Pascal module.
# The module can be a program, library or unit. The type is either autodetected
@@ -46,16 +53,18 @@
# Units/includes used by packages specified by the PACKAGES option do not have to be specified
# again with UNITS/INCLUDES. Package sources are not appended to auto-generated project files
# for lazarus.
+# You can pass additional compiler flags with <COMPILER>_FLAGS where <COMPILER>
+# must be one of FPC or DELPHI.
# Sets target properties:
-# - PASCAL_TYPE: module type (one of PROGRAM/LIBRARY/UNIT)
-# - PASCAL_LOCATION: full path of output file (equivalent to LOCATION)
+# - PASCAL_TYPE: module type (one of PROGRAM/LIBRARY/UNIT)
+# - PASCAL_LOCATION: full path of output file (equivalent to LOCATION)
# PASCAL_ADD_MODULE(
# <name>
# [PROGRAM | LIBRARY | UNIT]
# <main_source>
# [OUTPUT_NAME name]
# [OUTPUT_DIR dir]
-# [FLAGS ...]
+# [<COMPILER>_FLAGS ...]
# [DEPENDS depend [...]]
# [UNITS file1 [...]]
# [INCLUDES file1 [...]]
@@ -79,13 +88,22 @@ include(LazarusGenerator)
option(GENERATE_LAZARUS_PROJECTS "Generate lazarus project files (.lpi) for every Pascal target" OFF)
function(PASCAL_ADD_PACKAGE name)
+ # setup a list of property names to copy from the arguments
+ set(prop_list)
+ list(APPEND prop_list OBJECT_DIRS)
+ foreach(comp FPC DELPHI)
+ list(APPEND prop_list ${comp}_FLAGS ${comp}_LIBRARY_FLAGS)
+ endforeach(comp)
+
+ # parse arguments
set(ARG)
parse_arguments(ARG
- "UNITS;INCLUDES;OBJECT_DIRS"
+ "UNITS;INCLUDES;${prop_list}"
""
${ARGN}
)
+ # transform file paths to absolute paths
set(unit_abs_list)
foreach(unit ${ARG_UNITS})
get_filename_component(unit_abs ${unit} ABSOLUTE)
@@ -97,16 +115,19 @@ function(PASCAL_ADD_PACKAGE name)
list(APPEND inc_abs_list ${inc_abs})
endforeach(inc)
+ # store info in global properties
set_property(GLOBAL PROPERTY PASCAL_PKG_${name}_EXISTS TRUE)
set_property(GLOBAL PROPERTY PASCAL_PKG_${name}_UNITS "${unit_abs_list}")
set_property(GLOBAL PROPERTY PASCAL_PKG_${name}_INCLUDES "${inc_abs_list}")
- set_property(GLOBAL PROPERTY PASCAL_PKG_${name}_OBJECT_DIRS "${ARG_OBJECT_DIRS}")
+ foreach(prop ${prop_list})
+ set_property(GLOBAL PROPERTY PASCAL_PKG_${name}_${prop} "${ARG_${prop}}")
+ endforeach(prop)
endfunction(PASCAL_ADD_PACKAGE)
macro(PASCAL_ADD_MODULE)
set(ARG)
- parse_arguments(ARG
- "OUTPUT_NAME;OUTPUT_DIR;FLAGS;DEPENDS;UNITS;INCLUDES;OBJECT_DIRS;PACKAGES"
+ parse_arguments(ARG
+ "OUTPUT_NAME;OUTPUT_DIR;DEPENDS;UNITS;INCLUDES;OBJECT_DIRS;PACKAGES;FPC_FLAGS;DELPHI_FLAGS"
"EXCLUDE_FROM_ALL;REBUILD_ALL"
${ARGN}
)
@@ -197,7 +218,7 @@ macro(PASCAL_ADD_MODULE)
list(APPEND extra_clean_files ${output})
endif(type STREQUAL PROGRAM)
if(type STREQUAL LIBRARY)
- set(output "${output_dir}/${PPC_LIBRARY_PREFIX}${output_name}${PPC_LIBRARY_SUFFIX}")
+ set(output "${output_dir}/${PASCAL_LIBRARY_PREFIX}${output_name}${PASCAL_LIBRARY_SUFFIX}")
list(APPEND extra_clean_files ${output})
endif(type STREQUAL LIBRARY)
if(type STREQUAL UNIT)
@@ -212,6 +233,24 @@ macro(PASCAL_ADD_MODULE)
# set working dir
set(work_dir ${CMAKE_CURRENT_SOURCE_DIR})
+ # assemble pascal compiler flags
+ set(pflags ${PASCAL_FLAGS})
+ if(type STREQUAL LIBRARY)
+ list(APPEND pflags ${PASCAL_LIBRARY_FLAGS})
+ endif(type STREQUAL LIBRARY)
+ if(CMAKE_BUILD_TYPE STREQUAL Release)
+ list(APPEND pflags ${PASCAL_FLAGS_RELEASE})
+ elseif(CMAKE_BUILD_TYPE STREQUAL Debug)
+ list(APPEND pflags ${PASCAL_FLAGS_DEBUG})
+ elseif(CMAKE_BUILD_TYPE STREQUAL RelWithDebInfo)
+ list(APPEND pflags ${PASCAL_FLAGS_RELWITHDEBINFO})
+ elseif(CMAKE_BUILD_TYPE STREQUAL MinSizeRelDebug)
+ list(APPEND pflags ${PASCAL_FLAGS_MINSIZEREL})
+ endif()
+
+ # set target specific flags
+ list(APPEND pflags ${ARG_${PASCAL_COMPILER_TYPE}_FLAGS})
+
# init unit/include/object dir list
set(unit_dirs "")
set(inc_dirs "")
@@ -219,23 +258,39 @@ macro(PASCAL_ADD_MODULE)
# add packages
foreach(pkg ${ARG_PACKAGES})
+ # check existence
set(pkg_exists)
get_property(pkg_exists GLOBAL PROPERTY PASCAL_PKG_${pkg}_EXISTS)
if(NOT pkg_exists)
message(FATAL_ERROR "Unknown pascal package \"${pkg}\". See pascal_add_package().")
endif(NOT pkg_exists)
+ # append package units
set(pkg_units)
get_property(pkg_units GLOBAL PROPERTY PASCAL_PKG_${pkg}_UNITS)
list(APPEND units ${pkg_units})
+ # append package includes
set(pkg_incs)
get_property(pkg_incs GLOBAL PROPERTY PASCAL_PKG_${pkg}_INCLUDES)
list(APPEND incs ${pkg_incs})
+ # append package object dirs
set(pkg_obj_dirs)
get_property(pkg_obj_dirs GLOBAL PROPERTY PASCAL_PKG_${pkg}_OBJECT_DIRS)
list(APPEND obj_dirs ${pkg_obj_dirs})
+
+ # append package flags
+ set(pkg_flags)
+ get_property(pkg_flags GLOBAL PROPERTY PASCAL_PKG_${pkg}_${PASCAL_COMPILER_TYPE}_FLAGS)
+ list(APPEND pflags ${pkg_flags})
+
+ # append package library flags if appropriate
+ if(type STREQUAL LIBRARY)
+ set(pkg_lib_flags)
+ get_property(pkg_lib_flags GLOBAL PROPERTY PASCAL_PKG_${pkg}_${PASCAL_COMPILER_TYPE}_LIBRARY_FLAGS)
+ list(APPEND pflags ${pkg_lib_flags})
+ endif(type STREQUAL LIBRARY)
endforeach(pkg ${ARG_PACKAGES})
# add unit/include/object dirs passed as macro parameter
@@ -279,8 +334,7 @@ macro(PASCAL_ADD_MODULE)
# add *.pas/*.pp of each unit-dir and *.inc of each inc-dir
# to the depends list
set(depends)
- list(APPEND depends ${units})
- list(APPEND depends ${incs})
+ list(APPEND depends ${units} ${incs})
# check if we are to add the target to ALL
set(custom_target_all "ALL")
@@ -290,12 +344,16 @@ macro(PASCAL_ADD_MODULE)
# check if even unchanged units should be rebuild
if(ARG_REBUILD_ALL)
- list(APPEND PFLAGS -B)
+ # Note that the -B (build all modules) option does not work if not all
+ # unit-directories the project uses are passed with the -Fu flag.
+ # Sources in directories not given with -Fu (even if listed in the dpr/lpr file)
+ # are never recompiled.
+ # As a safer method clean the unit-output directory instead but keep
+ # the -B flag for lazarus project files as it does not hurt.
+ set(unit_out_clean COMMAND ${CMAKE_COMMAND} -E remove_directory ${unit_out_dir})
+ list(APPEND pflags -B)
endif(ARG_REBUILD_ALL)
- # set flags
- list(APPEND PFLAGS ${ARG_FLAGS})
-
# lower-case project type (just for user info)
string(TOLOWER ${type} proj_type_lowcase)
@@ -309,12 +367,11 @@ macro(PASCAL_ADD_MODULE)
add_custom_command(
OUTPUT ${target_timestamp}
# delete and create units dir (needed for proper update)
-# COMMAND ${CMAKE_COMMAND} -E remove_directory ${unit_out_dir}
+ ${unit_out_clean}
COMMAND ${CMAKE_COMMAND} -E make_directory ${unit_out_dir}
# build
- COMMAND ${PPC}
-# -l- -vi-
- ${PFLAGS}
+ COMMAND ${PASCAL_COMPILER}
+ ${pflags}
${dir_flag_list}
-FU${unit_out_dir}
-o${output}
@@ -328,7 +385,8 @@ macro(PASCAL_ADD_MODULE)
)
# add target
- add_custom_target(${target} ${custom_target_all}
+ add_custom_target(${target}
+ ${custom_target_all}
COMMENT "Checking dependencies of target ${target}"
DEPENDS ${target_timestamp}
)
@@ -350,7 +408,7 @@ macro(PASCAL_ADD_MODULE)
"${ARG_INCLUDES}"
"${inc_dirs}"
"${obj_dirs}"
- "${PFLAGS}"
+ "${pflags}"
)
endif(GENERATE_LAZARUS_PROJECTS)
endmacro(PASCAL_ADD_MODULE)
diff --git a/cmake/dists/gentoo/ultrastardx-9999.ebuild b/cmake/dists/gentoo/ultrastardx-9999.ebuild
index 7b092919..b1ffb5a4 100644
--- a/cmake/dists/gentoo/ultrastardx-9999.ebuild
+++ b/cmake/dists/gentoo/ultrastardx-9999.ebuild
@@ -2,7 +2,7 @@
# Distributed under the terms of the GNU General Public License v2
# $Header $
-inherit subversion eutils games
+inherit subversion cmake-utils games
SONGS_PKG=USDX-SongPackage
SONGS_VER=01
@@ -34,7 +34,7 @@ RDEPEND="virtual/opengl
projectm? ( media-libs/libprojectm )"
DEPEND="${RDEPEND}
dev-util/pkgconfig
- >=dev-lang/fpc-2.2.0"
+ >=dev-lang/fpc-2.2.2"
S=${WORKDIR}/${P}-src
@@ -50,10 +50,22 @@ src_unpack() {
}
src_compile() {
- egamesconf \
- $(use_with projectm libprojectM) \
- $(use_enable debug) \
- || die
+ if use projectm ; then
+ enable_projectm="ON"
+ else
+ enable_projectm="OFF"
+ fi
+ if use debug ; then
+ build_type="Debug"
+ else
+ build_type="Release"
+ fi
+ cmake \
+ -DCMAKE_BUILD_TYPE=$build_type \
+ -DENABLE_PROJECTM=$enable_projectm \
+ -DCMAKE_INSTALL_PREFIX="/usr" \
+ . \
+ || die "cmake failed"
emake || die "emake failed"
}