Index: third_party/libphonenumber/cpp/src/regexp_adapter.h |
diff --git a/third_party/libphonenumber/cpp/src/regexp_adapter.h b/third_party/libphonenumber/cpp/src/regexp_adapter.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..35681526f9cc4a7a665e4f9f0d4bd0b1a0e04c6b |
--- /dev/null |
+++ b/third_party/libphonenumber/cpp/src/regexp_adapter.h |
@@ -0,0 +1,162 @@ |
+// Copyright (C) 2011 Google Inc. |
+// |
+// Licensed under the Apache License, Version 2.0 (the "License"); |
+// you may not use this file except in compliance with the License. |
+// You may obtain a copy of the License at |
+// |
+// http://www.apache.org/licenses/LICENSE-2.0 |
+// |
+// Unless required by applicable law or agreed to in writing, software |
+// distributed under the License is distributed on an "AS IS" BASIS, |
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
+// See the License for the specific language governing permissions and |
+// limitations under the License. |
+ |
+// Author: George Yakovlev |
+// Philippe Liard |
+// |
+// Regexp adapter to allow a pluggable regexp engine. It has been introduced |
+// during the integration of the open-source version of this library into |
+// Chromium to be able to use the ICU Regex engine instead of RE2, which is not |
+// officially supported on Windows. |
+// Since RE2 was initially used in this library, the interface of this adapter |
+// is very close to the subset of the RE2 API used in phonenumberutil.cc. |
+ |
+#ifndef I18N_PHONENUMBERS_REGEXP_ADAPTER_H_ |
+#define I18N_PHONENUMBERS_REGEXP_ADAPTER_H_ |
+ |
+#include <cstddef> |
+#include <string> |
+ |
+namespace i18n { |
+namespace phonenumbers { |
+ |
+using std::string; |
+ |
+// RegExpInput is the interface that abstracts the input that feeds the |
+// Consume() method of RegExp which may differ depending on its various |
+// implementations (StringPiece for RE2, UnicodeString for ICU Regex). |
+class RegExpInput { |
+ public: |
+ virtual ~RegExpInput() {} |
+ |
+ // Creates a new instance of the default RegExpInput implementation. The |
+ // deletion of the returned instance is under the responsibility of the |
+ // caller. |
+ static RegExpInput* Create(const string& utf8_input); |
+ |
+ // Converts to a C++ string. |
+ virtual string ToString() const = 0; |
+}; |
+ |
+// The regular expression abstract class. It supports only functions used in |
+// phonenumberutil.cc. Consume(), Match() and Replace() methods must be |
+// implemented. |
+class RegExp { |
+ public: |
+ virtual ~RegExp() {} |
+ |
+ // Creates a new instance of the default RegExp implementation. The deletion |
+ // of the returned instance is under the responsibility of the caller. |
+ static RegExp* Create(const string& utf8_regexp); |
+ |
+ // Matches string to regular expression, returns true if expression was |
+ // matched, false otherwise, advances position in the match. |
+ // input_string - string to be searched. |
+ // anchor_at_start - if true, match would be successful only if it appears at |
+ // the beginning of the tested region of the string. |
+ // matched_string1 - the first string extracted from the match. Can be NULL. |
+ // matched_string2 - the second string extracted from the match. Can be NULL. |
+ // matched_string3 - the third string extracted from the match. Can be NULL. |
+ virtual bool Consume(RegExpInput* input_string, |
+ bool anchor_at_start, |
+ string* matched_string1, |
+ string* matched_string2, |
+ string* matched_string3) const = 0; |
+ |
+ // Helper methods calling the Consume method that assume the match must start |
+ // at the beginning. |
+ inline bool Consume(RegExpInput* input_string, |
+ string* matched_string1, |
+ string* matched_string2, |
+ string* matched_string3) const { |
+ return Consume(input_string, true, matched_string1, matched_string2, |
+ matched_string3); |
+ } |
+ |
+ inline bool Consume(RegExpInput* input_string, |
+ string* matched_string1, |
+ string* matched_string2) const { |
+ return Consume(input_string, true, matched_string1, matched_string2, NULL); |
+ } |
+ |
+ inline bool Consume(RegExpInput* input_string, string* matched_string) const { |
+ return Consume(input_string, true, matched_string, NULL, NULL); |
+ } |
+ |
+ inline bool Consume(RegExpInput* input_string) const { |
+ return Consume(input_string, true, NULL, NULL, NULL); |
+ } |
+ |
+ // Helper method calling the Consume method that assumes the match can start |
+ // at any place in the string. |
+ inline bool FindAndConsume(RegExpInput* input_string, |
+ string* matched_string) const { |
+ return Consume(input_string, false, matched_string, NULL, NULL); |
+ } |
+ |
+ // Matches string to regular expression, returns true if the expression was |
+ // matched, false otherwise. |
+ // input_string - string to be searched. |
+ // full_match - if true, match would be successful only if it matches the |
+ // complete string. |
+ // matched_string - the string extracted from the match. Can be NULL. |
+ virtual bool Match(const string& input_string, |
+ bool full_match, |
+ string* matched_string) const = 0; |
+ |
+ // Helper methods calling the Match method with the right arguments. |
+ inline bool PartialMatch(const string& input_string, |
+ string* matched_string) const { |
+ return Match(input_string, false, matched_string); |
+ } |
+ |
+ inline bool PartialMatch(const string& input_string) const { |
+ return Match(input_string, false, NULL); |
+ } |
+ |
+ inline bool FullMatch(const string& input_string, |
+ string* matched_string) const { |
+ return Match(input_string, true, matched_string); |
+ } |
+ |
+ inline bool FullMatch(const string& input_string) const { |
+ return Match(input_string, true, NULL); |
+ } |
+ |
+ // Replaces match(es) in 'string_to_process'. If 'global' is true, |
+ // replaces all the matches, otherwise only the first match. |
+ // replacement_string - text the matches are replaced with. The groups in the |
+ // replacement string are referenced with the $[0-9] notation. |
+ // Returns true if the pattern matches and a replacement occurs, false |
+ // otherwise. |
+ virtual bool Replace(string* string_to_process, |
+ bool global, |
+ const string& replacement_string) const = 0; |
+ |
+ // Helper methods calling the Replace method with the right arguments. |
+ inline bool Replace(string* string_to_process, |
+ const string& replacement_string) const { |
+ return Replace(string_to_process, false, replacement_string); |
+ } |
+ |
+ inline bool GlobalReplace(string* string_to_process, |
+ const string& replacement_string) const { |
+ return Replace(string_to_process, true, replacement_string); |
+ } |
+}; |
+ |
+} // namespace phonenumbers |
+} // namespace i18n |
+ |
+#endif // I18N_PHONENUMBERS_REGEXP_ADAPTER_H_ |