GithubHelp home page GithubHelp logo

4thel00z / python-client Goto Github PK

View Code? Open in Web Editor NEW

This project forked from neovim/pynvim

0.0 2.0 0.0 469 KB

pynvim: python client for Nvim

Home Page: http://pynvim.readthedocs.io/en/latest/

License: Apache License 2.0

Python 99.77% Shell 0.23%

python-client's Introduction

Pynvim: Python client to Neovim

Build Status Documentation Status Scrutinizer Code Quality Code Coverage

Pynvim implements support for python plugins in Nvim. It also works as a library for connecting to and scripting Nvim processes through its msgpack-rpc API.

Installation

Supports python 2.7, and 3.4 or later.

pip2 install neovim
pip3 install neovim

If you only use one of python2 or python3, it is enough to install that version. You can install the package without being root by adding the --user flag.

If you follow Neovim master, make sure to upgrade the python-client when you upgrade neovim:

pip2 install --upgrade neovim
pip3 install --upgrade neovim

Alternatively, the master version could be installed by executing the following in the root of this repository:

pip2 install .
pip3 install .

Python Plugin API

Pynvim supports python remote plugins (via the language-agnostic Nvim rplugin interface), as well as Vim plugins (via the :python[3] interface). Thus when pynvim is installed Neovim will report support for the +python[3] Vim feature.

The rplugin interface allows plugins to handle vimL function calls as well as defining commands and autocommands, and such plugins can operate asynchronously without blocking nvim. For details on the new rplugin interface, see the Remote Plugin documentation.

Pynvim defines some extensions over the vim python API:

  • Builtin and plugin vimL functions are available as nvim.funcs
  • API functions are available as vim.api and for objects such as buffer.api
  • Lua functions can be defined using vim.exec_lua and called with vim.lua
  • Support for thread-safety and async requests.

See the Python Plugin API documentation for usage of this new functionality.

Development

If you change the code, you need to run

pip2 install .
pip3 install .

for the changes to have effect. For instructions of testing and troubleshooting, see the development documentation.

Usage through the python REPL

A number of different transports are supported, but the simplest way to get started is with the python REPL. First, start Nvim with a known address (or use the $NVIM_LISTEN_ADDRESS of a running instance):

$ NVIM_LISTEN_ADDRESS=/tmp/nvim nvim

In another terminal, connect a python REPL to Nvim (note that the API is similar to the one exposed by the python-vim bridge):

>>> from neovim import attach
# Create a python API session attached to unix domain socket created above:
>>> nvim = attach('socket', path='/tmp/nvim')
# Now do some work. 
>>> buffer = nvim.current.buffer # Get the current buffer
>>> buffer[0] = 'replace first line'
>>> buffer[:] = ['replace whole buffer']
>>> nvim.command('vsplit')
>>> nvim.windows[1].width = 10
>>> nvim.vars['global_var'] = [1, 2, 3]
>>> nvim.eval('g:global_var')
[1, 2, 3]

You can embed neovim into your python application instead of binding to a running neovim instance.

>>> from neovim import attach
>>> nvim = attach('child', argv=["/bin/env", "nvim", "--embed"])

The tests can be consulted for more examples.

python-client's People

Contributors

tarruda avatar bfredl avatar equalsraf avatar blueyed avatar fwalch avatar justinmk avatar elmart avatar fgtatsuro avatar btipling avatar heliomeiralins avatar cherti avatar mhinz avatar rgrinberg avatar lambdalisue avatar brcolow avatar viccuad avatar timeyyy avatar meitham avatar malramsay64 avatar frewsxcv avatar traverseda avatar roxma avatar henadzit avatar bcho avatar tomastomecek avatar tbabej avatar stsewd avatar s0undt3ch avatar benekastah avatar diefans avatar

Watchers

James Cloos avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.