Package(Plugin) Management for Vim
Asked Answered
N

7

83

Emacs 24 looks like it will have a package manager. What package management options are there for Vim?

Normative answered 16/3, 2010 at 21:45 Comment(5)
What is a package manager in this context? Something like VimExplorer?Problem
Something which will install and manage third party plugins from a central repository.Normative
well, vim has a central repo (vim.org), a package system (vimballs), and scripts which check whether you've got the latest & the greatest (several of them, don't recall names now) ... what more do you want ? :-)Glenda
I wasn't aware of vimballs, and correct me if I'm wrong but it still appears you need to a) visit the site, b) download the vba file - if it exists, which doesn't appear to be the case for most plugins - and c) only then run vimballs. Not exactly what I had in mind (cf RubyGems) :)Normative
Voting to close as tool rec. On vi: vi.stackexchange.com/questions/388/…Knitting
U
87

I am now using VimPlug for my own Vim setup, and I definitely recommend it. Installation is very simple, and it is fast, pretty and effective!

VimPlug video

I used to recommend Vundle in this answer. But Vundle is no longer maintained, and there are better alternatives.

Urus answered 21/2, 2011 at 20:58 Comment(5)
The author stopped maintaining vundle gmarik.info/blog/2014/02/04/… . you can still see contributions on github but may be someone more knowledgeable can comment on the future of vundle.Lightness
He seems slightly annoyed that NeoBundle mostly just copied his code instead of making a fork.. But if he no longer maintains it, maybe NeoBundle will take over?Urus
The GitHub repo seems active to me. Also, in the comments of the link in your update, it seems like someone stepped up to help.Daynadays
My pain with Vundle is that it only uses git (primarily github projects) as the source. However when you search for a wellknown project there, e.g., TagList, you get a bunch of "mirrors" from the official vim plugin site. I don't trust any of those for security. Therefore I keep using the good old Pathogen with my own github maintained bundle directory.Benzidine
@Benzidine VAM has a plugin index, which theoretically has the most canonical source for each plugin, whether in a git repo, or on vim.org. It's community maintained, but there's only one repo for each plugin, so that's a start. (And, you can update it yourself, as the index is a git repo.)Southing
K
39

Plugin management for vim used to be a pain in the traditional way by spreading plugin files across the whole personal vim runtime directory, eg. ~/.vim for *nix system. Once a plugin is installed, it is hard to be updated because there is no easy way to remove the outdated plugin files which is a necessary step.

At the beginning, I'd like to list my personal requirements about how a fine plugin management tool should be:

  1. shall be written in pure VimL
  2. shall install plugins into their own directory
  3. shall autoload plugins when vim starts, nice to load as needed
  4. shall have a builtin method of installing, updating and removing plugins
  5. nice to have a builtin method of search needed plugins
  6. shall be able to declare needed plugins in a file
  7. nice to have dependency solving mechanism

There are lots of implementations out there(Vim-Scripts.org has a comprehensive summary of all the available tools), I will only talk about several major tools by their creating order.

vimball was the first attempt to solve the problem and actually had been a half-official solution that lots of plugins shipped with a *.vba package together for a long time. Combined with GetLatestVimScripts, this formed the traditional way for the vim plugin management.

Even though, the problem still remained until Tim Pope's pathogen(Github Repo), which places each plugin into its own directory and loads them at the startup by modifying the "rtp(runtimepath)" of the vim, showed up. This is great progress - combined with vim-scripts.org hosted by git/github and other tools(eg. vimmer), it forms the modern way of managing vim plugins. There are lots of articles and videos talking about this topic.

As a plugin that manage the plugins, pathogen is still missing some core functionalities like searching, install, updating and removing the plugins. As a result, VAM(Vim-Addon-Manager)(Github Repo) stepped out. VAM provides almost everything needed to be plugin manager: places plugin files in its own directory, loads plugins at vim startup, searching/installing/updating/removing plugins in ex command line, written in pure VimL, maintains its own plugins central info database, even resolves the plugin dependencies. It seems VAM should be the one that we need as a full-featured vim plugin manager, but from my point of view, the approach VAM takes is a little bit inelegant and sometimes over-designed. Though it is still a wonderful plugin and worth using.

Then, there came Tom Link's tplugin(Github Repo) which improved pathogen by having plugins only loaded when related commands or functions are called, similar to AsNeeded. Also, it has some sort of dependency solving mechanism which seems nice.

Finnaly, Gmarik created Vundle (Github Repo) which is a successor of Tim Pope's pathogen with inspiration from Ruby's Bundler, it provides a better user interface and additional management functionality. Vundle to Vim is much similar as Bundler to a Ruby Project. By having needed plugins declared in vimrc, vundle handles all the rest, including installing/updating and removing plugins, through the ex command line interface. Most importantly, vundle is implemented in pure VimL. With the help of vundle, managing vim configuration across several computers could be done with just a simple vimrc file. As a modern plugin management tool, vundle relies on Git and can install plugin directly from Github. Vundle also provides a fancy interactive interface for searching and installing plugins.

Vundle does not fully fulfill my requirements though, but it does head to the right direction, which seems to be a good start point for me.

Here are a discussion and another comparison between vim plugin managers by VAM's author MarcWeber.

Kike answered 23/10, 2012 at 7:29 Comment(3)
following this great answer, Neobundle seems the logical evolution from VundleBobby
Great to have some history of how vim package managers have evolved - very useful, and glad I'm using Vundle as I don't have complex requirements.Dispersion
@RichVel, Conversely, I'm glad I'm using VAM, as I have one very complex requirement: I want it to be very simple to use day-to-day. It's even pretty easy to add new plugins, on the off-chance that they're not all ready in the index (vim-pi)Southing
D
25

There's also pathogen.vim

http://www.vim.org/scripts/script.php?script_id=2332

Although its not exactly what you are asking for it provides a means to manage checkouts from your github's and bitbucket's.

This is good as it separates the plugin's directory structure. So you can checkout a repository of the plugin and get a proper version control rather than rely on the maintainer to update the code. Also it doesn't rely on the plugin author to set up/package as required by the other options cited.

There are some other plugins on vim.org that perform this task although I can't find them at the moment

Do answered 17/3, 2010 at 23:1 Comment(0)
D
12

I'm using a hand-crafted setup for now, but I keep telling myself to give this a shot sometime (the links all have to do with the same plugin):

  1. vim-addon-manager: manage and update plugins easily; a plugin by Marc Weber (@ vim.org)
  2. GitHub profile of Marc Weber; he's got a number of v-a-m-related repos
  3. Vim-plugin-manager @ Vim wiki -- the name of the page is different, but actually the same plugin is meant

Once again, I haven't actually tried this myself yet, but it certainly looks promising.

Dynode answered 16/3, 2010 at 22:0 Comment(0)
W
8

All these answers seem pretty old. As described in this answer to a similar question,

Both Vim 8.0 and Neovim have their own built-in package manager

There is no need at all for another plugin manager.

I've been using it for a year or two and it seems simple and easy to me.

Here are a few resources about its advantages and how to use it:

Whereabouts answered 26/6, 2020 at 10:59 Comment(2)
Kind of amazing that this answer hasn't received more upvotes. :/Hateful
I feel that way about all my answers :)Whereabouts
A
5

Vim.org + Vimballs + GetLatestVimScripts is preffered built in way to manage vim plugins at the moment.

:h GetLatestVimScripts

The bad things about it:

  • doesn't support Windows (GetLatestVimScripts uses wget AFAIR)
  • vim.org has a lot of plugins that are not GLVS and Vimball aware.
Augite answered 17/3, 2010 at 6:45 Comment(1)
You can install wget on Windows if you've been able to install Vim on Windows :)Heartbroken
S
3

Check out NeoBundle, the ultimate package manager for vim. It's a fork of Vundle.

Schramm answered 23/4, 2013 at 10:1 Comment(2)
What are the differences between the two?Outfight
From the NeoBundle readme: "Active developement on NeoBundle has stopped. The only future changes will be bug fixes."Amass

© 2022 - 2024 — McMap. All rights reserved.