[ Avaa Bypassed ]




Upload:

Command:

www-data@18.119.107.255: ~ $
*if_ole.txt*    For Vim version 8.1.  Last change: 2019 May 05


		  VIM REFERENCE MANUAL    by Paul Moore


The OLE Interface to Vim				*ole-interface*

1. Activation			|ole-activation|
2. Methods			|ole-methods|
3. The "normal" command		|ole-normal|
4. Registration			|ole-registration|
5. MS Visual Studio integration	|MSVisualStudio|

{only available when compiled with the |+ole| feature.  See
src/if_ole.INSTALL}
An alternative is using the client-server communication |clientserver|.

==============================================================================
1. Activation						*ole-activation*

Vim acts as an OLE automation server, accessible from any automation client,
for example, Visual Basic, Python, or Perl.  The Vim application "name" (its
"ProgID", in OLE terminology) is "Vim.Application".

Hence, in order to start a Vim instance (or connect to an already running
instance), code similar to the following should be used:

[Visual Basic] >
	Dim Vim As Object
	Set Vim = CreateObject("Vim.Application")

[Python] >
	from win32com.client.dynamic import Dispatch
	vim = Dispatch('Vim.Application')

[Perl] >
	use Win32::OLE;
	$vim = new Win32::OLE 'Vim.Application';

