cmStringAlgorithms.cxx 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. /* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
  2. file Copyright.txt or https://cmake.org/licensing for details. */
  3. #include "cmStringAlgorithms.h"
  4. #include <algorithm>
  5. #include <cstdio>
  6. std::string cmTrimWhitespace(cm::string_view str)
  7. {
  8. auto start = str.begin();
  9. while (start != str.end() && cmIsSpace(*start)) {
  10. ++start;
  11. }
  12. if (start == str.end()) {
  13. return std::string();
  14. }
  15. auto stop = str.end() - 1;
  16. while (cmIsSpace(*stop)) {
  17. --stop;
  18. }
  19. return std::string(start, stop + 1);
  20. }
  21. std::string cmEscapeQuotes(cm::string_view str)
  22. {
  23. std::string result;
  24. result.reserve(str.size());
  25. for (const char ch : str) {
  26. if (ch == '"') {
  27. result += '\\';
  28. }
  29. result += ch;
  30. }
  31. return result;
  32. }
  33. std::vector<std::string> cmTokenize(cm::string_view str, cm::string_view sep)
  34. {
  35. std::vector<std::string> tokens;
  36. cm::string_view::size_type tokend = 0;
  37. do {
  38. cm::string_view::size_type tokstart = str.find_first_not_of(sep, tokend);
  39. if (tokstart == cm::string_view::npos) {
  40. break; // no more tokens
  41. }
  42. tokend = str.find_first_of(sep, tokstart);
  43. if (tokend == cm::string_view::npos) {
  44. tokens.emplace_back(str.substr(tokstart));
  45. } else {
  46. tokens.emplace_back(str.substr(tokstart, tokend - tokstart));
  47. }
  48. } while (tokend != cm::string_view::npos);
  49. if (tokens.empty()) {
  50. tokens.emplace_back();
  51. }
  52. return tokens;
  53. }
  54. namespace {
  55. template <std::size_t N, typename T>
  56. inline void MakeDigits(cm::string_view& view, char (&digits)[N],
  57. const char* pattern, T value)
  58. {
  59. int res = std::snprintf(digits, N, pattern, value);
  60. if (res > 0 && res < static_cast<int>(N)) {
  61. view = cm::string_view(digits, static_cast<std::size_t>(res));
  62. }
  63. }
  64. } // unnamed namespace
  65. cmAlphaNum::cmAlphaNum(int val)
  66. {
  67. MakeDigits(View_, Digits_, "%i", val);
  68. }
  69. cmAlphaNum::cmAlphaNum(unsigned int val)
  70. {
  71. MakeDigits(View_, Digits_, "%u", val);
  72. }
  73. cmAlphaNum::cmAlphaNum(long int val)
  74. {
  75. MakeDigits(View_, Digits_, "%li", val);
  76. }
  77. cmAlphaNum::cmAlphaNum(unsigned long int val)
  78. {
  79. MakeDigits(View_, Digits_, "%lu", val);
  80. }
  81. cmAlphaNum::cmAlphaNum(long long int val)
  82. {
  83. MakeDigits(View_, Digits_, "%lli", val);
  84. }
  85. cmAlphaNum::cmAlphaNum(unsigned long long int val)
  86. {
  87. MakeDigits(View_, Digits_, "%llu", val);
  88. }
  89. cmAlphaNum::cmAlphaNum(float val)
  90. {
  91. MakeDigits(View_, Digits_, "%g", static_cast<double>(val));
  92. }
  93. cmAlphaNum::cmAlphaNum(double val)
  94. {
  95. MakeDigits(View_, Digits_, "%g", val);
  96. }
  97. std::string cmCatViews(std::initializer_list<cm::string_view> views)
  98. {
  99. std::size_t total_size = 0;
  100. for (cm::string_view const& view : views) {
  101. total_size += view.size();
  102. }
  103. std::string result(total_size, '\0');
  104. std::string::iterator sit = result.begin();
  105. for (cm::string_view const& view : views) {
  106. sit = std::copy_n(view.data(), view.size(), sit);
  107. }
  108. return result;
  109. }