Stopgap for unicode chars in filename strings
Such filenames still can't be matched against, but at least we won't throw an exception when it happens. Fixes #279, relevant to #278
This commit is contained in:
parent
440e3b6f38
commit
67e4495273
@ -21,6 +21,8 @@
|
|||||||
#include "Utils.h"
|
#include "Utils.h"
|
||||||
|
|
||||||
#include <boost/thread/locks.hpp>
|
#include <boost/thread/locks.hpp>
|
||||||
|
#include <boost/algorithm/string.hpp>
|
||||||
|
#include <locale>
|
||||||
|
|
||||||
#ifdef USE_CLANG_COMPLETER
|
#ifdef USE_CLANG_COMPLETER
|
||||||
# include "ClangCompleter/CompletionData.h"
|
# include "ClangCompleter/CompletionData.h"
|
||||||
@ -28,6 +30,9 @@
|
|||||||
|
|
||||||
namespace YouCompleteMe {
|
namespace YouCompleteMe {
|
||||||
|
|
||||||
|
using boost::all;
|
||||||
|
using boost::is_print;
|
||||||
|
|
||||||
boost::mutex CandidateRepository::singleton_mutex_;
|
boost::mutex CandidateRepository::singleton_mutex_;
|
||||||
CandidateRepository *CandidateRepository::instance_ = NULL;
|
CandidateRepository *CandidateRepository::instance_ = NULL;
|
||||||
|
|
||||||
@ -58,12 +63,18 @@ std::vector< const Candidate * > CandidateRepository::GetCandidatesForStrings(
|
|||||||
boost::lock_guard< boost::mutex > locker( holder_mutex_ );
|
boost::lock_guard< boost::mutex > locker( holder_mutex_ );
|
||||||
|
|
||||||
foreach ( const std::string & candidate_text, strings ) {
|
foreach ( const std::string & candidate_text, strings ) {
|
||||||
const Candidate *&candidate = GetValueElseInsert( candidate_holder_,
|
const std::string &validated_candidate_text =
|
||||||
candidate_text,
|
all( candidate_text, is_print( std::locale::classic() ) ) ?
|
||||||
|
candidate_text :
|
||||||
|
empty_;
|
||||||
|
|
||||||
|
const Candidate *&candidate = GetValueElseInsert(
|
||||||
|
candidate_holder_,
|
||||||
|
validated_candidate_text,
|
||||||
NULL );
|
NULL );
|
||||||
|
|
||||||
if ( !candidate )
|
if ( !candidate )
|
||||||
candidate = new Candidate( candidate_text );
|
candidate = new Candidate( validated_candidate_text );
|
||||||
|
|
||||||
candidates.push_back( candidate );
|
candidates.push_back( candidate );
|
||||||
}
|
}
|
||||||
|
@ -56,6 +56,8 @@ private:
|
|||||||
static boost::mutex singleton_mutex_;
|
static boost::mutex singleton_mutex_;
|
||||||
static CandidateRepository *instance_;
|
static CandidateRepository *instance_;
|
||||||
|
|
||||||
|
const std::string empty_;
|
||||||
|
|
||||||
// This data structure owns all the Candidate pointers
|
// This data structure owns all the Candidate pointers
|
||||||
CandidateHolder candidate_holder_;
|
CandidateHolder candidate_holder_;
|
||||||
};
|
};
|
||||||
|
52
cpp/ycm/tests/CandidateRepository_test.cpp
Normal file
52
cpp/ycm/tests/CandidateRepository_test.cpp
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
// Copyright (C) 2011, 2012 Strahinja Val Markovic <val@markovic.io>
|
||||||
|
//
|
||||||
|
// This file is part of YouCompleteMe.
|
||||||
|
//
|
||||||
|
// YouCompleteMe is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// YouCompleteMe is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with YouCompleteMe. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
#include <gtest/gtest.h>
|
||||||
|
#include "CandidateRepository.h"
|
||||||
|
#include "Candidate.h"
|
||||||
|
#include "Result.h"
|
||||||
|
|
||||||
|
namespace YouCompleteMe {
|
||||||
|
|
||||||
|
TEST( CandidateRepositoryTest, EmptyCandidatesForUnicode ) {
|
||||||
|
std::vector< std::string > inputs;
|
||||||
|
inputs.push_back( "fooδιακριτικός" );
|
||||||
|
inputs.push_back( "fooδιακός" );
|
||||||
|
|
||||||
|
CandidateRepository& repo = CandidateRepository::Instance();
|
||||||
|
std::vector< const Candidate* > candidates =
|
||||||
|
repo.GetCandidatesForStrings( inputs );
|
||||||
|
|
||||||
|
EXPECT_EQ( "", candidates[ 0 ]->Text() );
|
||||||
|
EXPECT_EQ( "", candidates[ 1 ]->Text() );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
TEST( CandidateRepositoryTest, EmptyCandidatesForNonPrintable ) {
|
||||||
|
std::vector< std::string > inputs;
|
||||||
|
inputs.push_back( "\x01\x05\x0a\x15" );
|
||||||
|
|
||||||
|
CandidateRepository& repo = CandidateRepository::Instance();
|
||||||
|
std::vector< const Candidate* > candidates =
|
||||||
|
repo.GetCandidatesForStrings( inputs );
|
||||||
|
|
||||||
|
EXPECT_EQ( "", candidates[ 0 ]->Text() );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
} // namespace YouCompleteMe
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user