diff options
author | Brad King <brad.king@kitware.com> | 2002-10-11 14:16:01 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2002-10-11 14:16:01 (GMT) |
commit | a8d038dbd0c64a22d35c10c71f4b59da1cadc3f4 (patch) | |
tree | c05672469848d0abde960c8af461216a60341142 | |
parent | 3d3d7a91469eb0f9bdababe3497849614ac99bb0 (diff) | |
download | CMake-a8d038dbd0c64a22d35c10c71f4b59da1cadc3f4.zip CMake-a8d038dbd0c64a22d35c10c71f4b59da1cadc3f4.tar.gz CMake-a8d038dbd0c64a22d35c10c71f4b59da1cadc3f4.tar.bz2 |
ENH: Added Split method to cmSystemTools to split a string into lines on its newlines.
-rw-r--r-- | Source/cmSystemTools.cxx | 28 | ||||
-rw-r--r-- | Source/cmSystemTools.h | 8 |
2 files changed, 34 insertions, 2 deletions
diff --git a/Source/cmSystemTools.cxx b/Source/cmSystemTools.cxx index 1941165..8bcaa84 100644 --- a/Source/cmSystemTools.cxx +++ b/Source/cmSystemTools.cxx @@ -1894,6 +1894,34 @@ std::string cmSystemTools::CollapseFullPath(const char* in_name) #endif } +bool cmSystemTools::Split(const char* str, std::vector<cmStdString>& lines) +{ + std::string data(str); + std::string::size_type lpos = 0; + while(lpos < data.length()) + { + std::string::size_type rpos = data.find_first_of("\n", lpos); + if(rpos == std::string::npos) + { + // Line ends at end of string without a newline. + lines.push_back(data.substr(lpos)); + return false; + } + if((rpos > lpos) && (data[rpos-1] == '\r')) + { + // Line ends in a "\r\n" pair, remove both characters. + lines.push_back(data.substr(lpos, (rpos-1)-lpos)); + } + else + { + // Line ends in a "\n", remove the character. + lines.push_back(data.substr(lpos, rpos-lpos)); + } + lpos = rpos+1; + } + return true; +} + /** * Return path of a full filename (no trailing slashes). * Warning: returned path is converted to Unix slashes format. diff --git a/Source/cmSystemTools.h b/Source/cmSystemTools.h index 04806cd..879f5c8 100644 --- a/Source/cmSystemTools.h +++ b/Source/cmSystemTools.h @@ -218,11 +218,11 @@ public: ///! Find a file in the system PATH, with optional extra paths. static std::string FindFile(const char* name, - const std::vector<std::string>& path= std::vector<std::string>()); + const std::vector<std::string>& path= std::vector<std::string>()); ///! Find an executable in the system PATH, with optional extra paths. static std::string FindProgram(const char* name, - const std::vector<std::string>& path = std::vector<std::string>(), + const std::vector<std::string>& path = std::vector<std::string>(), bool no_system_path = false); ///! Find a library in the system PATH, with optional extra paths. @@ -293,6 +293,10 @@ public: static void EnableRunCommandOutput() {s_DisableRunCommandOutput = false; } static bool GetRunCommandOutput() { return s_DisableRunCommandOutput; } + /** Split a string on its newlines into multiple lines. Returns + false only if the last line stored had no newline. */ + static bool Split(const char* str, std::vector<cmStdString>& lines); + /** * Come constants for different file formats. */ |