diff options
author | Joey Hess <joey@kitenet.net> | 2007-11-27 00:34:17 -0500 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2007-11-27 00:34:17 -0500 |
commit | 491847ed5311123b3ce58c636451c56a2a0f191b (patch) | |
tree | c5489bec4a7b0e6cf08c0b943d8506d7810dcb7d /ikiwiki-makerepo | |
parent | 892c981f47cf23e5d88d6849e9c628657dcdceef (diff) |
* Add a new ikiwiki-makerepo program, that automates setting up a repo
and importing existing content for svn, git, and mercurial. This makes
the setup process much simpler.
* Reorganised git documentation.
* Actually install the ikiwiki-update-wikilist program.
Diffstat (limited to 'ikiwiki-makerepo')
-rwxr-xr-x | ikiwiki-makerepo | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/ikiwiki-makerepo b/ikiwiki-makerepo new file mode 100755 index 000000000..a6999cb4a --- /dev/null +++ b/ikiwiki-makerepo @@ -0,0 +1,76 @@ +#!/bin/sh +set -e + +rcs="$1" +srcdir="$2" +repository="$3" + +usage () { + echo "usage: ikiwiki-makerepo svn|git srcdir repository" >&2 + echo " ikiwiki-makerepo mercurial srcdir" >&2 + exit 1 +} + +if [ -z "$rcs" ] || [ -z "$srcdir" ]; then + usage +fi + +if [ ! -d "$srcdir" ]; then + echo "srcdir $srcdir not found" >&2 + exit 1 +fi + +if [ "$rcs" != mercurial ]; then + if [ -e "$repository" ]; then + echo "repository $repository already exists, aborting" >&2 + exit 1 + fi + repository="$(perl -e 'use Cwd q{abs_path}; print abs_path(shift)' $repository)" + if [ -z "$repository" ]; then + echo "internal error finding repository abs_path" >&2 + exit 1 + fi +fi + +echo "Importing $srcdir into $rcs" + +case "$rcs" in +svn) + if [ -e "$srcdir/.svn" ]; then + echo "$srcdir already seems to be a svn working copy" >&2 + exit 1 + fi + svnadmin create "$repository" + svn mkdir "file://$repository/trunk" -m "create trunk directory" + cd "$srcdir" + svn co "file://$repository/trunk" . + svn propset svn:ignore ".ikiwiki" . + svn add * + svn commit -m "initial import" + echo "Directory $srcdir is now a checkout of $rcs repository $repository" +;; +git) + GIT_DIR="$repository" git --bare init --shared + cd "$srcdir" + git init + echo /.ikiwiki > .gitignore + git add . + git commit -m "initial commit" + git remote add origin "$repository" + git config branch.master.merge refs/heads/master + git push --all + echo "Directory $srcdir is now a clone of $rcs repository $repository" +;; +mercurial) + hg init "$srcdir" + cd "$srcdir" + echo .ikiwiki > .hgignore + hg add * .hgignore + hg commit -m "initial import" + echo "Directory $srcdir is now set up as a mercurial repository" +;; +*) + echo "Unsupported revision control system $rcs" >&2 + usage +;; +esac |