StringView.cpp 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. #include <AK/AKString.h>
  2. #include <AK/StringView.h>
  3. namespace AK {
  4. StringView::StringView(const String& string)
  5. : m_impl(string.impl())
  6. , m_characters(string.characters())
  7. , m_length(string.length())
  8. {
  9. }
  10. StringView::StringView(const ByteBuffer& buffer)
  11. : m_characters((const char*)buffer.data())
  12. , m_length(buffer.size())
  13. {
  14. }
  15. Vector<StringView> StringView::split_view(const char separator) const
  16. {
  17. if (is_empty())
  18. return {};
  19. Vector<StringView> v;
  20. ssize_t substart = 0;
  21. for (ssize_t i = 0; i < length(); ++i) {
  22. char ch = characters_without_null_termination()[i];
  23. if (ch == separator) {
  24. ssize_t sublen = i - substart;
  25. if (sublen != 0)
  26. v.append(substring_view(substart, sublen));
  27. substart = i + 1;
  28. }
  29. }
  30. ssize_t taillen = length() - substart;
  31. if (taillen != 0)
  32. v.append(substring_view(substart, taillen));
  33. if (characters_without_null_termination()[length() - 1] == separator)
  34. v.append(String::empty());
  35. return v;
  36. }
  37. StringView StringView::substring_view(int start, int length) const
  38. {
  39. if (!length)
  40. return {};
  41. ASSERT(start + length <= m_length);
  42. return { m_characters + start, length };
  43. }
  44. StringView StringView::substring_view_starting_from_substring(const StringView& substring) const
  45. {
  46. const char* remaining_characters = substring.characters_without_null_termination();
  47. ASSERT(remaining_characters >= m_characters);
  48. ASSERT(remaining_characters <= m_characters + m_length);
  49. int remaining_length = m_length - (remaining_characters - m_characters);
  50. return { remaining_characters, remaining_length };
  51. }
  52. StringView StringView::substring_view_starting_after_substring(const StringView& substring) const
  53. {
  54. const char* remaining_characters = substring.characters_without_null_termination() + substring.length();
  55. ASSERT(remaining_characters >= m_characters);
  56. ASSERT(remaining_characters <= m_characters + m_length);
  57. int remaining_length = m_length - (remaining_characters - m_characters);
  58. return { remaining_characters, remaining_length };
  59. }
  60. int StringView::to_int(bool& ok) const
  61. {
  62. bool negative = false;
  63. int value = 0;
  64. int i = 0;
  65. if (is_empty()) {
  66. ok = false;
  67. return 0;
  68. }
  69. if (characters_without_null_termination()[0] == '-') {
  70. i++;
  71. negative = true;
  72. }
  73. for (; i < length(); i++) {
  74. if (characters_without_null_termination()[i] < '0' || characters_without_null_termination()[i] > '9') {
  75. ok = false;
  76. return 0;
  77. }
  78. value = value * 10;
  79. value += characters_without_null_termination()[i] - '0';
  80. }
  81. ok = true;
  82. return negative ? -value : value;
  83. }
  84. unsigned StringView::to_uint(bool& ok) const
  85. {
  86. unsigned value = 0;
  87. for (ssize_t i = 0; i < length(); ++i) {
  88. if (characters_without_null_termination()[i] < '0' || characters_without_null_termination()[i] > '9') {
  89. ok = false;
  90. return 0;
  91. }
  92. value = value * 10;
  93. value += characters_without_null_termination()[i] - '0';
  94. }
  95. ok = true;
  96. return value;
  97. }
  98. unsigned StringView::hash() const
  99. {
  100. if (is_empty())
  101. return 0;
  102. if (m_impl)
  103. return m_impl->hash();
  104. return string_hash(characters_without_null_termination(), length());
  105. }
  106. }