the-bastion/doc/sphinx/build-bastion-conf-help.pl

118 lines
3 KiB
Perl
Raw Normal View History

#! /usr/bin/env perl
# vim: set filetype=perl ts=4 sw=4 sts=4 et:
use strict;
use warnings;
my %h;
my @out;
my $section;
my %sections;
my %sectiondesc;
my @orderedsections;
sub dumpdoc {
if (!%h) {
2020-12-16 20:53:47 +08:00
; # nothing to do
}
elsif (defined $h{param} && defined $h{default} && defined $h{desc} && defined $h{type}) {
die "attempting to dump data but section=$section" if !$section;
2020-12-16 20:53:47 +08:00
push @{$sections{$section}}, $h{param};
push @out, ".. _bastion_conf_$h{param}:\n";
push @out, "\n";
push @out, "$h{param}\n";
my $len = length($h{param});
2020-12-16 20:53:47 +08:00
push @out, "*" x $len . "\n\n";
push @out, ":Type: ``$h{type}``\n\n";
push @out, ":Default: ``$h{default}``\n\n";
push @out, ":Example: ``$h{example}``\n\n" if $h{example};
push @out, "$h{desc}\n\n";
}
else {
2020-12-16 20:53:47 +08:00
die "something is missing: " . ($h{param} ? "" : "param ") . ($h{default} ? "" : "default ") . ($h{desc} ? "" : "desc ") . ($h{type} ? "" : "type") . "\n";
}
%h = ();
2020-12-16 20:53:47 +08:00
return;
}
my $state = '';
while (<>) {
print STDERR $_;
next if /^\s*$/;
if (m{^# ([a-zA-Z0-9_]+) \((.+)\)}) {
$h{param} = $1;
2020-12-16 20:53:47 +08:00
$h{type} = $2;
$state = 'name';
}
elsif (m{^#\s+DESC:\s+(.+)$}) {
$h{desc} = $1;
$state = 'desc';
}
elsif (m{^#\s+EXAMPLE:\s+(.+)$}) {
$h{example} = $1;
$state = 'example';
}
elsif (m{^#\s+DEFAULT:\s+(.+)$}) {
$h{default} = $1;
$state = 'default';
}
elsif (m{^#\s{0,11}(.*)$} && exists $h{desc} && $state eq 'desc') {
$h{desc} .= "\n$1";
}
elsif (m{^"([^"]+)"} && $h{param} eq $1) {
$state = '';
dumpdoc();
}
elsif (m{^# > (.+)$}) {
if (%h or $state) { die "new section '$1' but we have pending data"; }
$section = $1;
2020-12-16 20:53:47 +08:00
$state = 'section';
push @orderedsections, $section;
2020-12-16 20:53:47 +08:00
push @out, "$1\n";
push @out, "-" x (length($1)) . "\n\n";
}
elsif (m{^# >> (.+)$} and $state eq 'section' and $section) {
$sectiondesc{$section} = $1;
}
elsif (!/^##|^[{}]|^#\s*$/) {
die("\\--- lost here, state='$state'");
}
}
dumpdoc();
2020-12-16 20:53:47 +08:00
print <<'EOF'
======================
bastion.conf reference
======================
.. note::
The Bastion has a lot of configuration options so that you can tailor it to your needs.
However, if you're just starting and would like to get started quickly, just configure
the ``Main Options``. All the other options have sane defaults that can still be customized
at a later time.
Option List
===========
EOF
2020-12-16 20:53:47 +08:00
;
foreach my $section (@orderedsections) {
die "no description for section $section" if !$sectiondesc{$section};
print "\n$section\n";
2020-12-16 20:53:47 +08:00
print "-" x (length($section)) . "\n\n";
print $sectiondesc{$section} . "\n\n";
foreach (@{$sections{$section}}) {
print "- :ref:`bastion_conf_$_`\n";
}
}
2020-12-16 20:53:47 +08:00
print <<'EOF'
Option Reference
================
EOF
2020-12-16 20:53:47 +08:00
;
print join("", @out);