Skip to content

Setting up irony mode on Windows using MSVC

3246251196 edited this page Apr 2, 2017 · 20 revisions

The findings in this article are based on https://github.com/Sarcasm/irony-mode/issues/280; All findings have been based on the following system: MSVS 2015, clang 3.7 (x86), Windows 7 x64, Emacs 24.5 and Irony server version (TODO)

Establishing an environment

In order to use Irony-Mode for completions for an MSVS 2015 project it is suggested to load emacs after establishing the MSVS environment. This can be done in a number of ways, but I convenient way is to create batch file along the lines of:

echo "Establishing Visual Studio variables..."
call "c:\Program Files (x86)\Microsoft Visual Studio 14.0\VC/vcvarsall.bat" amd64

echo "Running emacs..."
c:\emacs-24.5\bin\runemacs.exe

After running this batch file, the environment variables needed by Clang are set up; these are variables such as the Windows SDK includes and MSVS includes, etc.

.clang_complete

Now we need to supply the compiler options to Clang for completions. At the very least, you should have the following in your .clang_complete file:

-target
i686-pc-windows-msvc
-fms-extensions
-fms-compatibility
-fms-compatibility-version=19
-fdelayed-template-parsing

This basic set of options tells Clang that it should be dealing with the MSVS context.

However, that is not all. The chances are you are working with a project that has include directories, definitions etc. Therefore, in addition to the flags above, you should add:

--driver-mode=cl
/nologo
/DWIN32
/D_WINDOWS
/W3
/GR
/EHsc
/EHs
/D_HAS_EXCEPTIONS=0
[MORE OPTIONS]
/Tp [this is needed at the end if you want all files to be considered c++ (see below)]

All of the options that start with / are MSVS style options. The ones provided here are just an example, you should ideally replace all of them with whatever your project uses in MSVS. Important to note is the use of --driver-mode=cl : this is mandatory if what follows are MSVC style options!

It is probably safest to use the lower case variant for any option that has an upper and lower case variant.

I am getting a gosh darn Assertion!

Yes, this is annoying...

It is sometimes hard to track down. In my personal experience (3246251196) this is indicative of mal-configuration. That is, somewhere you have forgot to add an include or flag (even the most innocent of flags can cause an issue).

There is a hack available (I would prefer to see this as an option - ask Sarcasm about this). I would also prefer to quote a patch here, but for now:

Open TUManager.cpp (which will be in the downloaded irony-mode package), and change

if (CINDEX_VERSION < 6) {

to

if (true) {

This does mean slower completions but it will perhaps remove the assertion failure. If you are not working on a huge project it may be fine.

Recompile irony-server.

.h files in MSVC are compiling as C mode!

Recently I have discovered that if you use driver-mode=cl and you are using .h files in your C++ project then you must issue the \Tp flag (not even the \TP flag - as clang will not accept this variant) in order for those .h files to be seen as C++ code. Also, it should be added at the bottom of the .clang_complete file. I.e. you cannot apply it after --driver-mode=cl.

More information

For more information that covers everything in the WIKI, visit the already linked link: https://github.com/Sarcasm/irony-mode/issues/280

Update: 04/2017

I have noticed that with a large code base and the use of boost completion can be slow. Personally I have found that not executing clang_reparseTransationUnit on every call of TUManager::parse improves the speed of completions for me. Currently, I still disable PrecompiledPreamble (as suggested above in "I am getting a gosh darn Assertion!"), and I ensure that clang_reparseTranslationUnit does not get called at the latter stage of TUManager::parse().

Clone this wiki locally