Merge tag 'docs-for-linus' of git://git.lwn.net/linux-2.6
Pull documentation updates from Jonathan Corbet:
"There's been a fair amount going on in the docs tree this time around,
including:
- Support for reproducible document builds, from Ben Hutchings and
company.
- The ability to automatically generate cross-reference links within
a single DocBook book and embedded descriptions for large
structures. From Danilo Cesar Lemes de Paula.
- A new document on how to add a system call from David Drysdale.
- Chameleon bus documentation from Johannes Thumshirn.
...plus the usual collection of improvements, typo fixes, and more"
* tag 'docs-for-linus' of git://git.lwn.net/linux-2.6: (39 commits)
Documentation, add kernel-parameters.txt entry for dis_ucode_ldr
Documentation/x86: Rename IRQSTACKSIZE to IRQ_STACK_SIZE
Documentation/Intel-IOMMU.txt: Modify definition of DRHD
docs: update HOWTO for 3.x -> 4.x versioning
kernel-doc: ignore unneeded attribute information
scripts/kernel-doc: Adding cross-reference links to html documentation.
DocBook: Fix non-determinstic installation of duplicate man pages
Documentation: minor typo fix in mailbox.txt
Documentation: describe how to add a system call
doc: Add more workqueue functions to the documentation
ARM: keystone: add documentation for SoCs and EVMs
scripts/kernel-doc Allow struct arguments documentation in struct body
SubmittingPatches: remove stray quote character
Revert "DocBook: Avoid building man pages repeatedly and inconsistently"
Documentation: Minor changes to men-chameleon-bus.txt
Doc: fix trivial typo in SubmittingPatches
MAINTAINERS: Direct Documentation/DocBook/media properly
Documentation: installed man pages don't need to be executable
fix Evolution submenu name in email-clients.txt
Documentation: Add MCB documentation
...
This commit is contained in:
@@ -133,6 +133,30 @@ use strict;
|
||||
#
|
||||
# All descriptions can be multiline, except the short function description.
|
||||
#
|
||||
# For really longs structs, you can also describe arguments inside the
|
||||
# body of the struct.
|
||||
# eg.
|
||||
# /**
|
||||
# * struct my_struct - short description
|
||||
# * @a: first member
|
||||
# * @b: second member
|
||||
# *
|
||||
# * Longer description
|
||||
# */
|
||||
# struct my_struct {
|
||||
# int a;
|
||||
# int b;
|
||||
# /**
|
||||
# * @c: This is longer description of C
|
||||
# *
|
||||
# * You can use paragraphs to describe arguments
|
||||
# * using this method.
|
||||
# */
|
||||
# int c;
|
||||
# };
|
||||
#
|
||||
# This should be use only for struct/enum members.
|
||||
#
|
||||
# You can also add additional sections. When documenting kernel functions you
|
||||
# should document the "Context:" of the function, e.g. whether the functions
|
||||
# can be called form interrupts. Unlike other sections you can end it with an
|
||||
@@ -253,11 +277,20 @@ my %highlights = %highlights_man;
|
||||
my $blankline = $blankline_man;
|
||||
my $modulename = "Kernel API";
|
||||
my $function_only = 0;
|
||||
my $show_not_found = 0;
|
||||
|
||||
my @build_time;
|
||||
if (defined($ENV{'KBUILD_BUILD_TIMESTAMP'}) &&
|
||||
(my $seconds = `date -d"${ENV{'KBUILD_BUILD_TIMESTAMP'}}" +%s`) ne '') {
|
||||
@build_time = gmtime($seconds);
|
||||
} else {
|
||||
@build_time = localtime;
|
||||
}
|
||||
|
||||
my $man_date = ('January', 'February', 'March', 'April', 'May', 'June',
|
||||
'July', 'August', 'September', 'October',
|
||||
'November', 'December')[(localtime)[4]] .
|
||||
" " . ((localtime)[5]+1900);
|
||||
my $show_not_found = 0;
|
||||
'November', 'December')[$build_time[4]] .
|
||||
" " . ($build_time[5]+1900);
|
||||
|
||||
# Essentially these are globals.
|
||||
# They probably want to be tidied up, made more localised or something.
|
||||
@@ -287,9 +320,19 @@ my $lineprefix="";
|
||||
# 2 - scanning field start.
|
||||
# 3 - scanning prototype.
|
||||
# 4 - documentation block
|
||||
# 5 - gathering documentation outside main block
|
||||
my $state;
|
||||
my $in_doc_sect;
|
||||
|
||||
# Split Doc State
|
||||
# 0 - Invalid (Before start or after finish)
|
||||
# 1 - Is started (the /** was found inside a struct)
|
||||
# 2 - The @parameter header was found, start accepting multi paragraph text.
|
||||
# 3 - Finished (the */ was found)
|
||||
# 4 - Error - Comment without header was found. Spit a warning as it's not
|
||||
# proper kernel-doc and ignore the rest.
|
||||
my $split_doc_state;
|
||||
|
||||
#declaration types: can be
|
||||
# 'function', 'struct', 'union', 'enum', 'typedef'
|
||||
my $decl_type;
|
||||
@@ -304,6 +347,9 @@ my $doc_decl = $doc_com . '(\w+)';
|
||||
my $doc_sect = $doc_com . '([' . $doc_special . ']?[\w\s]+):(.*)';
|
||||
my $doc_content = $doc_com_body . '(.*)';
|
||||
my $doc_block = $doc_com . 'DOC:\s*(.*)?';
|
||||
my $doc_split_start = '^\s*/\*\*\s*$';
|
||||
my $doc_split_sect = '\s*\*\s*(@[\w\s]+):(.*)';
|
||||
my $doc_split_end = '^\s*\*/\s*$';
|
||||
|
||||
my %constants;
|
||||
my %parameterdescs;
|
||||
@@ -1753,7 +1799,9 @@ sub dump_struct($$) {
|
||||
# strip kmemcheck_bitfield_{begin,end}.*;
|
||||
$members =~ s/kmemcheck_bitfield_.*?;//gos;
|
||||
# strip attributes
|
||||
$members =~ s/__attribute__\s*\(\([a-z,_\*\s\(\)]*\)\)//i;
|
||||
$members =~ s/__aligned\s*\([^;]*\)//gos;
|
||||
$members =~ s/\s*CRYPTO_MINALIGN_ATTR//gos;
|
||||
|
||||
create_parameterlist($members, ';', $file);
|
||||
check_sections($file, $declaration_name, "struct", $sectcheck, $struct_actual, $nested);
|
||||
@@ -2181,6 +2229,7 @@ sub reset_state {
|
||||
$prototype = "";
|
||||
|
||||
$state = 0;
|
||||
$split_doc_state = 0;
|
||||
}
|
||||
|
||||
sub tracepoint_munge($) {
|
||||
@@ -2453,7 +2502,6 @@ sub process_file($) {
|
||||
}
|
||||
$section = $newsection;
|
||||
} elsif (/$doc_end/) {
|
||||
|
||||
if (($contents ne "") && ($contents ne "\n")) {
|
||||
dump_section($file, $section, xml_escape($contents));
|
||||
$section = $section_default;
|
||||
@@ -2494,8 +2542,44 @@ sub process_file($) {
|
||||
print STDERR "Warning(${file}:$.): bad line: $_";
|
||||
++$warnings;
|
||||
}
|
||||
} elsif ($state == 5) { # scanning for split parameters
|
||||
# First line (state 1) needs to be a @parameter
|
||||
if ($split_doc_state == 1 && /$doc_split_sect/o) {
|
||||
$section = $1;
|
||||
$contents = $2;
|
||||
if ($contents ne "") {
|
||||
while ((substr($contents, 0, 1) eq " ") ||
|
||||
substr($contents, 0, 1) eq "\t") {
|
||||
$contents = substr($contents, 1);
|
||||
}
|
||||
$contents .= "\n";
|
||||
}
|
||||
$split_doc_state = 2;
|
||||
# Documentation block end */
|
||||
} elsif (/$doc_split_end/) {
|
||||
if (($contents ne "") && ($contents ne "\n")) {
|
||||
dump_section($file, $section, xml_escape($contents));
|
||||
$section = $section_default;
|
||||
$contents = "";
|
||||
}
|
||||
$state = 3;
|
||||
$split_doc_state = 0;
|
||||
# Regular text
|
||||
} elsif (/$doc_content/) {
|
||||
if ($split_doc_state == 2) {
|
||||
$contents .= $1 . "\n";
|
||||
} elsif ($split_doc_state == 1) {
|
||||
$split_doc_state = 4;
|
||||
print STDERR "Warning(${file}:$.): ";
|
||||
print STDERR "Incorrect use of kernel-doc format: $_";
|
||||
++$warnings;
|
||||
}
|
||||
}
|
||||
} elsif ($state == 3) { # scanning for function '{' (end of prototype)
|
||||
if ($decl_type eq 'function') {
|
||||
if (/$doc_split_start/) {
|
||||
$state = 5;
|
||||
$split_doc_state = 1;
|
||||
} elsif ($decl_type eq 'function') {
|
||||
process_state3_function($_, $file);
|
||||
} else {
|
||||
process_state3_type($_, $file);
|
||||
@@ -2587,7 +2671,7 @@ $kernelversion = get_kernel_version();
|
||||
|
||||
# generate a sequence of code that will splice in highlighting information
|
||||
# using the s// operator.
|
||||
foreach my $pattern (keys %highlights) {
|
||||
foreach my $pattern (sort keys %highlights) {
|
||||
# print STDERR "scanning pattern:$pattern, highlight:($highlights{$pattern})\n";
|
||||
$dohighlight .= "\$contents =~ s:$pattern:$highlights{$pattern}:gs;\n";
|
||||
}
|
||||
|
||||
198
scripts/kernel-doc-xml-ref
Executable file
198
scripts/kernel-doc-xml-ref
Executable file
@@ -0,0 +1,198 @@
|
||||
#!/usr/bin/perl -w
|
||||
|
||||
use strict;
|
||||
|
||||
## Copyright (C) 2015 Intel Corporation ##
|
||||
# ##
|
||||
## This software falls under the GNU General Public License. ##
|
||||
## Please read the COPYING file for more information ##
|
||||
#
|
||||
#
|
||||
# This software reads a XML file and a list of valid interal
|
||||
# references to replace Docbook tags with links.
|
||||
#
|
||||
# The list of "valid internal references" must be one-per-line in the following format:
|
||||
# API-struct-foo
|
||||
# API-enum-bar
|
||||
# API-my-function
|
||||
#
|
||||
# The software walks over the XML file looking for xml tags representing possible references
|
||||
# to the Document. Each reference will be cross checked against the "Valid Internal Reference" list. If
|
||||
# the referece is found it replaces its content by a <link> tag.
|
||||
#
|
||||
# usage:
|
||||
# kernel-doc-xml-ref -db filename
|
||||
# xml filename > outputfile
|
||||
|
||||
# read arguments
|
||||
if ($#ARGV != 2) {
|
||||
usage();
|
||||
}
|
||||
|
||||
#Holds the database filename
|
||||
my $databasefile;
|
||||
my @database;
|
||||
|
||||
#holds the inputfile
|
||||
my $inputfile;
|
||||
my $errors = 0;
|
||||
|
||||
my %highlights = (
|
||||
"<function>(.*?)</function>",
|
||||
"\"<function>\" . convert_function(\$1, \$line) . \"</function>\"",
|
||||
"<structname>(.*?)</structname>",
|
||||
"\"<structname>\" . convert_struct(\$1) . \"</structname>\"",
|
||||
"<funcdef>(.*?)<function>(.*?)</function></funcdef>",
|
||||
"\"<funcdef>\" . convert_param(\$1) . \"<function>\$2</function></funcdef>\"",
|
||||
"<paramdef>(.*?)<parameter>(.*?)</parameter></paramdef>",
|
||||
"\"<paramdef>\" . convert_param(\$1) . \"<parameter>\$2</parameter></paramdef>\"");
|
||||
|
||||
while($ARGV[0] =~ m/^-(.*)/) {
|
||||
my $cmd = shift @ARGV;
|
||||
if ($cmd eq "-db") {
|
||||
$databasefile = shift @ARGV
|
||||
} else {
|
||||
usage();
|
||||
}
|
||||
}
|
||||
$inputfile = shift @ARGV;
|
||||
|
||||
sub open_database {
|
||||
open (my $handle, '<', $databasefile) or die "Cannot open $databasefile";
|
||||
chomp(my @lines = <$handle>);
|
||||
close $handle;
|
||||
|
||||
@database = @lines;
|
||||
}
|
||||
|
||||
sub process_file {
|
||||
open_database();
|
||||
|
||||
my $dohighlight;
|
||||
foreach my $pattern (keys %highlights) {
|
||||
$dohighlight .= "\$line =~ s:$pattern:$highlights{$pattern}:eg;\n";
|
||||
}
|
||||
|
||||
open(FILE, $inputfile) or die("Could not open $inputfile") or die ("Cannot open $inputfile");
|
||||
foreach my $line (<FILE>) {
|
||||
eval $dohighlight;
|
||||
print $line;
|
||||
}
|
||||
}
|
||||
|
||||
sub trim($_)
|
||||
{
|
||||
my $str = $_[0];
|
||||
$str =~ s/^\s+|\s+$//g;
|
||||
return $str
|
||||
}
|
||||
|
||||
sub has_key_defined($_)
|
||||
{
|
||||
if ( grep( /^$_[0]$/, @database)) {
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
# Gets a <function> content and add it a hyperlink if possible.
|
||||
sub convert_function($_)
|
||||
{
|
||||
my $arg = $_[0];
|
||||
my $key = $_[0];
|
||||
|
||||
my $line = $_[1];
|
||||
|
||||
$key = trim($key);
|
||||
|
||||
$key =~ s/[^A-Za-z0-9]/-/g;
|
||||
$key = "API-" . $key;
|
||||
|
||||
# We shouldn't add links to <funcdef> prototype
|
||||
if (!has_key_defined($key) || $line =~ m/\s+<funcdef/i) {
|
||||
return $arg;
|
||||
}
|
||||
|
||||
my $head = $arg;
|
||||
my $tail = "";
|
||||
if ($arg =~ /(.*?)( ?)$/) {
|
||||
$head = $1;
|
||||
$tail = $2;
|
||||
}
|
||||
return "<link linkend=\"$key\">$head</link>$tail";
|
||||
}
|
||||
|
||||
# Converting a struct text to link
|
||||
sub convert_struct($_)
|
||||
{
|
||||
my $arg = $_[0];
|
||||
my $key = $_[0];
|
||||
$key =~ s/(struct )?(\w)/$2/g;
|
||||
$key =~ s/[^A-Za-z0-9]/-/g;
|
||||
$key = "API-struct-" . $key;
|
||||
|
||||
if (!has_key_defined($key)) {
|
||||
return $arg;
|
||||
}
|
||||
|
||||
my ($head, $tail) = split_pointer($arg);
|
||||
return "<link linkend=\"$key\">$head</link>$tail";
|
||||
}
|
||||
|
||||
# Identify "object *" elements
|
||||
sub split_pointer($_)
|
||||
{
|
||||
my $arg = $_[0];
|
||||
if ($arg =~ /(.*?)( ?\* ?)/) {
|
||||
return ($1, $2);
|
||||
}
|
||||
return ($arg, "");
|
||||
}
|
||||
|
||||
sub convert_param($_)
|
||||
{
|
||||
my $type = $_[0];
|
||||
my $keyname = convert_key_name($type);
|
||||
|
||||
if (!has_key_defined($keyname)) {
|
||||
return $type;
|
||||
}
|
||||
|
||||
my ($head, $tail) = split_pointer($type);
|
||||
return "<link linkend=\"$keyname\">$head</link>$tail";
|
||||
|
||||
}
|
||||
|
||||
# DocBook links are in the API-<TYPE>-<STRUCT-NAME> format
|
||||
# This method gets an element and returns a valid DocBook reference for it.
|
||||
sub convert_key_name($_)
|
||||
{
|
||||
#Pattern $2 is optional and might be uninitialized
|
||||
no warnings 'uninitialized';
|
||||
|
||||
my $str = $_[0];
|
||||
$str =~ s/(const|static)? ?(struct)? ?([a-zA-Z0-9_]+) ?(\*|&)?/$2 $3/g ;
|
||||
|
||||
# trim
|
||||
$str =~ s/^\s+|\s+$//g;
|
||||
|
||||
# spaces and _ to -
|
||||
$str =~ s/[^A-Za-z0-9]/-/g;
|
||||
|
||||
return "API-" . $str;
|
||||
}
|
||||
|
||||
sub usage {
|
||||
print "Usage: $0 -db database filename\n";
|
||||
print " xml source file(s) > outputfile\n";
|
||||
exit 1;
|
||||
}
|
||||
|
||||
# starting point
|
||||
process_file();
|
||||
|
||||
if ($errors) {
|
||||
print STDERR "$errors errors\n";
|
||||
}
|
||||
|
||||
exit($errors);
|
||||
Reference in New Issue
Block a user