[C#] >
        // Add a reference to Vim in your project. 
        // Choose the COM tab.
        // Select "Vim Ole Interface 1.1 Type Library"
	Vim.Vim vimobj = new Vim.Vim();

Vim does not support acting as a "hidden" OLE server, like some other OLE
Automation servers.  When a client starts up an instance of Vim, that instance
is immediately visible.  Simply closing the OLE connection to the Vim instance
is not enough to shut down the Vim instance - it is necessary to explicitly
execute a quit command (for example, :qa!, :wqa).

==============================================================================
2. Methods						*ole-methods*

Vim exposes four methods for use by clients.

							*ole-sendkeys*
SendKeys(keys)		Execute a series of keys.

This method takes a single parameter, which is a string of keystrokes.  These
keystrokes are executed exactly as if they had been types in at the keyboard.
Special keys can be given using their <..> names, as for the right hand side
of a mapping.  Note: Execution of the Ex "normal" command is not supported -
see below |ole-normal|.

Examples (Visual Basic syntax) >
	Vim.SendKeys "ihello<Esc>"
	Vim.SendKeys "ma1GV4jy`a"

These examples assume that Vim starts in Normal mode.  To force Normal mode,
start the key sequence with CTRL-\ CTRL-N as in >

	Vim.SendKeys "<C-\><C-N>ihello<Esc>"

CTRL-\ CTRL-N returns Vim to Normal mode, when in Insert or Command-line mode.
Note that this doesn't work halfway a Vim command

							*ole-eval*
Eval(expr)		Evaluate an expression.

This method takes a single parameter, which is an expression in Vim's normal
format (see |expression|).  It returns a string, which is the result of
evaluating the expression.  A |List| is turned into a string by joining the
items and inserting line breaks.

Examples (Visual Basic syntax) >
	Line20 = Vim.Eval("getline(20)")
	Twelve = Vim.Eval("6 + 6")		' Note this is a STRING
	Font = Vim.Eval("&guifont")
<
							*ole-setforeground*
SetForeground()		Make the Vim window come to the foreground

This method takes no arguments.  No value is returned.

Example (Visual Basic syntax) >
	Vim.SetForeground
<

							*ole-gethwnd*
GetHwnd()		Return the handle of the Vim window.

This method takes no arguments.  It returns the hwnd of the main Vimwindow.
You can use this if you are writing something which needs to manipulate the
Vim window, or to track it in the z-order, etc.

Example (Visual Basic syntax) >
	Vim_Hwnd = Vim.GetHwnd
<

==============================================================================
3. The "normal" command					*ole-normal*

Due to the way Vim processes OLE Automation commands, combined with the method
of implementation of the Ex command :normal, it is not possible to execute the
:normal command via OLE automation.  Any attempt to do so will fail, probably
harmlessly, although possibly in unpredictable ways.

There is currently no practical way to trap this situation, and users must
simply be aware of the limitation.
==============================================================================
4. Registration					*ole-registration* *E243*

Before Vim will act as an OLE server, it must be registered in the system
registry.  In order to do this, Vim should be run with a single parameter of
"-register".
							*-register*  >
	gvim -register

If gvim with OLE support is run and notices that no Vim OLE server has been
registered, it will present a dialog and offers you the choice to register by
clicking "Yes".

In some situations registering is not possible.  This happens when the
registry is not writable.  If you run into this problem you need to run gvim
as "Administrator".

Once vim is registered, the application path is stored in the registry.
Before moving, deleting, or upgrading Vim, the registry entries should be
removed using the "-unregister" switch.
							*-unregister*  >
	gvim -unregister

The OLE mechanism will use the first registered Vim it finds.  If a Vim is
already running, this one will be used.  If you want to have (several) Vim
sessions open that should not react to OLE commands, use the non-OLE version,
and put it in a different directory.  The OLE version should then be put in a
directory that is not in your normal path, so that typing "gvim" will start
the non-OLE version.

							*-silent*
To avoid the message box that pops up to report the result, prepend "-silent":
>
	gvim -silent -register
	gvim -silent -unregister

==============================================================================
5. MS Visual Studio integration			*MSVisualStudio* *VisVim*

The OLE version can be used to run Vim as the editor in Microsoft Visual
Studio.  This is called "VisVim".  It is included in the archive that contains
the OLE version.  The documentation can be found in the runtime directory, the
README_VisVim.txt file.


Using Vim with Visual Studio .Net~

With .Net you no longer really need VisVim, since .Net studio has support for
external editors.  Follow these directions:

In .Net Studio choose from the menu Tools->External Tools...
Add
     Title     - Vim
     Command   - c:\vim\vim63\gvim.exe
     Arguments - --servername VS_NET --remote-silent "+call cursor($(CurLine), $(CurCol))" $(ItemPath)
     Init Dir  - Empty

Now, when you open a file in .Net, you can choose from the .Net menu:
Tools->Vim

That will open the file in Vim.
You can then add this external command as an icon and place it anywhere you
like.  You might also be able to set this as your default editor.

If you refine this further, please post back to the Vim maillist so we have a
record of it.

--servername VS_NET
This will create a new instance of vim called VS_NET.  So if you open multiple
files from VS, they will use the same instance of Vim.  This allows you to
have multiple copies of Vim running, but you can control which one has VS
files in it.

--remote-silent "+call cursor(10, 27)"
	      - Places the cursor on line 10 column 27
In Vim >
   :h --remote-silent for more details

[.Net remarks provided by Dave Fishburn and Brian Sturk]

==============================================================================
 vim:tw=78:ts=8:noet:ft=help:norl:

Filemanager

Name Type Size Permission Actions
README.Debian File 324 B 0644
arabic.txt File 11.62 KB 0644
autocmd.txt File 68.18 KB 0644
change.txt File 74.89 KB 0644
channel.txt File 47.41 KB 0644
cmdline.txt File 46.88 KB 0644
debug.txt File 6.73 KB 0644
debugger.txt File 5.74 KB 0644
develop.txt File 22.16 KB 0644
diff.txt File 16.43 KB 0644
digraph.txt File 60.43 KB 0644
editing.txt File 71.36 KB 0644
eval.txt File 480.89 KB 0644
farsi.txt File 523 B 0644
filetype.txt File 26.61 KB 0644
fold.txt File 23.13 KB 0644
ft_ada.txt File 17.82 KB 0644
ft_rust.txt File 9.37 KB 0644
ft_sql.txt File 29.98 KB 0644
gui.txt File 50.91 KB 0644
gui_w32.txt File 18.91 KB 0644
gui_x11.txt File 29.08 KB 0644
hangulin.txt File 3.22 KB 0644
hebrew.txt File 5.53 KB 0644
help.txt File 8.69 KB 0644
help.txt.vim-tiny File 1.4 KB 0644
helphelp.txt File 14.09 KB 0644
howto.txt File 2.85 KB 0644
if_cscop.txt File 18.87 KB 0644
if_lua.txt File 15.23 KB 0644
if_mzsch.txt File 11.68 KB 0644
if_ole.txt File 7.19 KB 0644
if_perl.txt File 11.01 KB 0644
if_pyth.txt File 37.44 KB 0644
if_ruby.txt File 8.33 KB 0644
if_sniff.txt File 271 B 0644
if_tcl.txt File 22.43 KB 0644
indent.txt File 40.72 KB 0644
index.txt File 77.7 KB 0644
insert.txt File 82.33 KB 0644
intro.txt File 37.94 KB 0644
map.txt File 64.79 KB 0644
mbyte.txt File 58.25 KB 0644
message.txt File 30.5 KB 0644
mlang.txt File 7.68 KB 0644
motion.txt File 49.89 KB 0644
netbeans.txt File 36.69 KB 0644
options.txt File 378.37 KB 0644
os_390.txt File 4.64 KB 0644
os_amiga.txt File 5.34 KB 0644
os_beos.txt File 10.73 KB 0644
os_dos.txt File 11.74 KB 0644
os_mac.txt File 6.7 KB 0644
os_mint.txt File 1.37 KB 0644
os_msdos.txt File 523 B 0644
os_os2.txt File 299 B 0644
os_qnx.txt File 3.98 KB 0644
os_risc.txt File 328 B 0644
os_unix.txt File 2.54 KB 0644
os_vms.txt File 31.79 KB 0644
os_win32.txt File 13.04 KB 0644
pattern.txt File 58.29 KB 0644
pi_getscript.txt File 20.59 KB 0644
pi_gzip.txt File 1.26 KB 0644
pi_logipat.txt File 4.09 KB 0644
pi_netrw.txt File 172.43 KB 0644
pi_paren.txt File 2.22 KB 0644
pi_spec.txt File 4.03 KB 0644
pi_tar.txt File 6.51 KB 0644
pi_vimball.txt File 11.58 KB 0644
pi_zip.txt File 6.88 KB 0644
popup.txt File 35.68 KB 0644
print.txt File 30.48 KB 0644
quickfix.txt File 77.23 KB 0644
quickref.txt File 70.29 KB 0644
quotes.txt File 12.45 KB 0644
recover.txt File 10.45 KB 0644
remote.txt File 8.22 KB 0644
repeat.txt File 40.06 KB 0644
rileft.txt File 4.82 KB 0644
russian.txt File 2.95 KB 0644
scroll.txt File 13.46 KB 0644
sign.txt File 24.34 KB 0644
spell.txt File 62.38 KB 0644
sponsor.txt File 7.03 KB 0644
starting.txt File 71.58 KB 0644
syntax.txt File 216.25 KB 0644
tabpage.txt File 16.5 KB 0644
tags File 337.32 KB 0644
tags.vim-tiny File 30 B 0644
tagsrch.txt File 38.22 KB 0644
term.txt File 45.81 KB 0644
terminal.txt File 52.45 KB 0644
testing.txt File 12.63 KB 0644
textprop.txt File 13.54 KB 0644
tips.txt File 19.8 KB 0644
todo.txt File 301.55 KB 0644
uganda.txt File 13.7 KB 0644
undo.txt File 16.2 KB 0644
usr_01.txt File 6.93 KB 0644
usr_02.txt File 23.77 KB 0644
usr_03.txt File 23.06 KB 0644
usr_04.txt File 18.64 KB 0644
usr_05.txt File 26.42 KB 0644
usr_06.txt File 9.39 KB 0644
usr_07.txt File 15.61 KB 0644
usr_08.txt File 18.92 KB 0644
usr_09.txt File 11.23 KB 0644
usr_10.txt File 28.5 KB 0644
usr_11.txt File 12.62 KB 0644
usr_12.txt File 13.11 KB 0644
usr_20.txt File 13.39 KB 0644
usr_21.txt File 18.02 KB 0644
usr_22.txt File 14.65 KB 0644
usr_23.txt File 12.41 KB 0644
usr_24.txt File 20.38 KB 0644
usr_25.txt File 18.73 KB 0644
usr_26.txt File 8.07 KB 0644
usr_27.txt File 17.31 KB 0644
usr_28.txt File 15.64 KB 0644
usr_29.txt File 19.65 KB 0644
usr_30.txt File 22.13 KB 0644
usr_31.txt File 10.16 KB 0644
usr_32.txt File 5.25 KB 0644
usr_40.txt File 22.65 KB 0644
usr_41.txt File 91.23 KB 0644
usr_42.txt File 13.53 KB 0644
usr_43.txt File 7.24 KB 0644
usr_44.txt File 28.53 KB 0644
usr_45.txt File 17.24 KB 0644
usr_90.txt File 17.17 KB 0644
usr_toc.txt File 9.05 KB 0644
various.txt File 29.62 KB 0644
version4.txt File 13.58 KB 0644
version5.txt File 301.31 KB 0644
version6.txt File 563.53 KB 0644
version7.txt File 658.96 KB 0644
version8.txt File 1.26 MB 0644
vi_diff.txt File 56.27 KB 0644
vim2html.pl File 4.41 KB 0755
visual.txt File 21.26 KB 0644
windows.txt File 53.64 KB 0644
workshop.txt File 371 B 0644