123456789101112131415161718192021222324252627282930313233 |
- #!/usr/bin/env python3
- import sys
- import subprocess
- ret = subprocess.run(["git", "config", "rebase.instructionFormat"], capture_output=True)
- if ret.returncode != 0 or ret.stdout.decode('ascii').strip() != "(%an <%ae>) %s":
- print("Git is using the wrong rebase instruction format, reconfigure it.")
- exit(1)
- try:
- f = open(".git/rebase-merge/git-rebase-todo", "r")
- except:
- print("Initiate the rebase first!")
- exit(1)
- lines = list(s.strip("\r\n") for s in f.readlines())
- f.close()
- for i in range(len(lines)):
- line = lines[i]
- if line.startswith("#") or " Translated using Weblate " not in line: continue
- pos = line.rfind("(")
- lang = line[pos:]
- author = line[line.find("("):line.rfind(")", 0, pos)+1]
- # try to grab the next commit by the same author for the same language
- for j in range(i+1, len(lines)):
- if lines[j].startswith("#") or not lines[j].endswith(lang): continue
- if author in lines[j]:
- lines.insert(i+1, "f " + lines.pop(j)[5:])
- break
- with open(".git/rebase-merge/git-rebase-todo", "w") as f:
- f.write("\n".join(lines) + "\n")
- print("You can now continue with the rebase.")
|