kernel-doc: concatenate contents of colliding sections
authorJani Nikula <jani.nikula@intel.com>
Sun, 29 May 2016 06:40:44 +0000 (09:40 +0300)
committerJani Nikula <jani.nikula@intel.com>
Mon, 30 May 2016 10:39:03 +0000 (13:39 +0300)
If there are multiple sections with the same section name, the current
implementation results in several sections by the same heading, with the
content duplicated from the last section to all. Even if there's the
error message, a more graceful approach is to combine all the
identically named sections into one, with concatenated contents.

With the supported sections already limited to select few, there are
massively fewer collisions than there used to be, but this is still
useful for e.g. when function parameters are documented in the middle of
a documentation comment, with description spread out above and
below. (This is not a recommended documentation style, but used in the
kernel nonetheless.)

We can now also demote the error to a warning.

Signed-off-by: Jani Nikula <jani.nikula@intel.com>
scripts/kernel-doc

index 20136564f2649a3463f10c9e2c39aa8c26c6e8e2..3ac4b57ed76a5c5b03db683a431200a694b2a173 100755 (executable)
@@ -524,11 +524,13 @@ sub dump_section {
     } else {
 #      print STDERR "other section '$name' = '$contents'\n";
        if (defined($sections{$name}) && ($sections{$name} ne "")) {
-               print STDERR "${file}:$.: error: duplicate section name '$name'\n";
-               ++$errors;
+           print STDERR "${file}:$.: warning: duplicate section name '$name'\n";
+           ++$warnings;
+           $sections{$name} .= $contents;
+       } else {
+           $sections{$name} = $contents;
+           push @sectionlist, $name;
        }
-       $sections{$name} = $contents;
-       push @sectionlist, $name;
     }
 }