orgweb/site/projects/git-auto-commit-mode.org

101 lines
2.8 KiB
Org Mode
Raw Normal View History

2012-06-21 21:24:54 +02:00
#+TITLE: git-auto-commit-mode
#+STYLE: <link rel="stylesheet" type="text/css" href="../../stylesheet.css" />
#+LINK_UP: ../index.html
#+LINK_HOME: http://ryuslash.org
2012-06-21 21:24:54 +02:00
#+LINK: src https://github.com/ryuslash/git-auto-commit-mode
#+LINK: tar_gz https://github.com/ryuslash/git-auto-commit-mode/tarball/master
#+LINK: zip https://github.com/ryuslash/git-auto-commit-mode/zipball/master
#+STARTUP: showall
#+begin_html
<script src="/keyjs.js" type="text/javascript"></script>
<script type="text/javascript">
keyjs_initialize({ "u": [ "keyjs_goto", "../index.html" ],
"h": [ "keyjs_goto", "http://ryuslash.org" ] });
</script>
#+end_html
2012-06-21 21:24:54 +02:00
#+INCLUDE: "dlmenu.inc"
* About
~git-auto-commit-mode~ is a minor mode for GNU
Emacs[fn::http://gnu.org/software/emacs/] that, when enabled, tries
to commit changes to a file after every save. It can also try to
push to the default upstream.
2012-06-21 21:24:54 +02:00
** Features
2012-06-21 21:24:54 +02:00
- Automatically commit changes to a file after each save.
2012-06-21 21:24:54 +02:00
- The commit message will contain the file name relative to the
repository root.
2012-06-21 21:24:54 +02:00
- Optionally, automatically push commits to the default upstream.
2012-06-21 21:24:54 +02:00
** Requirements
2012-06-21 21:24:54 +02:00
These should be mostly obvious.
2012-06-21 21:24:54 +02:00
- [[http://gnu.org/software/emacs][GNU Emacs]]
- [[http://git-scm.com][git]]
2012-06-21 21:24:54 +02:00
* Usage
To be able to use it you need to put it somewhere in your
~load-path~ and load it, for example:
#+begin_src emacs-lisp
(add-to-list 'load-path "~/path/to/git-auto-commit-mode.el")
(auto load 'git-auto-commit-mode "git-auto-commit-mode")
#+end_src
** Automatically commit
There are a few ways this could be used:
*** As file-local variable
2012-06-21 21:24:54 +02:00
This is the way I use it and I wanted to use it. Any file that you
would like to have automatically committed upon saving gets this
prop-line:
2012-06-21 21:24:54 +02:00
#+BEGIN_SRC emacs-lisp
;; -*- eval: (git-auto-commit-mode 1) -*-
#+END_SRC
2012-06-21 21:24:54 +02:00
Or, if you're in anything older than emacs 24:
2012-06-21 21:24:54 +02:00
#+BEGIN_SRC emacs-lisp
;; -*- mode: git-auto-commit -*-
#+END_SRC
2012-06-21 21:24:54 +02:00
*** As a directory-local variable
2012-06-21 21:24:54 +02:00
Put the following in a ~.dir-locals.el~ file in any directory where
you want to enable ~git-auto-commit-mode~ for *all* files:
2012-06-21 21:24:54 +02:00
#+BEGIN_SRC emacs-lisp
((nil . ((git-auto-commit-mode . t))))
#+END_SRC
2012-06-21 21:24:54 +02:00
*** As a hook
2012-06-21 21:24:54 +02:00
I doubt this will ever really be useful, but it is possible:
2012-06-21 21:24:54 +02:00
#+BEGIN_SRC emacs-lisp
(add-hook 'some-hook 'git-auto-commit-mode)
#+END_SRC
2012-06-21 21:24:54 +02:00
** Automatically push
2012-06-21 21:24:54 +02:00
If you wish to push your changes each time the file is saved you
should set =gac-automatically-push-p= to =t=. This is a buffer local
variable, so you will have to put it in your dir-local or
file-local variables. Alternatively, if you're sure you can also
set the default value to =t=, like so:
2012-06-21 21:24:54 +02:00
#+begin_src emacs-lisp
(setq-default gac-automatically-push-p t)
#+end_src