std::regex_constants:: error_type
|
Definiert im Header
<regex>
|
||
|
using
error_type
=
/* implementation-defined */
;
|
(1) | (seit C++11) |
|
constexpr
error_type error_collate
=
/* unspecified */
;
constexpr
error_type error_ctype
=
/* unspecified */
;
|
(2) |
(seit C++11)
(inline seit C++17) |
error_type
ist ein Typ, der Fehler beschreibt, die während der Parsing von regulären Ausdrücken auftreten können.
Inhaltsverzeichnis |
Konstanten
| Name | Erklärung |
error_collate
|
der Ausdruck enthält einen ungültigen Sortierelementnamen |
error_ctype
|
der Ausdruck enthält einen ungültigen Zeichenklassennamen |
error_escape
|
der Ausdruck enthält ein ungültiges Escape-Zeichen oder ein nachgestelltes Escape |
error_backref
|
der Ausdruck enthält eine ungültige Rückreferenz |
error_brack
|
der Ausdruck enthält nicht übereinstimmende eckige Klammern ( '[' und ']' ) |
error_paren
|
der Ausdruck enthält nicht übereinstimmende runde Klammern ( '(' und ')' ) |
error_brace
|
der Ausdruck enthält nicht übereinstimmende geschweifte Klammern ( '{' und '}' ) |
error_badbrace
|
der Ausdruck enthält einen ungültigen Bereich in einem { } Ausdruck |
error_range
|
der Ausdruck enthält einen ungültigen Zeichenbereich (z.B. [b-a]) |
error_space
|
es war nicht genügend Speicher vorhanden, um den Ausdruck in einen endlichen Automaten umzuwandeln |
error_badrepeat
|
'*' , '?' , '+' oder '{' wurde nicht durch einen gültigen regulären Ausdruck vorangestellt |
error_complexity
|
die Komplexität eines Versuchs zur Übereinstimmung überschritt ein vordefiniertes Niveau |
error_stack
|
es war nicht genügend Speicher vorhanden, um eine Übereinstimmung durchzuführen |
Beispiel
Implementiert einen regulären Ausdrücke-Checker:
#include <cstddef> #include <iomanip> #include <iostream> #include <regex> #include <sstream> #include <string> void regular_expression_checker(const std::string& text, const std::string& regex, const std::regex::flag_type flags) { std::cout << "Text: " << std::quoted(text) << '\n' << "Regex: " << std::quoted(regex) << '\n'; try { const std::regex re{regex, flags}; const bool matched = std::regex_match(text, re); std::stringstream out; out << (matched ? "MATCH!\n" : "DOES NOT MATCH!\n"); std::smatch m; if (std::regex_search(text, m, re); !m.empty()) { out << "prefix = [" << m.prefix().str().data() << "]\n"; for (std::size_t i{}; i != m.size(); ++i) out << " m[" << i << "] = [" << m[i].str().data() << "]\n"; out << "suffix = [" << m.suffix().str().data() << "]\n"; } std::cout << out.str() << '\n'; } catch (std::regex_error& e) { std::cout << "Error: " << e.what() << ".\n\n"; } } int main() { constexpr std::regex::flag_type your_flags = std::regex::flag_type{0} // Wählen Sie eine der unterstützten Grammatiken: | std::regex::ECMAScript // | std::regex::basic // | std::regex::extended // | std::regex::awk // | std::regex::grep // | std::regex::egrep // Wählen Sie eine der folgenden Optionen: // | std::regex::icase // | std::regex::nosubs // | std::regex::optimize // | std::regex::collate // | std::regex::multiline ; const std::string your_text = "Hello regular expressions."; const std::string your_regex = R"(([a-zA-Z]+) ([a-z]+) ([a-z]+)\.)"; regular_expression_checker(your_text, your_regex, your_flags); regular_expression_checker("Invalid!", R"(((.)(.))", your_flags); regular_expression_checker("Invalid!", R"([.)", your_flags); regular_expression_checker("Invalid!", R"([.]{})", your_flags); regular_expression_checker("Invalid!", R"([1-0])", your_flags); }
Mögliche Ausgabe:
Text: "Hello regular expressions."
Regex: "([a-zA-Z]+) ([a-z]+) ([a-z]+)\\."
MATCH!
prefix = []
m[0] = [Hello regular expressions.]
m[1] = [Hello]
m[2] = [regular]
m[3] = [expressions]
suffix = []
Text: "Invalid!"
Regex: "((.)(.)"
Error: Mismatched '(' and ')' in regular expression.
Text: "Invalid!"
Regex: "[."
Error: Unexpected character within '[...]' in regular expression.
Text: "Invalid!"
Regex: "[.]{}"
Error: Invalid range in '{}' in regular expression.
Text: "Invalid!"
Regex: "[1-0]"
Error: Invalid range in bracket expression..
Fehlerberichte
Die folgenden verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | Angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| LWG 2053 | C++11 | die Konstanten wurden als static deklariert | entfernte den static Spezifizierer |
Siehe auch
|
(C++11)
|
meldet Fehler, die von der Regular Expressions-Bibliothek erzeugt werden
(Klasse) |