RegexTest.cpp 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. //===- llvm/unittest/Support/RegexTest.cpp - Regex tests --===//
  2. //
  3. // The LLVM Compiler Infrastructure
  4. //
  5. // This file is distributed under the University of Illinois Open Source
  6. // License. See LICENSE.TXT for details.
  7. //
  8. //===----------------------------------------------------------------------===//
  9. #include "llvm/Support/Regex.h"
  10. #include "llvm/ADT/SmallVector.h"
  11. #include "gtest/gtest.h"
  12. #include <cstring>
  13. using namespace llvm;
  14. namespace {
  15. class RegexTest : public ::testing::Test {
  16. };
  17. TEST_F(RegexTest, Basics) {
  18. Regex r1("^[0-9]+$");
  19. EXPECT_TRUE(r1.match("916"));
  20. EXPECT_TRUE(r1.match("9"));
  21. EXPECT_FALSE(r1.match("9a"));
  22. SmallVector<StringRef, 1> Matches;
  23. Regex r2("[0-9]+");
  24. EXPECT_TRUE(r2.match("aa216b", &Matches));
  25. EXPECT_EQ(1u, Matches.size());
  26. EXPECT_EQ("216", Matches[0].str());
  27. Regex r3("[0-9]+([a-f])?:([0-9]+)");
  28. EXPECT_TRUE(r3.match("9a:513b", &Matches));
  29. EXPECT_EQ(3u, Matches.size());
  30. EXPECT_EQ("9a:513", Matches[0].str());
  31. EXPECT_EQ("a", Matches[1].str());
  32. EXPECT_EQ("513", Matches[2].str());
  33. EXPECT_TRUE(r3.match("9:513b", &Matches));
  34. EXPECT_EQ(3u, Matches.size());
  35. EXPECT_EQ("9:513", Matches[0].str());
  36. EXPECT_EQ("", Matches[1].str());
  37. EXPECT_EQ("513", Matches[2].str());
  38. Regex r4("a[^b]+b");
  39. std::string String="axxb";
  40. String[2] = '\0';
  41. EXPECT_FALSE(r4.match("abb"));
  42. EXPECT_TRUE(r4.match(String, &Matches));
  43. EXPECT_EQ(1u, Matches.size());
  44. EXPECT_EQ(String, Matches[0].str());
  45. std::string NulPattern="X[0-9]+X([a-f])?:([0-9]+)";
  46. String="YX99a:513b";
  47. NulPattern[7] = '\0';
  48. Regex r5(NulPattern);
  49. EXPECT_FALSE(r5.match(String));
  50. EXPECT_FALSE(r5.match("X9"));
  51. String[3]='\0';
  52. EXPECT_TRUE(r5.match(String));
  53. }
  54. TEST_F(RegexTest, Backreferences) {
  55. Regex r1("([a-z]+)_\\1");
  56. SmallVector<StringRef, 4> Matches;
  57. EXPECT_TRUE(r1.match("abc_abc", &Matches));
  58. EXPECT_EQ(2u, Matches.size());
  59. EXPECT_FALSE(r1.match("abc_ab", &Matches));
  60. Regex r2("a([0-9])b\\1c\\1");
  61. EXPECT_TRUE(r2.match("a4b4c4", &Matches));
  62. EXPECT_EQ(2u, Matches.size());
  63. EXPECT_EQ("4", Matches[1].str());
  64. EXPECT_FALSE(r2.match("a2b2c3"));
  65. Regex r3("a([0-9])([a-z])b\\1\\2");
  66. EXPECT_TRUE(r3.match("a6zb6z", &Matches));
  67. EXPECT_EQ(3u, Matches.size());
  68. EXPECT_EQ("6", Matches[1].str());
  69. EXPECT_EQ("z", Matches[2].str());
  70. EXPECT_FALSE(r3.match("a6zb6y"));
  71. EXPECT_FALSE(r3.match("a6zb7z"));
  72. }
  73. TEST_F(RegexTest, Substitution) {
  74. std::string Error;
  75. EXPECT_EQ("aNUMber", Regex("[0-9]+").sub("NUM", "a1234ber"));
  76. // Standard Escapes
  77. EXPECT_EQ("a\\ber", Regex("[0-9]+").sub("\\\\", "a1234ber", &Error));
  78. EXPECT_EQ(Error, "");
  79. EXPECT_EQ("a\nber", Regex("[0-9]+").sub("\\n", "a1234ber", &Error));
  80. EXPECT_EQ(Error, "");
  81. EXPECT_EQ("a\tber", Regex("[0-9]+").sub("\\t", "a1234ber", &Error));
  82. EXPECT_EQ(Error, "");
  83. EXPECT_EQ("ajber", Regex("[0-9]+").sub("\\j", "a1234ber", &Error));
  84. EXPECT_EQ(Error, "");
  85. EXPECT_EQ("aber", Regex("[0-9]+").sub("\\", "a1234ber", &Error));
  86. EXPECT_EQ(Error, "replacement string contained trailing backslash");
  87. // Backreferences
  88. EXPECT_EQ("aa1234bber", Regex("a[0-9]+b").sub("a\\0b", "a1234ber", &Error));
  89. EXPECT_EQ(Error, "");
  90. EXPECT_EQ("a1234ber", Regex("a([0-9]+)b").sub("a\\1b", "a1234ber", &Error));
  91. EXPECT_EQ(Error, "");
  92. EXPECT_EQ("aber", Regex("a[0-9]+b").sub("a\\100b", "a1234ber", &Error));
  93. EXPECT_EQ(Error, "invalid backreference string '100'");
  94. }
  95. }