Определение функции в правиле духа дает предупреждение

Функция qi :: repeat (1,2) в правиле предупреждает меня, и я не хочу игнорировать это предупреждение, поэтому я хочу оптимизировать этот код, например, отделяя правило от метод парсинга.

qi :: фразе_parse делает то же самое, что и в правиле, но я хочу задать правило и передать правило функции pharse_parse.

std::ifstream ifs("f:/test.txt");
 std::string line;

//In header in my code
std::vector<unsigned long long> v_BF_Char;


//qi::int_parser<uintmax_t, 16> hex_int;
static qi::uint_parser<unsigned long long, 16, 16, 16> hex_int;

while (std::getline(ifs, line))
{
    typedef std::string::const_iterator It;
    It begin = line.begin(), end = line.end();

    // rule for grammer
    qi::rule<It, unsigned long long()> braced_hex = '<' >> qi::repeat(1,2)[hex_int] >> '>';


    bool ok = qi::phrase_parse(begin, end,
           *('<' >> qi::repeat(1,2)[ hex_int ] >> '>'),  qi::space, v_BF_Char);

и хочу сделать что-то вроде этого

bool ok = qi::phrase_parse(begin, end,
           braced_hex ,  qi::space, v_BF_Char);

test.txt содержат

<51dc> <04001C0180000000000000000EE317BC>
<05001C0180000000> <04001C0180000000000000000EE317BC>
<51dc> <30ea30f330ae30c330c8>
<0000> <fffd>
<003d> <00a5>
<005d> <00a6>
<005e> <007d>
<005f> <0303>
<0060> <2019>
<0061> <005c>
<0062> <2018>
<0063> <007c>
<0064> <007e>
<0068> <2044>
<0069> <0192>
<006a> <00a7>
<006b> <00a4>
<006c> <201c>

Мой код работает только для 2-й строки и извлекает значения в векторе, но не для других значений строк.


person max william    schedule 17.06.2015    source источник
comment
К редактированию после моего ответа: вам нужно решить, что это означает, когда вы анализируете менее 16 шестнадцатеричных цифр. Означает ли это ведущие нули? Каков предполагается порядок байтов? Вы действительно хотели разобрать только std::vector<uint8_t>?   -  person sehe    schedule 17.06.2015
comment
Кроме того, этот вопрос кажется очень похожим, возможно, он может вам помочь: stackoverflow.com/questions/30365628/   -  person sehe    schedule 17.06.2015


Ответы (1)


Исправьте открытый атрибут правила:

qi::rule<It, std::vector<unsigned long long>()> braced_hex = '<' >> qi::repeat(1,2)[hex_int] >> '>';

Повторите предоставляет вектор hex_int открытого типа атрибута

Живая демонстрация:

Live On Coliru

#include <boost/spirit/include/qi.hpp>
#include <fstream>

namespace qi = boost::spirit::qi;

int main() {
    std::ifstream ifs("input.txt");

    //In header in my code
    std::vector<unsigned long long> v_BF_Char;

    //qi::int_parser<uintmax_t, 16> hex_int;
    static qi::uint_parser<uint64_t, 16, 16, 16> hex_int;

    std::string line;
    while (std::getline(ifs, line))
    {
        typedef std::string::const_iterator It;
        It begin = line.begin(), end = line.end();

        // rule for grammer
        qi::rule<It, std::vector<uint64_t>()> braced_hex = '<' >> qi::repeat(1,2)[hex_int] >> '>';

        bool ok = qi::phrase_parse(begin, end, *braced_hex,  qi::space, v_BF_Char);
        assert(ok);
    }

    std::cout << "Parsed: " << v_BF_Char.size() << " 64bit elements\n";
}

Печать:

Parsed: 50 64bit elements

Например. для этого входа:

<1353cd278dd1f003636bc155006ac5ce> <1e83b053032565f0> <d1e97c841e68153a5d82d57df3074a21>
<92adee538fd147a337ebc8a4fc8d0ad3> <0ed9fb22ab42b3a4> <756ad64486054d22c62329e8dcaef0c5>
<16eeaec1108b1159b49c6bf884564519> <b4b87d1fd1aa10af> <1f710495fd863a1d191355adf1b33d5a>
<947ac523b4450ec26446840ccde3965b> <faa860f7763b23dc> <571decbfd0fcfe9a4047f72c101b9d87>
<50d726028b79b1a531a2c3752a4fdde7> <644e057721fa7fe1> <6bf66d2e1ae50351db53eddcee5fae41>
<6916580258e94f2be66eb71f103d3023> <a427df9bd05edd6d> <d896cfe92e6634867fcab5c6fc2de60b>
<9e50d5c9cda9e9a2fbf78eeb10f3a6bd> <9cff72edea319328> <0aabc7f36fcd058a2dfa7bb94602919a>
<923832f107c94d4a04b1de96241fda14> <003c7554390cabaf> <c43d58504fc6659bb226707efc0221b8>
<1040a8d23eac10e9e4b6abb2efcde1bd> <f38ac3906542529d> <ffbd836c54b0f498d358e4ea50170c94>
<7c4c6fd86a60cf7b4ac62faa0395c06b> <61156478683a6b01> <fb92ef7030068f25471e8049fb0f7cd3>

случайные данные, сгенерированные с помощью

od -A none -t x8 -w256 < /dev/urandom | head | awk '{ print "<" $1 $2 "> <" $3 "> <" $4 $5 ">" }'
person sehe    schedule 17.06.2015
comment
test.txt содержит следующие значения. ‹51dc› ‹04001C0180000000000000000EE317BC› ‹05001C0180000000› ‹04001C0180000000000000000EE317BC› ‹51dc› ‹30ea30f330ae30c330c330c8›0000› canfffd›b> ‹^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ хранить только значения 2-й строки, не работающие для строк 1, 3, 4 - person max william; 17.06.2015
comment
@maxwilliam Я не знаю, что вы пытаетесь сказать. Пожалуйста, посмотрите мой живой образец. Попробуйте прояснить свой вопрос вместо того, чтобы использовать комментарии для подобных деталей. - person sehe; 17.06.2015
comment
@maxwilliam Подсказка int_parser<T, 16,16,16> прямо говорит: должно появиться ровно 16 шестнадцатеричных цифр. Конечно <fffd> не совпадает - person sehe; 17.06.2015
comment
пожалуйста, проверьте мой файл данных, как мне написать общее решение этой проблемы? - person max william; 17.06.2015
comment
Пожалуйста, проверьте мой предыдущий комментарий. Я вернусь позже сегодня вечером - person sehe; 17.06.2015
comment
Вам нужно решить, что это означает, когда вы разбираете менее 16 шестнадцатеричных цифр. Означает ли это ведущие нули? Каков предполагается порядок байтов? Вы действительно хотели разобрать только std::vector<uint8_t>? - person sehe; 17.06.2015
comment
@maxwilliam в отсутствие дополнительной информации: coliru.stacked-crooked.com/a/fa27fa6bd9b5c55c - person sehe; 18.06.2015