Повысьте Xpressive Sregex назначение и захват группы проблемы

Я замечаю странное поведение в назначениях 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; (проходит разбор)

2

Решение

Когда вы сопоставляете шаблон с вложенными регулярными выражениями, вы получаете результаты вложенного соответствия. это все объясняет

2

Другие решения

Других решений пока нет …