> URL: http://svn.apache.org/r1476374
> Log:
> Add support for YouCompleteMe vim plugin.
>
> Needs the following tools to be useful:
> YouCompleteMe: https://github.com/Valloric/YouCompleteMe
> Bear: https://github.com/rizsotto/Bear
>
> * .ycm_extra_conf.py: Add config file for YouCompleteMe plugin, which
> looks for compile flags in compile_commands.json in the srcdir.
Hi Ben. I believe you need to add a copyright/whatever boiler-plate header to this new file. If it also included a comment saying what it is for and where it came from, that would be awesome.
Also a comment in the Makefile noting what the 'compile-commands' target is for wouldn't go amiss, as it's pretty obscure.
- Julian
> * Makefile.in: Add new compile-commands target that produces
> compile_commands.json by using bear.
>
> * trunk/ (svn:ignore): Ignore compile_commands.json file.
>
> Added:
> subversion/trunk/.ycm_extra_conf.py
> Modified:
> subversion/trunk/ (props changed)
> subversion/trunk/Makefile.in
>
> Propchange: subversion/trunk/
> ------------------------------------------------------------------------------
> --- svn:ignore (original)
> +++ svn:ignore Fri Apr 26 20:06:35 2013
> @@ -52,3 +52,4 @@ serf
> gtest
> .git
> .gitignore
> +compile_commands.json
>
> Added: subversion/trunk/.ycm_extra_conf.py
> URL:
> http://svn.apache.org/viewvc/subversion/trunk/.ycm_extra_conf.py?rev=1476374&view=auto
> ==============================================================================
> --- subversion/trunk/.ycm_extra_conf.py (added)
> +++ subversion/trunk/.ycm_extra_conf.py Fri Apr 26 20:06:35 2013
> @@ -0,0 +1,59 @@
> +import os
> +import ycm_core
> +from clang_helpers import PrepareClangFlags
> +
> +compilation_database_folder = os.path.dirname(os.path.realpath(__file__))
> +
> +if compilation_database_folder:
> + database = ycm_core.CompilationDatabase( compilation_database_folder )
> +else:
> + database = None
> +
> +def MakeRelativePathsInFlagsAbsolute( flags, working_directory ):
> + if not working_directory:
> + return flags
> + new_flags = []
> + make_next_absolute = False
> + path_flags = [ '-isystem', '-I', '-iquote',
> '--sysroot=' ]
> + for flag in flags:
> + new_flag = flag
> +
> + if make_next_absolute:
> + make_next_absolute = False
> + if not flag.startswith( '/' ):
> + new_flag = os.path.join( working_directory, flag )
> +
> + for path_flag in path_flags:
> + if flag == path_flag:
> + make_next_absolute = True
> + break
> +
> + if flag.startswith( path_flag ):
> + path = flag[ len( path_flag ): ]
> + new_flag = path_flag + os.path.join( working_directory, path )
> + break
> +
> + if new_flag:
> + new_flags.append( new_flag )
> + return new_flags
> +
> +
> +def FlagsForFile( filename ):
> + if database:
> + # Bear in mind that compilation_info.compiler_flags_ does NOT return a
> + # python list, but a "list-like" StringVec object
> + compilation_info = database.GetCompilationInfoForFile( filename )
> + final_flags = PrepareClangFlags(
> + MakeRelativePathsInFlagsAbsolute(
> + compilation_info.compiler_flags_,
> + compilation_info.compiler_working_dir_ ),
> + filename )
> + do_cache = False
> + else:
> + final_flags = [ ]
> + do_cache = True
> +
> + return {
> + 'flags': final_flags,
> + 'do_cache': do_cache
> + }
>
> Modified: subversion/trunk/Makefile.in
> URL:
> http://svn.apache.org/viewvc/subversion/trunk/Makefile.in?rev=1476374&r1=1476373&r2=1476374&view=diff
> ==============================================================================
> --- subversion/trunk/Makefile.in (original)
> +++ subversion/trunk/Makefile.in Fri Apr 26 20:06:35 2013
> @@ -571,6 +571,9 @@ svnsshcheck: bin $(TEST_DEPS) @BDB_TEST_
> bdbcheck: bin $(TEST_DEPS) @BDB_TEST_DEPS@
> @$(MAKE) check FS_TYPE=bdb
>
> +compile-commands:
> + @bear -o $(abs_srcdir)/compile_commands.json -- $(MAKE) all
> +
> # Create an execution coverage report from the data collected during
> # all execution since the last reset.
> gcov:
>
Received on 2013-04-26 23:30:07 CEST