summaryrefslogtreecommitdiffstats
Commit message (Collapse)AuthorAgeFilesLines
* Merge branch 'test-property-genex' into generate-modern-styleBrad King2013-09-207-25/+112
|\ | | | | | | | | | | Resolve conflict in Source/cmTestGenerator.cxx by taking "their" side (test-property-genex). It already accounts for the lower-case change in "our" side (generate-modern-style).
| * add_test: Mention generator expressions in old-style add_test docsBen Boeckel2013-09-201-1/+2
| | | | | | | | | | | | The old-style add_test() call does not support generator expressions at all. This also applies to the properties for the test, but it is not mentioned at all.
| * cmTestGenerator: Evaluate generator expressions in test propertiesBen Boeckel2013-09-206-3/+78
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is useful for cases like: add_test(NAME mytest COMMAND mydriver $<TARGET_FILE:myexe>) set_tests_properties(mytest PROPERTIES REQUIRED_FILES "$<TARGET_FILE:myexe>" WORKING_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/$<CONFIGURATION>" ) In this example we require the actual test executable to exist to run the test in addition to the test driver at argv[0]. Also the $<CONFIGURATION> expression improves over \${CTEST_CONFIGURATION_TYPE} because the latter is not normalized for case-sensitive filesystems.
| * cmTestGenerator: Separate test properties for each configurationBrad King2013-09-201-22/+33
| | | | | | | | | | | | | | | | | | | | | | | | Move property generation from GenerateScriptConfigs to separate copies in GenerateOldStyle and GenerateScriptForConfig. This causes the per-config tests generated for the add_test(NAME) signature to each get their own test properties. This will allow us to later change the property values based on the test configuration. While at it, generate lower-case CMake code (e.g. set_tests_properties). Inspired-by: Ben Boeckel <mathstuf@gmail.com>
* | Generate modern-style cmake code.Stephen Kelly2013-08-2215-136/+137
|/ | | | | | | | | | | The commits 9db31162 (Remove CMake-language block-end command arguments, 2012-08-13) and 77543bde (Convert CMake-language commands to lower case, 2012-08-13) changed most cmake code to use lowercase commands and no parameters in termination commands. However, those changes excluded cmake code generated in c++ by cmake. Make a similar style change to code generated by cmake.
* CMake Nightly Date StampKitware Robot2013-08-211-1/+1
|
* CMake Nightly Date StampKitware Robot2013-08-201-1/+1
|
* CMake Nightly Date StampKitware Robot2013-08-191-1/+1
|
* CMake Nightly Date StampKitware Robot2013-08-181-1/+1
|
* CMake Nightly Date StampKitware Robot2013-08-171-1/+1
|
* CMake Nightly Date StampKitware Robot2013-08-161-1/+1
|
* Merge topic 'cmake-syntax'Brad King2013-08-155-1/+7
|\ | | | | | | | | 9040ec9 Do not warn about left paren not separated by a space
| * Do not warn about left paren not separated by a spaceBrad King2013-08-155-1/+7
| | | | | | | | | | | | | | | | | | | | Since commit 58e52416 (Warn about arguments not separated by whitespace, 2013-02-16) we warn about arguments not separated by spaces. Loosen the warning to not complain about left parens not separated by spaces from the preceding token. This is common in code like "if(NOT(X))". Teach the RunCMake.Syntax test to cover cases of left parens not separated by spaces and check that no warning appears.
* | Merge topic 'osx-sysroot-default'Brad King2013-08-151-2/+14
|\ \ | | | | | | | | | | | | 335a127 OS X: Do not default to non-existent deployment target SDK
| * | OS X: Do not default to non-existent deployment target SDKBrad King2013-08-141-2/+14
| | | | | | | | | | | | | | | | | | | | | Since commit 95f78e08 (OS X: Search for SDK based on deployment target, 2013-08-02) we select the default OS X SDK path to match the deployment target. Fix this behavior in the case that the matching SDK does not exist and fall back to the SDK for the current host OS X version.
* | | CMake Nightly Date StampKitware Robot2013-08-151-1/+1
|/ /
* | Merge topic 'fix-new-policy-versions'Brad King2013-08-141-3/+3
|\ \ | | | | | | | | | | | | 07c16ee Update version introducing CMP0021, CMP0022, and CMP0023
| * | Update version introducing CMP0021, CMP0022, and CMP0023Brad King2013-08-141-3/+3
|/ / | | | | | | These policies will be first released in 2.8.12.
* | Merge topic 'cygwin-RunCMake-tests'Brad King2013-08-1436-36/+36
|\ \ | | | | | | | | | | | | d05a9bd Cygwin: Avoid legacy warnings in RunCMake.* tests
| * | Cygwin: Avoid legacy warnings in RunCMake.* testsBrad King2013-08-1336-36/+36
| | | | | | | | | | | | | | | | | | Set the minimum required version of CMake high enough to avoid the warning for CMAKE_LEGACY_CYGWIN_WIN32. The warning appears on stderr and breaks the expected output matching.
* | | Merge topic 'fix-genex-segfault'Brad King2013-08-143-1/+23
|\ \ \ | | | | | | | | | | | | | | | | 36eef30 Genex: Fix segfault when parsing ends with parameter expectation.
| * | | Genex: Fix segfault when parsing ends with parameter expectation.Stephen Kelly2013-08-133-1/+23
| | | | | | | | | | | | | | | | | | | | | | | | | | | | The extendResult method expects a non-empty parameters vector, as assured by the normal case. Avoid calling the method when the parser finds an incomplete generator expression, but has already entered the state of expecting to find parameters.
* | | | CMake Nightly Date StampKitware Robot2013-08-141-1/+1
| |/ / |/| |
* | | CMake Nightly Date StampKitware Robot2013-08-131-1/+1
| | |
* | | CMake Nightly Date StampKitware Robot2013-08-121-1/+1
| | |
* | | CMake Nightly Date StampKitware Robot2013-08-111-1/+1
|/ /
* | CMake Nightly Date StampKitware Robot2013-08-101-1/+1
| |
* | Merge topic 'revert-COMPILER_TARGET-feature'Brad King2013-08-094-21/+0
|\ \ | | | | | | | | | | | | b33c984 Revert "Add compiler target compile options."
| * | Revert "Add compiler target compile options."Stephen Kelly2013-08-094-21/+0
|/ / | | | | | | This reverts commit 2d9ec1dadfdd10043a98d425abb25d0aef117699.
* | CMake Nightly Date StampKitware Robot2013-08-091-1/+1
| |
* | Merge topic 'cmake-syntax'Brad King2013-08-0850-247/+651
|\ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | b93982f Merge branch 'dev/fix-variable-watch-crash' into cmake-syntax c50f7ed cmListFileLexer: Modify flex output to avoid Borland warning bf73264 Warn about unquoted arguments that look like long brackets 58e5241 Warn about arguments not separated by whitespace e75b69f cmListFileCache: Convert CMake language parser to class e945949 Add RunCMake.Syntax test cases for command invocation styles 0546484 cmListFileArgument: Generalize 'Quoted' bool to 'Delimeter' enum 28685ad cmListFileLexer: Split normal and legacy unquoted arguments 1eafa3e cmListFileLexer: Fix line number after backslash in string f3155cd Add RunCMake.Syntax test to cover argument parsing
| * \ Merge branch 'dev/fix-variable-watch-crash' into cmake-syntaxBrad King2013-08-087-86/+156
| |\ \ | | |/ | |/| | | | | | | Resolve conflict in Source/cmVariableWatchCommand.cxx by integrating the changes from both sides.
| * | cmListFileLexer: Modify flex output to avoid Borland warningBrad King2013-08-082-24/+25
| | | | | | | | | | | | | | | | | | Remove the "yyscanner = NULL" assignment from the end of the yylex_destroy function because Borland warns that the value is never used.
| * | Warn about unquoted arguments that look like long bracketsBrad King2013-08-085-0/+59
| | | | | | | | | | | | | | | | | | | | | | | | | | | In the future CMake will introduce Lua-style long bracket syntax. Warn about unquoted arguments that in the future will be treated as opening long brackets. Teach the RunCMake.Syntax test to cover such cases and ensure that the warning appears.
| * | Warn about arguments not separated by whitespaceBrad King2013-08-085-65/+119
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Teach the lexer to return tokens for whitespace. Teach the parser to tolerate the space tokens where whitespace is allowed. Also teach the parser to diagnose and warn about cases of quoted arguments followed immediately by another argument. This was accidentally allowed previously, so we only warn. Update the RunCMake.Syntax test case StringNoSpace expected stderr to include the warnings.
| * | cmListFileCache: Convert CMake language parser to classBrad King2013-08-081-69/+97
| | | | | | | | | | | | | | | Refactor the parser implementation into a class to make it easier to extend.
| * | Add RunCMake.Syntax test cases for command invocation stylesBrad King2013-08-0816-0/+74
| | | | | | | | | | | | | | | Cover commands with whitespace present in allowed combinations. Also cover command error cases such as two on one line.
| * | cmListFileArgument: Generalize 'Quoted' bool to 'Delimeter' enumBrad King2013-08-087-26/+38
| | | | | | | | | | | | | | | | | | Replace the boolean value that indicates whether an argument is unquoted or quoted with a generalized enumeration of possible argument types. For now "Quoted" and "Unquoted" remain the only types.
| * | cmListFileLexer: Split normal and legacy unquoted argumentsBrad King2013-08-082-78/+103
| | | | | | | | | | | | | | | Match legacy arguments separately. Add macros to simplify and clarify matching rules.
| * | cmListFileLexer: Fix line number after backslash in stringBrad King2013-08-086-148/+246
| | | | | | | | | | | | | | | | | | If a line inside a string ends in a backslash count the following newline character as a line increment. Add a test covering this case to verify that subsequent line numbers are correct.
| * | Add RunCMake.Syntax test to cover argument parsingBrad King2013-08-0819-0/+53
| | | | | | | | | | | | | | | | | | | | | Test basic unquoted and quoted argument parsing cases including failure on an unterminated string and an unterminated command invocation. Also cover arguments not separated by any spaces, which is accidentally allowed by the current parser.
* | | Merge topic 'dev/fix-variable-watch-crash'Brad King2013-08-087-86/+156
|\ \ \ | | |/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 6aa0c21 variable_watch: Add test for watching a variable multiple times b86e37c variable_watch: Check newValue for NULL f9bb20f variable_watch: Don't share memory for callbacks 05dad99 variable_watch: Fix a typo in the error message 00ce12a variable_watch: Prevent making extra entries in the watch map 34b397e variable_watch: Allow specifying the data to match in RemoveWatch e43e207 variable_watch: Match client_data when finding duplicates 0d6acb1 variable_watch: Add a deleter for the client data fc7c3b4 variable_watch: Store client data as pointers
| * | variable_watch: Add test for watching a variable multiple timesBen Boeckel2013-08-083-0/+14
| | |
| * | variable_watch: Check newValue for NULLBen Boeckel2013-08-081-1/+1
| | | | | | | | | | | | | | | On read access, newValue can be NULL since there is no new value, so use the empty string instead.
| * | variable_watch: Don't share memory for callbacksBen Boeckel2013-08-082-67/+87
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The command itself is owned by the cmMakefile class, but the cmVariableWatch which holds a pointer to the cmVariableWatchCommand via the client_data for the callback outlives the cmMakefile class in the Qt GUI. This means that when the cmMakefile is destroyed, the variable watch is still in effect, but with a stale pointer. To fix this, each callback is now a separate entity completely and doesn't rely on the command which spawned it at all. An example CMakeLists.txt which demonstrates the issue (only displayed in cmake-gui, so no tests can be written for it): set(var 0) variable_watch(var)
| * | variable_watch: Fix a typo in the error messageBen Boeckel2013-08-081-1/+1
| | | | | | | | | | | | There was no space between "callback" and the quoted command name.
| * | variable_watch: Prevent making extra entries in the watch mapBen Boeckel2013-08-081-0/+4
| | | | | | | | | | | | | | | | | | | | | When removing a watch on a variable, using the operator [] on the internal map will create an empty watch if the variable doesn't have any existing watches. Rather than creating this empty structure in the map, return if there isn't a watch on the variable already.
| * | variable_watch: Allow specifying the data to match in RemoveWatchBen Boeckel2013-08-082-3/+8
| | | | | | | | | | | | | | | Now that watches are dependent on their client_data when adding, it also makes sense to allow matching the data for removal.
| * | variable_watch: Match client_data when finding duplicatesBen Boeckel2013-08-082-6/+7
| | | | | | | | | | | | | | | | | | | | | | | | | | | If a callback has the same data as another call, we don't want to delete the old callback. This is because if the client_data is the same, it might get deleted causing the new client_data to be bogus. Now, AddWatch will return true if it will use the watch, false otherwise. Callers should check the return value to know whether client_data was adopted by the watch or not.
| * | variable_watch: Add a deleter for the client dataBen Boeckel2013-08-082-3/+14
| | | | | | | | | | | | | | | | | | The client data is arbitrary and the callback may be called an unspecified number of times, so the cmVariableWatch must be the one to delete the client data in the end (if it is needed at all).