Don't create the repository for each change

This commit is contained in:
Guillaume Ayoub 2013-08-30 19:00:10 +02:00
parent 97a19405c4
commit dbb866a750

View File

@ -35,11 +35,9 @@ FOLDER = os.path.expanduser(config.get("storage", "filesystem_folder"))
try: try:
from dulwich.repo import Repo from dulwich.repo import Repo
except ImportError: GIT_REPOSITORY = Repo(os.path.join(FOLDER, ".git"))
GIT_FOLDER = None except:
else: GIT_REPOSITORY = None
GIT_FOLDER = (os.path.join(FOLDER, ".git")
if os.path.isdir(os.path.join(FOLDER, ".git")) else None)
# This function overrides the builtin ``open`` function for this module # This function overrides the builtin ``open`` function for this module
@ -52,11 +50,10 @@ def open(path, mode="r"):
with codecs.open(abs_path, mode, config.get("encoding", "stock")) as fd: with codecs.open(abs_path, mode, config.get("encoding", "stock")) as fd:
yield fd yield fd
# On exit # On exit
if GIT_FOLDER and mode == "w": if GIT_REPOSITORY and mode == "w":
repo = Repo(FOLDER)
path = os.path.relpath(abs_path, FOLDER) path = os.path.relpath(abs_path, FOLDER)
repo.stage([path]) GIT_REPOSITORY.stage([path])
repo.do_commit("Commit by Radicale") GIT_REPOSITORY.do_commit("Commit by Radicale")
# pylint: enable=W0622 # pylint: enable=W0622