]> git.vanrenterghem.biz Git - git.ikiwiki.info.git/blob - ikiwiki-makerepo
web commit by http://andreyvit.livejournal.com/
[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         git add .
62         git commit -m "initial commit"
63         git remote add origin "$repository"
64         git config branch.master.merge refs/heads/master
65         git config branch.master.remote origin
66         git push --all
67         echo "Directory $srcdir is now a clone of $rcs repository $repository"
68 ;;
69 mercurial)
70         hg init "$srcdir"
71         cd "$srcdir"
72         echo .ikiwiki > .hgignore
73         hg add * .hgignore
74         hg commit -m "initial import"
75         echo "Directory $srcdir is now set up as a mercurial repository"
76 ;;
77 bzr)
78         bzr init "$srcdir"
79         cd "$srcdir"
80         echo .ikiwiki > .bzrignore
81         bzr add * .bzrignore
82         bzr commit -m "initial import"
83         echo "Directory $srcdir is now set up as a bzr repository"
84 ;;
85 *)
86         echo "Unsupported revision control system $rcs" >&2
87         usage
88 ;;
89 esac