summaryrefslogtreecommitdiffstats
path: root/Source/cmMakefile.cxx
Commit message (Collapse)AuthorAgeFilesLines
* Use quotes for non-system includesDaniel Pfeifer2017-04-111-2/+2
| | | | | | | | | | | | | Automate with: git grep -l '#include <cm_' -- Source \ | xargs sed -i 's/#include <\(cm_.*\)>/#include "\1"/g' git grep -l '#include <cmsys/' -- Source \ | xargs sed -i 's/#include <\(cmsys\/.*\)>/#include "\1"/g' git grep -l '#include <cm[A-Z]' -- Source \ | xargs sed -i 's/#include <\(cm[A-Z].*\)>/#include "\1"/g'
* cmMakefile: Create an explicit "Object Libraries" source groupBrad King2017-04-111-0/+16
| | | | | The generators should not need special logic to place object library object files in this group.
* Add self-sufficient wrapper for <sys/stat.h>Daniel Pfeifer2017-03-241-0/+1
|
* Merge topic 'master'Brad King2017-03-091-0/+17
|\ | | | | | | | | | | | | | | | | | | d9bdcf34 Tests: Add x32 tests to test suite 5b6d354f Help: Add notes for topic 'x32-abi' bed9c73d Modules: Add x32-abi support to hard-coded paths 462cf254 Add support for x32-abi Acked-by: Kitware Robot <kwrobot@kitware.com> Merge-request: !532
| * Add support for x32-abiSteven Newbury2017-03-071-0/+17
| | | | | | | | | | | | | | | | Detect x32-abi through CMakeCompilerABI infrastruture and use this information at runtime to determine the correct library paths with `FIND_LIBRARY_USE_LIBX32_PATHS`. Fixes: #15994
* | cmWorkingDirectory: use the new classBen Boeckel2017-03-061-9/+2
|/ | | | | | These functions just need to change the directory for a block of code and then go back to the caller's expected location. Use cmWorkingDirectory to ensure that all return paths are handled.
* Merge topic '16615-xcode-object-libraries-depends'Brad King2017-02-241-2/+4
|\ | | | | | | | | | | | | | | | | 624021a0 Add test for object library dependencies 5da9266a Xcode: Always track object library dependencies via hacky Makefile e80ac953 Xcode: Record dependency information also for object libraries 9293e57d Xcode: Collect dummy rules during iteration and emit afterwards 33a1d727 Makefile: Allow adding post-build rules to object libraries
| * Makefile: Allow adding post-build rules to object librariesGregor Jasny2017-02-221-2/+4
| |
* | Merge topic 'fix-CMP0017-path-case'Brad King2017-02-201-1/+1
|\ \ | |/ |/| | | | | e2d78f75 Windows: Fix inconsistent behavior on changes to case of path to cmake
| * Windows: Fix inconsistent behavior on changes to case of path to cmakeBrad King2017-02-171-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In commit v3.4.0-rc1~333^2 (Merge branch 'upstream-kwsys' into update-kwsys, 2015-07-15) we brought in upstream KWSys commit 86a24794 (SystemTools: Fix GetActualCaseForPath drive letter case handling, 2015-07-09). This caused our path processing to convert drive letters to upper-case and exposed an existing bug in our implementation of CMP0017. Policy CMP0017 is responsible for ensuring that modules included from a builtin module only load other builtin modules and cannot be overridden by a file in `CMAKE_MODULE_PATH`. If there is a case difference in the drive letter (or other path components) then the path to the including module may not match our builtin module directory in a simple string comparison. This means builtin modules may not be recognized as such, and they may not reliably include their builtin dependencies. For example, if a project provides a `Platform/Windows` module in `CMAKE_MODULE_PATH` it can break inclusion of our builtin `Platform/Windows` module, leading to strange behavior. Fix this by comparing the path to the including module to our builtin module directory using a function that is aware of case-insensitivity of paths on Windows. Fixes: #16648, #16622
* | cmCommand: Don't prefix error message with command nameDaniel Pfeifer2017-02-131-1/+2
| | | | | | | | | | Instead, prefix the error message at the two places where the errors are handled: cmMakefile and cmCTestHandlerCommand.
* | cmAlgorithms: add cmEraseIf functionDaniel Pfeifer2017-02-101-11/+2
|/
* add_custom_{command,target}: Add COMMAND_EXPAND_LISTS optionEd Branch2017-01-141-8/+14
| | | | | | This option allows lists generated by generator expressions to be expanded. Closes: #15935
* Fix typo in error message on missing required variableBrad King2016-12-161-1/+1
| | | | Reported-by: Albrecht Schlosser <AlbrechtS.fltk@online.de>
* clang-tidy: apply readability-redundant-string-init fixesDaniel Pfeifer2016-12-121-2/+2
|
* Merge topic 'try_compile-lang-std'Brad King2016-12-071-6/+10
|\ | | | | | | | | | | | | f72ba42b try_compile: Add policy CMP0067 to honor language standards 45aa03b9 try_compile: Add options to specify language standards 3bb2051e try_compile: Stop processing when test build system fails to generate
| * try_compile: Stop processing when test build system fails to generateBrad King2016-12-061-6/+10
| | | | | | | | | | | | Failing to generate the build system of the test project is a failure to compute the result of the test compilation, and so must be treated as any other CMake Error and stop processing.
* | Features: Add infrastructure for C++ 17 language standardBrad King2016-12-021-7/+26
|/ | | | Issue: #16468
* CUDA: C++ compile features now enable cuda c++11 support.Robert Maynard2016-11-141-0/+3
|
* Fix several include-what-you-use findingsDaniel Pfeifer2016-11-081-14/+14
|
* Remove cmCommand::Enabled and all related accessorsDaniel Pfeifer2016-10-241-1/+1
| | | | | Enabled is never set to false. Remove the member variable and all related getters and setters.
* cmState: Split auxiliary classes into separate filesStephen Kelly2016-10-191-0/+2
| | | | | | | Port dependents to the new locations as needed. Leave behind a cmState.h include in cmListFileCache to reduce noise. It is removed in a following commit.
* cmState: Port dependents to new cmStateTypes headerStephen Kelly2016-10-191-1/+1
|
* cmState: Port dependent code to new cmStateSnapshot nameStephen Kelly2016-10-191-6/+6
|
* cmState: Move CacheEntryType enum to separate namespaceStephen Kelly2016-10-191-7/+8
| | | | Port dependent code to the change.
* cmState: Move TargetType enum to separate namespaceStephen Kelly2016-10-191-22/+25
|
* Merge topic 'clean-up-link-configuration'Brad King2016-10-101-92/+55
|\ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | a1cfc4fe cmMakefile: Simplify programmer error to an assert 4079ba20 cmMakefile: Implement LinkLibraries as an internal property 17ab8e33 cmMakefile: Inline method into only remaining caller 7edfcd0e cmMakefile: Inline method into caller 6c8dc7f1 cmake: Simplify find-package mode library addition 1efca9f4 cmMakefile: Remove obsolete parameter d9b5f0a3 cmTarget: Remove target name from parameter list 1c70c6cc cmMakefile: Use public API to find a target 2b7baed7 cmMakefile: Inline method into only caller 7ba95492 cmMakefile: Use public API to find a target 6d98b15f cmMakefile: Invert if() condition to remove else 869037ee cmMakefile: Remove ALIAS check 2f6462a6 cmMakefile: Collapse two consecutive if()s into one 148b83a1 cmMakefile: DeMorgan-invert condition 4457a9f1 cmMakefile: Return after error and remove else condition 4d039c5b cmMakefile: Invert handling of error condition ...
| * cmMakefile: Simplify programmer error to an assertStephen Kelly2016-10-071-8/+3
| |
| * cmMakefile: Implement LinkLibraries as an internal propertyStephen Kelly2016-10-071-28/+47
| | | | | | | | | | | | | | | | | | cmMakefile should not have logic particular to individual cmake commands. The link_libraries() command is generally obsolete in favor of target_link_libraries(). An alternative language for CMake probably would not offer the former. The quirks and historical behaviors of the current language should be separate from the core classes of CMake to allow replacing the language.
| * cmMakefile: Inline method into only remaining callerStephen Kelly2016-10-071-29/+0
| |
| * cmMakefile: Remove obsolete parameterStephen Kelly2016-10-071-4/+3
| |
| * cmTarget: Remove target name from parameter listStephen Kelly2016-10-071-3/+3
| | | | | | | | Use the member state instead.
| * cmMakefile: Use public API to find a targetStephen Kelly2016-10-071-3/+3
| |
| * cmMakefile: Inline method into only callerStephen Kelly2016-10-071-14/+0
| | | | | | | | | | cmMakefile should not have API which is only useful for deprecated systems like cmPluginAPI.
| * cmMakefile: Use public API to find a targetStephen Kelly2016-10-071-3/+4
| |
| * cmMakefile: Invert if() condition to remove elseStephen Kelly2016-10-071-3/+3
| |
| * cmMakefile: Remove ALIAS checkStephen Kelly2016-10-071-7/+0
| | | | | | | | | | This method is only called from the cmPlugin API, which predates ALIAS targets and is obsolete.
| * cmMakefile: Collapse two consecutive if()s into oneStephen Kelly2016-10-071-14/+11
| |
| * cmMakefile: DeMorgan-invert conditionStephen Kelly2016-10-071-4/+4
| |
| * cmMakefile: Return after error and remove else conditionStephen Kelly2016-10-071-17/+18
| |
| * cmMakefile: Invert handling of error conditionStephen Kelly2016-10-071-6/+6
| |
| * cmMakefile: Remove superfluous overloadStephen Kelly2016-10-071-5/+0
| | | | | | | | Explicit is better than implicit.
| * cmMakefile: Remove useless link directory containerStephen Kelly2016-10-071-4/+1
| | | | | | | | It is never populated - a find will never find anything.
| * cmTarget: Inline MergeLinkLibraries into only callerStephen Kelly2016-10-071-1/+10
| |
* | cmMakefile: Remove pointless conditionStephen Kelly2016-10-091-4/+2
|/ | | | This method is never called with an empty string.
* project: Fix support for explicit RC languageBrad King2016-09-281-1/+20
| | | | | | | | | | | | | | | The check added in commit v3.6.0-rc1~293^2 (Diagnose recursive project/enable_language without crashing, 2016-03-07) broke support for enabling `RC` explicitly along with other languages like `C`. The reason is that we enable all listed languages at once so the internal `enable_language(RC)` that we do while enabling `C` or `CXX` on some platforms triggers the recursion check if `RC` is explicitly listed. Ideally we should refactor things to only enable one language at a time, but for now it is simplest to just exclude `RC` from the explicit list until other languages are enabled, and then enable it. Closes: #16330
* Simplify CMake per-source license noticesBrad King2016-09-271-11/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | Per-source copyright/license notice headers that spell out copyright holder names and years are hard to maintain and often out-of-date or plain wrong. Precise contributor information is already maintained automatically by the version control tool. Ultimately it is the receiver of a file who is responsible for determining its licensing status, and per-source notices are merely a convenience. Therefore it is simpler and more accurate for each source to have a generic notice of the license name and references to more detailed information on copyright holders and full license terms. Our `Copyright.txt` file now contains a list of Contributors whose names appeared source-level copyright notices. It also references version control history for more precise information. Therefore we no longer need to spell out the list of Contributors in each source file notice. Replace CMake per-source copyright/license notice headers with a short description of the license and links to `Copyright.txt` and online information available from "https://cmake.org/licensing". The online URL also handles cases of modules being copied out of our source into other projects, so we can drop our notices about replacing links with full license text. Run the `Utilities/Scripts/filter-notices.bash` script to perform the majority of the replacements mechanically. Manually fix up shebang lines and trailing newlines in a few files. Manually update the notices in a few files that the script does not handle.
* cmState: Record buildsystem target names in each directoryBrad King2016-09-191-0/+1
| | | | | | Maintain in the directory state the list of target names added to be built. These are normal, non-imported targets (but do include INTERFACE libraries).
* cmTarget: Construct with basic information up frontBrad King2016-09-141-8/+8
| | | | | Avoid having partially constructed cmTarget instances around, except for the special case of GLOBAL_TARGET construction.
* Avoid requiring default cmTarget constructor for map indexingBrad King2016-09-141-2/+3
| | | | | | The `std::map<>` index operator requires a default constructor on the value type. Avoid requiring a default constructor on `cmTarget` just for this purpose.