Parser library for project Change Log documents.
Project Links
Meta
Author: Ben Finney
Maintainer: Ben Finney <ben+python@benfinney.id>
Requires Python: >=3.7
Classifiers
Development Status
- 2 - Pre-Alpha
License
- OSI Approved :: GNU Affero General Public License v3 or later (AGPLv3+)
Programming Language
- Python :: 3
Intended Audience
- Developers
Topic
- Software Development :: Build Tools
changelog-chug is a parser for project Change Log documents.
changelog-chug
Example
Given a reStructuredText document ChangeLog:
Change Log ########## Version 1.0.1 ============= :Released: 2020-01-10 :Maintainer: Cathy Morris <cathy.morris@example.com> … Version 1.0 =========== :Released: 2020-01-10 :Maintainer: Luis Flores <ayalaian@example.org> … Version 0.2 =========== :Released: 2019-07-04 :Maintainer: Cathy Morris <cathy.morris@example.com> … Version 0.2-alpha1 ================== :Released: 2019-07-04 :Maintainer: Cathy Morris <cathy.morris@example.com> … Version 0.1 =========== :Released: 2019-05-16 :Maintainer: Cathy Morris <cathy.morris@example.com> …
Generate Change Log entry data for all versions from the reStructuredText formatted ChangeLog:
>>> import pathlib >>> import pprint >>> import chug.parsers.rest >>> import chug.writers >>> infile_path = pathlib.Path(".", "ChangeLog") >>> document_text = chug.parsers.get_changelog_document_text(infile_path) >>> document = chug.parsers.rest.parse_rest_document_from_text( ... document_text) >>> entries = chug.parsers.rest.make_change_log_entries_from_document( ... document) >>> pprint.pprint([entry.as_version_info_entry() for entry in entries]) [OrderedDict([('release_date', '2020-01-10'), ('version', '1.0.1'), ('maintainer', 'Cathy Morris <cathy.morris@example.com>'), ('body', '…')]), OrderedDict([('release_date', '2020-01-10'), ('version', '1.0'), ('maintainer', 'Luis Flores <ayalaian@example.org>'), ('body', '…')]), OrderedDict([('release_date', '2019-07-04'), ('version', '0.2'), ('maintainer', 'Cathy Morris <cathy.morris@example.com>'), ('body', '…')]), OrderedDict([('release_date', '2019-07-04'), ('version', '0.2-alpha1'), ('maintainer', 'Cathy Morris <cathy.morris@example.com>'), ('body', '…')]), OrderedDict([('release_date', '2019-05-16'), ('version', '0.1'), ('maintainer', 'Cathy Morris <cathy.morris@example.com>'), ('body', '…')])]
Generate a JSON document describing the latest version:
>>> import json >>> latest_entry = entries[0] >>> latest_entry_json = json.dumps( ... latest_entry.as_version_info_entry(), indent=4) >>> print(latest_entry_json) { "release_date": "2020-01-10", "version": "1.0.1", "maintainer": "Cathy Morris <cathy.morris@example.com>", "body": "\u2026" }
Copying
changelog-chug is free software. See the file COPYING for details.