if_ruby.txt 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. *if_ruby.txt* Nvim
  2. VIM REFERENCE MANUAL by Shugo Maeda
  3. The Ruby Interface to Vim *if_ruby* *ruby* *Ruby*
  4. *E266* *E267* *E268* *E269* *E270* *E271* *E272* *E273*
  5. The home page for ruby is https://www.ruby-lang.org/. You can find links for
  6. downloading Ruby there.
  7. Type |gO| to see the table of contents.
  8. ==============================================================================
  9. 1. Commands *ruby-commands*
  10. *:ruby* *:rub*
  11. :rub[y] {cmd} Execute Ruby command {cmd}. A command to try it out: >
  12. :ruby print "Hello"
  13. :rub[y] << [trim] [{endmarker}]
  14. {script}
  15. {endmarker}
  16. Execute Ruby script {script}.
  17. If [endmarker] is omitted, it defaults to a dot '.'
  18. like for the |:append| and |:insert| commands. Refer
  19. to |:let-heredoc| for more information.
  20. This form of the |:ruby| command is mainly useful for
  21. including ruby code in vim scripts.
  22. Example Vim script: >
  23. function! RedGem()
  24. ruby << EOF
  25. class Garnet
  26. def initialize(s)
  27. @buffer = VIM::Buffer.current
  28. vimputs(s)
  29. end
  30. def vimputs(s)
  31. @buffer.append(@buffer.count,s)
  32. end
  33. end
  34. gem = Garnet.new("pretty")
  35. EOF
  36. endfunction
  37. <
  38. To see what version of Ruby you have: >
  39. :ruby print RUBY_VERSION
  40. <
  41. *:rubydo* *:rubyd* *E265*
  42. :[range]rubyd[o] {cmd} Evaluate Ruby command {cmd} for each line in the
  43. [range], with $_ being set to the text of each line in
  44. turn, without a trailing <EOL>. Setting $_ will change
  45. the text, but note that it is not possible to add or
  46. delete lines using this command.
  47. The default for [range] is the whole file: "1,$".
  48. *:rubyfile* *:rubyf*
  49. :rubyf[ile] {file} Execute the Ruby script in {file}. This is the same as
  50. `:ruby load 'file'`, but allows file name completion.
  51. Executing Ruby commands is not possible in the |sandbox|.
  52. ==============================================================================
  53. 2. The VIM module *ruby-vim*
  54. Ruby code gets all of its access to vim via the "VIM" module.
  55. Overview >
  56. print "Hello" # displays a message
  57. VIM.command(cmd) # execute an Ex command
  58. num = VIM::Window.count # gets the number of windows
  59. w = VIM::Window[n] # gets window "n"
  60. cw = VIM::Window.current # gets the current window
  61. num = VIM::Buffer.count # gets the number of buffers
  62. b = VIM::Buffer[n] # gets buffer "n"
  63. cb = VIM::Buffer.current # gets the current buffer
  64. w.height = lines # sets the window height
  65. w.cursor = [row, col] # sets the window cursor position
  66. pos = w.cursor # gets an array [row, col]
  67. name = b.name # gets the buffer file name
  68. line = b[n] # gets a line from the buffer
  69. num = b.count # gets the number of lines
  70. b[n] = str # sets a line in the buffer
  71. b.delete(n) # deletes a line
  72. b.append(n, str) # appends a line after n
  73. line = VIM::Buffer.current.line # gets the current line
  74. num = VIM::Buffer.current.line_number # gets the current line number
  75. VIM::Buffer.current.line = "test" # sets the current line number
  76. <
  77. Module Functions:
  78. *ruby-message*
  79. VIM::message({msg})
  80. Displays the message {msg}.
  81. *ruby-set_option*
  82. VIM::set_option({arg})
  83. Sets a vim option. {arg} can be any argument that the ":set" command
  84. accepts. Note that this means that no spaces are allowed in the
  85. argument! See |:set|.
  86. *ruby-command*
  87. VIM::command({cmd})
  88. Executes Ex command {cmd}.
  89. *ruby-evaluate*
  90. VIM::evaluate({expr})
  91. Evaluates {expr} using the vim internal expression evaluator (see
  92. |expression|). Returns the expression result as a string.
  93. A |List| is turned into a string by joining the items and inserting
  94. line breaks.
  95. ==============================================================================
  96. 3. VIM::Buffer objects *ruby-buffer*
  97. VIM::Buffer objects represent vim buffers.
  98. Class Methods:
  99. current Returns the current buffer object.
  100. count Returns the number of buffers.
  101. self[{n}] Returns the buffer object for the number {n}. The first number
  102. is 0.
  103. Methods:
  104. name Returns the full name of the buffer.
  105. number Returns the number of the buffer.
  106. count Returns the number of lines.
  107. length Returns the number of lines.
  108. self[{n}] Returns a line from the buffer. {n} is the line number.
  109. self[{n}] = {str}
  110. Sets a line in the buffer. {n} is the line number.
  111. delete({n}) Deletes a line from the buffer. {n} is the line number.
  112. append({n}, {str})
  113. Appends a line after the line {n}.
  114. line Returns the current line of the buffer if the buffer is
  115. active.
  116. line = {str} Sets the current line of the buffer if the buffer is active.
  117. line_number Returns the number of the current line if the buffer is
  118. active.
  119. ==============================================================================
  120. 4. VIM::Window objects *ruby-window*
  121. VIM::Window objects represent vim windows.
  122. Class Methods:
  123. current Returns the current window object.
  124. count Returns the number of windows.
  125. self[{n}] Returns the window object for the number {n}. The first number
  126. is 0.
  127. Methods:
  128. buffer Returns the buffer displayed in the window.
  129. height Returns the height of the window.
  130. height = {n} Sets the window height to {n}.
  131. width Returns the width of the window.
  132. width = {n} Sets the window width to {n}.
  133. cursor Returns a [row, col] array for the cursor position.
  134. First line number is 1 and first column number is 0.
  135. cursor = [{row}, {col}]
  136. Sets the cursor position to {row} and {col}.
  137. ==============================================================================
  138. 5. Global variables *ruby-globals*
  139. There are two global variables.
  140. $curwin The current window object.
  141. $curbuf The current buffer object.
  142. ==============================================================================
  143. 6. rubyeval() Vim function *ruby-rubyeval*
  144. To facilitate bi-directional interface, you can use |rubyeval()| function to
  145. evaluate Ruby expressions and pass their values to Vim script.
  146. The Ruby value "true", "false" and "nil" are converted to v:true, v:false and
  147. v:null, respectively.
  148. ==============================================================================
  149. vim:tw=78:ts=8:noet:ft=help:norl: