From f9a516704b4a517952844ca2691a7cdd7bbfb069 Mon Sep 17 00:00:00 2001 From: Strahinja Val Markovic Date: Thu, 17 Jan 2013 17:08:28 -0800 Subject: [PATCH] Now explicitly adding the clang includes to flags --- python/completers/cpp/flags.py | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/python/completers/cpp/flags.py b/python/completers/cpp/flags.py index d7ad2ed0..3aa1b4b5 100644 --- a/python/completers/cpp/flags.py +++ b/python/completers/cpp/flags.py @@ -31,6 +31,7 @@ class Flags( object ): self.flags_for_file = {} self.flags_module_for_file = {} self.flags_module_for_flags_module_file = {} + self.special_clang_flags = _SpecialClangIncludes() def FlagsForFile( self, filename ): @@ -42,6 +43,7 @@ class Flags( object ): return ycm_core.StringVec() results = flags_module.FlagsForFile( filename ) + results[ 'flags' ] += self.special_clang_flags sanitized_flags = _SanitizeFlags( results[ 'flags' ] ) if results[ 'do_cache' ]: @@ -69,6 +71,7 @@ class Flags( object ): return flags_module + def _FlagsModuleSourceFileForFile( filename ): """For a given filename, finds its nearest CLANG_OPTIONS_FILENAME file that will compute the flags necessary to compile the file. Returns None if no @@ -116,3 +119,9 @@ def _SanitizeFlags( flags ): for flag in sanitized_flags: vector.append( flag ) return vector + + +def _SpecialClangIncludes(): + libclang_dir = os.path.dirname( ycm_core.__file__ ) + path_to_includes = os.path.join( libclang_dir, 'clang_includes' ) + return [ '-I', path_to_includes ]