Emacs ruby-mode and RVM propmt

On emacs ruby-mode, if you do M-x run-ruby (or C-c C-s), the inferior ruby interpreter is provided in the "*ruby*" buffer so that you can evaluate lots of ruby statements or expressions.

When you press M-p (M-x comint-previous-input), Emacs will cycle to the previous input histrory saving input, so that you can easily re-evaulate of your previous input.

It works like other inferior interpreter provided by python-mode, slime, and so on.

What makes me frustrated is, it works for the ruby 1.8 installed in my gentoo system, but it does not work for the ruby 1.9.3 installed via RVM. The minibuffer shows sulpurous error:

Search failed: "^irb(.*)[0-9:]+0> *"

Looking at the ruby-mode's source, I found that string is the value of 'inferior-ruby-first-prompt-pattern' in inf-ruby.el. It looks like that ruby-mode uses inferior-ruby-first-prompt-pattern and inferior-ruby-prompt-pattern for the ruby's prompt pattern.

Another notable different from the start between two rubies (v1.8 system versus v1.9 RVM) are their prompt patterns:

# ruby 1.8 (system)
irb(main):001:0> _

# ruby 1.9.3 (RVM)
ruby-1.9.2-p180 :001 > _

Now it's clear who is the culprit. Due to the difference of the prompt pattern, ruby-mode could not provide me M-p or M-n working.

So I modified two variables in inf-ruby.el and reports a bug to the Ruby issue tracking system and got a quick response.

It turns out that it's not the fault of ruby-mode, but it's the fault of RVM. (Actually, it's not a defect. It just not right for my purpose.)

By default, RVM uses different prompt from the native ruby. To solve this, you can force RVM ruby (irb) to use the native prompt pattern. It's simple: modify $HOME/.irbrc to include following:

IRB.conf[:PROMPT_MODE] = :DEFAULT

I feel embbarassed that I blamed ruby-mode when I found something is wrong :(

Comments

Comments powered by Disqus