Я замечаю странное поведение в назначениях boost xpressive sregex. Смотрите код ниже. Первый фрагмент кода, который не работает, имеет sregex, имеет предварительные назначения объекта и затем используется в основном выражении позже. Второй фрагмент кода, который работает хорошо, не имеет предыдущих назначений sregex (кроме последнего основного). Пожалуйста, дайте мне знать, если я использую api boost xpressive.
Код, который не работает
mark_tag Value1(1), Value2(2), Value3(3), Value4(4), Value5(5), Value6(6), Value7(7);
boost::xpressive::sregex name,multicast,rtsp;
name = ( (Value1 = (+boost::xpressive::set[_w|_d|'-'|'_'|as_xpr(' ')]) ) >> ',' );
name1 =
( (Value2 = icase(as_xpr("mark1:") ) )
>> (Value3 = (+boost::xpressive::set[_d|'.']) )
>> ':'
>> (Value4 = (+boost::xpressive::set[_d]) ) >> optional(as_xpr(",")) );
name2 =
( (Value5 = icase(as_xpr("mark2:") ) )
>> (Value6 = (+boost::xpressive::set[_d|'.']) )
>> ':'
>> (Value7 = (+boost::xpressive::set[_d]) ) >> optional(as_xpr(",")) ) ;
boost::xpressive::sregex pt = bos
>> (
name
>> repeat<0,2>(
name1
|
name2)
)
>> eos;boost::trim(string_to_parse);
smatch what;
if ( !regex_search(string_to_parse, what, pt)) {
std::stringstream ss;
ss << "Unable to parse: " << string_to_parse;
throw parse::MyException(ss.str());
}
std::string Value1_str = what[Value1]; // print them later
std::string Value2_str = what[Value2]; // print them later
std::string Value3_str = what[Value3]; // print them later
std::string Value4_str = what[Value4]; // print them later
std::string Value5_str = what[Value5]; // print them later
std::string Value6_str = what[Value6]; // print them later
std::string Value7_str = what[Value7]; // print them later
string_to_parse = NameX,mark1:192.168.1.100:5555,mark2:192.168.1.101:5556;
(не разбирает) Это означает, что[<>] не содержит никакого значения.
Код, который работает
mark_tag Value1(1), Value2(2), Value3(3), Value4(4), Value5(5), Value6(6), Value7(7);
sregex pt = bos
>> (
( (Value1 = (+boost::xpressive::set[_w|_d|'-'|'_'|as_xpr(' ')]) ) >> ',' )
>> repeat<0,2>(
( (Value2 = icase(as_xpr("mark1:") ) ) >> (Value3 = (+boost::xpressive::set[_d|'.']) ) >> ':' >> (Value4 = (+boost::xpressive::set[_d]) ) >> optional(as_xpr(",")) )
|
( (Value5 = icase(as_xpr("mark2:") ) ) >> (Value6 = (+boost::xpressive::set[_d|'.']) ) >> ':' >> (Value7 = (+boost::xpressive::set[_d]) ) >> optional(as_xpr(",")) ) )
)
>> eos;
boost::trim(string_to_parse);
smatch what;
if ( !regex_search(string_to_parse, what, pt)) {
std::stringstream ss;
ss << "Unable to parse: " << string_to_parse;
throw parse::MyException(ss.str());
}
std::string Value1_str = what[Value1]; // print them later
std::string Value2_str = what[Value2]; // print them later
std::string Value3_str = what[Value3]; // print them later
std::string Value4_str = what[Value4]; // print them later
std::string Value5_str = what[Value5]; // print them later
std::string Value6_str = what[Value6]; // print them later
std::string Value7_str = what[Value7]; // print them later
string_to_parse = NameX,mark1:192.168.1.100:5555,mark2:192.168.1.101:5556;
(проходит разбор)
Когда вы сопоставляете шаблон с вложенными регулярными выражениями, вы получаете результаты вложенного соответствия. это все объясняет
Других решений пока нет …