File: grand-replace.py

package info (click to toggle)
lilypond 2.24.4-6
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 70,352 kB
  • sloc: cpp: 87,962; lisp: 43,344; xml: 31,269; python: 22,974; sh: 4,090; yacc: 4,080; perl: 2,873; lex: 1,387; makefile: 76
file content (69 lines) | stat: -rw-r--r-- 2,367 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
# grand-replace.py
#
# This file is part of LilyPond, the GNU music typesetter.
#
# Copyright (C) 2009--2022 Jan Nieuwenhuizen <janneke@gnu.org>
#
# LilyPond is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# LilyPond is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with LilyPond.  If not, see <http://www.gnu.org/licenses/>.

import datetime
import fnmatch
import os
import re
import subprocess

ignored_files = [
    # files maintained outside of LilyPond
    'config/*',
    'Documentation/en/fdl.itexi',
    'Documentation/en/gpl.itexi',
    'scripts/build/help2man.pl',
    'mf/mf2pt1.mp',
    'scripts/build/mf2pt1.pl',
    'tex/texinfo*.tex',
    'tex/txi-*.tex',
    # files maintained by the translation team
    'po/*.po',
    # historical files
    'Documentation/misc/CHANGES*',
    'Documentation/misc/ChangeLog*',
]


def main():
    all_files = subprocess.run(['git', 'ls-files'],
                               capture_output=True, check=True,
                               encoding='utf-8').stdout.splitlines()
    files = [file for file in all_files
             if not any(fnmatch.fnmatch(file, pat) for pat in ignored_files)]
    year = datetime.datetime.now().year
    last_year = year - 1
    copyright_part = r'(Copyright|\(c\)|\(C\)|@copyright\{\}[^\d-]*)'
    for filename in files:
        with open(filename, encoding='utf-8') as file:
            try:
                content = file.read()
            except UnicodeDecodeError:
                continue # ignore binary files
        content = re.sub(copyright_part + rf'{last_year}(?!-)',
                         rf'\1{last_year}--{year}',
                         content)
        content = re.sub(copyright_part + r'(\d{4})--\d{4}',
                         rf'\1\2--{year}',
                         content)
        with open(filename, 'w', encoding='utf-8') as file:
            file.write(content)

if __name__ == '__main__':
    main()