Blame view

scripts/kernel-doc 62.3 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
2
3
4
5
6
7
  #!/usr/bin/perl -w
  
  use strict;
  
  ## Copyright (c) 1998 Michael Zucchi, All Rights Reserved        ##
  ## Copyright (C) 2000, 1  Tim Waugh <twaugh@redhat.com>          ##
  ## Copyright (C) 2001  Simon Huggins                             ##
2b35f4d9c   Randy Dunlap   kernel-doc: escap...
8
  ## Copyright (C) 2005-2010  Randy Dunlap                         ##
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
9
10
11
12
13
14
  ## 								 ##
  ## #define enhancements by Armin Kuster <akuster@mvista.com>	 ##
  ## Copyright (c) 2000 MontaVista Software, Inc.			 ##
  ## 								 ##
  ## This software falls under the GNU General Public License.     ##
  ## Please read the COPYING file for more information             ##
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
  # 18/01/2001 - 	Cleanups
  # 		Functions prototyped as foo(void) same as foo()
  # 		Stop eval'ing where we don't need to.
  # -- huggie@earth.li
  
  # 27/06/2001 -  Allowed whitespace after initial "/**" and
  #               allowed comments before function declarations.
  # -- Christian Kreibich <ck@whoop.org>
  
  # Still to do:
  # 	- add perldoc documentation
  # 	- Look more closely at some of the scarier bits :)
  
  # 26/05/2001 - 	Support for separate source and object trees.
  #		Return error code.
  # 		Keith Owens <kaos@ocs.com.au>
  
  # 23/09/2001 - Added support for typedefs, structs, enums and unions
  #              Support for Context section; can be terminated using empty line
  #              Small fixes (like spaces vs. \s in regex)
  # -- Tim Jansen <tim@tjansen.de>
  
  
  #
  # This will read a 'c' file and scan for embedded comments in the
  # style of gnome comments (+minor extensions - see below).
  #
  
  # Note: This only supports 'c'.
  
  # usage:
eda603f6c   Johannes Berg   docbook: warn on ...
46
  # kernel-doc [ -docbook | -html | -text | -man | -list ] [ -no-doc-sections ]
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
47
48
49
50
51
  #           [ -function funcname [ -function funcname ...] ] c file(s)s > outputfile
  # or
  #           [ -nofunction funcname [ -function funcname ...] ] c file(s)s > outputfile
  #
  #  Set output format using one of -docbook -html -text or -man.  Default is man.
eda603f6c   Johannes Berg   docbook: warn on ...
52
  #  The -list format is for internal use by docproc.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
53
  #
4b44595a7   Johannes Berg   kernel-doc: proce...
54
55
56
  #  -no-doc-sections
  #	Do not output DOC: sections
  #
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
57
  #  -function funcname
b112e0f73   Johannes Berg   kernel-doc: singl...
58
59
  #	If set, then only generate documentation for the given function(s) or
  #	DOC: section titles.  All other functions and DOC: sections are ignored.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
60
61
  #
  #  -nofunction funcname
b112e0f73   Johannes Berg   kernel-doc: singl...
62
63
64
  #	If set, then only generate documentation for the other function(s)/DOC:
  #	sections. Cannot be used together with -function (yes, that's a bug --
  #	perl hackers can fix it 8))
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
  #
  #  c files - list of 'c' files to process
  #
  #  All output goes to stdout, with errors to stderr.
  
  #
  # format of comments.
  # In the following table, (...)? signifies optional structure.
  #                         (...)* signifies 0 or more structure elements
  # /**
  #  * function_name(:)? (- short description)?
  # (* @parameterx: (description of parameter x)?)*
  # (* a blank line)?
  #  * (Description:)? (Description of function)?
  #  * (section header: (section description)? )*
  #  (*)?*/
  #
  # So .. the trivial example would be:
  #
  # /**
  #  * my_function
b9d97328e   Randy Dunlap   kernel-doc: clean...
86
  #  */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
87
  #
891dcd2f7   Randy Dunlap   [PATCH] kernel-do...
88
  # If the Description: header tag is omitted, then there must be a blank line
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
89
90
91
92
93
94
  # after the last parameter specification.
  # e.g.
  # /**
  #  * my_function - does my stuff
  #  * @my_arg: its mine damnit
  #  *
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
95
  #  * Does my stuff explained.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
96
97
98
99
100
101
  #  */
  #
  #  or, could also use:
  # /**
  #  * my_function - does my stuff
  #  * @my_arg: its mine damnit
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
102
  #  * Description: Does my stuff explained.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
103
104
105
  #  */
  # etc.
  #
b9d97328e   Randy Dunlap   kernel-doc: clean...
106
  # Besides functions you can also write documentation for structs, unions,
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
107
108
109
  # enums and typedefs. Instead of the function name you must write the name
  # of the declaration;  the struct/union/enum/typedef must always precede
  # the name. Nesting of declarations is not supported.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
110
111
112
113
114
115
  # Use the argument mechanism to document members or constants.
  # e.g.
  # /**
  #  * struct my_struct - short description
  #  * @a: first member
  #  * @b: second member
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
116
  #  *
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
117
118
119
120
121
  #  * Longer description
  #  */
  # struct my_struct {
  #     int a;
  #     int b;
aeec46b97   Martin Waitz   [PATCH] DocBook: ...
122
123
  # /* private: */
  #     int c;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
124
125
126
  # };
  #
  # All descriptions can be multiline, except the short function description.
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
127
128
129
  #
  # You can also add additional sections. When documenting kernel functions you
  # should document the "Context:" of the function, e.g. whether the functions
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
130
  # can be called form interrupts. Unlike other sections you can end it with an
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
131
132
  # empty line.
  # Example-sections should contain the string EXAMPLE so that they are marked
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
133
134
135
136
137
138
139
  # appropriately in DocBook.
  #
  # Example:
  # /**
  #  * user_function - function that can only be called in user context
  #  * @a: some argument
  #  * Context: !in_interrupt()
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
140
  #  *
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
  #  * Some description
  #  * Example:
  #  *    user_function(22);
  #  */
  # ...
  #
  #
  # All descriptive text is further processed, scanning for the following special
  # patterns, which are highlighted appropriately.
  #
  # 'funcname()' - function
  # '$ENVVAR' - environmental variable
  # '&struct_name' - name of a structure (up to two words including 'struct')
  # '@parameter' - name of a parameter
  # '%CONST' - name of a constant.
8484baaa5   Randy Dunlap   kernel-doc: code ...
156
  ## init lots of data
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
157
158
  my $errors = 0;
  my $warnings = 0;
5f8c7c98a   Randy Dunlap   kernel-doc: fix u...
159
  my $anon_struct_union = 0;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
160
161
162
163
164
  
  # match expressions used to find embedded type information
  my $type_constant = '\%([-_\w]+)';
  my $type_func = '(\w+)\(\)';
  my $type_param = '\@(\w+)';
3eb014a10   Randy Dunlap   kernel-doc: html ...
165
  my $type_struct = '\&((struct\s*)*[_\w]+)';
6b5b55f6c   Randy Dunlap   kernel-doc: fix d...
166
  my $type_struct_xml = '\\&amp;((struct\s*)*[_\w]+)';
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
167
168
169
170
171
172
173
174
  my $type_env = '(\$\w+)';
  
  # Output conversion substitutions.
  #  One for each output format
  
  # these work fairly well
  my %highlights_html = ( $type_constant, "<i>\$1</i>",
  			$type_func, "<b>\$1</b>",
3eb014a10   Randy Dunlap   kernel-doc: html ...
175
176
  			$type_struct_xml, "<i>\$1</i>",
  			$type_env, "<b><i>\$1</i></b>",
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
177
  			$type_param, "<tt><b>\$1</b></tt>" );
6b5b55f6c   Randy Dunlap   kernel-doc: fix d...
178
179
180
  my $local_lt = "\\\\\\\\lt:";
  my $local_gt = "\\\\\\\\gt:";
  my $blankline_html = $local_lt . "p" . $local_gt;	# was "<p>"
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
181
182
183
184
185
  
  # XML, docbook format
  my %highlights_xml = ( "([^=])\\\"([^\\\"<]+)\\\"", "\$1<quote>\$2</quote>",
  			$type_constant, "<constant>\$1</constant>",
  			$type_func, "<function>\$1</function>",
5c98fc036   Johannes Berg   kernel-doc: fix x...
186
  			$type_struct_xml, "<structname>\$1</structname>",
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
187
188
  			$type_env, "<envar>\$1</envar>",
  			$type_param, "<parameter>\$1</parameter>" );
5c98fc036   Johannes Berg   kernel-doc: fix x...
189
190
  my $blankline_xml = $local_lt . "/para" . $local_gt . $local_lt . "para" . $local_gt . "
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
  
  # gnome, docbook format
  my %highlights_gnome = ( $type_constant, "<replaceable class=\"option\">\$1</replaceable>",
  			 $type_func, "<function>\$1</function>",
  			 $type_struct, "<structname>\$1</structname>",
  			 $type_env, "<envar>\$1</envar>",
  			 $type_param, "<parameter>\$1</parameter>" );
  my $blankline_gnome = "</para><para>
  ";
  
  # these are pretty rough
  my %highlights_man = ( $type_constant, "\$1",
  		       $type_func, "\\\\fB\$1\\\\fP",
  		       $type_struct, "\\\\fI\$1\\\\fP",
  		       $type_param, "\\\\fI\$1\\\\fP" );
  my $blankline_man = "";
  
  # text-mode
  my %highlights_text = ( $type_constant, "\$1",
  			$type_func, "\$1",
  			$type_struct, "\$1",
  			$type_param, "\$1" );
  my $blankline_text = "";
eda603f6c   Johannes Berg   docbook: warn on ...
214
215
216
217
218
219
  # list mode
  my %highlights_list = ( $type_constant, "\$1",
  			$type_func, "\$1",
  			$type_struct, "\$1",
  			$type_param, "\$1" );
  my $blankline_list = "";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
220

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
221
  # read arguments
b9d97328e   Randy Dunlap   kernel-doc: clean...
222
  if ($#ARGV == -1) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
223
224
      usage();
  }
8484baaa5   Randy Dunlap   kernel-doc: code ...
225
226
  my $kernelversion;
  my $dohighlight = "";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
227
228
  my $verbose = 0;
  my $output_mode = "man";
4b44595a7   Johannes Berg   kernel-doc: proce...
229
  my $no_doc_sections = 0;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
230
231
232
233
  my %highlights = %highlights_man;
  my $blankline = $blankline_man;
  my $modulename = "Kernel API";
  my $function_only = 0;
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
234
235
236
  my $man_date = ('January', 'February', 'March', 'April', 'May', 'June',
  		'July', 'August', 'September', 'October',
  		'November', 'December')[(localtime)[4]] .
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
237
    " " . ((localtime)[5]+1900);
8484baaa5   Randy Dunlap   kernel-doc: code ...
238
  # Essentially these are globals.
b9d97328e   Randy Dunlap   kernel-doc: clean...
239
240
  # They probably want to be tidied up, made more localised or something.
  # CAVEAT EMPTOR!  Some of the others I localised may not want to be, which
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
241
  # could cause "use of undefined value" or other bugs.
b9d97328e   Randy Dunlap   kernel-doc: clean...
242
243
  my ($function, %function_table, %parametertypes, $declaration_purpose);
  my ($type, $declaration_name, $return_type);
1c32fd0c5   Ilya Dryomov   kernel-doc: drop ...
244
  my ($newsection, $newcontents, $prototype, $brcount, %source_map);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
245

bd0e88e51   Randy Dunlap   kernel-doc: set v...
246
247
248
  if (defined($ENV{'KBUILD_VERBOSE'})) {
  	$verbose = "$ENV{'KBUILD_VERBOSE'}";
  }
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
249
  # Generated docbook code is inserted in a template at a point where
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
  # docbook v3.1 requires a non-zero sequence of RefEntry's; see:
  # http://www.oasis-open.org/docbook/documentation/reference/html/refentry.html
  # We keep track of number of generated entries and generate a dummy
  # if needs be to ensure the expanded template can be postprocessed
  # into html.
  my $section_counter = 0;
  
  my $lineprefix="";
  
  # states
  # 0 - normal code
  # 1 - looking for function name
  # 2 - scanning field start.
  # 3 - scanning prototype.
  # 4 - documentation block
  my $state;
850622dfa   Randy Dunlap   [PATCH] kernel-do...
266
  my $in_doc_sect;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
267
268
269
270
271
272
273
274
275
276
  
  #declaration types: can be
  # 'function', 'struct', 'union', 'enum', 'typedef'
  my $decl_type;
  
  my $doc_special = "\@\%\$\&";
  
  my $doc_start = '^/\*\*\s*$'; # Allow whitespace at end of comment start.
  my $doc_end = '\*/';
  my $doc_com = '\s*\*\s*';
b9d97328e   Randy Dunlap   kernel-doc: clean...
277
278
279
280
  my $doc_decl = $doc_com . '(\w+)';
  my $doc_sect = $doc_com . '([' . $doc_special . ']?[\w\s]+):(.*)';
  my $doc_content = $doc_com . '(.*)';
  my $doc_block = $doc_com . 'DOC:\s*(.*)?';
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
281
282
283
284
285
286
  
  my %constants;
  my %parameterdescs;
  my @parameterlist;
  my %sections;
  my @sectionlist;
