to do the following, but this might be easiest:
REPOSITORY=~/wiki.git
+ GIT_DIR=$REPOSITORY git --bare init --shared
cd $SRCDIR
git init
echo /.ikiwiki > .gitignore
git add .
- git commit -m'Initial commit'
- # if you expect $REPOSITORY to receive pushs from multiple
- # clones, then it is advisable to stop git performing
- # fast forwards -- this is to avoid overwriting the
- # remote ref and losing commits from there.
- git config receive.denyNonFastForwards true
- git config core.bare true
- mv .git $REPOSITORY
- mv .ikiwiki ..
- cd ..
- rm -r $SRCDIR
- git clone -l -s $REPOSITORY $SRCDIR
- mv .ikiwiki $SRCDIR
+ git commit -m "initial commit"
+ git remote add origin $REPOSITORY
+ git config branch.master.merge refs/heads/master
+ git push --all
It is **paramount** that you **never** push to the Git repository in
`$SRCDIR` ([this FAQ entry explains
`ssh`.
If at any point you commit changes in `$SRCDIR`, make sure to `git
- push` them to the `$REPOSITORY`.
+ push` them to the `$REPOSITORY`. ikiwiki will do this automatically
+ for any changes made via the web.
+
+ Finally, see [[Git_pitfalls]] if you experience problems.
"""]]
[[toggle id=tla text="TLA"]]
you chose to use. Be sure to set `svnrepo` to $REPOSITORY, if using
subversion. Uncomment the block for the wrapper for your revision
control system, and configure the wrapper path in that block
- appropriately (for Git, it should be `$REPO/hooks/post-update`).
+ appropriately (for Git, it should be `$REPOSITORY/hooks/post-update`).
Once it's all set up, run `ikiwiki --setup ikiwiki.setup` once more.
Now you should be able to edit files in $SRCDIR, and use your revision