diff options
author | Marc Chevrier <marc.chevrier@gmail.com> | 2021-08-15 13:27:47 (GMT) |
---|---|---|
committer | Marc Chevrier <marc.chevrier@gmail.com> | 2021-08-19 08:49:30 (GMT) |
commit | 2984df91002fe3e3db0d38f364e9842024a8ab2e (patch) | |
tree | f7b14050b6beddd7d828e7ed0e90491b6eb17922 | |
parent | 5917b6277fc171fc61d0b277af9bf5950915f863 (diff) | |
download | CMake-2984df91002fe3e3db0d38f364e9842024a8ab2e.zip CMake-2984df91002fe3e3db0d38f364e9842024a8ab2e.tar.gz CMake-2984df91002fe3e3db0d38f364e9842024a8ab2e.tar.bz2 |
Refactor: cmHasPrefix and cmHasSuffix accept now cmProp
-rw-r--r-- | Source/cmStringAlgorithms.h | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/Source/cmStringAlgorithms.h b/Source/cmStringAlgorithms.h index 531678a..20061e9 100644 --- a/Source/cmStringAlgorithms.h +++ b/Source/cmStringAlgorithms.h @@ -291,6 +291,16 @@ inline bool cmHasPrefix(cm::string_view str, cm::string_view prefix) } /** Returns true if string @a str starts with string @a prefix. */ +inline bool cmHasPrefix(cm::string_view str, cmProp prefix) +{ + if (!prefix) { + return false; + } + + return str.compare(0, prefix->size(), prefix) == 0; +} + +/** Returns true if string @a str starts with string @a prefix. */ template <size_t N> inline bool cmHasLiteralPrefix(cm::string_view str, const char (&prefix)[N]) { @@ -311,6 +321,17 @@ inline bool cmHasSuffix(cm::string_view str, cm::string_view suffix) } /** Returns true if string @a str ends with string @a suffix. */ +inline bool cmHasSuffix(cm::string_view str, cmProp suffix) +{ + if (!suffix) { + return false; + } + + return str.size() >= suffix->size() && + str.compare(str.size() - suffix->size(), suffix->size(), suffix) == 0; +} + +/** Returns true if string @a str ends with string @a suffix. */ template <size_t N> inline bool cmHasLiteralSuffix(cm::string_view str, const char (&suffix)[N]) { |