| #!/usr/bin/env python3 |
| |
| # Copyright 2019 The Meson development team |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| ''' |
| Generates release notes for new releases of Meson build system |
| ''' |
| import argparse |
| import subprocess |
| import re |
| import shutil |
| from pathlib import Path |
| |
| RELNOTE_TEMPLATE = '''--- |
| title: Release {} |
| short-description: Release notes for {} |
| ... |
| |
| # New features{} |
| |
| ''' |
| |
| |
| def add_to_sitemap(sitemap, output_sitemap): |
| ''' |
| Adds release note entry to sitemap.txt. |
| ''' |
| sitemapfile = Path(sitemap) |
| with sitemapfile.open(encoding='utf-8') as s_f: |
| lines = s_f.readlines() |
| relnotes = None |
| to_version = None |
| output = Path(output_sitemap) |
| output.parent.mkdir(exist_ok=True, parents=True) |
| with output.open('w', encoding='utf-8') as s_f: |
| for line in lines: |
| if relnotes is None: |
| m = re.match(r'[\s]*Release-notes-for-([0-9]+)\.([0-9]+)\.([0-9]+)\.md', line) |
| if m: |
| from_version = f'{m[1]}.{m[2]}.{m[3]}' |
| to_version = f'{m[1]}.{int(m[2]) + 1}.{m[3]}' |
| new_line = line.replace(from_version, to_version) |
| relnotes = new_line.strip() |
| s_f.write(new_line) |
| s_f.write(line) |
| |
| if sitemapfile == output: |
| subprocess.check_call(['git', 'add', output]) |
| |
| return relnotes, to_version |
| |
| def generate(relnotes, to_version, source_dir, output_dir): |
| ''' |
| Generate notes for Meson build next release. |
| ''' |
| title_suffix = ' (in development)' if output_dir else '' |
| title = f'{to_version}{title_suffix}' |
| output = Path(output_dir, relnotes) if output_dir else Path('markdown', relnotes) |
| output.parent.mkdir(exist_ok=True, parents=True) |
| with output.open('w', encoding='utf-8') as ofile: |
| ofile.write(RELNOTE_TEMPLATE.format(title, to_version, title_suffix)) |
| for snippetfile in sorted(Path(source_dir, 'markdown/snippets').glob('*.md')): |
| snippet = snippetfile.read_text(encoding='utf-8') |
| ofile.write(snippet) |
| if not snippet.endswith('\n'): |
| ofile.write('\n') |
| ofile.write('\n') |
| |
| if not output_dir: |
| subprocess.check_call(['git', 'rm', 'markdown/snippets/*.md']) |
| subprocess.check_call(['git', 'add', output]) |
| |
| if __name__ == '__main__': |
| parser = argparse.ArgumentParser(description='Generate meson docs') |
| parser.add_argument('--input-sitemap', default='sitemap.txt') |
| parser.add_argument('--output-sitemap', default='sitemap.txt') |
| parser.add_argument('--source-dir', default='.') |
| parser.add_argument('--output-dir') |
| |
| args = parser.parse_args() |
| |
| if Path(args.source_dir, 'markdown/snippets').glob('*.md'): |
| relnotes, to_version = add_to_sitemap(args.input_sitemap, args.output_sitemap) |
| generate(relnotes, to_version, args.source_dir, args.output_dir) |
| elif args.input_sitemap != args.output_sitemap: |
| shutil.copyfile(args.input_sitemap, args.output_sitemap) |