Merge pull request #295 from dryabov/patch-6

Sync with twister-html/pull/202 (double hashtags)
This commit is contained in:
miguelfreitas 2014-11-11 17:54:30 -02:00
commit 10eb6abfe0

View File

@ -1447,15 +1447,24 @@ void updateSeenHashtags(std::string &message, int64_t msgTime)
boost::algorithm::split(tokens,message,boost::algorithm::is_any_of(" \n\t.,:/?!;'\"()[]{}*"), boost::algorithm::split(tokens,message,boost::algorithm::is_any_of(" \n\t.,:/?!;'\"()[]{}*"),
boost::algorithm::token_compress_on); boost::algorithm::token_compress_on);
BOOST_FOREACH(string const& token, tokens) { BOOST_FOREACH(string const& token, tokens) {
if( token.length() >= 2 ) { if( token.length() >= 2 && token.at(0) == '#' ) {
string word = token.substr(1); string word = token.substr(1);
#ifdef HAVE_BOOST_LOCALE #ifdef HAVE_BOOST_LOCALE
word = boost::locale::to_lower(word); word = boost::locale::to_lower(word);
#else #else
boost::algorithm::to_lower(word); boost::algorithm::to_lower(word);
#endif #endif
if( token.at(0) == '#') { if( word.find('#') == string::npos ) {
hashtags.insert(word); hashtags.insert(word);
} else {
vector<string> subtokens;
boost::algorithm::split(subtokens,word,std::bind1st(std::equal_to<char>(),'#'),
boost::algorithm::token_compress_on);
BOOST_FOREACH(string const& word, subtokens) {
if( word.length() ) {
hashtags.insert(word);
}
}
} }
} }
} }