- Apr 15, 2015
-
-
Steffen Müthing authored
The check for a correct cmake_minimum_version already happened in dune_enable_all_packages, so let's avoid spamming the user...
-
Steffen Müthing authored
The library support in dune_enable_all_packages (more specifically, the ability to add source files to an existing library target with dune_library_add_sources) relies on target_sources, which only exists in CMake 3.1+. To avoid confusing users, this patch emits a meaningful error for older versions of CMake and generates a warning for more recent versions. This warning can be disabled by defining DUNE_ENABLE_ALL_PACKAGES_SILENCE_LIBRARY_WARNING.
-
- Apr 08, 2015
-
-
Steffen Müthing authored
dune_enable_all_packages() doesn't really work if a module contains libraries (it triggers CMP022 and CMP038). This patch works around that problem and also adds a number of convenience features to the overall mechanism. In particular: - dune_enable_all_packages() now accepts optional lists of additional include directories and compile definitions that will be applied to all targets in the module. There is a new option APPEND that controls the placement of those compiler arguments, analogous to dune_register_package_flags(). - Libraries need special handling to work around the problem with the two CMake policies listed above. Those get triggered because libraries defined in the module ended up linking to themselves, and newer versions of CMake really don't like that. We can avoid this problem by exploiting the fact that the set of libraries contained in link_libraries is evaluated only once, at the point when a target is created. So we only have to make sure that libraries inside the module are created before they are added to link_libraries(). But we have to be careful to make sure that link_libraries() is called before the user creates any targets that depend on the module library. In order to minimize the risk of user error, I have integrated those two tasks (creating the library and adding it to link_libraries()) into the dune_enable_all_packages() macro. So this macro now accepts a list of library names (as the multi argument MODULE_LIBRARIES). These are automatically created using dune_add_library() (placing them in lib/) in the order that they are listed and added to link_libraries() afterwards. Users MUST use this mechanism if they want the library to be linked automatically to programs in the module. On the other hand, you can still manually create libraries, but then you have to link to them manually (e.g. the Alberta libs in dune-grid). - There is a new macro dune_library_add_sources() that can be used to add source files to libraries created with the help of dune_enable_all_packages(). That macro can be called repeatedly and in any subdirectory of the source tree. Using this facility, I think we can mostly get rid of OBJECT libraries. :-) - CMake doesn't like to create a target without any source files, so the patch generates a small stub source for each library that contains two functions that are named after the library and return the version of the associated dune module.
-
Steffen Müthing authored
-
Steffen Müthing authored
CMake exports the major and minor components of the module version, but not the revision. This patch fixes that omission.
-
- Apr 01, 2015
-
-
Steffen Müthing authored
* master: Allow enabling dune_symlink_to_source_tree from the opts file Fix dune_symlink_to_source_tree for cmake 3.1
-
Dominic Kempf authored
Patching the dune core modules just to have the advantages of symlinks to the source tree is a bad idea. The patch introduces a check for the variable DUNE_SYMLINK_TO_SOURCE_TREE instead, which enables the macro if set.
-
Dominic Kempf authored
CMake 3.1 issued a lot of warnings because it tried to symlink: - git specific subdirs that are not present in the build tree - build directories that are a subdir of the source instead of a sibling The change - adds a symlink iff a CMakeLists file was found in the source dir. - excludes such build directory.
-
Steffen Müthing authored
* master: (82 commits) [Type] Fix documentation of DuneSymlinkOrCopy [CMake][CPack] Set some basic CPack wariables for tarballs. [CMake] Don't search for malloc.h, stdint.h and memory. [CMake] Don't output twice that we generate Doxyfile.in. [CMake] Doxygen ignores existens of doc/doxygen/html/index.html in src [duneproject] use CMake variable for install dir [duneproject] fix typos in README [duneproject] remove empty lines at beginning and end of generated files [Autotools] Install DuneSymlinkOrCopy.cmake [CMake] install DuneSymlinkOrCopy.cmake [Cmake][bugfix] Still do the header globbing [Cmake][bugfix] Fix error in making headercheck configurable [CMake] make the headercheck feature configurable [bugfix] fix typos in add_dune_library [cleanup] Replace or and not by || and !. [m4] fix mixup when using autools/cmake 2.4 + an installed 2.3 [bugfix] inlcude header algorithm to pass headercheck [dunecontrol] check for left over la files [reservedvector] allow to construct a reserved vector from an initializer_list Document new option --current-dep on the man page ...
-
- Mar 24, 2015
-
-
Dominic Kempf authored
-
- Mar 22, 2015
-
-
Christoph Grüninger authored
Tarballs can be built using "make package_source". But they contain all files from the source directory. There is a way to ignore files.
-
- Mar 20, 2015
-
-
Christoph Grüninger authored
We assume anyway that stdint.h and memrory are provided. The according macros are never used. They were probably provided to stay as compatible to Autotools as possible. This fixes FS#1605.
-
- Mar 18, 2015
-
-
Christoph Grüninger authored
It is already printed as the comment of the custom command.
-
Christoph Grüninger authored
-
The install path for header files can be configured in CMake with the variable ${CMAKE_INSTALL_INCLUDEDIR}.
-
-
-
- Mar 17, 2015
-
-
Christoph Grüninger authored
Similar to last commit: This macro was split off from DuneMacros.cmake in commit e63ea0cf, but the new macro file was not included in the list of installed modules.
-
This macro was split off from DuneMacros.cmake in commit e63ea0cf, but the new macro file was not included in the list of installed macros.
-
- Mar 16, 2015
-
-
Dominic Kempf authored
It seems the exclusion macros need to have a full list of headers to work. This is hopefully the last commit...
-
Dominic Kempf authored
The property must exist in order to have the exclusion macros work. I only tested dune common which has no exclusions... Thanks to Andreas Buhr for noticing!
-
Dominic Kempf authored
As proposed in FS1584, make headercheck is now disabled by default in cmake. This fact and how to enable it is printed upon "make headercheck".
-
Dominic Kempf authored
Apparently, that code never for executed/tested...
-
- Mar 15, 2015
-
-
Christoph Grüninger authored
-
- Mar 14, 2015
-
-
Christian Engwer authored
Ich a module is not updated to cmake yet, we can have the situation, that the core modules are built using cmake, but used by autotools. When trying to detect a dune library, we either explicitly stated the /blablabla/libdunefoo.la file if the the dependency was built using autools, or used the '-ldunefoo -L/blablabla/' options. This failed with very subtle errors if dune was also installed globally, e.g. a 2.3 from your favorite distribution. We fix this now in the same way as we fixed it for autotools. If the module is local, we explicitly state the lib... either as .la or as .a.
-
- Mar 13, 2015
-
-
Christoph Grüninger authored
-
Tobias Malkmus authored
-
- Mar 12, 2015
-
-
Christian Engwer authored
if the user has for some reason old la files from the autotools era, these can lead to very subtle and hard to understand errors. We now check for old la files and bail out in case some are found.
-
Christian Engwer authored
-
- Mar 11, 2015
-
-
Dominic Kempf authored
-
Oliver Sander authored
-
- Mar 10, 2015
-
-
Christoph Grüninger authored
Together with the last patch, this fixes FS#1592.
-
-
Steffen Müthing authored
[Typetraits][Compatibility] Provide partial backwards compatibility for is_indexable on old GCC versions Older GCC versions have some nasty bugs related to SFINAE and indexing with operator[]. This patch adds a configuration check for those problems and a partial backwards compatibility hack for those older compilers that is sufficient for our current use case in the VTK writer.
-
Steffen Müthing authored
GCC 4.4, I'm looking at you
-
Steffen Müthing authored
-
Steffen Müthing authored
is_indexable can be used to test whether a type can be indexed (via operator[]).
-
- Mar 07, 2015
-
-
Martin Nolte authored
Previously, the command vcsetup, which is executed on command 'all', was not listed on the help screen.
-
- Mar 06, 2015
-
-
Dominic Kempf authored
The file DuneMacros.cmake is very crowded. Macros that belong together should be placed in a separate module in order to increase the visibility of its documentation IMO.
-
- Mar 05, 2015
-
-
Christian Engwer authored
This reverts commit 9f9bc5c0. see FS#1576
-