]> git.vanrenterghem.biz Git - git.ikiwiki.info.git/blob - ikiwiki-makerepo
fixes
[git.ikiwiki.info.git] / ikiwiki-makerepo
1 #!/bin/sh
2 set -e
4 rcs="$1"
5 srcdir="$2"
6 repository="$3"
7         
8 usage () {
9         echo "usage: ikiwiki-makerepo svn|git srcdir repository" >&2
10         echo "       ikiwiki-makerepo bzr|mercurial srcdir" >&2
11         exit 1
12 }
14 if [ -z "$rcs" ] || [ -z "$srcdir" ]; then
15         usage
16 fi
18 if [ ! -d "$srcdir" ]; then
19         echo "srcdir $srcdir not found" >&2 
20         exit 1
21 fi
23 if [ "$rcs" != mercurial ] && [ "$rcs" != bzr ]; then
24         if [ -e "$repository" ]; then
25                 echo "repository $repository already exists, aborting" >&2 
26                 exit 1
27         fi
28         repository="$(perl -e 'use Cwd q{abs_path}; $r=shift; $r=~s/\/*$//; print abs_path($r)' $repository)"
29         if [ -z "$repository" ]; then
30                 echo "internal error finding repository abs_path" >&2
31                 exit 1
32         fi
33 fi
35 echo "Importing $srcdir into $rcs"
37 case "$rcs" in
38 svn)
39         if [ -e "$srcdir/.svn" ]; then
40                 echo "$srcdir already seems to be a svn working copy" >&2
41                 exit 1
42         fi
43         svnadmin create "$repository"
44         svn mkdir "file://$repository/trunk" -m "create trunk directory"
45         cd "$srcdir"
46         svn co "file://$repository/trunk" .
47         svn propset svn:ignore ".ikiwiki" .
48         svn add *
49         svn commit -m "initial import"
50         echo "Directory $srcdir is now a checkout of $rcs repository $repository"
51 ;;
52 git)
53         # There are better ways to do this, but this works with older
54         # versions of git.)
55         mkdir -p "$repository"
56         (cd "$repository" && git --bare init --shared)
58         cd "$srcdir"
59         git init
60         echo /.ikiwiki > .gitignore
61         echo /recentchanges >> .gitignore
62         git add .
63         git commit -m "initial commit"
64         git remote add origin "$repository"
65         git config branch.master.merge refs/heads/master
66         git config branch.master.remote origin
67         git push --all
68         echo "Directory $srcdir is now a clone of $rcs repository $repository"
69 ;;
70 mercurial)
71         hg init "$srcdir"
72         cd "$srcdir"
73         echo .ikiwiki > .hgignore
74         hg add * .hgignore
75         hg commit -m "initial import"
76         echo "Directory $srcdir is now set up as a mercurial repository"
77 ;;
78 bzr)
79         bzr init "$srcdir"
80         cd "$srcdir"
81         echo .ikiwiki > .bzrignore
82         bzr add * .bzrignore
83         bzr commit -m "initial import"
84         echo "Directory $srcdir is now set up as a bzr repository"
85 ;;
86 *)
87         echo "Unsupported revision control system $rcs" >&2
88         usage
89 ;;
90 esac