Protecting diagnostic access with mutex
This commit is contained in:
parent
06d653c60d
commit
11a52d018c
@ -38,6 +38,7 @@ using boost::shared_ptr;
|
|||||||
using boost::bind;
|
using boost::bind;
|
||||||
using boost::thread;
|
using boost::thread;
|
||||||
using boost::lock_guard;
|
using boost::lock_guard;
|
||||||
|
using boost::unique_lock;
|
||||||
using boost::mutex;
|
using boost::mutex;
|
||||||
using boost::unordered_map;
|
using boost::unordered_map;
|
||||||
|
|
||||||
@ -340,12 +341,14 @@ void ClangCompleter::SetFileCompileFlags(
|
|||||||
std::vector< Diagnostic > ClangCompleter::DiagnosticsForFile(
|
std::vector< Diagnostic > ClangCompleter::DiagnosticsForFile(
|
||||||
const std::string &filename )
|
const std::string &filename )
|
||||||
{
|
{
|
||||||
// TODO: make sure that accessing the translation unit is thread safe; what if
|
std::vector< Diagnostic > diagnostics;
|
||||||
// a bg thread is parsing the TU when we try to access the diagnostics?
|
unique_lock< mutex > lock( file_parse_task_mutex_, boost::try_to_lock_t );
|
||||||
|
if ( !lock.owns_lock() )
|
||||||
|
return diagnostics;
|
||||||
|
|
||||||
CXTranslationUnit unit = FindWithDefault( filename_to_translation_unit_,
|
CXTranslationUnit unit = FindWithDefault( filename_to_translation_unit_,
|
||||||
filename,
|
filename,
|
||||||
NULL );
|
NULL );
|
||||||
std::vector< Diagnostic > diagnostics;
|
|
||||||
if ( !unit )
|
if ( !unit )
|
||||||
return diagnostics;
|
return diagnostics;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user