Skip to content

Commit

Permalink
Add gen_changelog.py compatibility shim, fix paths when run under cmake
Browse files Browse the repository at this point in the history
  • Loading branch information
lethosor committed Jul 4, 2020
1 parent f81f773 commit b0fe96f
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 9 deletions.
5 changes: 5 additions & 0 deletions docs/gen_changelog.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
import os, sys
sys.path.append(os.path.join(os.path.dirname(os.path.abspath(__file__)), 'sphinx_extensions'))

from dfhack.changelog import cli_entrypoint
cli_entrypoint()
19 changes: 10 additions & 9 deletions docs/sphinx_extensions/dfhack/changelog.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,14 @@
import os
import sys

from dfhack.util import DFHACK_ROOT, DOCS_ROOT

CHANGELOG_PATHS = (
'docs/changelog.txt',
'scripts/changelog.txt',
'library/xml/changelog.txt',
)
CHANGELOG_PATHS = (os.path.join(DFHACK_ROOT, p) for p in CHANGELOG_PATHS)

CHANGELOG_SECTIONS = [
'New Plugins',
Expand Down Expand Up @@ -237,8 +240,8 @@ def generate_changelog(all=False):
consolidate_changelog(stable_entries)
consolidate_changelog(dev_entries)

print_changelog(versions, stable_entries, 'docs/_auto/news.rst')
print_changelog(versions, dev_entries, 'docs/_auto/news-dev.rst')
print_changelog(versions, stable_entries, os.path.join(DOCS_ROOT, '_auto/news.rst'))
print_changelog(versions, dev_entries, os.path.join(DOCS_ROOT, '_auto/news-dev.rst'))

if all:
for version in versions:
Expand All @@ -250,16 +253,16 @@ def generate_changelog(all=False):
else:
version_entries = {version: dev_entries[version]}
print_changelog([version], version_entries,
'docs/_changelogs/%s-github.txt' % version,
os.path.join(DOCS_ROOT, '_changelogs/%s-github.txt' % version),
replace=False)
print_changelog([version], version_entries,
'docs/_changelogs/%s-reddit.txt' % version,
os.path.join(DOCS_ROOT, '_changelogs/%s-reddit.txt' % version),
replace=False,
prefix='> ')

return entries

if __name__ == '__main__':
def cli_entrypoint():
import argparse
parser = argparse.ArgumentParser()
parser.add_argument('-a', '--all', action='store_true',
Expand All @@ -268,14 +271,12 @@ def generate_changelog(all=False):
help='Check that all entries are printed')
args = parser.parse_args()

os.chdir(os.path.abspath(os.path.dirname(__file__)))
os.chdir('..')
entries = generate_changelog(all=args.all)

if args.check:
with open('docs/_auto/news.rst') as f:
with open(os.path.join(DOCS_ROOT, '_auto/news.rst')) as f:
content_stable = f.read()
with open('docs/_auto/news-dev.rst') as f:
with open(os.path.join(DOCS_ROOT, '_auto/news-dev.rst')) as f:
content_dev = f.read()
for entry in entries:
for description in entry.children:
Expand Down
7 changes: 7 additions & 0 deletions docs/sphinx_extensions/dfhack/util.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
import os

DFHACK_ROOT = os.path.dirname(os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__)))))
DOCS_ROOT = os.path.join(DFHACK_ROOT, 'docs')

if not os.path.isdir(DOCS_ROOT):
raise ReferenceError('docs root not found: %s' % DOCS_ROOT)

0 comments on commit b0fe96f

Please sign in to comment.