Skip to main content

A Python3-to-Vim bridge decorator that allows transparent calls to Python 3 functions in native Vim scripts.

Project description

Python 3 port of the original for Python 2: https://github.com/nvie/vim_bridge

What is it?

vim_bridge3 is a Python-to-Vim bridge decorator that allows transparent calls to Python functions in native Vim scripts.

Installation

Install the vim_bridge3 Python package, using setuptools, easy_install, or pip.

Usage

In a Vim script, decorate your Python functions as follows to expose them as native Vim callables. Both arguments and return values are casted so it should be transparent:

python3 << endpython
from vim_bridge import bridged

@bridged
def SayHello(first, last):
    return "Hello, %s %s!" % (first, last)

endpython

" Now call directly into the Python function!
echo SayHello("John", "Doe")
" prints "Hello, John Doe!"

Supported

The following data types have proven to work:

  • Strings

  • Integers

  • Lists

  • Exceptions

More examples

Passing in a list:

python3 << endpython
from vim_bridge import bridged

@bridged
def GetLongest(list):
    return max(map(lambda s: len(s), list))

endpython

echo GetLongest(['one', 'two', 'three', 'four'])
            " returns 5 (because "three" is 5 chars long)

Catching exceptions:

python3 << endpython
from vim_bridge import bridged

@bridged
def WillCauseException():
    raise Exception("Oops")

endpython

" This will throw an error to the user...
echo WillCauseException()

" But here's how you can catch that in Vim
try
    echo WillCauseException()
catch
    echo "Something went wrong. Aborting."
finally
    echo "Cleaning up."
endtry

Using Python stdlib functions to do work that would be more difficult using pure Vim scripting:

python3 << endpython
import os.path
from vim_bridge import bridged

@bridged
def NormalizePath(path):
    return os.path.realpath(path)
endpython

echo NormalizePath("/this/../or/./.././that/is/./a/.//very/../obscure/..//././long/./../path/name")
echo NormalizePath("..")

You can use the bridged function definitions within a Python block itself, or from inside Vim, it does not matter. In this example, NormalizePath is called from both Python and Vim:

python3 << endpython
import os.path
from vim_bridge import bridged

@bridged
def NormalizePath(path):
    return os.path.realpath(path)

@bridged
def RealPath(path):
    # It does not matter if you call NormalizePath from here...
    return NormalizePath(path)
endpython

" ...or from here
echo NormalizePath("/this/../or/./.././that/is/./a/.//very/../obscure/..//././long/./../path/name")
echo RealPath("..")

Since vim_bridge 0.4, the function name casing convention is automatically converted to match Vim’s conventions (and requirement even, since function names must start with a capital letter). Besides casing, prefixing the Python function with an underscore will lead to the function being defined in the Vim context as a <SID>-prefixed function (i.e. a “private” function that cannot be called from outside the script):

python3 << endpython
import os
import vim
from vim_bridge import bridged

@bridged
def public():
    return "I am public."

@bridged
def _private():
    return "I am private (available in the current script only)."

@bridged
def my_name_is_auto_converted():
    return "In Python, I'm called my_name_is_auto_converted, " + \
           "but in Vim, I'm called MyNameIsAutoConverted :)"

@bridged
def _long_private_name():
    return "I'm private, and my case is converted automatically."
endpython

echo Public()
echo s:Private()
echo MyNameIsAutoConverted()
echo s:LongPrivateName()

Changes

  • Original code by Vincent Driessen (@nvie) in 2010. BSD License.

  • Support for Python2 and Python3 by Roland Puntaier (@rpuntaie) in 2016.

  • Support for Python3 by Walter Doekes (@wdoekes) in 2017.

  • vim_bridge3 for pypi by Roland Puntaier (@rpuntaie) in 2018.

Project details


Release history Release notifications | RSS feed

This version

0.6

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

vim_bridge3-0.6-py3-none-any.whl (6.5 kB view details)

Uploaded Python 3

File details

Details for the file vim_bridge3-0.6-py3-none-any.whl.

File metadata

File hashes

Hashes for vim_bridge3-0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 7fe470eecb8f04ad08749c33a40d855fd60825cf24a1176a160c9914ad98b2a2
MD5 d8632f3776ecd106c2c0409d48fdff8a
BLAKE2b-256 4d816c32e8ca86c85ac65a98741461e6510664f2bf8e2a8031852e3dddb82121

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page