avoid needless format string position identifiers
[git-mirror.git] / githook.py
1 #!/usr/bin/python3
2 # Copyright (c) 2015, Ralf Jung <post@ralfj.de>
3 # All rights reserved.
4
5 # Redistribution and use in source and binary forms, with or without
6 # modification, are permitted provided that the following conditions are met:
7
8 # 1. Redistributions of source code must retain the above copyright notice, this
9 #    list of conditions and the following disclaimer. 
10 # 2. Redistributions in binary form must reproduce the above copyright notice,
11 #    this list of conditions and the following disclaimer in the documentation
12 #    and/or other materials provided with the distribution.
13
14 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
15 # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
16 # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
17 # DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
18 # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
19 # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
20 # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
21 # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
23 # SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 #==============================================================================
25
26 # This is the hook called by git post-commit. It updats all mirrors to the status of the local repository.
27 import traceback
28 from git_mirror import *
29
30 if __name__ == "__main__":
31     repo = None # we will try to use this during exception handling
32     try:
33         repos = load_repos()
34         
35         # find the repository we are dealing with
36         reponame = find_repo_by_directory(repos, os.getcwd())
37         if reponame is None or reponame not in repos:
38             raise Exception("Unknown repository.")
39         
40         # now sync this repository
41         repo = repos[reponame]
42         # parse the information we get from stdin. we trust this information.
43         for line in sys.stdin:
44             (oldsha, newsha, ref) = line.split()
45             repo.update_mirrors(ref, oldsha, newsha)
46     except Exception as e:
47         if repo is not None:
48             repo.mail_owner("There was a problem running the git-mirror git hook:\n\n{}".format(traceback.format_exc()))
49         # do not print all the details
50         sys.stderr.write("We have a problem:\n{}".format('\n'.join(traceback.format_exception_only(type(e), e))))
51