Commit 27f56271 authored by Dmitry Gutov's avatar Dmitry Gutov

New command ruby-find-library-file

* lisp/progmodes/ruby-mode.el (ruby-find-library-file):
New command.
(ruby-mode-map): Add binding for it.
parent b367a3de
......@@ -733,6 +733,8 @@ it can't find the config file.
*** Rubocop is called with 'bundle exec' if Gemfile mentions it.
*** New command 'ruby-find-library-file' bound to 'C-c C-f'.
** Package
*** Change of 'package-check-signature' for packages with multiple sigs
......@@ -155,6 +155,7 @@ This should only be called after matching against `ruby-here-doc-beg-re'."
(define-key map (kbd "M-C-n") 'ruby-end-of-block)
(define-key map (kbd "C-c {") 'ruby-toggle-block)
(define-key map (kbd "C-c '") 'ruby-toggle-string-quotes)
(define-key map (kbd "C-c C-f") 'ruby-find-library-file)
"Keymap used in Ruby mode.")
......@@ -1802,6 +1803,28 @@ If the result is do-end block, it will always be multiline."
(format "%s%s%s" string-quote content string-quote))
(goto-char orig-point)))))
(defun ruby-find-library-file (&optional feature-name)
"Visit a library file denoted by FEATURE-NAME.
FEATURE-NAME is a relative file name, file extension is optional.
This commands delegates to 'gem which', which searches both
installed gems and the standard library. When called
interactively, defaults to the feature name in the 'require'
statement around point."
(unless feature-name
(let ((init (save-excursion
(forward-line 0)
(when (looking-at "require [\"']\\(.?*\\)[\"']")
(match-string 1)))))
(setq feature-name (read-string "Feature name: " init))))
(let ((out
(shell-command-to-string (concat "gem which " feature-name))
0 -1)))
(if (string-match-p "\\`ERROR" out)
(user-error "%s" out)
(find-file out))))
(defconst ruby-percent-literal-beg-re
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment