Project

robot-vim

0.01
No commit activity in last 3 years
No release in over 3 years
Automate Vim with Ruby to allow for TDD/BDD of Vim plugins and scripts
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

>= 1.0.0
>= 0
~> 2.5.0

Runtime

~> 2.3.1
 Project Readme

RobotVim - Easy Vim Automation

RobotVim is a Ruby gem that allows you to invoke Vim from inside of Ruby programs. It was designed to allow Vim developers to TDD/BDD their Vim plugins and scripts.

Installation

To install RobotVim run

gem install robot-vim

or clone this reposity and run rake install

Dependencies

RobotVim is developed with Vim 7.3, Ruby 1.9.2, and bundler.

Example Usage

Initialization

Create an instance that will use your user's default Vim and vimrc

robot = RobotVim::Runner.new()

Create an instance with a specific Vim

robot = RobotVim::Runner.new(:vim => "/bin/vim")

Create an instance with a specific vimrc

robot = RobotVim::Runner.new(:vimrc => "something/vimrc")

Running commands

Commands are passed in as a string with one command per line.

The input file can be specified as a path to an existing input file, or as a string which RobotVim will turn into an short lived file backed buffer.

commands = <<-COMMANDS
  :s/old/new
  :normal! gg
  :call setline('.', "RobotVim")
  :call MyAwesomePluginFunction
COMMANDS


vim_response = robot.run(:input_file => "some/file.txt", :commands => commands)


input = <<-CONTENT
  This text will be used
  as the contents of my input file
CONTENT

vim_response = robot.run(:input_file => input, :commands => commands)
buffer_text = vim_response.body

VimResponse

The return value of RobotVim::Runner#run is a RobotVim::VimResponse instance with the following fields

  • body: The contents of the last buffer that was active when your commands completed
  • line_number: The line number the cursor was on when your commands completed
  • column_number: The column number the cursor was on when your commands completed

Please submit pull requests or issues if there are additional values that you want to be able to assert against

Making Assertions

Use your preferred Ruby testing library to make assertions about the VimResponse returned by RobotVim::Runner#run

Take a look at spec/integration_spec.rb for examples of asserting with Rspec

Author

RobotVim is developed by Matt Margolis | @mrmargolis | matt@mattmargolis.net