Skip to content

rhopfer/vcsh

This branch is 268 commits behind RichiH/vcsh:main.

Folders and files

NameName
Last commit message
Last commit date
Jul 17, 2017
Jul 17, 2017
Feb 11, 2015
May 8, 2014
Oct 27, 2013
Dec 22, 2015
Feb 23, 2015
Dec 5, 2011
Feb 23, 2015
Feb 24, 2015
Aug 28, 2017
Aug 23, 2017
Oct 25, 2014
Aug 29, 2017

Repository files navigation

vcsh - Version Control System for $HOME - multiple Git repositories in $HOME

Build Status

Index

  1. 30 Second How-to
  2. Introduction
  3. Contact

30 Second How-to

While it may appear that there's an overwhelming amount of documentation and while the explanation of the concepts behind vcsh needs to touch a few gory details of git internals, getting started with vcsh is extremely simple.

Let's say you want to version control your vim configuration:

vcsh init vim
vcsh vim add ~/.vimrc ~/.vim
vcsh vim commit -m 'Initial commit of my Vim configuration'
# optionally push your files to a remote
vcsh vim remote add origin <remote>
vcsh vim push -u origin master
# from now on you can push additional commits like this
vcsh vim push

If all that looks a lot like standard git, that's no coincidence; it's a design feature.

Introduction

vcsh allows you to maintain several Git repositories in one single directory. They all maintain their working trees without clobbering each other or interfering otherwise. By default, all Git repositories maintained via vcsh store the actual files in $HOME but you can override this setting if you want to.

All this means that you can have one repository per application or application family, i.e. zsh, vim, ssh, etc. This, in turn, allows you to clone custom sets of configurations onto different machines or even for different users; picking and mixing which configurations you want to use where. For example, you may not need to have your mplayer configuration on a server or available to root and you may want to maintain different configuration for ssh on your personal and your work machines.

A lot of modern UNIX-based systems offer packages for vcsh. In case yours does not, read INSTALL.md for install instructions or PACKAGING.md to create a package yourself. If you do end up packaging vcsh please let us know so we can give you your own packaging branch in the upstream repository.

Talks

Some people found it useful to look at slides and videos explaining how vcsh works instead of working through the docs. All slides, videos, and further information can be found on the author's talk page.

Contact

There are several ways to get in touch with the author and a small but committed community around the general idea of version controlling your (digital) life.

About

config manager based on Git

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Shell 85.6%
  • Perl 8.8%
  • Makefile 5.6%