a1d94aa55   Randy Dunlap   kernel-doc: check...
287
288
  my $sectcheck;
  my $struct_actual;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
  
  my $contents = "";
  my $section_default = "Description";	# default section
  my $section_intro = "Introduction";
  my $section = $section_default;
  my $section_context = "Context";
  
  my $undescribed = "-- undescribed --";
  
  reset_state();
  
  while ($ARGV[0] =~ m/^-(.*)/) {
      my $cmd = shift @ARGV;
      if ($cmd eq "-html") {
  	$output_mode = "html";
  	%highlights = %highlights_html;
  	$blankline = $blankline_html;
      } elsif ($cmd eq "-man") {
  	$output_mode = "man";
  	%highlights = %highlights_man;
  	$blankline = $blankline_man;
      } elsif ($cmd eq "-text") {
  	$output_mode = "text";
  	%highlights = %highlights_text;
  	$blankline = $blankline_text;
      } elsif ($cmd eq "-docbook") {
  	$output_mode = "xml";
  	%highlights = %highlights_xml;
  	$blankline = $blankline_xml;
eda603f6c   Johannes Berg   docbook: warn on ...
318
319
320
321
      } elsif ($cmd eq "-list") {
  	$output_mode = "list";
  	%highlights = %highlights_list;
  	$blankline = $blankline_list;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
      } elsif ($cmd eq "-gnome") {
  	$output_mode = "gnome";
  	%highlights = %highlights_gnome;
  	$blankline = $blankline_gnome;
      } elsif ($cmd eq "-module") { # not needed for XML, inherits from calling document
  	$modulename = shift @ARGV;
      } elsif ($cmd eq "-function") { # to only output specific functions
  	$function_only = 1;
  	$function = shift @ARGV;
  	$function_table{$function} = 1;
      } elsif ($cmd eq "-nofunction") { # to only output specific functions
  	$function_only = 2;
  	$function = shift @ARGV;
  	$function_table{$function} = 1;
      } elsif ($cmd eq "-v") {
  	$verbose = 1;
      } elsif (($cmd eq "-h") || ($cmd eq "--help")) {
  	usage();
4b44595a7   Johannes Berg   kernel-doc: proce...
340
341
      } elsif ($cmd eq '-no-doc-sections') {
  	    $no_doc_sections = 1;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
342
343
      }
  }
8484baaa5   Randy Dunlap   kernel-doc: code ...
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
  # continue execution near EOF;
  
  sub usage {
      print "Usage: $0 [ -v ] [ -docbook | -html | -text | -man | -list ]
  ";
      print "         [ -no-doc-sections ]
  ";
      print "         [ -function funcname [ -function funcname ...] ]
  ";
      print "         [ -nofunction funcname [ -nofunction funcname ...] ]
  ";
      print "         c source file(s) > outputfile
  ";
      print "         -v : verbose output, more warnings & other info listed
  ";
      exit 1;
  }
53f049fa5   Borislav Petkov   kill warnings whe...
361
362
  # get kernel version from env
  sub get_kernel_version() {
1b9bc22d7   Johannes Berg   kernel-doc: init ...
363
      my $version = 'unknown kernel version';
53f049fa5   Borislav Petkov   kill warnings whe...
364
365
366
367
368
369
  
      if (defined($ENV{'KERNELVERSION'})) {
  	$version = $ENV{'KERNELVERSION'};
      }
      return $version;
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
370
371
372
373
374
  
  ##
  # dumps section contents to arrays/hashes intended for that purpose.
  #
  sub dump_section {
94dc7ad55   Randy Dunlap   kernel-doc: detec...
375
      my $file = shift;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
376
377
378
379
380
381
382
383
384
385
386
387
388
389
      my $name = shift;
      my $contents = join "
  ", @_;
  
      if ($name =~ m/$type_constant/) {
  	$name = $1;
  #	print STDERR "constant section '$1' = '$contents'
  ";
  	$constants{$name} = $contents;
      } elsif ($name =~ m/$type_param/) {
  #	print STDERR "parameter def '$1' = '$contents'
  ";
  	$name = $1;
  	$parameterdescs{$name} = $contents;
a1d94aa55   Randy Dunlap   kernel-doc: check...
390
  	$sectcheck = $sectcheck . $name . " ";
ced69090c   Randy Dunlap   kernel-doc: handl...
391
392
393
394
395
      } elsif ($name eq "@\.\.\.") {
  #	print STDERR "parameter def '...' = '$contents'
  ";
  	$name = "...";
  	$parameterdescs{$name} = $contents;
a1d94aa55   Randy Dunlap   kernel-doc: check...
396
  	$sectcheck = $sectcheck . $name . " ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
397
398
399
      } else {
  #	print STDERR "other section '$name' = '$contents'
  ";
94dc7ad55   Randy Dunlap   kernel-doc: detec...
400
401
402
403
404
  	if (defined($sections{$name}) && ($sections{$name} ne "")) {
  		print STDERR "Error(${file}:$.): duplicate section name '$name'
  ";
  		++$errors;
  	}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
405
406
407
408
409
410
  	$sections{$name} = $contents;
  	push @sectionlist, $name;
      }
  }
  
  ##
b112e0f73   Johannes Berg   kernel-doc: singl...
411
412
413
  # dump DOC: section after checking that it should go out
  #
  sub dump_doc_section {
94dc7ad55   Randy Dunlap   kernel-doc: detec...
414
      my $file = shift;
b112e0f73   Johannes Berg   kernel-doc: singl...
415
416
417
      my $name = shift;
      my $contents = join "
  ", @_;
4b44595a7   Johannes Berg   kernel-doc: proce...
418
419
420
      if ($no_doc_sections) {
          return;
      }
b112e0f73   Johannes Berg   kernel-doc: singl...
421
422
423
424
      if (($function_only == 0) ||
  	( $function_only == 1 && defined($function_table{$name})) ||
  	( $function_only == 2 && !defined($function_table{$name})))
      {
94dc7ad55   Randy Dunlap   kernel-doc: detec...
425
  	dump_section($file, $name, $contents);
b112e0f73   Johannes Berg   kernel-doc: singl...
426
427
428
429
430
431
432
433
  	output_blockhead({'sectionlist' => \@sectionlist,
  			  'sections' => \%sections,
  			  'module' => $modulename,
  			  'content-only' => ($function_only != 0), });
      }
  }
  
  ##
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
434
435
436
437
438
439
440
  # output function
  #
  # parameterdescs, a hash.
  #  function => "function name"
  #  parameterlist => @list of parameters
  #  parameterdescs => %parameter descriptions
  #  sectionlist => @list of sections
a21217daa   Randy Dunlap   [PATCH] kernel-do...
441
  #  sections => %section descriptions
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
442
  #
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
443
444
445
446
447
448
449
450
451
452
453
454
  
  sub output_highlight {
      my $contents = join "
  ",@_;
      my $line;
  
  #   DEBUG
  #   if (!defined $contents) {
  #	use Carp;
  #	confess "output_highlight got called with no args?
  ";
  #   }
5c98fc036   Johannes Berg   kernel-doc: fix x...
455
      if ($output_mode eq "html" || $output_mode eq "xml") {
6b5b55f6c   Randy Dunlap   kernel-doc: fix d...
456
457
  	$contents = local_unescape($contents);
  	# convert data read & converted thru xml_escape() into &xyz; format:
2b35f4d9c   Randy Dunlap   kernel-doc: escap...
458
  	$contents =~ s/\\\\\\/\&/g;
6b5b55f6c   Randy Dunlap   kernel-doc: fix d...
459
      }
3eb014a10   Randy Dunlap   kernel-doc: html ...
460
461
  #   print STDERR "contents b4:$contents
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
462
463
      eval $dohighlight;
      die $@ if $@;
3eb014a10   Randy Dunlap   kernel-doc: html ...
464
465
  #   print STDERR "contents af:$contents
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
466
467
      foreach $line (split "
  ", $contents) {
3c308798a   Randy Dunlap   scripts: kernel-d...
468
  	if ($line eq ""){
6b5b55f6c   Randy Dunlap   kernel-doc: fix d...
469
  	    print $lineprefix, local_unescape($blankline);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
470
  	} else {
3c308798a   Randy Dunlap   scripts: kernel-d...
471
  	    $line =~ s/\\\\\\/\&/g;
cdccb316c   Randy Dunlap   kernel-doc: fix l...
472
473
474
475
476
  	    if ($output_mode eq "man" && substr($line, 0, 1) eq ".") {
  		print "\\&$line";
  	    } else {
  		print $lineprefix, $line;
  	    }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
  	}
  	print "
  ";
      }
  }
  
  #output sections in html
  sub output_section_html(%) {
      my %args = %{$_[0]};
      my $section;
  
      foreach $section (@{$args{'sectionlist'}}) {
  	print "<h3>$section</h3>
  ";
  	print "<blockquote>
  ";
  	output_highlight($args{'sections'}{$section});
  	print "</blockquote>
  ";
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
496
      }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
497
498
499
500
501
502
503
  }
  
  # output enum in html
  sub output_enum_html(%) {
      my %args = %{$_[0]};
      my ($parameter);
      my $count;
b9d97328e   Randy Dunlap   kernel-doc: clean...
504
505
      print "<h2>enum " . $args{'enum'} . "</h2>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
506

b9d97328e   Randy Dunlap   kernel-doc: clean...
507
508
      print "<b>enum " . $args{'enum'} . "</b> {<br>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
509
510
      $count = 0;
      foreach $parameter (@{$args{'parameterlist'}}) {
b9d97328e   Randy Dunlap   kernel-doc: clean...
511
  	print " <b>" . $parameter . "</b>";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
  	if ($count != $#{$args{'parameterlist'}}) {
  	    $count++;
  	    print ",
  ";
  	}
  	print "<br>";
      }
      print "};<br>
  ";
  
      print "<h3>Constants</h3>
  ";
      print "<dl>
  ";
      foreach $parameter (@{$args{'parameterlist'}}) {
b9d97328e   Randy Dunlap   kernel-doc: clean...
527
528
  	print "<dt><b>" . $parameter . "</b>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
529
530
531
532
533
534
535
536
537
  	print "<dd>";
  	output_highlight($args{'parameterdescs'}{$parameter});
      }
      print "</dl>
  ";
      output_section_html(@_);
      print "<hr>
  ";
  }
d28bee0c0   Randy Dunlap   [PATCH] Doc/kerne...
538
  # output typedef in html
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
539
540
541
542
  sub output_typedef_html(%) {
      my %args = %{$_[0]};
      my ($parameter);
      my $count;
b9d97328e   Randy Dunlap   kernel-doc: clean...
543
544
      print "<h2>typedef " . $args{'typedef'} . "</h2>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
545

b9d97328e   Randy Dunlap   kernel-doc: clean...
546
547
      print "<b>typedef " . $args{'typedef'} . "</b>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
548
549
550
551
552
553
554
555
556
      output_section_html(@_);
      print "<hr>
  ";
  }
  
  # output struct in html
  sub output_struct_html(%) {
      my %args = %{$_[0]};
      my ($parameter);
b9d97328e   Randy Dunlap   kernel-doc: clean...
557
558
559
560
      print "<h2>" . $args{'type'} . " " . $args{'struct'} . " - " . $args{'purpose'} . "</h2>
  ";
      print "<b>" . $args{'type'} . " " . $args{'struct'} . "</b> {<br>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
561
562
563
564
565
566
567
568
      foreach $parameter (@{$args{'parameterlist'}}) {
  	if ($parameter =~ /^#/) {
  		print "$parameter<br>
  ";
  		next;
  	}
  	my $parameter_name = $parameter;
  	$parameter_name =~ s/\[.*//;
3c308798a   Randy Dunlap   scripts: kernel-d...
569
  	($args{'parameterdescs'}{$parameter_name} ne $undescribed) || next;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
570
571
572
  	$type = $args{'parametertypes'}{$parameter};
  	if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) {
  	    # pointer-to-function
3eb014a10   Randy Dunlap   kernel-doc: html ...
573
574
  	    print "&nbsp; &nbsp; <i>$1</i><b>$parameter</b>) <i>($2)</i>;<br>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
575
  	} elsif ($type =~ m/^(.*?)\s*(:.*)/) {
3eb014a10   Randy Dunlap   kernel-doc: html ...
576
577
578
  	    # bitfield
  	    print "&nbsp; &nbsp; <i>$1</i> <b>$parameter</b>$2;<br>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
579
  	} else {
3eb014a10   Randy Dunlap   kernel-doc: html ...
580
581
  	    print "&nbsp; &nbsp; <i>$type</i> <b>$parameter</b>;<br>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
582
583
584
585
586
587
588
589
590
591
592
593
594
595
  	}
      }
      print "};<br>
  ";
  
      print "<h3>Members</h3>
  ";
      print "<dl>
  ";
      foreach $parameter (@{$args{'parameterlist'}}) {
  	($parameter =~ /^#/) && next;
  
  	my $parameter_name = $parameter;
  	$parameter_name =~ s/\[.*//;
3c308798a   Randy Dunlap   scripts: kernel-d...
596
  	($args{'parameterdescs'}{$parameter_name} ne $undescribed) || next;
b9d97328e   Randy Dunlap   kernel-doc: clean...
597
598
  	print "<dt><b>" . $parameter . "</b>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
  	print "<dd>";
  	output_highlight($args{'parameterdescs'}{$parameter_name});
      }
      print "</dl>
  ";
      output_section_html(@_);
      print "<hr>
  ";
  }
  
  # output function in html
  sub output_function_html(%) {
      my %args = %{$_[0]};
      my ($parameter, $section);
      my $count;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
614

b9d97328e   Randy Dunlap   kernel-doc: clean...
615
616
617
618
619
620
      print "<h2>" . $args{'function'} . " - " . $args{'purpose'} . "</h2>
  ";
      print "<i>" . $args{'functiontype'} . "</i>
  ";
      print "<b>" . $args{'function'} . "</b>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
621
622
623
624
625
626
627
628
      print "(";
      $count = 0;
      foreach $parameter (@{$args{'parameterlist'}}) {
  	$type = $args{'parametertypes'}{$parameter};
  	if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) {
  	    # pointer-to-function
  	    print "<i>$1</i><b>$parameter</b>) <i>($2)</i>";
  	} else {
b9d97328e   Randy Dunlap   kernel-doc: clean...
629
  	    print "<i>" . $type . "</i> <b>" . $parameter . "</b>";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
  	}
  	if ($count != $#{$args{'parameterlist'}}) {
  	    $count++;
  	    print ",
  ";
  	}
      }
      print ")
  ";
  
      print "<h3>Arguments</h3>
  ";
      print "<dl>
  ";
      foreach $parameter (@{$args{'parameterlist'}}) {
  	my $parameter_name = $parameter;
  	$parameter_name =~ s/\[.*//;
3c308798a   Randy Dunlap   scripts: kernel-d...
647
  	($args{'parameterdescs'}{$parameter_name} ne $undescribed) || next;
b9d97328e   Randy Dunlap   kernel-doc: clean...
648
649
  	print "<dt><b>" . $parameter . "</b>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
650
651
652
653
654
655
656
657
658
  	print "<dd>";
  	output_highlight($args{'parameterdescs'}{$parameter_name});
      }
      print "</dl>
  ";
      output_section_html(@_);
      print "<hr>
  ";
  }
b112e0f73   Johannes Berg   kernel-doc: singl...
659
660
  # output DOC: block header in html
  sub output_blockhead_html(%) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
      my %args = %{$_[0]};
      my ($parameter, $section);
      my $count;
  
      foreach $section (@{$args{'sectionlist'}}) {
  	print "<h3>$section</h3>
  ";
  	print "<ul>
  ";
  	output_highlight($args{'sections'}{$section});
  	print "</ul>
  ";
      }
      print "<hr>
  ";
  }
  
  sub output_section_xml(%) {
      my %args = %{$_[0]};
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
680
      my $section;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
681
682
683
      # print out each section
      $lineprefix="   ";
      foreach $section (@{$args{'sectionlist'}}) {
c73894c1e   Rich Walker   [PATCH] DocBook: ...
684
685
686
687
  	print "<refsect1>
  ";
  	print "<title>$section</title>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
688
  	if ($section =~ m/EXAMPLE/i) {
c73894c1e   Rich Walker   [PATCH] DocBook: ...
689
690
691
692
693
  	    print "<informalexample><programlisting>
  ";
  	} else {
  	    print "<para>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
694
695
696
  	}
  	output_highlight($args{'sections'}{$section});
  	if ($section =~ m/EXAMPLE/i) {
c73894c1e   Rich Walker   [PATCH] DocBook: ...
697
698
699
700
701
  	    print "</programlisting></informalexample>
  ";
  	} else {
  	    print "</para>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
702
  	}
c73894c1e   Rich Walker   [PATCH] DocBook: ...
703
704
  	print "</refsect1>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
705
706
707
708
709
710
711
712
713
      }
  }
  
  # output function in XML DocBook
  sub output_function_xml(%) {
      my %args = %{$_[0]};
      my ($parameter, $section);
      my $count;
      my $id;
b9d97328e   Randy Dunlap   kernel-doc: clean...
714
      $id = "API-" . $args{'function'};
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
715
      $id =~ s/[^A-Za-z0-9]/-/g;
5449bc941   Pavel Pisa   [PATCH] DocBook/H...
716
717
      print "<refentry id=\"$id\">
  ";
8b0c2d989   Martin Waitz   [PATCH] DocBook: ...
718
719
720
721
722
723
724
725
726
727
      print "<refentryinfo>
  ";
      print " <title>LINUX</title>
  ";
      print " <productname>Kernel Hackers Manual</productname>
  ";
      print " <date>$man_date</date>
  ";
      print "</refentryinfo>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
728
729
      print "<refmeta>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
730
731
      print " <refentrytitle><phrase>" . $args{'function'} . "</phrase></refentrytitle>
  ";
8b0c2d989   Martin Waitz   [PATCH] DocBook: ...
732
733
      print " <manvolnum>9</manvolnum>
  ";
0366299bd   Borislav Petkov   kernel-doc: small...
734
735
      print " <refmiscinfo class=\"version\">" . $kernelversion . "</refmiscinfo>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
736
737
738
739
      print "</refmeta>
  ";
      print "<refnamediv>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
740
741
      print " <refname>" . $args{'function'} . "</refname>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
      print " <refpurpose>
  ";
      print "  ";
      output_highlight ($args{'purpose'});
      print " </refpurpose>
  ";
      print "</refnamediv>
  ";
  
      print "<refsynopsisdiv>
  ";
      print " <title>Synopsis</title>
  ";
      print "  <funcsynopsis><funcprototype>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
757
758
759
      print "   <funcdef>" . $args{'functiontype'} . " ";
      print "<function>" . $args{'function'} . " </function></funcdef>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
760
761
762
763
764
765
766
767
768
769
770
771
  
      $count = 0;
      if ($#{$args{'parameterlist'}} >= 0) {
  	foreach $parameter (@{$args{'parameterlist'}}) {
  	    $type = $args{'parametertypes'}{$parameter};
  	    if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) {
  		# pointer-to-function
  		print "   <paramdef>$1<parameter>$parameter</parameter>)
  ";
  		print "     <funcparams>$2</funcparams></paramdef>
  ";
  	    } else {
b9d97328e   Randy Dunlap   kernel-doc: clean...
772
  		print "   <paramdef>" . $type;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
773
774
775
776
777
  		print " <parameter>$parameter</parameter></paramdef>
  ";
  	    }
  	}
      } else {
6013d5445   Martin Waitz   [PATCH] DocBook: ...
778
779
  	print "  <void/>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
      }
      print "  </funcprototype></funcsynopsis>
  ";
      print "</refsynopsisdiv>
  ";
  
      # print parameters
      print "<refsect1>
   <title>Arguments</title>
  ";
      if ($#{$args{'parameterlist'}} >= 0) {
  	print " <variablelist>
  ";
  	foreach $parameter (@{$args{'parameterlist'}}) {
  	    my $parameter_name = $parameter;
  	    $parameter_name =~ s/\[.*//;
  
  	    print "  <varlistentry>
     <term><parameter>$parameter</parameter></term>
  ";
  	    print "   <listitem>
      <para>
  ";
  	    $lineprefix="     ";
  	    output_highlight($args{'parameterdescs'}{$parameter_name});
  	    print "    </para>
     </listitem>
    </varlistentry>
  ";
  	}
  	print " </variablelist>
  ";
      } else {
  	print " <para>
    None
   </para>
  ";
      }
      print "</refsect1>
  ";
  
      output_section_xml(@_);
      print "</refentry>
  
  ";
  }
  
  # output struct in XML DocBook
  sub output_struct_xml(%) {
      my %args = %{$_[0]};
      my ($parameter, $section);
      my $id;
b9d97328e   Randy Dunlap   kernel-doc: clean...
832
      $id = "API-struct-" . $args{'struct'};
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
833
      $id =~ s/[^A-Za-z0-9]/-/g;
5449bc941   Pavel Pisa   [PATCH] DocBook/H...
834
835
      print "<refentry id=\"$id\">
  ";
8b0c2d989   Martin Waitz   [PATCH] DocBook: ...
836
837
838
839
840
841
842
843
844
845
      print "<refentryinfo>
  ";
      print " <title>LINUX</title>
  ";
      print " <productname>Kernel Hackers Manual</productname>
  ";
      print " <date>$man_date</date>
  ";
      print "</refentryinfo>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
846
847
      print "<refmeta>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
848
849
      print " <refentrytitle><phrase>" . $args{'type'} . " " . $args{'struct'} . "</phrase></refentrytitle>
  ";
8b0c2d989   Martin Waitz   [PATCH] DocBook: ...
850
851
      print " <manvolnum>9</manvolnum>
  ";
0366299bd   Borislav Petkov   kernel-doc: small...
852
853
      print " <refmiscinfo class=\"version\">" . $kernelversion . "</refmiscinfo>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
854
855
856
857
      print "</refmeta>
  ";
      print "<refnamediv>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
858
859
      print " <refname>" . $args{'type'} . " " . $args{'struct'} . "</refname>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
      print " <refpurpose>
  ";
      print "  ";
      output_highlight ($args{'purpose'});
      print " </refpurpose>
  ";
      print "</refnamediv>
  ";
  
      print "<refsynopsisdiv>
  ";
      print " <title>Synopsis</title>
  ";
      print "  <programlisting>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
875
876
      print $args{'type'} . " " . $args{'struct'} . " {
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
877
878
      foreach $parameter (@{$args{'parameterlist'}}) {
  	if ($parameter =~ /^#/) {
2b35f4d9c   Randy Dunlap   kernel-doc: escap...
879
880
881
882
883
884
  	    my $prm = $parameter;
  	    # convert data read & converted thru xml_escape() into &xyz; format:
  	    # This allows us to have #define macros interspersed in a struct.
  	    $prm =~ s/\\\\\\/\&/g;
  	    print "$prm
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
885
886
887
888
889
890
891
  	    next;
  	}
  
  	my $parameter_name = $parameter;
  	$parameter_name =~ s/\[.*//;
  
  	defined($args{'parameterdescs'}{$parameter_name}) || next;
3c308798a   Randy Dunlap   scripts: kernel-d...
892
  	($args{'parameterdescs'}{$parameter_name} ne $undescribed) || next;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
893
894
895
896
897
898
  	$type = $args{'parametertypes'}{$parameter};
  	if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) {
  	    # pointer-to-function
  	    print "  $1 $parameter) ($2);
  ";
  	} elsif ($type =~ m/^(.*?)\s*(:.*)/) {
51f5a0c8f   Randy Dunlap   kernel-doc: strip...
899
  	    # bitfield
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
900
901
902
  	    print "  $1 $parameter$2;
  ";
  	} else {
b9d97328e   Randy Dunlap   kernel-doc: clean...
903
904
  	    print "  " . $type . " " . $parameter . ";
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
905
906
907
908
909
910
911
912
913
914
915
916
  	}
      }
      print "};";
      print "  </programlisting>
  ";
      print "</refsynopsisdiv>
  ";
  
      print " <refsect1>
  ";
      print "  <title>Members</title>
  ";
39f00c087   Randy Dunlap   kernel-doc: allow...
917
      if ($#{$args{'parameterlist'}} >= 0) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
      print "  <variablelist>
  ";
      foreach $parameter (@{$args{'parameterlist'}}) {
        ($parameter =~ /^#/) && next;
  
        my $parameter_name = $parameter;
        $parameter_name =~ s/\[.*//;
  
        defined($args{'parameterdescs'}{$parameter_name}) || next;
        ($args{'parameterdescs'}{$parameter_name} ne $undescribed) || next;
        print "    <varlistentry>";
        print "      <term>$parameter</term>
  ";
        print "      <listitem><para>
  ";
        output_highlight($args{'parameterdescs'}{$parameter_name});
        print "      </para></listitem>
  ";
        print "    </varlistentry>
  ";
      }
      print "  </variablelist>
  ";
39f00c087   Randy Dunlap   kernel-doc: allow...
941
942
943
944
945
946
      } else {
  	print " <para>
    None
   </para>
  ";
      }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
      print " </refsect1>
  ";
  
      output_section_xml(@_);
  
      print "</refentry>
  
  ";
  }
  
  # output enum in XML DocBook
  sub output_enum_xml(%) {
      my %args = %{$_[0]};
      my ($parameter, $section);
      my $count;
      my $id;
b9d97328e   Randy Dunlap   kernel-doc: clean...
963
      $id = "API-enum-" . $args{'enum'};
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
964
      $id =~ s/[^A-Za-z0-9]/-/g;
5449bc941   Pavel Pisa   [PATCH] DocBook/H...
965
966
      print "<refentry id=\"$id\">
  ";
8b0c2d989   Martin Waitz   [PATCH] DocBook: ...
967
968
969
970
971
972
973
974
975
976
      print "<refentryinfo>
  ";
      print " <title>LINUX</title>
  ";
      print " <productname>Kernel Hackers Manual</productname>
  ";
      print " <date>$man_date</date>
  ";
      print "</refentryinfo>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
977
978
      print "<refmeta>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
979
980
      print " <refentrytitle><phrase>enum " . $args{'enum'} . "</phrase></refentrytitle>
  ";
8b0c2d989   Martin Waitz   [PATCH] DocBook: ...
981
982
      print " <manvolnum>9</manvolnum>
  ";
0366299bd   Borislav Petkov   kernel-doc: small...
983
984
      print " <refmiscinfo class=\"version\">" . $kernelversion . "</refmiscinfo>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
985
986
987
988
      print "</refmeta>
  ";
      print "<refnamediv>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
989
990
      print " <refname>enum " . $args{'enum'} . "</refname>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
      print " <refpurpose>
  ";
      print "  ";
      output_highlight ($args{'purpose'});
      print " </refpurpose>
  ";
      print "</refnamediv>
  ";
  
      print "<refsynopsisdiv>
  ";
      print " <title>Synopsis</title>
  ";
      print "  <programlisting>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1006
1007
      print "enum " . $args{'enum'} . " {
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1008
1009
      $count = 0;
      foreach $parameter (@{$args{'parameterlist'}}) {
3c308798a   Randy Dunlap   scripts: kernel-d...
1010
1011
  	print "  $parameter";
  	if ($count != $#{$args{'parameterlist'}}) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1012
1013
  	    $count++;
  	    print ",";
3c308798a   Randy Dunlap   scripts: kernel-d...
1014
  	}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
  	print "
  ";
      }
      print "};";
      print "  </programlisting>
  ";
      print "</refsynopsisdiv>
  ";
  
      print "<refsect1>
  ";
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
1026
1027
      print " <title>Constants</title>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
      print "  <variablelist>
  ";
      foreach $parameter (@{$args{'parameterlist'}}) {
        my $parameter_name = $parameter;
        $parameter_name =~ s/\[.*//;
  
        print "    <varlistentry>";
        print "      <term>$parameter</term>
  ";
        print "      <listitem><para>
  ";
        output_highlight($args{'parameterdescs'}{$parameter_name});
        print "      </para></listitem>
  ";
        print "    </varlistentry>
  ";
      }
      print "  </variablelist>
  ";
      print "</refsect1>
  ";
  
      output_section_xml(@_);
  
      print "</refentry>
  
  ";
  }
  
  # output typedef in XML DocBook
  sub output_typedef_xml(%) {
      my %args = %{$_[0]};
      my ($parameter, $section);
      my $id;
b9d97328e   Randy Dunlap   kernel-doc: clean...
1062
      $id = "API-typedef-" . $args{'typedef'};
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1063
      $id =~ s/[^A-Za-z0-9]/-/g;
5449bc941   Pavel Pisa   [PATCH] DocBook/H...
1064
1065
      print "<refentry id=\"$id\">
  ";
8b0c2d989   Martin Waitz   [PATCH] DocBook: ...
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
      print "<refentryinfo>
  ";
      print " <title>LINUX</title>
  ";
      print " <productname>Kernel Hackers Manual</productname>
  ";
      print " <date>$man_date</date>
  ";
      print "</refentryinfo>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1076
1077
      print "<refmeta>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1078
1079
      print " <refentrytitle><phrase>typedef " . $args{'typedef'} . "</phrase></refentrytitle>
  ";
8b0c2d989   Martin Waitz   [PATCH] DocBook: ...
1080
1081
      print " <manvolnum>9</manvolnum>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1082
1083
1084
1085
      print "</refmeta>
  ";
      print "<refnamediv>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1086
1087
      print " <refname>typedef " . $args{'typedef'} . "</refname>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
      print " <refpurpose>
  ";
      print "  ";
      output_highlight ($args{'purpose'});
      print " </refpurpose>
  ";
      print "</refnamediv>
  ";
  
      print "<refsynopsisdiv>
  ";
      print " <title>Synopsis</title>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1101
1102
      print "  <synopsis>typedef " . $args{'typedef'} . ";</synopsis>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
      print "</refsynopsisdiv>
  ";
  
      output_section_xml(@_);
  
      print "</refentry>
  
  ";
  }
  
  # output in XML DocBook
b112e0f73   Johannes Berg   kernel-doc: singl...
1114
  sub output_blockhead_xml(%) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
      my %args = %{$_[0]};
      my ($parameter, $section);
      my $count;
  
      my $id = $args{'module'};
      $id =~ s/[^A-Za-z0-9]/-/g;
  
      # print out each section
      $lineprefix="   ";
      foreach $section (@{$args{'sectionlist'}}) {
b112e0f73   Johannes Berg   kernel-doc: singl...
1125
1126
1127
1128
1129
  	if (!$args{'content-only'}) {
  		print "<refsect1>
   <title>$section</title>
  ";
  	}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1130
1131
1132
  	if ($section =~ m/EXAMPLE/i) {
  	    print "<example><para>
  ";
b112e0f73   Johannes Berg   kernel-doc: singl...
1133
1134
1135
  	} else {
  	    print "<para>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1136
1137
1138
1139
1140
  	}
  	output_highlight($args{'sections'}{$section});
  	if ($section =~ m/EXAMPLE/i) {
  	    print "</para></example>
  ";
b112e0f73   Johannes Berg   kernel-doc: singl...
1141
1142
1143
1144
1145
1146
1147
  	} else {
  	    print "</para>";
  	}
  	if (!$args{'content-only'}) {
  		print "
  </refsect1>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1148
  	}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
      }
  
      print "
  
  ";
  }
  
  # output in XML DocBook
  sub output_function_gnome {
      my %args = %{$_[0]};
      my ($parameter, $section);
      my $count;
      my $id;
b9d97328e   Randy Dunlap   kernel-doc: clean...
1162
      $id = $args{'module'} . "-" . $args{'function'};
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1163
1164
1165
1166
      $id =~ s/[^A-Za-z0-9]/-/g;
  
      print "<sect2>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1167
1168
      print " <title id=\"$id\">" . $args{'function'} . "</title>
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1169
1170
1171
  
      print "  <funcsynopsis>
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1172
1173
      print "   <funcdef>" . $args{'functiontype'} . " ";
      print "<function>" . $args{'function'} . " ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
      print "</function></funcdef>
  ";
  
      $count = 0;
      if ($#{$args{'parameterlist'}} >= 0) {
  	foreach $parameter (@{$args{'parameterlist'}}) {
  	    $type = $args{'parametertypes'}{$parameter};
  	    if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) {
  		# pointer-to-function
  		print "   <paramdef>$1 <parameter>$parameter</parameter>)
  ";
  		print "     <funcparams>$2</funcparams></paramdef>
  ";
  	    } else {
b9d97328e   Randy Dunlap   kernel-doc: clean...
1188
  		print "   <paramdef>" . $type;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
  		print " <parameter>$parameter</parameter></paramdef>
  ";
  	    }
  	}
      } else {
  	print "  <void>
  ";
      }
      print "  </funcsynopsis>
  ";
      if ($#{$args{'parameterlist'}} >= 0) {
  	print " <informaltable pgwide=\"1\" frame=\"none\" role=\"params\">
  ";
  	print "<tgroup cols=\"2\">
  ";
  	print "<colspec colwidth=\"2*\">
  ";
  	print "<colspec colwidth=\"8*\">
  ";
  	print "<tbody>
  ";
  	foreach $parameter (@{$args{'parameterlist'}}) {
  	    my $parameter_name = $parameter;
  	    $parameter_name =~ s/\[.*//;
  
  	    print "  <row><entry align=\"right\"><parameter>$parameter</parameter></entry>
  ";
  	    print "   <entry>
  ";
  	    $lineprefix="     ";
  	    output_highlight($args{'parameterdescs'}{$parameter_name});
  	    print "    </entry></row>
  ";
  	}
  	print " </tbody></tgroup></informaltable>
  ";
      } else {
  	print " <para>
    None
   </para>
  ";
      }
  
      # print out each section
      $lineprefix="   ";
      foreach $section (@{$args{'sectionlist'}}) {
  	print "<simplesect>
   <title>$section</title>
  ";
  	if ($section =~ m/EXAMPLE/i) {
  	    print "<example><programlisting>
  ";
  	} else {
  	}
  	print "<para>
  ";
  	output_highlight($args{'sections'}{$section});
  	print "</para>
  ";
  	if ($section =~ m/EXAMPLE/i) {
  	    print "</programlisting></example>
  ";
  	} else {
  	}
  	print " </simplesect>
  ";
      }
  
      print "</sect2>
  
  ";
  }
  
  ##
  # output function in man
  sub output_function_man(%) {
      my %args = %{$_[0]};
      my ($parameter, $section);
      my $count;
  
      print ".TH \"$args{'function'}\" 9 \"$args{'function'}\" \"$man_date\" \"Kernel Hacker's Manual\" LINUX
  ";
  
      print ".SH NAME
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1274
1275
      print $args{'function'} . " \\- " . $args{'purpose'} . "
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1276
1277
1278
  
      print ".SH SYNOPSIS
  ";
a21217daa   Randy Dunlap   [PATCH] kernel-do...
1279
      if ($args{'functiontype'} ne "") {
b9d97328e   Randy Dunlap   kernel-doc: clean...
1280
1281
  	print ".B \"" . $args{'functiontype'} . "\" " . $args{'function'} . "
  ";
a21217daa   Randy Dunlap   [PATCH] kernel-do...
1282
      } else {
b9d97328e   Randy Dunlap   kernel-doc: clean...
1283
1284
  	print ".B \"" . $args{'function'} . "
  ";
a21217daa   Randy Dunlap   [PATCH] kernel-do...
1285
      }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
      $count = 0;
      my $parenth = "(";
      my $post = ",";
      foreach my $parameter (@{$args{'parameterlist'}}) {
  	if ($count == $#{$args{'parameterlist'}}) {
  	    $post = ");";
  	}
  	$type = $args{'parametertypes'}{$parameter};
  	if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) {
  	    # pointer-to-function
b9d97328e   Randy Dunlap   kernel-doc: clean...
1296
1297
  	    print ".BI \"" . $parenth . $1 . "\" " . $parameter . " \") (" . $2 . ")" . $post . "\"
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1298
1299
  	} else {
  	    $type =~ s/([^\*])$/$1 /;
b9d97328e   Randy Dunlap   kernel-doc: clean...
1300
1301
  	    print ".BI \"" . $parenth . $type . "\" " . $parameter . " \"" . $post . "\"
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
  	}
  	$count++;
  	$parenth = "";
      }
  
      print ".SH ARGUMENTS
  ";
      foreach $parameter (@{$args{'parameterlist'}}) {
  	my $parameter_name = $parameter;
  	$parameter_name =~ s/\[.*//;
b9d97328e   Randy Dunlap   kernel-doc: clean...
1312
1313
  	print ".IP \"" . $parameter . "\" 12
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
  	output_highlight($args{'parameterdescs'}{$parameter_name});
      }
      foreach $section (@{$args{'sectionlist'}}) {
  	print ".SH \"", uc $section, "\"
  ";
  	output_highlight($args{'sections'}{$section});
      }
  }
  
  ##
  # output enum in man
  sub output_enum_man(%) {
      my %args = %{$_[0]};
      my ($parameter, $section);
      my $count;
  
      print ".TH \"$args{'module'}\" 9 \"enum $args{'enum'}\" \"$man_date\" \"API Manual\" LINUX
  ";
  
      print ".SH NAME
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1335
1336
      print "enum " . $args{'enum'} . " \\- " . $args{'purpose'} . "
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1337
1338
1339
  
      print ".SH SYNOPSIS
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1340
1341
      print "enum " . $args{'enum'} . " {
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1342
1343
      $count = 0;
      foreach my $parameter (@{$args{'parameterlist'}}) {
3c308798a   Randy Dunlap   scripts: kernel-d...
1344
1345
1346
  	print ".br
  .BI \"    $parameter\"
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
  	if ($count == $#{$args{'parameterlist'}}) {
  	    print "
  };
  ";
  	    last;
  	}
  	else {
  	    print ", 
  .br
  ";
  	}
  	$count++;
      }
  
      print ".SH Constants
  ";
      foreach $parameter (@{$args{'parameterlist'}}) {
  	my $parameter_name = $parameter;
  	$parameter_name =~ s/\[.*//;
b9d97328e   Randy Dunlap   kernel-doc: clean...
1366
1367
  	print ".IP \"" . $parameter . "\" 12
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
  	output_highlight($args{'parameterdescs'}{$parameter_name});
      }
      foreach $section (@{$args{'sectionlist'}}) {
  	print ".SH \"$section\"
  ";
  	output_highlight($args{'sections'}{$section});
      }
  }
  
  ##
  # output struct in man
  sub output_struct_man(%) {
      my %args = %{$_[0]};
      my ($parameter, $section);
b9d97328e   Randy Dunlap   kernel-doc: clean...
1382
1383
      print ".TH \"$args{'module'}\" 9 \"" . $args{'type'} . " " . $args{'struct'} . "\" \"$man_date\" \"API Manual\" LINUX
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1384
1385
1386
  
      print ".SH NAME
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1387
1388
      print $args{'type'} . " " . $args{'struct'} . " \\- " . $args{'purpose'} . "
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1389
1390
1391
  
      print ".SH SYNOPSIS
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1392
1393
1394
      print $args{'type'} . " " . $args{'struct'} . " {
  .br
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
  
      foreach my $parameter (@{$args{'parameterlist'}}) {
  	if ($parameter =~ /^#/) {
  	    print ".BI \"$parameter\"
  .br
  ";
  	    next;
  	}
  	my $parameter_name = $parameter;
  	$parameter_name =~ s/\[.*//;
3c308798a   Randy Dunlap   scripts: kernel-d...
1405
  	($args{'parameterdescs'}{$parameter_name} ne $undescribed) || next;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1406
1407
1408
  	$type = $args{'parametertypes'}{$parameter};
  	if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) {
  	    # pointer-to-function
b9d97328e   Randy Dunlap   kernel-doc: clean...
1409
1410
1411
  	    print ".BI \"    " . $1 . "\" " . $parameter . " \") (" . $2 . ")" . "\"
  ;
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1412
  	} elsif ($type =~ m/^(.*?)\s*(:.*)/) {
1d7e1d451   Randy.Dunlap   [PATCH] kernel-do...
1413
  	    # bitfield
b9d97328e   Randy Dunlap   kernel-doc: clean...
1414
1415
1416
  	    print ".BI \"    " . $1 . "\ \" " . $parameter . $2 . " \"" . "\"
  ;
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1417
1418
  	} else {
  	    $type =~ s/([^\*])$/$1 /;
b9d97328e   Randy Dunlap   kernel-doc: clean...
1419
1420
1421
  	    print ".BI \"    " . $type . "\" " . $parameter . " \"" . "\"
  ;
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1422
1423
1424
1425
1426
1427
1428
1429
  	}
  	print "
  .br
  ";
      }
      print "};
  .br
  ";
c51d3dac3   Randy Dunlap   [PATCH] kernel-do...
1430
1431
      print ".SH Members
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1432
1433
1434
1435
1436
      foreach $parameter (@{$args{'parameterlist'}}) {
  	($parameter =~ /^#/) && next;
  
  	my $parameter_name = $parameter;
  	$parameter_name =~ s/\[.*//;
3c308798a   Randy Dunlap   scripts: kernel-d...
1437
  	($args{'parameterdescs'}{$parameter_name} ne $undescribed) || next;
b9d97328e   Randy Dunlap   kernel-doc: clean...
1438
1439
  	print ".IP \"" . $parameter . "\" 12
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
  	output_highlight($args{'parameterdescs'}{$parameter_name});
      }
      foreach $section (@{$args{'sectionlist'}}) {
  	print ".SH \"$section\"
  ";
  	output_highlight($args{'sections'}{$section});
      }
  }
  
  ##
  # output typedef in man
  sub output_typedef_man(%) {
      my %args = %{$_[0]};
      my ($parameter, $section);
  
      print ".TH \"$args{'module'}\" 9 \"$args{'typedef'}\" \"$man_date\" \"API Manual\" LINUX
  ";
  
      print ".SH NAME
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1460
1461
      print "typedef " . $args{'typedef'} . " \\- " . $args{'purpose'} . "
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1462
1463
1464
1465
1466
1467
1468
  
      foreach $section (@{$args{'sectionlist'}}) {
  	print ".SH \"$section\"
  ";
  	output_highlight($args{'sections'}{$section});
      }
  }
b112e0f73   Johannes Berg   kernel-doc: singl...
1469
  sub output_blockhead_man(%) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
      my %args = %{$_[0]};
      my ($parameter, $section);
      my $count;
  
      print ".TH \"$args{'module'}\" 9 \"$args{'module'}\" \"$man_date\" \"API Manual\" LINUX
  ";
  
      foreach $section (@{$args{'sectionlist'}}) {
  	print ".SH \"$section\"
  ";
  	output_highlight($args{'sections'}{$section});
      }
  }
  
  ##
  # output in text
  sub output_function_text(%) {
      my %args = %{$_[0]};
      my ($parameter, $section);
a21217daa   Randy Dunlap   [PATCH] kernel-do...
1489
      my $start;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1490

f47634b27   Randy Dunlap   [PATCH] kernel-do...
1491
1492
1493
      print "Name:
  
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1494
1495
      print $args{'function'} . " - " . $args{'purpose'} . "
  ";
f47634b27   Randy Dunlap   [PATCH] kernel-do...
1496
1497
1498
1499
1500
  
      print "
  Synopsis:
  
  ";
a21217daa   Randy Dunlap   [PATCH] kernel-do...
1501
      if ($args{'functiontype'} ne "") {
b9d97328e   Randy Dunlap   kernel-doc: clean...
1502
  	$start = $args{'functiontype'} . " " . $args{'function'} . " (";
a21217daa   Randy Dunlap   [PATCH] kernel-do...
1503
      } else {
b9d97328e   Randy Dunlap   kernel-doc: clean...
1504
  	$start = $args{'function'} . " (";
a21217daa   Randy Dunlap   [PATCH] kernel-do...
1505
      }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1506
      print $start;
a21217daa   Randy Dunlap   [PATCH] kernel-do...
1507

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1508
1509
1510
1511
1512
      my $count = 0;
      foreach my $parameter (@{$args{'parameterlist'}}) {
  	$type = $args{'parametertypes'}{$parameter};
  	if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) {
  	    # pointer-to-function
b9d97328e   Randy Dunlap   kernel-doc: clean...
1513
  	    print $1 . $parameter . ") (" . $2;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1514
  	} else {
b9d97328e   Randy Dunlap   kernel-doc: clean...
1515
  	    print $type . " " . $parameter;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
  	}
  	if ($count != $#{$args{'parameterlist'}}) {
  	    $count++;
  	    print ",
  ";
  	    print " " x length($start);
  	} else {
  	    print ");
  
  ";
  	}
      }
  
      print "Arguments:
  
  ";
      foreach $parameter (@{$args{'parameterlist'}}) {
  	my $parameter_name = $parameter;
  	$parameter_name =~ s/\[.*//;
b9d97328e   Randy Dunlap   kernel-doc: clean...
1535
1536
1537
  	print $parameter . "
  \t" . $args{'parameterdescs'}{$parameter_name} . "
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
      }
      output_section_text(@_);
  }
  
  #output sections in text
  sub output_section_text(%) {
      my %args = %{$_[0]};
      my $section;
  
      print "
  ";
      foreach $section (@{$args{'sectionlist'}}) {
  	print "$section:
  
  ";
  	output_highlight($args{'sections'}{$section});
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
1554
      }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
      print "
  
  ";
  }
  
  # output enum in text
  sub output_enum_text(%) {
      my %args = %{$_[0]};
      my ($parameter);
      my $count;
      print "Enum:
  
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1568
1569
1570
1571
1572
      print "enum " . $args{'enum'} . " - " . $args{'purpose'} . "
  
  ";
      print "enum " . $args{'enum'} . " {
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1573
1574
      $count = 0;
      foreach $parameter (@{$args{'parameterlist'}}) {
3c308798a   Randy Dunlap   scripts: kernel-d...
1575
  	print "\t$parameter";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
  	if ($count != $#{$args{'parameterlist'}}) {
  	    $count++;
  	    print ",";
  	}
  	print "
  ";
      }
      print "};
  
  ";
  
      print "Constants:
  
  ";
      foreach $parameter (@{$args{'parameterlist'}}) {
  	print "$parameter
  \t";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1593
1594
  	print $args{'parameterdescs'}{$parameter} . "
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1595
1596
1597
1598
1599
1600
1601
1602
1603
1604
1605
1606
1607
      }
  
      output_section_text(@_);
  }
  
  # output typedef in text
  sub output_typedef_text(%) {
      my %args = %{$_[0]};
      my ($parameter);
      my $count;
      print "Typedef:
  
  ";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1608
1609
      print "typedef " . $args{'typedef'} . " - " . $args{'purpose'} . "
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1610
1611
1612
1613
1614
1615
1616
      output_section_text(@_);
  }
  
  # output struct as text
  sub output_struct_text(%) {
      my %args = %{$_[0]};
      my ($parameter);
b9d97328e   Randy Dunlap   kernel-doc: clean...
1617
1618
1619
1620
1621
      print $args{'type'} . " " . $args{'struct'} . " - " . $args{'purpose'} . "
  
  ";
      print $args{'type'} . " " . $args{'struct'} . " {
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1622
1623
1624
1625
1626
1627
1628
1629
1630
      foreach $parameter (@{$args{'parameterlist'}}) {
  	if ($parameter =~ /^#/) {
  	    print "$parameter
  ";
  	    next;
  	}
  
  	my $parameter_name = $parameter;
  	$parameter_name =~ s/\[.*//;
3c308798a   Randy Dunlap   scripts: kernel-d...
1631
  	($args{'parameterdescs'}{$parameter_name} ne $undescribed) || next;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1632
1633
1634
1635
1636
1637
  	$type = $args{'parametertypes'}{$parameter};
  	if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) {
  	    # pointer-to-function
  	    print "\t$1 $parameter) ($2);
  ";
  	} elsif ($type =~ m/^(.*?)\s*(:.*)/) {
51f5a0c8f   Randy Dunlap   kernel-doc: strip...
1638
  	    # bitfield
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1639
1640
1641
  	    print "\t$1 $parameter$2;
  ";
  	} else {
b9d97328e   Randy Dunlap   kernel-doc: clean...
1642
1643
  	    print "\t" . $type . " " . $parameter . ";
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
  	}
      }
      print "};
  
  ";
  
      print "Members:
  
  ";
      foreach $parameter (@{$args{'parameterlist'}}) {
  	($parameter =~ /^#/) && next;
  
  	my $parameter_name = $parameter;
  	$parameter_name =~ s/\[.*//;
3c308798a   Randy Dunlap   scripts: kernel-d...
1658
  	($args{'parameterdescs'}{$parameter_name} ne $undescribed) || next;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1659
1660
  	print "$parameter
  \t";
b9d97328e   Randy Dunlap   kernel-doc: clean...
1661
1662
  	print $args{'parameterdescs'}{$parameter_name} . "
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1663
1664
1665
1666
1667
      }
      print "
  ";
      output_section_text(@_);
  }
b112e0f73   Johannes Berg   kernel-doc: singl...
1668
  sub output_blockhead_text(%) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
      my %args = %{$_[0]};
      my ($parameter, $section);
  
      foreach $section (@{$args{'sectionlist'}}) {
  	print " $section:
  ";
  	print "    -> ";
  	output_highlight($args{'sections'}{$section});
      }
  }
eda603f6c   Johannes Berg   docbook: warn on ...
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718
  ## list mode output functions
  
  sub output_function_list(%) {
      my %args = %{$_[0]};
  
      print $args{'function'} . "
  ";
  }
  
  # output enum in list
  sub output_enum_list(%) {
      my %args = %{$_[0]};
      print $args{'enum'} . "
  ";
  }
  
  # output typedef in list
  sub output_typedef_list(%) {
      my %args = %{$_[0]};
      print $args{'typedef'} . "
  ";
  }
  
  # output struct as list
  sub output_struct_list(%) {
      my %args = %{$_[0]};
  
      print $args{'struct'} . "
  ";
  }
  
  sub output_blockhead_list(%) {
      my %args = %{$_[0]};
      my ($parameter, $section);
  
      foreach $section (@{$args{'sectionlist'}}) {
  	print "DOC: $section
  ";
      }
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1719
  ##
272057447   Randy Dunlap   [PATCH] kernel-do...
1720
1721
1722
  # generic output function for all types (function, struct/union, typedef, enum);
  # calls the generated, variable output_ function name based on
  # functype and output_mode
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1723
1724
1725
1726
1727
  sub output_declaration {
      no strict 'refs';
      my $name = shift;
      my $functype = shift;
      my $func = "output_${functype}_$output_mode";
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
1728
1729
      if (($function_only==0) ||
  	( $function_only == 1 && defined($function_table{$name})) ||
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1730
1731
  	( $function_only == 2 && !defined($function_table{$name})))
      {
3c308798a   Randy Dunlap   scripts: kernel-d...
1732
  	&$func(@_);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1733
1734
1735
1736
1737
  	$section_counter++;
      }
  }
  
  ##
272057447   Randy Dunlap   [PATCH] kernel-do...
1738
  # generic output function - calls the right one based on current output mode.
b112e0f73   Johannes Berg   kernel-doc: singl...
1739
  sub output_blockhead {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1740
      no strict 'refs';
b9d97328e   Randy Dunlap   kernel-doc: clean...
1741
      my $func = "output_blockhead_" . $output_mode;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1742
1743
1744
1745
1746
      &$func(@_);
      $section_counter++;
  }
  
  ##
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
1747
  # takes a declaration (struct, union, enum, typedef) and
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1748
1749
1750
1751
  # invokes the right handler. NOT called for functions.
  sub dump_declaration($$) {
      no strict 'refs';
      my ($prototype, $file) = @_;
b9d97328e   Randy Dunlap   kernel-doc: clean...
1752
      my $func = "dump_" . $decl_type;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1753
1754
1755
1756
1757
1758
1759
1760
1761
1762
      &$func(@_);
  }
  
  sub dump_union($$) {
      dump_struct(@_);
  }
  
  sub dump_struct($$) {
      my $x = shift;
      my $file = shift;
a1d94aa55   Randy Dunlap   kernel-doc: check...
1763
      my $nested;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1764

52dc5aec9   Randy Dunlap   kernel-doc: restr...
1765
1766
      if ($x =~ /(struct|union)\s+(\w+)\s*{(.*)}/) {
  	#my $decl_type = $1;
3c308798a   Randy Dunlap   scripts: kernel-d...
1767
1768
  	$declaration_name = $2;
  	my $members = $3;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1769
1770
  
  	# ignore embedded structs or unions
a1d94aa55   Randy Dunlap   kernel-doc: check...
1771
1772
  	$members =~ s/({.*})//g;
  	$nested = $1;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1773

aeec46b97   Martin Waitz   [PATCH] DocBook: ...
1774
  	# ignore members marked private:
52dc5aec9   Randy Dunlap   kernel-doc: restr...
1775
1776
  	$members =~ s/\/\*\s*private:.*?\/\*\s*public:.*?\*\///gos;
  	$members =~ s/\/\*\s*private:.*//gos;
aeec46b97   Martin Waitz   [PATCH] DocBook: ...
1777
1778
  	# strip comments:
  	$members =~ s/\/\*.*?\*\///gos;
a1d94aa55   Randy Dunlap   kernel-doc: check...
1779
  	$nested =~ s/\/\*.*?\*\///gos;
d960eea97   Randy Dunlap   kernel-doc: move ...
1780
1781
  	# strip kmemcheck_bitfield_{begin,end}.*;
  	$members =~ s/kmemcheck_bitfield_.*?;//gos;
ef5da59f1   Randy Dunlap   scripts/kernel-do...
1782
1783
  	# strip attributes
  	$members =~ s/__aligned\s*\(\d+\)//gos;
aeec46b97   Martin Waitz   [PATCH] DocBook: ...
1784

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1785
  	create_parameterlist($members, ';', $file);
a1d94aa55   Randy Dunlap   kernel-doc: check...
1786
  	check_sections($file, $declaration_name, "struct", $sectcheck, $struct_actual, $nested);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
1801
  
  	output_declaration($declaration_name,
  			   'struct',
  			   {'struct' => $declaration_name,
  			    'module' => $modulename,
  			    'parameterlist' => \@parameterlist,
  			    'parameterdescs' => \%parameterdescs,
  			    'parametertypes' => \%parametertypes,
  			    'sectionlist' => \@sectionlist,
  			    'sections' => \%sections,
  			    'purpose' => $declaration_purpose,
  			    'type' => $decl_type
  			   });
      }
      else {
3c308798a   Randy Dunlap   scripts: kernel-d...
1802
1803
  	print STDERR "Error(${file}:$.): Cannot parse struct or union!
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1804
1805
1806
1807
1808
1809
1810
  	++$errors;
      }
  }
  
  sub dump_enum($$) {
      my $x = shift;
      my $file = shift;
aeec46b97   Martin Waitz   [PATCH] DocBook: ...
1811
      $x =~ s@/\*.*?\*/@@gos;	# strip comments.
b6d676db3   Randy Dunlap   mtd/nand_base: fi...
1812
      $x =~ s/^#\s*define\s+.*$//; # strip #define macros inside enums
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1813
      if ($x =~ /enum\s+(\w+)\s*{(.*)}/) {
3c308798a   Randy Dunlap   scripts: kernel-d...
1814
1815
  	$declaration_name = $1;
  	my $members = $2;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1816
1817
1818
1819
1820
  
  	foreach my $arg (split ',', $members) {
  	    $arg =~ s/^\s*(\w+).*/$1/;
  	    push @parameterlist, $arg;
  	    if (!$parameterdescs{$arg}) {
3c308798a   Randy Dunlap   scripts: kernel-d...
1821
1822
  		$parameterdescs{$arg} = $undescribed;
  		print STDERR "Warning(${file}:$.): Enum value '$arg' ".
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1823
1824
1825
1826
1827
  		    "not described in enum '$declaration_name'
  ";
  	    }
  
  	}
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
1828

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
  	output_declaration($declaration_name,
  			   'enum',
  			   {'enum' => $declaration_name,
  			    'module' => $modulename,
  			    'parameterlist' => \@parameterlist,
  			    'parameterdescs' => \%parameterdescs,
  			    'sectionlist' => \@sectionlist,
  			    'sections' => \%sections,
  			    'purpose' => $declaration_purpose
  			   });
      }
      else {
3c308798a   Randy Dunlap   scripts: kernel-d...
1841
1842
  	print STDERR "Error(${file}:$.): Cannot parse enum!
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1843
1844
1845
1846
1847
1848
1849
  	++$errors;
      }
  }
  
  sub dump_typedef($$) {
      my $x = shift;
      my $file = shift;
aeec46b97   Martin Waitz   [PATCH] DocBook: ...
1850
      $x =~ s@/\*.*?\*/@@gos;	# strip comments.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1851
      while (($x =~ /\(*.\)\s*;$/) || ($x =~ /\[*.\]\s*;$/)) {
3c308798a   Randy Dunlap   scripts: kernel-d...
1852
  	$x =~ s/\(*.\)\s*;$/;/;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1853
1854
1855
1856
  	$x =~ s/\[*.\]\s*;$/;/;
      }
  
      if ($x =~ /typedef.*\s+(\w+)\s*;/) {
3c308798a   Randy Dunlap   scripts: kernel-d...
1857
  	$declaration_name = $1;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
  
  	output_declaration($declaration_name,
  			   'typedef',
  			   {'typedef' => $declaration_name,
  			    'module' => $modulename,
  			    'sectionlist' => \@sectionlist,
  			    'sections' => \%sections,
  			    'purpose' => $declaration_purpose
  			   });
      }
      else {
3c308798a   Randy Dunlap   scripts: kernel-d...
1869
1870
  	print STDERR "Error(${file}:$.): Cannot parse typedef!
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1871
1872
1873
  	++$errors;
      }
  }
a1d94aa55   Randy Dunlap   kernel-doc: check...
1874
1875
1876
1877
1878
1879
1880
  sub save_struct_actual($) {
      my $actual = shift;
  
      # strip all spaces from the actual param so that it looks like one string item
      $actual =~ s/\s*//g;
      $struct_actual = $struct_actual . $actual . " ";
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1881
1882
1883
1884
1885
1886
  sub create_parameterlist($$$) {
      my $args = shift;
      my $splitter = shift;
      my $file = shift;
      my $type;
      my $param;
a6d3fe77d   Martin Waitz   [PATCH] DocBook: ...
1887
      # temporarily replace commas inside function pointer definition
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1888
      while ($args =~ /(\([^\),]+),/) {
3c308798a   Randy Dunlap   scripts: kernel-d...
1889
  	$args =~ s/(\([^\),]+),/$1#/g;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1890
      }
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
1891

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1892
1893
1894
      foreach my $arg (split($splitter, $args)) {
  	# strip comments
  	$arg =~ s/\/\*.*\*\///;
3c308798a   Randy Dunlap   scripts: kernel-d...
1895
1896
  	# strip leading/trailing spaces
  	$arg =~ s/^\s*//;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1897
1898
1899
1900
1901
1902
1903
1904
  	$arg =~ s/\s*$//;
  	$arg =~ s/\s+/ /;
  
  	if ($arg =~ /^#/) {
  	    # Treat preprocessor directive as a typeless variable just to fill
  	    # corresponding data structures "correctly". Catch it later in
  	    # output_* subs.
  	    push_parameter($arg, "", $file);
00d629614   Richard Kennedy   kernel-doc: fix f...
1905
  	} elsif ($arg =~ m/\(.+\)\s*\(/) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1906
1907
  	    # pointer-to-function
  	    $arg =~ tr/#/,/;
00d629614   Richard Kennedy   kernel-doc: fix f...
1908
  	    $arg =~ m/[^\(]+\(\*?\s*(\w*)\s*\)/;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1909
1910
  	    $param = $1;
  	    $type = $arg;
00d629614   Richard Kennedy   kernel-doc: fix f...
1911
  	    $type =~ s/([^\(]+\(\*?)\s*$param/$1/;
a1d94aa55   Randy Dunlap   kernel-doc: check...
1912
  	    save_struct_actual($param);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1913
  	    push_parameter($param, $type, $file);
aeec46b97   Martin Waitz   [PATCH] DocBook: ...
1914
  	} elsif ($arg) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1915
1916
1917
1918
1919
1920
1921
  	    $arg =~ s/\s*:\s*/:/g;
  	    $arg =~ s/\s*\[/\[/g;
  
  	    my @args = split('\s*,\s*', $arg);
  	    if ($args[0] =~ m/\*/) {
  		$args[0] =~ s/(\*+)\s*/ $1/;
  	    }
884f2810b   Borislav Petkov   kernel-doc: handl...
1922
1923
1924
1925
1926
1927
1928
1929
1930
  
  	    my @first_arg;
  	    if ($args[0] =~ /^(.*\s+)(.*?\[.*\].*)$/) {
  		    shift @args;
  		    push(@first_arg, split('\s+', $1));
  		    push(@first_arg, $2);
  	    } else {
  		    @first_arg = split('\s+', shift @args);
  	    }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1931
1932
1933
1934
1935
  	    unshift(@args, pop @first_arg);
  	    $type = join " ", @first_arg;
  
  	    foreach $param (@args) {
  		if ($param =~ m/^(\*+)\s*(.*)/) {
a1d94aa55   Randy Dunlap   kernel-doc: check...
1936
  		    save_struct_actual($2);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1937
1938
1939
  		    push_parameter($2, "$type $1", $file);
  		}
  		elsif ($param =~ m/(.*?):(\d+)/) {
7b97887ea   Randy Dunlap   kernel-doc: allow...
1940
  		    if ($type ne "") { # skip unnamed bit-fields
a1d94aa55   Randy Dunlap   kernel-doc: check...
1941
  			save_struct_actual($1);
7b97887ea   Randy Dunlap   kernel-doc: allow...
1942
1943
  			push_parameter($1, "$type:$2", $file)
  		    }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1944
1945
  		}
  		else {
a1d94aa55   Randy Dunlap   kernel-doc: check...
1946
  		    save_struct_actual($param);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
  		    push_parameter($param, $type, $file);
  		}
  	    }
  	}
      }
  }
  
  sub push_parameter($$$) {
  	my $param = shift;
  	my $type = shift;
  	my $file = shift;
5f8c7c98a   Randy Dunlap   kernel-doc: fix u...
1958
1959
1960
1961
1962
1963
  	if (($anon_struct_union == 1) && ($type eq "") &&
  	    ($param eq "}")) {
  		return;		# ignore the ending }; from anon. struct/union
  	}
  
  	$anon_struct_union = 0;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1964
1965
  	my $param_name = $param;
  	$param_name =~ s/\[.*//;
a6d3fe77d   Martin Waitz   [PATCH] DocBook: ...
1966
  	if ($type eq "" && $param =~ /\.\.\.$/)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1967
  	{
ced69090c   Randy Dunlap   kernel-doc: handl...
1968
1969
1970
  	    if (!defined $parameterdescs{$param} || $parameterdescs{$param} eq "") {
  		$parameterdescs{$param} = "variable arguments";
  	    }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1971
1972
1973
  	}
  	elsif ($type eq "" && ($param eq "" or $param eq "void"))
  	{
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1974
1975
1976
  	    $param="void";
  	    $parameterdescs{void} = "no arguments";
  	}
134fe01bf   Randy Dunlap   [PATCH] kernel-do...
1977
1978
1979
1980
  	elsif ($type eq "" && ($param eq "struct" or $param eq "union"))
  	# handle unnamed (anonymous) union or struct:
  	{
  		$type = $param;
5f8c7c98a   Randy Dunlap   kernel-doc: fix u...
1981
  		$param = "{unnamed_" . $param . "}";
134fe01bf   Randy Dunlap   [PATCH] kernel-do...
1982
1983
  		$parameterdescs{$param} = "anonymous
  ";
5f8c7c98a   Randy Dunlap   kernel-doc: fix u...
1984
  		$anon_struct_union = 1;
134fe01bf   Randy Dunlap   [PATCH] kernel-do...
1985
  	}
a6d3fe77d   Martin Waitz   [PATCH] DocBook: ...
1986
  	# warn if parameter has no description
134fe01bf   Randy Dunlap   [PATCH] kernel-do...
1987
1988
1989
  	# (but ignore ones starting with # as these are not parameters
  	# but inline preprocessor statements);
  	# also ignore unnamed structs/unions;
5f8c7c98a   Randy Dunlap   kernel-doc: fix u...
1990
  	if (!$anon_struct_union) {
a6d3fe77d   Martin Waitz   [PATCH] DocBook: ...
1991
  	if (!defined $parameterdescs{$param_name} && $param_name !~ /^#/) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1992
1993
1994
  	    $parameterdescs{$param_name} = $undescribed;
  
  	    if (($type eq 'function') || ($type eq 'enum')) {
3c308798a   Randy Dunlap   scripts: kernel-d...
1995
  		print STDERR "Warning(${file}:$.): Function parameter ".
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1996
1997
1998
1999
  		    "or member '$param' not " .
  		    "described in '$declaration_name'
  ";
  	    }
b9d97328e   Randy Dunlap   kernel-doc: clean...
2000
  	    print STDERR "Warning(${file}:$.):" .
3c308798a   Randy Dunlap   scripts: kernel-d...
2001
2002
  			 " No description found for parameter '$param'
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2003
  	    ++$warnings;
3c308798a   Randy Dunlap   scripts: kernel-d...
2004
2005
  	}
  	}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2006

2b35f4d9c   Randy Dunlap   kernel-doc: escap...
2007
  	$param = xml_escape($param);
25985edce   Lucas De Marchi   Fix common misspe...
2008
  	# strip spaces from $param so that it is one continuous string
e34e7dbb3   Randy Dunlap   kernel-doc: fix p...
2009
2010
2011
2012
2013
2014
2015
2016
  	# on @parameterlist;
  	# this fixes a problem where check_sections() cannot find
  	# a parameter like "addr[6 + 2]" because it actually appears
  	# as "addr[6", "+", "2]" on the parameter list;
  	# but it's better to maintain the param string unchanged for output,
  	# so just weaken the string compare in check_sections() to ignore
  	# "[blah" in a parameter string;
  	###$param =~ s/\s*//g;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2017
2018
2019
  	push @parameterlist, $param;
  	$parametertypes{$param} = $type;
  }
a1d94aa55   Randy Dunlap   kernel-doc: check...
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
  sub check_sections($$$$$$) {
  	my ($file, $decl_name, $decl_type, $sectcheck, $prmscheck, $nested) = @_;
  	my @sects = split ' ', $sectcheck;
  	my @prms = split ' ', $prmscheck;
  	my $err;
  	my ($px, $sx);
  	my $prm_clean;		# strip trailing "[array size]" and/or beginning "*"
  
  	foreach $sx (0 .. $#sects) {
  		$err = 1;
  		foreach $px (0 .. $#prms) {
  			$prm_clean = $prms[$px];
  			$prm_clean =~ s/\[.*\]//;
1f3a66889   Johannes Berg   kernel-doc: ignor...
2033
  			$prm_clean =~ s/__attribute__\s*\(\([a-z,_\*\s\(\)]*\)\)//i;
e34e7dbb3   Randy Dunlap   kernel-doc: fix p...
2034
2035
2036
2037
2038
2039
2040
  			# ignore array size in a parameter string;
  			# however, the original param string may contain
  			# spaces, e.g.:  addr[6 + 2]
  			# and this appears in @prms as "addr[6" since the
  			# parameter list is split at spaces;
  			# hence just ignore "[..." for the sections check;
  			$prm_clean =~ s/\[.*//;
a1d94aa55   Randy Dunlap   kernel-doc: check...
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
  			##$prm_clean =~ s/^\**//;
  			if ($prm_clean eq $sects[$sx]) {
  				$err = 0;
  				last;
  			}
  		}
  		if ($err) {
  			if ($decl_type eq "function") {
  				print STDERR "Warning(${file}:$.): " .
  					"Excess function parameter " .
  					"'$sects[$sx]' " .
  					"description in '$decl_name'
  ";
  				++$warnings;
  			} else {
  				if ($nested !~ m/\Q$sects[$sx]\E/) {
  				    print STDERR "Warning(${file}:$.): " .
  					"Excess struct/union/enum/typedef member " .
  					"'$sects[$sx]' " .
  					"description in '$decl_name'
  ";
  				    ++$warnings;
  				}
  			}
  		}
  	}
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
  ##
  # takes a function prototype and the name of the current file being
  # processed and spits out all the details stored in the global
  # arrays/hashes.
  sub dump_function($$) {
      my $prototype = shift;
      my $file = shift;
  
      $prototype =~ s/^static +//;
      $prototype =~ s/^extern +//;
4dc3b16ba   Pavel Pisa   [PATCH] DocBook: ...
2078
      $prototype =~ s/^asmlinkage +//;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2079
2080
      $prototype =~ s/^inline +//;
      $prototype =~ s/^__inline__ +//;
32e794015   Randy Dunlap   [PATCH] kernel-do...
2081
2082
2083
      $prototype =~ s/^__inline +//;
      $prototype =~ s/^__always_inline +//;
      $prototype =~ s/^noinline +//;
0129a057b   Randy Dunlap   [PATCH] kernel-do...
2084
      $prototype =~ s/__devinit +//;
74fc5c653   Randy Dunlap   kernel-doc: handl...
2085
      $prototype =~ s/__init +//;
20072205f   Randy Dunlap   scripts/kernel-do...
2086
      $prototype =~ s/__init_or_module +//;
890c78c2d   Randy Dunlap   kernel-doc: allow...
2087
      $prototype =~ s/^#\s*define\s+//; #ak added
328d24403   Randy Dunlap   [PATCH] kernel-do...
2088
      $prototype =~ s/__attribute__\s*\(\([a-z,]*\)\)//;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
  
      # Yes, this truly is vile.  We are looking for:
      # 1. Return type (may be nothing if we're looking at a macro)
      # 2. Function name
      # 3. Function parameters.
      #
      # All the while we have to watch out for function pointer parameters
      # (which IIRC is what the two sections are for), C types (these
      # regexps don't even start to express all the possibilities), and
      # so on.
      #
      # If you mess with these regexps, it's a good idea to check that
      # the following functions' documentation still comes out right:
      # - parport_register_device (function pointer parameters)
      # - atomic_set (macro)
9598f91f2   Martin Waitz   [PATCH] DocBook: ...
2104
      # - pci_match_device, __copy_to_user (long return type)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2105
2106
2107
2108
2109
  
      if ($prototype =~ m/^()([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ ||
  	$prototype =~ m/^(\w+)\s+([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ ||
  	$prototype =~ m/^(\w+\s*\*)\s*([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ ||
  	$prototype =~ m/^(\w+\s+\w+)\s+([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ ||
94b3e03c8   Randy Dunlap   kernel-doc: fix f...
2110
  	$prototype =~ m/^(\w+\s+\w+\s*\*+)\s*([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ ||
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2111
2112
2113
2114
2115
2116
2117
2118
  	$prototype =~ m/^(\w+\s+\w+\s+\w+)\s+([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ ||
  	$prototype =~ m/^(\w+\s+\w+\s+\w+\s*\*)\s*([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ ||
  	$prototype =~ m/^()([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ ||
  	$prototype =~ m/^(\w+)\s+([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ ||
  	$prototype =~ m/^(\w+\s*\*)\s*([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ ||
  	$prototype =~ m/^(\w+\s+\w+)\s+([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ ||
  	$prototype =~ m/^(\w+\s+\w+\s*\*)\s*([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ ||
  	$prototype =~ m/^(\w+\s+\w+\s+\w+)\s+([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ ||
9598f91f2   Martin Waitz   [PATCH] DocBook: ...
2119
2120
  	$prototype =~ m/^(\w+\s+\w+\s+\w+\s*\*)\s*([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ ||
  	$prototype =~ m/^(\w+\s+\w+\s+\w+\s+\w+)\s+([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ ||
412ecd775   Randy Dunlap   [PATCH] fix fatal...
2121
2122
  	$prototype =~ m/^(\w+\s+\w+\s+\w+\s+\w+\s*\*)\s*([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ ||
  	$prototype =~ m/^(\w+\s+\w+\s*\*\s*\w+\s*\*\s*)\s*([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/)  {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2123
2124
2125
2126
2127
2128
2129
2130
2131
2132
2133
  	$return_type = $1;
  	$declaration_name = $2;
  	my $args = $3;
  
  	create_parameterlist($args, ',', $file);
      } else {
  	print STDERR "Error(${file}:$.): cannot understand prototype: '$prototype'
  ";
  	++$errors;
  	return;
      }
a1d94aa55   Randy Dunlap   kernel-doc: check...
2134
2135
  	my $prms = join " ", @parameterlist;
  	check_sections($file, $declaration_name, "function", $sectcheck, $prms, "");
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
2136
      output_declaration($declaration_name,
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2137
2138
2139
2140
2141
2142
2143
2144
2145
2146
2147
2148
  		       'function',
  		       {'function' => $declaration_name,
  			'module' => $modulename,
  			'functiontype' => $return_type,
  			'parameterlist' => \@parameterlist,
  			'parameterdescs' => \%parameterdescs,
  			'parametertypes' => \%parametertypes,
  			'sectionlist' => \@sectionlist,
  			'sections' => \%sections,
  			'purpose' => $declaration_purpose
  		       });
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2149
2150
2151
2152
2153
2154
2155
2156
  sub reset_state {
      $function = "";
      %constants = ();
      %parameterdescs = ();
      %parametertypes = ();
      @parameterlist = ();
      %sections = ();
      @sectionlist = ();
a1d94aa55   Randy Dunlap   kernel-doc: check...
2157
2158
      $sectcheck = "";
      $struct_actual = "";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2159
      $prototype = "";
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
2160

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2161
2162
      $state = 0;
  }
56afb0f88   Jason Baron   kerneldoc, tracin...
2163
2164
2165
2166
  sub tracepoint_munge($) {
  	my $file = shift;
  	my $tracepointname = 0;
  	my $tracepointargs = 0;
3a9089fd7   Jason Baron   tracing: Add DEFI...
2167
  	if ($prototype =~ m/TRACE_EVENT\((.*?),/) {
56afb0f88   Jason Baron   kerneldoc, tracin...
2168
2169
  		$tracepointname = $1;
  	}
3a9089fd7   Jason Baron   tracing: Add DEFI...
2170
2171
2172
2173
2174
2175
2176
2177
  	if ($prototype =~ m/DEFINE_SINGLE_EVENT\((.*?),/) {
  		$tracepointname = $1;
  	}
  	if ($prototype =~ m/DEFINE_EVENT\((.*?),(.*?),/) {
  		$tracepointname = $2;
  	}
  	$tracepointname =~ s/^\s+//; #strip leading whitespace
  	if ($prototype =~ m/TP_PROTO\((.*?)\)/) {
56afb0f88   Jason Baron   kerneldoc, tracin...
2178
2179
2180
2181
2182
2183
2184
2185
2186
2187
2188
  		$tracepointargs = $1;
  	}
  	if (($tracepointname eq 0) || ($tracepointargs eq 0)) {
  		print STDERR "Warning(${file}:$.): Unrecognized tracepoint format: 
  ".
  			     "$prototype
  ";
  	} else {
  		$prototype = "static inline void trace_$tracepointname($tracepointargs)";
  	}
  }
b4870bc5e   Randy Dunlap   kernel-doc: fix s...
2189
2190
2191
2192
2193
2194
2195
2196
2197
2198
2199
2200
2201
2202
2203
2204
2205
2206
2207
2208
2209
2210
2211
2212
2213
2214
2215
2216
2217
2218
2219
2220
2221
2222
  sub syscall_munge() {
  	my $void = 0;
  
  	$prototype =~ s@[\r
  \t]+@ @gos; # strip newlines/CR's/tabs
  ##	if ($prototype =~ m/SYSCALL_DEFINE0\s*\(\s*(a-zA-Z0-9_)*\s*\)/) {
  	if ($prototype =~ m/SYSCALL_DEFINE0/) {
  		$void = 1;
  ##		$prototype = "long sys_$1(void)";
  	}
  
  	$prototype =~ s/SYSCALL_DEFINE.*\(/long sys_/; # fix return type & func name
  	if ($prototype =~ m/long (sys_.*?),/) {
  		$prototype =~ s/,/\(/;
  	} elsif ($void) {
  		$prototype =~ s/\)/\(void\)/;
  	}
  
  	# now delete all of the odd-number commas in $prototype
  	# so that arg types & arg names don't have a comma between them
  	my $count = 0;
  	my $len = length($prototype);
  	if ($void) {
  		$len = 0;	# skip the for-loop
  	}
  	for (my $ix = 0; $ix < $len; $ix++) {
  		if (substr($prototype, $ix, 1) eq ',') {
  			$count++;
  			if ($count % 2 == 1) {
  				substr($prototype, $ix, 1) = ' ';
  			}
  		}
  	}
  }
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
2223
  sub process_state3_function($$) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2224
2225
      my $x = shift;
      my $file = shift;
51f5a0c8f   Randy Dunlap   kernel-doc: strip...
2226
      $x =~ s@\/\/.*$@@gos; # strip C99-style comments to end of line
890c78c2d   Randy Dunlap   kernel-doc: allow...
2227
      if ($x =~ m#\s*/\*\s+MACDOC\s*#io || ($x =~ /^#/ && $x !~ /^#\s*define/)) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2228
2229
2230
  	# do nothing
      }
      elsif ($x =~ /([^\{]*)/) {
3c308798a   Randy Dunlap   scripts: kernel-d...
2231
  	$prototype .= $1;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2232
      }
b4870bc5e   Randy Dunlap   kernel-doc: fix s...
2233

890c78c2d   Randy Dunlap   kernel-doc: allow...
2234
      if (($x =~ /\{/) || ($x =~ /\#\s*define/) || ($x =~ /;/)) {
3c308798a   Randy Dunlap   scripts: kernel-d...
2235
  	$prototype =~ s@/\*.*?\*/@@gos;	# strip comments.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2236
2237
2238
  	$prototype =~ s@[\r
  ]+@ @gos; # strip newlines/cr's.
  	$prototype =~ s@^\s+@@gos; # strip leading spaces
b4870bc5e   Randy Dunlap   kernel-doc: fix s...
2239
2240
2241
  	if ($prototype =~ /SYSCALL_DEFINE/) {
  		syscall_munge();
  	}
3a9089fd7   Jason Baron   tracing: Add DEFI...
2242
2243
2244
  	if ($prototype =~ /TRACE_EVENT/ || $prototype =~ /DEFINE_EVENT/ ||
  	    $prototype =~ /DEFINE_SINGLE_EVENT/)
  	{
56afb0f88   Jason Baron   kerneldoc, tracin...
2245
2246
  		tracepoint_munge($file);
  	}
b4870bc5e   Randy Dunlap   kernel-doc: fix s...
2247
  	dump_function($prototype, $file);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2248
2249
2250
  	reset_state();
      }
  }
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
2251
  sub process_state3_type($$) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2252
2253
      my $x = shift;
      my $file = shift;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2254
2255
2256
2257
      $x =~ s@[\r
  ]+@ @gos; # strip newlines/cr's.
      $x =~ s@^\s+@@gos; # strip leading spaces
      $x =~ s@\s+$@@gos; # strip trailing spaces
51f5a0c8f   Randy Dunlap   kernel-doc: strip...
2258
      $x =~ s@\/\/.*$@@gos; # strip C99-style comments to end of line
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2259
2260
2261
2262
2263
2264
      if ($x =~ /^#/) {
  	# To distinguish preprocessor directive from regular declaration later.
  	$x .= ";";
      }
  
      while (1) {
3c308798a   Randy Dunlap   scripts: kernel-d...
2265
  	if ( $x =~ /([^{};]*)([{};])(.*)/ ) {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2266
2267
2268
2269
  	    $prototype .= $1 . $2;
  	    ($2 eq '{') && $brcount++;
  	    ($2 eq '}') && $brcount--;
  	    if (($2 eq ';') && ($brcount == 0)) {
b9d97328e   Randy Dunlap   kernel-doc: clean...
2270
  		dump_declaration($prototype, $file);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2271
  		reset_state();
3c308798a   Randy Dunlap   scripts: kernel-d...
2272
  		last;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2273
2274
  	    }
  	    $x = $3;
3c308798a   Randy Dunlap   scripts: kernel-d...
2275
  	} else {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2276
2277
2278
2279
2280
  	    $prototype .= $x;
  	    last;
  	}
      }
  }
6b5b55f6c   Randy Dunlap   kernel-doc: fix d...
2281
2282
2283
2284
2285
2286
2287
  # xml_escape: replace <, >, and & in the text stream;
  #
  # however, formatting controls that are generated internally/locally in the
  # kernel-doc script are not escaped here; instead, they begin life like
  # $blankline_html (4 of '\' followed by a mnemonic + ':'), then these strings
  # are converted to their mnemonic-expected output, without the 4 * '\' & ':',
  # just before actual output; (this is done by local_unescape())
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2288
2289
  sub xml_escape($) {
  	my $text = shift;
ecfb251a9   Randy Dunlap   [PATCH] kernel-do...
2290
2291
2292
  	if (($output_mode eq "text") || ($output_mode eq "man")) {
  		return $text;
  	}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2293
2294
2295
2296
2297
  	$text =~ s/\&/\\\\\\amp;/g;
  	$text =~ s/\</\\\\\\lt;/g;
  	$text =~ s/\>/\\\\\\gt;/g;
  	return $text;
  }
6b5b55f6c   Randy Dunlap   kernel-doc: fix d...
2298
2299
2300
2301
2302
2303
2304
2305
2306
2307
2308
  # convert local escape strings to html
  # local escape strings look like:  '\\\\menmonic:' (that's 4 backslashes)
  sub local_unescape($) {
  	my $text = shift;
  	if (($output_mode eq "text") || ($output_mode eq "man")) {
  		return $text;
  	}
  	$text =~ s/\\\\\\\\lt:/</g;
  	$text =~ s/\\\\\\\\gt:/>/g;
  	return $text;
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2309
  sub process_file($) {
2283a117f   Randy Dunlap   [PATCH] scripts/k...
2310
      my $file;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2311
2312
      my $identifier;
      my $func;
a21217daa   Randy Dunlap   [PATCH] kernel-do...
2313
      my $descr;
6423133bd   Johannes Weiner   kernel-doc: allow...
2314
      my $in_purpose = 0;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2315
      my $initial_section_counter = $section_counter;
2283a117f   Randy Dunlap   [PATCH] scripts/k...
2316
2317
2318
2319
2320
2321
      if (defined($ENV{'SRCTREE'})) {
  	$file = "$ENV{'SRCTREE'}" . "/" . "@_";
      }
      else {
  	$file = "@_";
      }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2322
2323
2324
2325
2326
2327
2328
2329
2330
2331
      if (defined($source_map{$file})) {
  	$file = $source_map{$file};
      }
  
      if (!open(IN,"<$file")) {
  	print STDERR "Error: Cannot open file $file
  ";
  	++$errors;
  	return;
      }
a9e7314b7   Ilya Dryomov   kernel-doc: track...
2332
      $. = 1;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2333
2334
2335
2336
2337
      $section_counter = 0;
      while (<IN>) {
  	if ($state == 0) {
  	    if (/$doc_start/o) {
  		$state = 1;		# next line is always the function name
850622dfa   Randy Dunlap   [PATCH] kernel-do...
2338
  		$in_doc_sect = 0;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2339
2340
2341
2342
2343
2344
2345
2346
2347
2348
  	    }
  	} elsif ($state == 1) {	# this line is the function name (always)
  	    if (/$doc_block/o) {
  		$state = 4;
  		$contents = "";
  		if ( $1 eq "" ) {
  			$section = $section_intro;
  		} else {
  			$section = $1;
  		}
3c308798a   Randy Dunlap   scripts: kernel-d...
2349
  	    }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2350
2351
2352
2353
2354
2355
2356
2357
  	    elsif (/$doc_decl/o) {
  		$identifier = $1;
  		if (/\s*([\w\s]+?)\s*-/) {
  		    $identifier = $1;
  		}
  
  		$state = 2;
  		if (/-(.*)/) {
51f5a0c8f   Randy Dunlap   kernel-doc: strip...
2358
  		    # strip leading/trailing/multiple spaces
a21217daa   Randy Dunlap   [PATCH] kernel-do...
2359
2360
2361
2362
2363
  		    $descr= $1;
  		    $descr =~ s/^\s*//;
  		    $descr =~ s/\s*$//;
  		    $descr =~ s/\s+/ /;
  		    $declaration_purpose = xml_escape($descr);
6423133bd   Johannes Weiner   kernel-doc: allow...
2364
  		    $in_purpose = 1;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2365
2366
2367
  		} else {
  		    $declaration_purpose = "";
  		}
77cc23b8c   Randy Dunlap   kernel-doc: warn ...
2368
2369
2370
2371
2372
2373
2374
  
  		if (($declaration_purpose eq "") && $verbose) {
  			print STDERR "Warning(${file}:$.): missing initial short description on line:
  ";
  			print STDERR $_;
  			++$warnings;
  		}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2375
2376
2377
2378
2379
2380
2381
2382
2383
2384
2385
2386
2387
2388
2389
2390
2391
2392
2393
2394
2395
2396
2397
2398
2399
2400
2401
  		if ($identifier =~ m/^struct/) {
  		    $decl_type = 'struct';
  		} elsif ($identifier =~ m/^union/) {
  		    $decl_type = 'union';
  		} elsif ($identifier =~ m/^enum/) {
  		    $decl_type = 'enum';
  		} elsif ($identifier =~ m/^typedef/) {
  		    $decl_type = 'typedef';
  		} else {
  		    $decl_type = 'function';
  		}
  
  		if ($verbose) {
  		    print STDERR "Info(${file}:$.): Scanning doc for $identifier
  ";
  		}
  	    } else {
  		print STDERR "Warning(${file}:$.): Cannot understand $_ on line $.",
  		" - I thought it was a doc line
  ";
  		++$warnings;
  		$state = 0;
  	    }
  	} elsif ($state == 2) {	# look for head: lines, and include content
  	    if (/$doc_sect/o) {
  		$newsection = $1;
  		$newcontents = $2;
792aa2f2c   Randy Dunlap   kernel-doc: preve...
2402
2403
  		if (($contents ne "") && ($contents ne "
  ")) {
850622dfa   Randy Dunlap   [PATCH] kernel-do...
2404
2405
2406
2407
2408
  		    if (!$in_doc_sect && $verbose) {
  			print STDERR "Warning(${file}:$.): contents before sections
  ";
  			++$warnings;
  		    }
94dc7ad55   Randy Dunlap   kernel-doc: detec...
2409
  		    dump_section($file, $section, xml_escape($contents));
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2410
2411
  		    $section = $section_default;
  		}
850622dfa   Randy Dunlap   [PATCH] kernel-do...
2412
  		$in_doc_sect = 1;
6423133bd   Johannes Weiner   kernel-doc: allow...
2413
  		$in_purpose = 0;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2414
2415
  		$contents = $newcontents;
  		if ($contents ne "") {
272057447   Randy Dunlap   [PATCH] kernel-do...
2416
2417
2418
  		    while ((substr($contents, 0, 1) eq " ") ||
  			substr($contents, 0, 1) eq "\t") {
  			    $contents = substr($contents, 1);
05189497d   Randy Dunlap   [PATCH] kernel-do...
2419
  		    }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2420
2421
2422
2423
2424
  		    $contents .= "
  ";
  		}
  		$section = $newsection;
  	    } elsif (/$doc_end/) {
4c98ecaf3   Randy Dunlap   scripts/kernel-do...
2425
2426
  		if (($contents ne "") && ($contents ne "
  ")) {
94dc7ad55   Randy Dunlap   kernel-doc: detec...
2427
  		    dump_section($file, $section, xml_escape($contents));
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2428
2429
2430
  		    $section = $section_default;
  		    $contents = "";
  		}
46b958eb8   Randy Dunlap   kernel-doc: detec...
2431
2432
2433
2434
2435
  		# look for doc_com + <text> + doc_end:
  		if ($_ =~ m'\s*\*\s*[a-zA-Z_0-9:\.]+\*/') {
  		    print STDERR "Warning(${file}:$.): suspicious ending line: $_";
  		    ++$warnings;
  		}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2436
2437
2438
2439
  
  		$prototype = "";
  		$state = 3;
  		$brcount = 0;
232acbcf5   Randy Dunlap   [PATCH] kernel-do...
2440
2441
  #		print STDERR "end of doc comment, looking for prototype
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2442
2443
2444
  	    } elsif (/$doc_content/) {
  		# miguel-style comment kludge, look for blank lines after
  		# @parameter line to signify start of description
6423133bd   Johannes Weiner   kernel-doc: allow...
2445
2446
2447
2448
2449
2450
2451
2452
2453
2454
2455
2456
2457
2458
  		if ($1 eq "") {
  		    if ($section =~ m/^@/ || $section eq $section_context) {
  			dump_section($file, $section, xml_escape($contents));
  			$section = $section_default;
  			$contents = "";
  		    } else {
  			$contents .= "
  ";
  		    }
  		    $in_purpose = 0;
  		} elsif ($in_purpose == 1) {
  		    # Continued declaration purpose
  		    chomp($declaration_purpose);
  		    $declaration_purpose .= " " . xml_escape($1);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2459
  		} else {
b9d97328e   Randy Dunlap   kernel-doc: clean...
2460
2461
  		    $contents .= $1 . "
  ";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2462
2463
2464
  		}
  	    } else {
  		# i dont know - bad line?  ignore.
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
2465
  		print STDERR "Warning(${file}:$.): bad line: $_";
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2466
2467
  		++$warnings;
  	    }
232acbcf5   Randy Dunlap   [PATCH] kernel-do...
2468
  	} elsif ($state == 3) {	# scanning for function '{' (end of prototype)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2469
  	    if ($decl_type eq 'function') {
3c308798a   Randy Dunlap   scripts: kernel-d...
2470
  		process_state3_function($_, $file);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2471
  	    } else {
3c308798a   Randy Dunlap   scripts: kernel-d...
2472
  		process_state3_type($_, $file);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2473
2474
2475
  	    }
  	} elsif ($state == 4) {
  		# Documentation block
3c308798a   Randy Dunlap   scripts: kernel-d...
2476
  		if (/$doc_block/) {
94dc7ad55   Randy Dunlap   kernel-doc: detec...
2477
  			dump_doc_section($file, $section, xml_escape($contents));
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2478
2479
2480
2481
2482
2483
2484
2485
2486
2487
2488
2489
2490
2491
  			$contents = "";
  			$function = "";
  			%constants = ();
  			%parameterdescs = ();
  			%parametertypes = ();
  			@parameterlist = ();
  			%sections = ();
  			@sectionlist = ();
  			$prototype = "";
  			if ( $1 eq "" ) {
  				$section = $section_intro;
  			} else {
  				$section = $1;
  			}
3c308798a   Randy Dunlap   scripts: kernel-d...
2492
  		}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2493
2494
  		elsif (/$doc_end/)
  		{
94dc7ad55   Randy Dunlap   kernel-doc: detec...
2495
  			dump_doc_section($file, $section, xml_escape($contents));
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2496
2497
2498
2499
2500
2501
2502
2503
2504
2505
2506
2507
2508
2509
2510
2511
2512
2513
2514
2515
2516
  			$contents = "";
  			$function = "";
  			%constants = ();
  			%parameterdescs = ();
  			%parametertypes = ();
  			@parameterlist = ();
  			%sections = ();
  			@sectionlist = ();
  			$prototype = "";
  			$state = 0;
  		}
  		elsif (/$doc_content/)
  		{
  			if ( $1 eq "" )
  			{
  				$contents .= $blankline;
  			}
  			else
  			{
  				$contents .= $1 . "
  ";
3c3b809e2   Randy Dunlap   [PATCH] kernel-do...
2517
  			}
3c308798a   Randy Dunlap   scripts: kernel-d...
2518
2519
  		}
  	}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2520
2521
2522
2523
2524
2525
2526
2527
2528
2529
2530
2531
2532
2533
2534
2535
2536
2537
2538
2539
2540
2541
2542
2543
2544
2545
2546
2547
2548
2549
2550
2551
2552
2553
2554
2555
2556
2557
2558
2559
2560
2561
2562
2563
2564
2565
2566
2567
2568
2569
2570
2571
2572
2573
2574
2575
2576
2577
2578
      }
      if ($initial_section_counter == $section_counter) {
  	print STDERR "Warning(${file}): no structured comments found
  ";
  	if ($output_mode eq "xml") {
  	    # The template wants at least one RefEntry here; make one.
  	    print "<refentry>
  ";
  	    print " <refnamediv>
  ";
  	    print "  <refname>
  ";
  	    print "   ${file}
  ";
  	    print "  </refname>
  ";
  	    print "  <refpurpose>
  ";
  	    print "   Document generation inconsistency
  ";
  	    print "  </refpurpose>
  ";
  	    print " </refnamediv>
  ";
  	    print " <refsect1>
  ";
  	    print "  <title>
  ";
  	    print "   Oops
  ";
  	    print "  </title>
  ";
  	    print "  <warning>
  ";
  	    print "   <para>
  ";
  	    print "    The template for this document tried to insert
  ";
  	    print "    the structured comment from the file
  ";
  	    print "    <filename>${file}</filename> at this point,
  ";
  	    print "    but none was found.
  ";
  	    print "    This dummy section is inserted to allow
  ";
  	    print "    generation to continue.
  ";
  	    print "   </para>
  ";
  	    print "  </warning>
  ";
  	    print " </refsect1>
  ";
  	    print "</refentry>
  ";
  	}
      }
  }
8484baaa5   Randy Dunlap   kernel-doc: code ...
2579
2580
2581
2582
2583
2584
2585
2586
2587
2588
2589
2590
2591
2592
2593
2594
2595
2596
2597
2598
2599
2600
2601
2602
2603
2604
2605
2606
2607
2608
2609
2610
2611
2612
2613
2614
2615
2616
2617
2618
  
  
  $kernelversion = get_kernel_version();
  
  # generate a sequence of code that will splice in highlighting information
  # using the s// operator.
  foreach my $pattern (keys %highlights) {
  #   print STDERR "scanning pattern:$pattern, highlight:($highlights{$pattern})
  ";
      $dohighlight .=  "\$contents =~ s:$pattern:$highlights{$pattern}:gs;
  ";
  }
  
  # Read the file that maps relative names to absolute names for
  # separate source and object directories and for shadow trees.
  if (open(SOURCE_MAP, "<.tmp_filelist.txt")) {
  	my ($relname, $absname);
  	while(<SOURCE_MAP>) {
  		chop();
  		($relname, $absname) = (split())[0..1];
  		$relname =~ s:^/+::;
  		$source_map{$relname} = $absname;
  	}
  	close(SOURCE_MAP);
  }
  
  foreach (@ARGV) {
      chomp;
      process_file($_);
  }
  if ($verbose && $errors) {
    print STDERR "$errors errors
  ";
  }
  if ($verbose && $warnings) {
    print STDERR "$warnings warnings
  ";
  }
  
  exit($errors);