annotate runtime/doc/if_ruby.txt @ 81:bf3f798c35c6

updated for version 7.0033
author vimboss
date Fri, 07 Jan 2005 21:45:22 +0000
parents 3fc0f57ecb91
children 4707450c2b33
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1 *if_ruby.txt* For Vim version 7.0aa. Last change: 2004 Mar 14
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4 VIM REFERENCE MANUAL by Shugo Maeda
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
6 The Ruby Interface to Vim *ruby* *Ruby*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
8
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
9 1. Commands |ruby-commands|
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
10 2. The VIM module |ruby-vim|
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
11 3. VIM::Buffer objects |ruby-buffer|
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
12 4. VIM::Window objects |ruby-window|
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
13 5. Global variables |ruby-globals|
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
14
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
15 {Vi does not have any of these commands}
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
16 *E266* *E267* *E268* *E269* *E270* *E271* *E272* *E273*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
17
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
18 The Ruby interface only works when Vim was compiled with the |+ruby| feature.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
19
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
20 The home page for ruby is http://www.ruby-lang.org/. You can find links for
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
21 downloading Ruby there.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
22
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
23 ==============================================================================
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
24 1. Commands *ruby-commands*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
25
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
26 *:ruby* *:rub*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
27 :rub[y] {cmd} Execute Ruby command {cmd}.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
28
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
29 :rub[y] << {endpattern}
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
30 {script}
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
31 {endpattern}
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
32 Execute Ruby script {script}.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
33 {endpattern} must NOT be preceded by any white space.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
34 If {endpattern} is omitted, it defaults to a dot '.'
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
35 like for the |:append| and |:insert| commands. This
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
36 form of the |:ruby| command is mainly useful for
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
37 including ruby code in vim scripts.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
38 Note: This command doesn't work when the Ruby feature
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
39 wasn't compiled in. To avoid errors, see
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
40 |script-here|.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
41
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
42 Example Vim script: >
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
43
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
44 function! RedGem()
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
45 ruby << EOF
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
46 class Garnet
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
47 def initialize(s)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
48 @buffer = VIM::Buffer.current
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
49 vimputs(s)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
50 end
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
51 def vimputs(s)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
52 @buffer.append(@buffer.count,s)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
53 end
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
54 end
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
55 gem = Garnet.new("pretty")
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
56 EOF
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
57 endfunction
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
58 <
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
59
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
60 *:rubydo* *:rubyd* *E265*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
61 :[range]rubyd[o] {cmd} Evaluate Ruby command {cmd} for each line in the
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
62 [range], with $_ being set to the text of each line in
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
63 turn, without a trailing <EOL>. Setting $_ will change
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
64 the text, but note that it is not possible to add or
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
65 delete lines using this command.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
66 The default for [range] is the whole file: "1,$".
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
67
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
68 *:rubyfile* *:rubyf*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
69 :rubyf[ile] {file} Execute the Ruby script in {file}. This is the same as
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
70 ":ruby load 'file'", but allows file name completion.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
71
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
72 Executing Ruby commands is not possible in the |sandbox|.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
73
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
74 ==============================================================================
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
75 2. The VIM module *ruby-vim*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
76
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
77 Ruby code gets all of its access to vim via the "VIM" module.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
78
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
79 Overview >
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
80 print "Hello" # displays a message
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
81 VIM.command(cmd) # execute an ex command
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
82 num = VIM::Window.count # gets the number of windows
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
83 w = VIM::Window[n] # gets window "n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
84 cw = VIM::Window.current # gets the current window
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
85 num = VIM::Buffer.count # gets the number of buffers
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
86 b = VIM::Buffer[n] # gets buffer "n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
87 cb = VIM::Buffer.current # gets the current buffer
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
88 w.height = lines # sets the window height
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
89 w.cursor = [row, col] # sets the window cursor position
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
90 pos = w.cursor # gets an array [row, col]
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
91 name = b.name # gets the buffer file name
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
92 line = b[n] # gets a line from the buffer
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
93 num = b.count # gets the number of lines
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
94 b[n] = str # sets a line in the buffer
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
95 b.delete(n) # deletes a line
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
96 b.append(n, str) # appends a line after n
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
97 <
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
98
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
99 Module Functions:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
100
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
101 *ruby-message*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
102 VIM::message({msg})
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
103 Displays the message {msg}.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
104
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
105 *ruby-set_option*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
106 VIM::set_option({arg})
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
107 Sets a vim option. {arg} can be any argument that the ":set" command
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
108 accepts. Note that this means that no spaces are allowed in the
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
109 argument! See |:set|.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
110
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
111 *ruby-command*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
112 VIM::command({cmd})
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
113 Executes Ex command {cmd}.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
114
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
115 *ruby-evaluate*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
116 VIM::evaluate({expr})
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
117 Evaluates {expr} using the vim internal expression evaluator (see
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
118 |expression|). Returns the expression result as a string.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
119
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
120 ==============================================================================
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
121 3. VIM::Buffer objects *ruby-buffer*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
122
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
123 VIM::Buffer objects represent vim buffers.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
124
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
125 Class Methods:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
126
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
127 current Returns the current buffer object.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
128 count Returns the number of buffers.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
129 self[{n}] Returns the buffer object for the number {n}. The first number
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
130 is 0.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
131
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
132 Methods:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
133
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
134 name Returns the name of the buffer.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
135 number Returns the number of the buffer.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
136 count Returns the number of lines.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
137 length Returns the number of lines.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
138 self[{n}] Returns a line from the buffer. {n} is the line number.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
139 self[{n}] = {str}
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
140 Sets a line in the buffer. {n} is the line number.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
141 delete({n}) Deletes a line from the buffer. {n} is the line number.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
142 append({n}, {str})
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
143 Appends a line after the line {n}.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
144
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
145 ==============================================================================
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
146 4. VIM::Window objects *ruby-window*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
147
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
148 VIM::Window objects represent vim windows.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
149
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
150 Class Methods:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
151
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
152 current Returns the current window object.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
153 count Returns the number of windows.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
154 self[{n}] Returns the window object for the number {n}. The first number
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
155 is 0.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
156
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
157 Methods:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
158
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
159 buffer Returns the buffer displayed in the window.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
160 height Returns the height of the window.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
161 height = {n} Sets the window height to {n}.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
162 cursor Returns a [row, col] array for the cursor position.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
163 cursor = [{row}, {col}]
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
164 Sets the cursor position to {row} and {col}.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
165
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
166 ==============================================================================
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
167 4. Global variables *ruby-globals*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
168
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
169 There are two global variables.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
170
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
171 $curwin The current window object.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
172 $curbuf The current buffer object.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
173
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
174 ==============================================================================
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
175 vim:tw=78:ts=8:ft=help:norl: