blob: 5a6898c251c62b2585548c336df4064d65dcf7b6 [file] [log] [blame]
Christian Brabandtb4ddc6c2024-01-02 16:51:11 +01001*remote.txt* For Vim version 9.1. Last change: 2022 Feb 17
Bram Moolenaar071d4272004-06-13 20:20:40 +00002
3
4 VIM REFERENCE MANUAL by Bram Moolenaar
5
6
7Vim client-server communication *client-server*
8
91. Common functionality |clientserver|
102. X11 specific items |x11-clientserver|
113. MS-Windows specific items |w32-clientserver|
12
Bram Moolenaar071d4272004-06-13 20:20:40 +000013==============================================================================
141. Common functionality *clientserver*
15
16When compiled with the |+clientserver| option, Vim can act as a command
17server. It accepts messages from a client and executes them. At the same
18time, Vim can function as a client and send commands to a Vim server.
19
20The following command line arguments are available:
21
22 argument meaning ~
23
24 --remote [+{cmd}] {file} ... *--remote*
25 Open the file list in a remote Vim. When
26 there is no Vim server, execute locally.
27 There is one optional init command: +{cmd}.
28 This must be an Ex command that can be
29 followed by "|".
30 The rest of the command line is taken as the
31 file list. Thus any non-file arguments must
32 come before this.
33 You cannot edit stdin this way |--|.
34 The remote Vim is raised. If you don't want
35 this use >
36 vim --remote-send "<C-\><C-N>:n filename<CR>"
Bram Moolenaarf3c2afb2015-03-02 23:16:07 +010037<
38 --remote-silent [+{cmd}] {file} ... *--remote-silent*
Bram Moolenaar071d4272004-06-13 20:20:40 +000039 As above, but don't complain if there is no
40 server and the file is edited locally.
41 --remote-wait [+{cmd}] {file} ... *--remote-wait*
42 As --remote, but wait for files to complete
43 (unload) in remote Vim.
44 --remote-wait-silent [+{cmd}] {file} ... *--remote-wait-silent*
45 As --remote-wait, but don't complain if there
46 is no server.
Bram Moolenaarc9b4b052006-04-30 18:54:39 +000047 *--remote-tab*
Bram Moolenaar038221b2006-03-11 21:32:59 +000048 --remote-tab Like --remote but open each file in a new
Bram Moolenaarc9b4b052006-04-30 18:54:39 +000049 tabpage.
50 *--remote-tab-silent*
Bram Moolenaar038221b2006-03-11 21:32:59 +000051 --remote-tab-silent Like --remote-silent but open each file in a
Bram Moolenaarc9b4b052006-04-30 18:54:39 +000052 new tabpage.
Bram Moolenaar038221b2006-03-11 21:32:59 +000053 *--remote-tab-wait*
54 --remote-tab-wait Like --remote-wait but open each file in a new
Bram Moolenaarc9b4b052006-04-30 18:54:39 +000055 tabpage.
Bram Moolenaar038221b2006-03-11 21:32:59 +000056
Bram Moolenaarc9b4b052006-04-30 18:54:39 +000057 *--remote-tab-wait-silent*
Bram Moolenaar038221b2006-03-11 21:32:59 +000058 --remote-tab-wait-silent Like --remote-wait-silent but open each file
Bram Moolenaarc9b4b052006-04-30 18:54:39 +000059 in a new tabpage.
Bram Moolenaar071d4272004-06-13 20:20:40 +000060 *--servername*
61 --servername {name} Become the server {name}. When used together
62 with one of the --remote commands: connect to
63 server {name} instead of the default (see
Bram Moolenaar675e8d62018-06-24 20:42:01 +020064 below). The name used will be uppercase.
Bram Moolenaar071d4272004-06-13 20:20:40 +000065 *--remote-send*
Bram Moolenaar8c8de832008-06-24 22:58:06 +000066 --remote-send {keys} Send {keys} to server and exit. The {keys}
Bram Moolenaar938ae282023-02-20 20:44:55 +000067 are not mapped. Special key names are
Bram Moolenaar8c8de832008-06-24 22:58:06 +000068 recognized, e.g., "<CR>" results in a CR
69 character.
Bram Moolenaar071d4272004-06-13 20:20:40 +000070 *--remote-expr*
Bram Moolenaar362e1a32006-03-06 23:29:24 +000071 --remote-expr {expr} Evaluate {expr} in server and print the result
Bram Moolenaarc9b4b052006-04-30 18:54:39 +000072 on stdout.
Bram Moolenaar071d4272004-06-13 20:20:40 +000073 *--serverlist*
74 --serverlist Output a list of server names.
75
76
77Examples ~
78
79Edit "file.txt" in an already running GVIM server: >
80 gvim --remote file.txt
81
82Edit "file.txt" in an already running server called FOOBAR: >
83 gvim --servername FOOBAR --remote file.txt
84
85Edit "file.txt" in server "FILES" if it exists, become server "FILES"
86otherwise: >
87 gvim --servername FILES --remote-silent file.txt
88
89This doesn't work, all arguments after --remote will be used as file names: >
90 gvim --remote --servername FOOBAR file.txt
91
92Edit file "+foo" in a remote server (note the use of "./" to avoid the special
93meaning of the leading plus): >
94 vim --remote ./+foo
95
96Tell the remote server "BLA" to write all files and exit: >
97 vim --servername BLA --remote-send '<C-\><C-N>:wqa<CR>'
98
99
Bram Moolenaarf55e4c82017-08-01 20:44:53 +0200100SERVER NAME *client-server-name*
Bram Moolenaar071d4272004-06-13 20:20:40 +0000101
102By default Vim will try to register the name under which it was invoked (gvim,
103egvim ...). This can be overridden with the --servername argument. If the
104specified name is not available, a postfix is applied until a free name is
Bram Moolenaar13fcaaf2005-04-15 21:13:42 +0000105encountered, i.e. "gvim1" for the second invocation of gvim on a particular
Bram Moolenaar071d4272004-06-13 20:20:40 +0000106X-server. The resulting name is available in the servername builtin variable
107|v:servername|. The case of the server name is ignored, thus "gvim" and
108"GVIM" are considered equal.
109
110When Vim is invoked with --remote, --remote-wait or --remote-send it will try
111to locate the server name determined by the invocation name and --servername
112argument as described above. If an exact match is not available, the first
113server with the number postfix will be used. If a name with the number
114postfix is specified with the --servername argument, it must match exactly.
115
116If no server can be located and --remote or --remote-wait was used, Vim will
117start up according to the rest of the command line and do the editing by
118itself. This way it is not necessary to know whether gvim is already started
119when sending command to it.
120
121The --serverlist argument will cause Vim to print a list of registered command
122servers on the standard output (stdout) and exit.
Bram Moolenaar944697a2022-02-20 19:48:20 +0000123 *{server}*
124The {server} argument is used by several functions. When this is an empty
125string then on Unix the default server name is used, which is "GVIM". On
126MS-Windows an empty string does not work.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000127
128Win32 Note: Making the Vim server go to the foreground doesn't always work,
129because MS-Windows doesn't allow it. The client will move the server to the
130foreground when using the --remote or --remote-wait argument and the server
131name starts with "g".
132
133
134REMOTE EDITING
135
136The --remote argument will cause a |:drop| command to be constructed from the
137rest of the command line and sent as described above.
138The --remote-wait argument does the same thing and additionally sets up to
139wait for each of the files to have been edited. This uses the BufUnload
140event, thus as soon as a file has been unloaded, Vim assumes you are done
141editing it.
142Note that the --remote and --remote-wait arguments will consume the rest of
Bram Moolenaar13fcaaf2005-04-15 21:13:42 +0000143the command line. I.e. all remaining arguments will be regarded as filenames.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000144You can not put options there!
145
146
147FUNCTIONS
148 *E240* *E573*
149There are a number of Vim functions for scripting the command server. See
Bram Moolenaar1cae5a02021-12-27 21:28:34 +0000150the description in |builtin.txt| or use CTRL-] on the function name to jump to
Bram Moolenaar071d4272004-06-13 20:20:40 +0000151the full explanation.
152
153 synopsis explanation ~
Bram Moolenaar3c2881d2017-03-21 19:18:29 +0100154 remote_startserver( name) run a server
Bram Moolenaar071d4272004-06-13 20:20:40 +0000155 remote_expr( server, string, idvar) send expression
156 remote_send( server, string, idvar) send key sequence
157 serverlist() get a list of available servers
158 remote_peek( serverid, retvar) check for reply string
159 remote_read( serverid) read reply string
160 server2client( serverid, string) send reply string
161 remote_foreground( server) bring server to the front
162
163See also the explanation of |CTRL-\_CTRL-N|. Very useful as a leading key
164sequence.
165The {serverid} for server2client() can be obtained with expand("<client>")
166
167==============================================================================
1682. X11 specific items *x11-clientserver*
169 *E247* *E248* *E251* *E258* *E277*
170
171The communication between client and server goes through the X server. The
172display of the Vim server must be specified. The usual protection of the X
173server is used, you must be able to open a window on the X server for the
174communication to work. It is possible to communicate between different
175systems.
176
177By default, a GUI Vim will register a name on the X-server by which it can be
178addressed for subsequent execution of injected strings. Vim can also act as
179a client and send strings to other instances of Vim on the same X11 display.
180
181When an X11 GUI Vim (gvim) is started, it will try to register a send-server
182name on the 'VimRegistry' property on the root window.
183
184A non GUI Vim with access to the X11 display (|xterm-clipboard| enabled), can
185also act as a command server if a server name is explicitly given with the
Bram Moolenaare7b1ea02020-08-07 19:54:59 +0200186--servername argument, or when Vim was built with the |+autoservername|
Bram Moolenaara2a80162017-11-21 23:09:50 +0100187feature.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000188
189An empty --servername argument will cause the command server to be disabled.
190
191To send commands to a Vim server from another application, read the source
192file src/if_xcmdsrv.c, it contains some hints about the protocol used.
193
194==============================================================================
1953. Win32 specific items *w32-clientserver*
196
197Every Win32 Vim can work as a server, also in the console. You do not need a
198version compiled with OLE. Windows messages are used, this works on any
199version of MS-Windows. But only communication within one system is possible.
200
201Since MS-Windows messages are used, any other application should be able to
202communicate with a Vim server. An alternative is using the OLE functionality
203|ole-interface|.
204
205When using gvim, the --remote-wait only works properly this way: >
206
207 start /w gvim --remote-wait file.txt
208<
Bram Moolenaar91f84f62018-07-29 15:07:52 +0200209 vim:tw=78:sw=4:ts=8:noet:ft=help:norl: