91 lines
3.0 KiB
Python
91 lines
3.0 KiB
Python
#!/usr/bin/env python3
|
|
#
|
|
# fontconfig/doc/extract-man-list.py
|
|
#
|
|
# Parses .fncs files and extracts list of man pages that will be generated
|
|
#
|
|
# Copyright © 2020 Tim-Philipp Müller
|
|
#
|
|
# Permission to use, copy, modify, distribute, and sell this software and its
|
|
# documentation for any purpose is hereby granted without fee, provided that
|
|
# the above copyright notice appear in all copies and that both that
|
|
# copyright notice and this permission notice appear in supporting
|
|
# documentation, and that the name of the author(s) not be used in
|
|
# advertising or publicity pertaining to distribution of the software without
|
|
# specific, written prior permission. The authors make no
|
|
# representations about the suitability of this software for any purpose. It
|
|
# is provided "as is" without express or implied warranty.
|
|
#
|
|
# THE AUTHOR(S) DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
|
# INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
|
|
# EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
|
# CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
|
|
# DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
|
|
# TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
# PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
import sys
|
|
import re
|
|
|
|
replacement_sets = []
|
|
|
|
# -------------------------------------
|
|
# Read replacement sets from .fncs file
|
|
# -------------------------------------
|
|
|
|
def read_fncs_file(fn):
|
|
global replacement_sets
|
|
|
|
with open(fn, 'r', encoding='utf8') as f:
|
|
fncs_text = f.read()
|
|
|
|
# split into replacement sets
|
|
fncs_chunks = fncs_text.strip().split('@@')
|
|
|
|
for chunk in fncs_chunks:
|
|
# get rid of any preamble such as license and FcFreeTypeQueryAll decl in fcfreetype.fncs
|
|
start = chunk.find('@')
|
|
if start:
|
|
chunk = chunk[start:]
|
|
|
|
# split at '@' and remove empty lines (keep it simple instead of doing fancy
|
|
# things with regular expression matches, we control the input after all)
|
|
lines = [line for line in chunk.split('@') if line.strip()]
|
|
|
|
replacement_set = {}
|
|
|
|
while lines:
|
|
tag = lines.pop(0).strip()
|
|
# FIXME: this hard codes the tag used in funcs.sgml - we're lazy
|
|
if tag.startswith('PROTOTYPE'):
|
|
text = ''
|
|
else:
|
|
text = lines.pop(0).strip()
|
|
if text.endswith('%'):
|
|
text = text[:-1] + ' '
|
|
|
|
replacement_set[tag] = text
|
|
|
|
if replacement_set:
|
|
replacement_sets += [replacement_set]
|
|
|
|
# ----------------------------------------------------------------------------
|
|
# Main
|
|
# ----------------------------------------------------------------------------
|
|
|
|
if len(sys.argv) < 2:
|
|
sys.exit('Usage: {} FILE1.FNCS [FILE2.FNCS...]'.format(sys.argv[0]))
|
|
|
|
fout = sys.stdout
|
|
|
|
for input_fn in sys.argv[1:]:
|
|
read_fncs_file(input_fn)
|
|
|
|
# process template for each replacement set
|
|
for rep in replacement_sets:
|
|
if 'FUNC+' in rep:
|
|
man_page_title = rep.get('TITLE', rep['FUNC'])
|
|
else:
|
|
man_page_title = rep['FUNC']
|
|
print(man_page_title)
|