|  | //===-- Regex.h - Regular Expression matcher implementation -*- C++ -*-----===// | 
|  | // | 
|  | //                     The LLVM Compiler Infrastructure | 
|  | // | 
|  | // This file is distributed under the University of Illinois Open Source | 
|  | // License. See LICENSE.TXT for details. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  | // | 
|  | // This file implements a POSIX regular expression matcher.  Both Basic and | 
|  | // Extended POSIX regular expressions (ERE) are supported.  EREs were extended | 
|  | // to support backreferences in matches. | 
|  | // This implementation also supports matching strings with embedded NUL chars. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  |  | 
|  | #ifndef LLVM_SUPPORT_REGEX_H | 
|  | #define LLVM_SUPPORT_REGEX_H | 
|  |  | 
|  | #include <string> | 
|  |  | 
|  | struct llvm_regex; | 
|  |  | 
|  | namespace llvm { | 
|  | class StringRef; | 
|  | template<typename T> class SmallVectorImpl; | 
|  |  | 
|  | class Regex { | 
|  | public: | 
|  | enum { | 
|  | NoFlags=0, | 
|  | /// Compile for matching that ignores upper/lower case distinctions. | 
|  | IgnoreCase=1, | 
|  | /// Compile for newline-sensitive matching. With this flag '[^' bracket | 
|  | /// expressions and '.' never match newline. A ^ anchor matches the | 
|  | /// null string after any newline in the string in addition to its normal | 
|  | /// function, and the $ anchor matches the null string before any | 
|  | /// newline in the string in addition to its normal function. | 
|  | Newline=2, | 
|  | /// By default, the POSIX extended regular expression (ERE) syntax is | 
|  | /// assumed. Pass this flag to turn on basic regular expressions (BRE) | 
|  | /// instead. | 
|  | BasicRegex=4 | 
|  | }; | 
|  |  | 
|  | Regex(); | 
|  | /// Compiles the given regular expression \p Regex. | 
|  | Regex(StringRef Regex, unsigned Flags = NoFlags); | 
|  | Regex(const Regex &) = delete; | 
|  | Regex &operator=(Regex regex) { | 
|  | std::swap(preg, regex.preg); | 
|  | std::swap(error, regex.error); | 
|  | return *this; | 
|  | } | 
|  | Regex(Regex &®ex); | 
|  | ~Regex(); | 
|  |  | 
|  | /// isValid - returns the error encountered during regex compilation, or | 
|  | /// matching, if any. | 
|  | bool isValid(std::string &Error); | 
|  |  | 
|  | /// getNumMatches - In a valid regex, return the number of parenthesized | 
|  | /// matches it contains.  The number filled in by match will include this | 
|  | /// many entries plus one for the whole regex (as element 0). | 
|  | unsigned getNumMatches() const; | 
|  |  | 
|  | /// matches - Match the regex against a given \p String. | 
|  | /// | 
|  | /// \param Matches - If given, on a successful match this will be filled in | 
|  | /// with references to the matched group expressions (inside \p String), | 
|  | /// the first group is always the entire pattern. | 
|  | /// | 
|  | /// This returns true on a successful match. | 
|  | bool match(StringRef String, SmallVectorImpl<StringRef> *Matches = nullptr); | 
|  |  | 
|  | /// sub - Return the result of replacing the first match of the regex in | 
|  | /// \p String with the \p Repl string. Backreferences like "\0" in the | 
|  | /// replacement string are replaced with the appropriate match substring. | 
|  | /// | 
|  | /// Note that the replacement string has backslash escaping performed on | 
|  | /// it. Invalid backreferences are ignored (replaced by empty strings). | 
|  | /// | 
|  | /// \param Error If non-null, any errors in the substitution (invalid | 
|  | /// backreferences, trailing backslashes) will be recorded as a non-empty | 
|  | /// string. | 
|  | std::string sub(StringRef Repl, StringRef String, | 
|  | std::string *Error = nullptr); | 
|  |  | 
|  | /// \brief If this function returns true, ^Str$ is an extended regular | 
|  | /// expression that matches Str and only Str. | 
|  | static bool isLiteralERE(StringRef Str); | 
|  |  | 
|  | /// \brief Turn String into a regex by escaping its special characters. | 
|  | static std::string escape(StringRef String); | 
|  |  | 
|  | private: | 
|  | struct llvm_regex *preg; | 
|  | int error; | 
|  | }; | 
|  | } | 
|  |  | 
|  | #endif // LLVM_SUPPORT_REGEX_H |