-
Notifications
You must be signed in to change notification settings - Fork 770
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Possible Feature]: Add Ruby completion #314
Comments
We had an issue for this in ycm-core/YouCompleteMe#1502.
A couple things to consider:
For ycmd?? If so, show me yours and I'll show you mine 😝 |
Hah. Didn't spot that @vheon thanks. Makes sense to have one for ycmd, where it belongs :)
Well, yes. But mostly because I am investigating a whole bunch of Configuration Management and DevOps options at work and thought I would use ycmd as a small test case. Work application is, give or take, infinity times more complex. And ymcd something else I know well >:) Given my knowledge of vagrant + salt is everything i've learned today. here;s where I got to: Vagrant.configure(2) do |config|
config.vm.box = "parallels/ubuntu-14.04"
config.vm.provision :salt do |salt|
salt.masterless = true
salt.minion_config = "salt/minon"
salt.run_highstate = true
end
end top.sls: # vi: ft=sls sw=2
file_client: local
base:
'*':
- cmake
- clang
- mono
- gocode
- node
- rust
# TODO: different python versions ?
- python
- virtualenv So, err... Not far. Not even far enough to know what the above state thingy is likely to do :) PS. What's an Given my experience with the Tern completer, I estimate adding an rsense completer to ycmd, including tests, to be a few hours work for a working prototype. Assuming sense works etc. |
I went for the bash provisioning directly to avoid adding another "language"/dependency but with salt/puppet/chef/name-your-favorite-provisioner it would be surely more maintainable.
Yes it needs a vim which is compiled with the ruby interface. On Mac OS X is easy (if not the default) but neovim still don't have it because they have change how to do the interface layer.
Well the https://github.com/vim-ruby/vim-ruby uses both information from vim directly and evaluate on the fly some code to get some autocompletion. |
Other things to note about rsense:
|
Yeah, my main goal was learning the capabilities of salt/puppet/chef/ansible. |
I've got a little experience working with the ruby.vim plugin, and I've also looked at rsense. ruby.vim does a decent job of providing completions, but not perfect. Aside from being seemingly abandoned, there was no evidence that rsense would provide a better experience for completions than ruby.vim. To have a compelling story for Ruby in YCM we need to minimally achieve what the rust.vim plugin has done with completions, and add good find_definition support. Most Vim users in the Ruby community still rely on ctags for GoTo, but the experience really sucks. It can actually be really hard to provide good GoTo in ruby since the language is so dynamic; things like I would really like to see rubymine level support for Ruby in YCM, but I think we've got a lot of work to do! |
Well rubymine level would be really hard! we're talking of a whole team of people working full time with a base foundation that is IntelliJ IDEA. Whoever will build something like that I think many people would be really grateful :) |
We have the advantage of a base foundation of YCM and an ecosystem of opensource semantic analysis tools for various languages. I think most of the languages supported by YCM are very professional quality even though we're not all working full time on this. Most of the YCM languages are made possible by third party plugins who have already done a lot of the work. In the case of C family of languages, Val and the YCM team have done that work. The point I was trying to make with my previous comment was, for the case of ruby, there is no third party library we can just drop in to get us 90% of the way there. You're definitely right.. many people would be very grateful, including myself. I'm just questioning at this point whether we can do much that is a big value add over something like ruby.vim. |
That was my point. I thought that rsense would be good enough for the job but since I don't have much experience with it or ruby in general and you said that it wasn't that good (or at least not good enough to switch from ruby-vim) so I don't know how much can we do about it. |
I was actually saying it's not clear that it's better (it might be, for completions). That coupled with the fact of no find-definition support, it's a hard sell to me. |
Just found this un-sent. I wrote this on tuesday i think... @vheon FYI/FWIW I managed to get my salt all shaken and with: $ vagrant up --provision
<wait ages>
$ vagrant ssh
vagrant$ ls
ycmd You get a fully built ycmd in that directory on which almost all of the tests pass when running impressive tech. |
I'm using https://gist.github.com/vheon/1e43fb45cb90e1fae928 and the only issue I got is that if I run the whole test it passes, but if I run it again the go tests fail. I have the |
I welcome better ruby semantic completion; @jwilm does bring up a good point that what we bring in should be better than ruby.vim. OTOH, if we have it in ycmd, we instantly bring semantic completion support for ruby to other editors like emacs etc. I don't know how good rsense is personally; worth checking out. For the parallel discussion about Vagrant, I've personally used it quite a bit for other stuff and dear lord is it absolutely fantastic. I have nothing but praise for that tool. |
Also worth noting, we've had many users file issues on YCM about ruby.vim completion (through our omnifunc integration) crashing Vim. Something is funky with that thing and the problems persist to this day. So if we could replace it, we would probably make quite a few users very happy. |
FYI - I made a prototype of this which works after a fashion, but:
So I'm thinking that unfortunately, unless we invest quite heavily in improving rsense, then I don't think this is totally viable. |
That's that then for rsense. :) |
Once PR #857 is merged, we may consider LanguageServer. |
@puremourning do you mind to share your work on integrating ycmd with rsense? I know it is not a perfect solution, but I would like to take a look to it. |
Jeez, that was a long time ago. If it isn't in a branch in my fork, then it is long gone |
@puremourning thanks. I searched but unfortunately the branch seems gone. I am playing with eclim and ycmd with ruby, which works quite well. I just need to figure out how to automate a bit project creation and library inclusion.. |
@puremourning I find this https://github.com/castwide/solargraph |
YCM now supports plugging LSP servers, so if someone wants to test the ruby server, just add the following to vimrc: let g:ycm_language_server = [{
\ 'name': 'ruby',
\ 'filetypes': [ 'ruby' ],
\ 'cmdline': [ command_line ]
\ } ] |
I am trying solargraph again, but it is crashing and has a buggy LSP implementation. |
Solargraph is fixed (was a ycmd bug actually!), works with the generic LSP server per @bstaletic great work, so closing this. If there's sufficient community support for "native" (i.e. tested and supported) ruby completion in ycmd we can open a new issue to track that. Judging by the responses on this one, I don't see that it is a high priority. |
Is there any documentation on how to setup solargraph? |
@bstaletic included what you need above. we're considering adding a community-supported wiki page for non-core completers. |
Oh, I thought that was just a snippet not the real config. Thanks! |
This is WIP, but it might help you: https://github.com/ycm-core/lsp-examples |
I was playing with a Vagrantfile and thought this might be worthwhile. Not urgent, but might be a fun idea.
There's a project for ruby completion: https://github.com/rsense/rsense
Looks like it:
Might be worth checking out.
The text was updated successfully, but these errors were encountered: