Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dawsbot/swim

🏊‍♀️ Switch between multiple vimrc files
https://github.com/dawsbot/swim

bash bash-script shell shell-script vim vimrc vimrc-files

Last synced: 2 months ago
JSON representation

🏊‍♀️ Switch between multiple vimrc files

Awesome Lists containing this project

README

        


swim logo





switch vimrc files instantly






![](https://img.shields.io/badge/version-0.4.0-brightgreen.svg)
![](https://img.shields.io/badge/license-MIT-blue.svg)

## Demo
![demo fig](media/demo.gif)


## Why
Trying out and switching vimrc's shouldn't be hard. It shouldn't require several ```mv```'s combined with a ```wget```. Most importantly, it shouldn't stop you from always having the perfect vim configuration so you can be efficient.



swim add vimrc's directly from the internet


or locally and alias your vimrc's with names that are easy to remember. Swim entirely replaces the need for per-directory vimrc's, headers, and external vimrc configs.


## Install
Backup your files **before** swimming

```shell
curl -s https://raw.githubusercontent.com/dawsonbotsford/swim/master/install | bash
```


## Examples

```shell
swim add ~/dotfiles/myVimrc favorite #Add new swim alias
swim ls #Show available swim aliases
swim add https://raw.githubusercontent.com/dawsonbotsford/swim/master/exampleVimrcs/vimrcWikia.vim example
swim with favorite #Set alias favorite as primary .vimrc
swim with main #Set alias main as primary .vimrc

```


## Update

```shell
swim update #Update to the newest version of swim
```


## Available Commands

```shell
swim add #Add a swim alias
swim with #Change active vimrc file
swim ls #List aliased vimrc files
swim active #Show currently aliased vimrc
swim vim #Edit the vimrc stored at alias

swim mv #Rename alias (like Linux mv)
swim rm #Delete an alias entirely
swim update #Download newest version
swim version #Print version
swim help #Print this message
```


## FAQ

* Where does swim store my vimrc files?
* swim stores your vimrc files in ```~/.swim```. You can edit the vimrc files with ```swim vim ``` or edit them manually from their file location.


* Can I set a custom executable location?
* Yes, the default install location of the `swim` executable is `/usr/local/bin`, but if you would like a custom location, simply set the environmental variable named `usrDir`.
* Example: `export usrDir="/usr/sbin"`
(That only needs to be set for when you perform the swim install. So no need to set this in your bashrc or zshrc)


* Does swim support emacs?
* No, but pull requests are always welcome :)


* Can I call swim within vim?
* It may be possible to hack together a several command ```:! ``` solution at the moment, but there is not a supported method.


#### Requirements

* node.js and npm (to auto-install [chalk-cli](https://github.com/chalk/chalk-cli))


## Changelog

* **0.4.0**: Custom executable install location
* **0.3.2-prelaunch**: Prelaunch Beta Testing