diff options
author | Andy Cedilnik <andy.cedilnik@kitware.com> | 2005-07-21 19:54:57 (GMT) |
---|---|---|
committer | Andy Cedilnik <andy.cedilnik@kitware.com> | 2005-07-21 19:54:57 (GMT) |
commit | a2acc029ae743c6b485b99a168b54b73e1a8494f (patch) | |
tree | 7993d15616b284cc1323243a8a53d42854e2b15f /Source | |
parent | 3074513009c5a9064f97be170067f7db5cbe9c01 (diff) | |
download | CMake-a2acc029ae743c6b485b99a168b54b73e1a8494f.zip CMake-a2acc029ae743c6b485b99a168b54b73e1a8494f.tar.gz CMake-a2acc029ae743c6b485b99a168b54b73e1a8494f.tar.bz2 |
ENH: Add support for detecting files that were removed
Diffstat (limited to 'Source')
-rw-r--r-- | Source/CTest/cmCTestUpdateHandler.cxx | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/Source/CTest/cmCTestUpdateHandler.cxx b/Source/CTest/cmCTestUpdateHandler.cxx index 6983d21..7f2f524 100644 --- a/Source/CTest/cmCTestUpdateHandler.cxx +++ b/Source/CTest/cmCTestUpdateHandler.cxx @@ -520,6 +520,9 @@ int cmCTestUpdateHandler::ProcessHandler() // Even though it failed, we may have some useful information. Try to continue... std::vector<cmStdString> lines; cmSystemTools::Split(goutput.c_str(), lines); + std::vector<cmStdString> errLines; + cmSystemTools::Split(errors.c_str(), errLines); + lines.insert(lines.end(), errLines.begin(), errLines.end()); // CVS style regular expressions cmsys::RegularExpression cvs_date_author_regex("^date: +([^;]+); +author: +([^;]+); +state: +[^;]+;"); @@ -531,6 +534,7 @@ int cmCTestUpdateHandler::ProcessHandler() cmsys::RegularExpression svn_status_line_regex("^ *([0-9]+) *([0-9]+) *([^ ]+) *([^ ][^\t\r\n]*)[ \t\r\n]*$"); cmsys::RegularExpression svn_latest_revision_regex("(Updated to|At) revision ([0-9]+)\\."); + cmsys::RegularExpression file_removed_line("cvs update: `(.*)' is no longer in the repository"); cmsys::RegularExpression file_update_line("([A-Z]) *(.*)"); std::string current_path = "<no-path>"; bool first_file = true; @@ -562,9 +566,15 @@ int cmCTestUpdateHandler::ProcessHandler() cmCTestLog(m_CTest, HANDLER_OUTPUT, " Gathering version information (each . represents one updated file):" << std::endl); int file_count = 0; + std::string removed_line; for ( cc= 0 ; cc < lines.size(); cc ++ ) { const char* line = lines[cc].c_str(); + if ( file_removed_line.find(line) ) + { + removed_line = "D " + file_removed_line.match(1); + line = removed_line.c_str(); + } if ( file_update_line.find(line) ) { if ( file_count == 0 ) @@ -575,6 +585,11 @@ int cmCTestUpdateHandler::ProcessHandler() std::string upChar = file_update_line.match(1); std::string upFile = file_update_line.match(2); char mod = upChar[0]; + bool removed = false; + if ( mod != 'D' ) + { + removed = true; + } bool modifiedOrConflict = false; if ( mod != 'M' && mod != 'C' && mod != 'G' ) { @@ -761,6 +776,10 @@ int cmCTestUpdateHandler::ProcessHandler() comment1 = "Locally modified file\n"; sauthor1 = "Local User"; } + if ( mod == 'R' ) + { + comment1 = "Removed file\n"; + } if ( mod == 'C' ) { comment1 = "Conflict while updating\n"; |