ошибка при использовании функции regex_replace из - PullRequest
3 голосов
/ 21 октября 2010
#include <string>
#include <tr1/regex>

#include "TextProcessing.h"

const std::string URL_PATTERN("((http://)[-a-zA-Z0-9@:%_\\+.~#?&//=]+)");
const std::string REPLACEMENT("<a href=\"$&\"\">$&</a>");

std::string textprocessing::processLinks(const std::string & text)
{

    // essentially the same regex as in the previous example, but using a dynamic regex
    std::tr1::regex url(URL_PATTERN);

    // As in Perl, $& is a reference to the sub-string that matched the regex
    return std::tr1::regex_replace(text, url, REPLACEMENT);
}

Я использую mingw gcc copiler 4.5.0 version.

У меня следующая ошибка:

%DEV%> mingw32-make all
g++  -Wl,--enable-auto-import -Wall -Wextra -std=c++0x -pedantic -Werror -c  -I./include TextProcessing.cpp
cc1plus.exe: warnings being treated as errors
c:\dev\mingw\bin\../lib/gcc/mingw32/4.5.0/include/c++/tr1_impl/regex:2390:5: error: inline function '_Out_iter std::tr1::regex_replace(_Out_iter, _Bi_iter, _Bi_iter, const std::tr1::basic_regex<_Ch_type, _Rx_traits>&, const std::basic_string<_Ch_type>&, std::tr1::regex_constants::match_flag_type) [with _Out_iter = std::back_insert_iterator<std::basic_string<char> >, _Bi_iter = __gnu_cxx::__normal_iterator<const char*, std::basic_string<char> >, _Rx_traits = std::tr1::regex_traits<char>, _Ch_type = char, std::tr1::regex_constants::match_flag_type = std::bitset<11u>]' used but never defined
mingw32-make: *** [TextProcessing.o] Error 1
Process mingw32-make exited with code 2

Ответы [ 2 ]

2 голосов
/ 21 октября 2010

Да, в моих включаемых файлах g ++ я также вижу, что regex_replace объявлен и не определен. Для меня это в файле /usr/include/c++/4.4.4/tr1_impl/regex. Чуть выше объявления находится раздел комментариев Doxygen, который включает в себя:

/** @todo Implement this function. */
1 голос
/ 21 октября 2010

Ваша стандартная библиотека C ++ не имеет полной поддержки c ++ 0x (теперь c ++ 1x?). Попробуйте использовать код Boost. Смотри также этот ответ .

...