First things first: the issue tracker is NOT for tech support. It is for reporting bugs and requesting features. If your issue amounts to "I can't get YCM to work on my machine" and the reason why is obviously related to your machine configuration and the problem would not be resolved with reasonable changes to the YCM codebase, then the issue is likely to be closed.
A good place to ask questions is the Gitter room or the ycm-users Google group. Rule of thumb: if you're not sure whether your problem is a real bug, ask on the room or the group.
Don't go to #vim
on freenode for support. See the
readme for further help.
YCM compiles just fine; the build bots say so. If the bots are green and YCM doesn't compile on your machine, then your machine is the root cause. Now read the first paragraph again.
Realize that quite literally thousands of people have gotten YCM to work successfully so if you can't, it's probably because you have a peculiar system/Vim configuration or you didn't go through the docs carefully enough. It's very unlikely to be caused by an actual bug in YCM because someone would have already found it and reported it.
This leads us to point #2: make sure you have checked the docs before reporting an issue. The docs are extensive and cover a ton of things; there's also an FAQ at the bottom that quite possibly addresses your problem.
For installation problems, make sure that any issue report includes the entire output of any build or installation commands, including the command used to run them.
For common issues such as "the ycmd server SHUT DOWN", please check the GitHub Wiki.
Further, search the issue tracker for similar issues before creating a new one. There's no point in duplication; if an existing issue addresses your problem, please comment there instead of creating a duplicate. However, if the issue you found is closed as resolved (e.g. with a PR or the original user's problem was resolved), raise a new issue, because you've found a new problem. Reference the original issue if you think that's useful information.
Please note: Closed issues which have been inactive for 60 days will be locked, this helps to keep discussions focussed. If you believe you are still experiencing an issue which has been closed, please raise a new issue, completing the issue template.
If you do find a similar open issue, don't just post 'me too' or similar responses. This almost never helps resolve the issue, and just causes noise for the maintainers. Only post if it will aid the maintainers in solving the issue; if there are existing diagnostics requested in the thread, perform them and post the results.
When replying, follow the instructions for getting the required diagnostics for posting a new issue (see below), and add them to your response. This is likely to help the maintainers find a fix for you, rather than have them spend time requesting them again. To be clear, the maintainers always need the diagnostics (debug info, log files, versions, etc.) even for responses on existing issues.
You should also search the archives of the ycm-users mailing list.
Lastly, make sure you are running the latest version of YCM. The issue you
have encountered may have already been fixed. Don't forget to recompile
ycm_core.so too (usually by just running install.py
again).
OK, so we've reached this far. You need to create an issue. First realize that the time it takes to fix your issue is a multiple of how long it takes the developer to reproduce it. The easier it is to reproduce, the quicker it'll be fixed.
Here are the things you should do when creating an issue:
vim
-Nu /path/to/YCM/vimrc_ycm_minimal
and reproduce this issue. If it doesn't
repro, then copy your ycm-specific settings into this file and try again. If
it still doesn't repro, the issue is likely with another plugin.:YcmDebugInfo
command. Make
sure that when you run this, your cursor is in the file that is experiencing
the issue.vim -Nu /path/to/YCM/vimrc_ycm_minimal
and attach the contents of the logfiles. Use the
:YcmToggleLogs
command to directly open them in
Vim.vim --version
.Follow the code style of the existing codebase.
style_format.sh
that runs
astyle
) but it's not perfect. Again, look at the other C++ files and
match the code style you see.Your code needs to be well written and easy to maintain. This is of the utmost importance. Other people will have to maintain your code so don't just throw stuff against the wall until things kinda work.
Split your pull request into several smaller ones if possible. This makes it easier to review your changes, which means they will be merged faster.
Write tests for your code. If you're changing the VimScript code then you don't have to since it's hard to test that code. This is also why you should strive to implement your change in Python if at all possible (and if it makes sense to do so). Python is also much faster than VimScript.
Explain in detail why your pull request makes sense. Ask yourself, would this feature be helpful to others? Not just a few people, but a lot of YCM’s users? See, good features are useful to many. If your feature is only useful to you and maybe a couple of others, then that’s not a good feature. There is such a thing as “feature overload”. When software accumulates so many features of which most are only useful to a handful, then that software has become “bloated”. We don’t want that.
Requests for features that are obscure or are helpful to but a few, or are not part of YCM's "vision" will be rejected. Yes, even if you provide a patch that completely implements it.
Please include details on exactly what you would like to see, and why. The why is important - it's not always clear why a feature is really useful. And sometimes what you want can be done in a different way if the reason for the change is known. What goal is your change trying to accomplish?