Skip to content
This repository was archived by the owner on Nov 5, 2021. It is now read-only.

martinwilli/clangcomplete

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 

Repository files navigation

Gedit plugin providing libclang based autocompletion suggestions

This Python based gedit plugin implements autocompletion using LLVMs libclang. It currently supports the C language only.

Installation

The plugin requires libclang and its Python bindings for the Python version gedit uses, usually Python 3. LLVM 5 is known to work, and it finally comes with clang bindings for Python 3. https://apt.llvm.org provides Debian/Ubuntu packages, but unfortunately python-clang-5.0 is for Python 2; one may move that packages files to a Python 3 site, though.

Please note that your Python libclang binding might require a specific libclang-v.x.so.y library name it tries to dlopen(). Just create an appropriate symlink (in Ubuntu/x64 under /usr/lib/x86_64-linux-gnu/) until we have some support to find installed libclang libraries.

To install the plugin itself, copy both the clangcomplete.plugin and clangcomplete.py files to ~/.local/share/gedit/plugins/.

C build environment

To allow clang to process your sources for completion suggestions, it must reuse the environment that your build system usually would use. For a simple project that is not much of a problem, but for lager projects, where autocompletion really shines, this gets more complex. The plugin can currently handle automake based projects.

Automake build environment

When feeding a source file to libclang, the plugin first tries to find a Makefile in the local or any parent directory of the source file. It uses the directory of such a file as working dir when feeding the sources to libclang. Then it uses make to read some CPPFLAGS and CFLAGS from the Makefile, and uses these flags when processing the sources. This should make clang aware of any include directorories or defines that your build system requires.

Issues

Depending on the include structure of your project, things might... get... slow... when typing. The plugin uses some minimal caching, but this certainly can be improved. If it gets too slow in your project, you may change the plugin to use GtkSource.CompletionActivation.USER_REQUESTED. Then you'll explicitly have to hit CTRL+Space to get suggestions.

About

Gedit plugin providing autocompletion suggestions using libclang

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages