X-Git-Url: https://git.proxmox.com/?p=pve-docs.git;a=blobdiff_plain;f=asciidoc-pve.in;h=3f789761f002455e9df8458743da814e0f3f72f3;hp=223908fc84c45deba89c059bbf68832287764d41;hb=b2a47ab2b563eed8ed7cdd9a91e0cb2b2f6dabb4;hpb=94a60df796635339273d192aa01f94a773ef575e diff --git a/asciidoc-pve.in b/asciidoc-pve.in index 223908f..3f78976 100644 --- a/asciidoc-pve.in +++ b/asciidoc-pve.in @@ -33,7 +33,7 @@ if (-f "attributes.txt" && -f "pve-admin-guide.adoc") { my $prepared_files = {}; -my $man_target_html = 0; +my $man_target = 'man'; my $env_stack = []; my $env_skip = 0; @@ -133,15 +133,17 @@ sub replace_man_xref { die "link target is not a manual page" if !defined($section); - if (0 && $man_target_html) { + if ($man_target eq 'html') { my $target = $link; $target =~ s/\.adoc//; $target .= ".$section"; return "link:${target}.html#${blockid}\[$text\]"; - } else { + } elsif ($man_target eq 'man') { my $command = $link; $command =~ s/\.adoc//; return "\*${text}\* (man \*${command}\*($section))"; + } else { + die "internal error" } } @@ -151,7 +153,13 @@ sub replace_xref { if ($env eq 'wiki') { return replace_wiki_xref($blockid, $text); } elsif ($env eq 'manvolnum') { - return replace_man_xref($blockid, $text); + if (($man_target eq 'man') || ($man_target eq 'html')) { + return replace_man_xref($blockid, $text); + } elsif ($man_target eq 'wiki') { + return replace_wiki_xref($blockid, $text); + } else { + die "internal error" + } } elsif ($env eq 'default') { return replace_default_xref($blockid, $text); } else { @@ -260,6 +268,8 @@ sub compile_asciidoc { my $attributes = { $env => undef, leveloffset => $leveloffset, + revnumber => $release, + revdate => $date, }; my $mansection = $fileinfo->{mansection}->{$env}->{$infile}; @@ -277,7 +287,7 @@ sub compile_asciidoc { $outfile = $infile; $outfile =~ s/\.adoc$//; if ($env eq 'manvolnum') { - if ($man_target_html) { + if (($man_target eq 'html') || ($man_target eq 'wiki')) { $outfile .= ".$mansection.html"; } else { $outfile .= ".$mansection"; @@ -287,7 +297,7 @@ sub compile_asciidoc { } } - if (($env eq 'manvolnum') && !$man_target_html) { + if (($env eq 'manvolnum') && ($man_target eq 'man')) { # asciidoc /etc/asciidoc/docbook-xsl/manpage.xsl skip REFERENCES # section like footnotes, so we cannot use a2x. @@ -334,11 +344,11 @@ sub compile_asciidoc { $attributes->{icons} = undef; $attributes->{'data-uri'} = undef; - $attributes->{revnumber} = $release; my $cmd = ['asciidoc']; - push @$cmd, '-s' if $env eq 'wiki'; + push @$cmd, '-s' if ($env eq 'wiki') || + (($env eq 'manvolnum') && ($man_target eq 'wiki')); foreach my $key (keys %$attributes) { my $value = $attributes->{$key}; @@ -384,7 +394,18 @@ if ($clicmd eq 'compile-wiki') { } elsif ($clicmd eq 'compile-man-html') { - $man_target_html = 1; + $man_target = 'html'; + + eval { compile_asciidoc('manvolnum'); }; + my $err = $@; + + cleanup(); + + die $err if $err; + +} elsif ($clicmd eq 'compile-man-wiki') { + + $man_target = 'wiki'; eval { compile_asciidoc('manvolnum'); }; my $err = $@; @@ -402,6 +423,51 @@ if ($clicmd eq 'compile-wiki') { die $err if $err; +} elsif ($clicmd eq 'print-links-json') { + + my $outfile; + + GetOptions("outfile=s" => \$outfile, + "verbose" => \$verbose) or + die("Error in command line arguments\n"); + + scalar(@ARGV) == 0 or + die "too many arguments...\n"; + + my $data = {}; + + foreach my $blockid (sort keys %{$fileinfo->{blockid_target}->{default}}) { + my $link = $fileinfo->{blockid_target}->{default}->{$blockid}; + my $reftitle = $fileinfo->{reftitle}->{default}->{$blockid}; + my $reftext = $fileinfo->{reftext}->{default}->{$blockid}; + die "internal error" if $link !~ m/^link:/; + $link =~ s/^link://; + + my $file = $fileinfo->{blockid}->{default}->{$blockid}; + die "internal error - no filename" if ! defined($file); + my $title = $fileinfo->{titles}->{default}->{$file} || + die "internal error - no title"; + + $data->{$blockid}->{title} = $title; + $data->{$blockid}->{link} = $link; + my $subtitle = $reftitle || $reftext; + $data->{$blockid}->{subtitle} = $subtitle + if $subtitle && ($title ne $subtitle); + } + + my $res = to_json($data, { pretty => 1, canonical => 1 } ); + + if (defined($outfile)) { + my $outfh = IO::File->new("$outfile", "w") or + die "unable to open temporary file '$outfile'\n"; + + print $outfh $res; + + } else { + + print $res; + } + } else { die "unknown command '$clicmd'\n";