/vim-ios

iOS plugin for Vim

Primary LanguageRuby

About

ios.vim is a plugin for Vim for iOS development. It is inspired mostly by rails.vim.

Installation

ios.vim requires a Vim with ruby scripting support built in. You can get one using either the Homebrew or MacPorts package managers. For MacPorts, use:

ports install vim +ruby

For Homebrew:

brew install macvim --override-system-vim

Once you have a good Vim installed, we move merrily along to installing ios.vim itself. If you have no preference, I recommend using pathogen.vim. Once pathogen is installed and configured, you can clone this repository into ~/.vim/bundle like so:

mkdir -p ~/.vim/bundle
cd ~/.vim/bundle
git clone https://github.com/eraserhd/vim-ios.git

After which, everything should Just Work(tm).

Building Your Project

The :Xbuild command will build the Xcode project in Vim's working directory. If the build is successful, you will see 'OK' in the status line. Otherwise, the command will put you into quickfix mode so you can fix compilation errors.

Similar to clang_complete, a configuration file named .build must be in your project's root directory to be properly built. A build file simply contains switches that are sent to xcodebuild when building a project. For example, a .build file may look like this:

-sdk iphoneos6.0
-configuration Debug

Installing Your Application

The :Xinstall command will install a built application. Please note that fruitstrap is a dependency that must be in your PATH for installing to work. A specific fork of fruitstrap is required. Others may work, but only the one located here has been tested. Currently, installing to the simulator is not supported however adding support is in the pipeline.

Navigation

replace file in new split in new vertical split in new tab Description
:A, :AE :AS :AV :AT Open alternate file. This will open the corresponding header or implementation file for the current buffer.
:Rspec, :REspec :RSspec :RVspec :RTspec Open corresponding test suite or spec.
:Rimpl, :REimpl :RSimpl :RVimpl :RTimpl Open corresponding implementation file.
:R, :RE :RS :RV :RT Open corresponding file of next type.

Feature Requests (and More)

I use Trello to track development progress. You can vote on new features or watch progress on my Vim for Objective-C Trello board.

Trello does not seem to allow setting a column to be world-writable at the moment. If you'd like to request a feature, ping me on Twitter (@eraserhd) or by e-mail.

Shameless Self-Promotion

I am writing this to help Vimmers in the Apple world, since it is quite convenient for a platform provider like Apple to stick everyone into one little box (oh, just use Xcode, it is what we provide) and perhaps forget that we've been developing some pretty good tools and idioms for building software since around 1973.

If you like this philosophy, I would like to help you. I produce weekly screencasts and charge the small sum of $9 US per month for them. I also make free screencasts and the usual text-style blog posts (also free) from time to time. You can find these at The Objective Vimmer.