mirror of
https://git.proxmox.com/git/pve-docs
synced 2025-06-14 22:58:14 +00:00
asciidoc-pve.in: add code to auto generate online help data
We include that in the extjs code for the GUI.
This commit is contained in:
parent
80c0adcbc3
commit
a297b96efb
118
asciidoc-pve.in
118
asciidoc-pve.in
@ -37,6 +37,21 @@ my $man_target = 'man';
|
|||||||
my $env_stack = [];
|
my $env_stack = [];
|
||||||
my $env_skip = 0;
|
my $env_skip = 0;
|
||||||
|
|
||||||
|
my $online_help_links = {
|
||||||
|
'pve_service_daemons' => {
|
||||||
|
link => '/pve-docs/index.html#_service_daemons',
|
||||||
|
title => 'Service Daemons',
|
||||||
|
},
|
||||||
|
'pve_documentation_index' => {
|
||||||
|
link => '/pve-docs/index.html',
|
||||||
|
title => 'Proxmox VE Documentation Index',
|
||||||
|
},
|
||||||
|
'pve_admin_guide' => {
|
||||||
|
link => '/pve-docs/pve-admin-guide.html',
|
||||||
|
title => 'Proxmox VE Administration Guide',
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
sub debug {
|
sub debug {
|
||||||
my $msg = shift;
|
my $msg = shift;
|
||||||
|
|
||||||
@ -374,6 +389,52 @@ sub compile_asciidoc {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub get_links {
|
||||||
|
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub scan_extjs_file {
|
||||||
|
my ($filename, $res_data) = @_;
|
||||||
|
|
||||||
|
my $fh = IO::File->new($filename, "r") ||
|
||||||
|
die "unable to open '$filename' - $!\n";
|
||||||
|
|
||||||
|
debug("scan-extjs $filename");
|
||||||
|
|
||||||
|
while(defined(my $line = <$fh>)) {
|
||||||
|
if ($line =~ m/\s+onlineHelp:\s*[\'\"](.*?)[\'\"]/) {
|
||||||
|
my $blockid = $1;
|
||||||
|
my $link = $fileinfo->{blockid_target}->{default}->{$blockid};
|
||||||
|
die "undefined blockid '$blockid' ($filename, line $.)\n"
|
||||||
|
if !(defined($link) || defined($online_help_links->{$blockid}));
|
||||||
|
|
||||||
|
$res_data->{$blockid} = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if ($clicmd eq 'compile-wiki') {
|
if ($clicmd eq 'compile-wiki') {
|
||||||
|
|
||||||
eval { compile_asciidoc('wiki'); };
|
eval { compile_asciidoc('wiki'); };
|
||||||
@ -423,7 +484,7 @@ if ($clicmd eq 'compile-wiki') {
|
|||||||
|
|
||||||
die $err if $err;
|
die $err if $err;
|
||||||
|
|
||||||
} elsif ($clicmd eq 'print-links-json') {
|
} elsif ($clicmd eq 'print-links') {
|
||||||
|
|
||||||
my $outfile;
|
my $outfile;
|
||||||
|
|
||||||
@ -434,26 +495,7 @@ if ($clicmd eq 'compile-wiki') {
|
|||||||
scalar(@ARGV) == 0 or
|
scalar(@ARGV) == 0 or
|
||||||
die "too many arguments...\n";
|
die "too many arguments...\n";
|
||||||
|
|
||||||
my $data = {};
|
my $data = get_links();
|
||||||
|
|
||||||
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 } );
|
my $res = to_json($data, { pretty => 1, canonical => 1 } );
|
||||||
|
|
||||||
@ -468,6 +510,36 @@ if ($clicmd eq 'compile-wiki') {
|
|||||||
print $res;
|
print $res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
} elsif ($clicmd eq 'scan-extjs') {
|
||||||
|
|
||||||
|
GetOptions("verbose" => \$verbose) or
|
||||||
|
die("Error in command line arguments\n");
|
||||||
|
|
||||||
|
my $link_hash = {};
|
||||||
|
my $scanned_files = {};
|
||||||
|
while (my $filename = shift) {
|
||||||
|
die "got strange file name '$filename'\n"
|
||||||
|
if $filename !~ m/\.js$/;
|
||||||
|
next if $scanned_files->{$filename};
|
||||||
|
|
||||||
|
scan_extjs_file($filename, $link_hash);
|
||||||
|
$scanned_files->{$filename} = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
my $data = get_links();
|
||||||
|
|
||||||
|
my $res_data = {};
|
||||||
|
|
||||||
|
foreach my $blockid (keys %$link_hash) {
|
||||||
|
$res_data->{$blockid} = $data->{$blockid} || $online_help_links->{$blockid} ||
|
||||||
|
die "internal error - no data for '$blockid'";
|
||||||
|
}
|
||||||
|
|
||||||
|
my $data_str = to_json($res_data, { pretty => 1, canonical => 1 });
|
||||||
|
chomp $data_str;
|
||||||
|
|
||||||
|
print "var pveOnlineHelpInfo = ${data_str};\n";
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
die "unknown command '$clicmd'\n";
|
die "unknown command '$clicmd'\n";
|
||||||
@ -475,10 +547,6 @@ if ($clicmd eq 'compile-wiki') {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
exit 0;
|
exit 0;
|
||||||
|
|
||||||
__END__
|
__END__
|
||||||
|
Loading…
Reference in New Issue
Block a user