1JAVADOC(1) JDK Commands JAVADOC(1)
2
3
4
6 javadoc - generate HTML pages of API documentation from Java source
7 files
8
10 javadoc [options] [packagenames] [sourcefiles] [@files]
11
12 options
13 Specifies command-line options, separated by spaces. See Op‐
14 tions for javadoc, Extended Options, Standard doclet Options,
15 and Additional Options Provided by the Standard doclet.
16
17 packagenames
18 Specifies names of packages that you want to document, separated
19 by spaces, for example java.lang java.lang.reflect java.awt. If
20 you want to also document the subpackages, then use the -sub‐
21 packages option to specify the packages.
22
23 By default, javadoc looks for the specified packages in the cur‐
24 rent directory and subdirectories. Use the -sourcepath option
25 to specify the list of directories where to look for packages.
26
27 sourcefiles
28 Specifies names of Java source files that you want to document,
29 separated by spaces, for example Class.java Object.java But‐
30 ton.java. By default, javadoc looks for the specified classes
31 in the current directory. However, you can specify the full
32 path to the class file and use wildcard characters, for example
33 /home/src/java/awt/Graphics*.java. You can also specify the
34 path relative to the current directory.
35
36 @files Specifies names of files that contain a list of javadoc tool op‐
37 tions, package names, and source file names in any order.
38
40 The javadoc tool parses the declarations and documentation comments in
41 a set of Java source files and produces corresponding HTML pages that
42 describe (by default) the public and protected classes, nested classes
43 (but not anonymous inner classes), interfaces, constructors, methods,
44 and fields. You can use the javadoc tool to generate the API documen‐
45 tation or the implementation documentation for a set of source files.
46
47 You can run the javadoc tool on entire packages, individual source
48 files, or both. When documenting entire packages, you can use the
49 -subpackages option either to recursively traverse a directory and its
50 subdirectories, or to pass in an explicit list of package names. When
51 you document individual source files, pass in a list of Java source
52 file names. See javadoc Overview [https://www.oracle.com/pls/top‐
53 ic/lookup?ctx=en/java/javase/13/tools&id=JS‐
54 JAV-GUID-7A344353-3BBF-45C4-8B28-15025DDCC643] in Java Platform, Stan‐
55 dard Edition Javadoc Guide for information about using the javadoc
56 tool.
57
59 The standard doclet does not validate the content of documentation com‐
60 ments for conformance, nor does it attempt to correct any errors in
61 documentation comments. Anyone running javadoc is advised to be aware
62 of the problems that may arise when generating non-conformant output or
63 output containing executable content, such as JavaScript. The standard
64 doclet does provide the doclint feature to help developers detect com‐
65 mon problems in documentation comments; but it is also recommended to
66 check the generated output with any appropriate conformance and other
67 checking tools.
68
69 For more details on the conformance requirements for HTML5 documents,
70 see Conformance requirements [https://www.w3.org/TR/html5/infrastruc‐
71 ture.html#conformance-requirements] in the HTML5 Specification. For
72 more details on security issues related to web pages, see the Open Web
73 Application Security Project (OWASP) [https://www.owasp.org] page.
74
76 The following core javadoc options are equivalent to corresponding
77 javac options. See Standard Options in javac for the detailed descrip‐
78 tions of using these options:
79
80 · --add-modules
81
82 · -bootclasspath
83
84 · --class-path, -classpath, or -cp
85
86 · --enable-preview
87
88 · -encoding
89
90 · -extdirs
91
92 · --limit-modules
93
94 · --module
95
96 · --module-path or -p
97
98 · --module-source-path
99
100 · --release
101
102 · -source
103
104 · --source-path or -sourcepath
105
106 · --system
107
108 · --upgrade-module-path
109
110 The following options are the core javadoc options that are not equiva‐
111 lent to a corresponding javac option:
112
113 Note:
114
115 In tools that support -- style options, the GNU-style options can use
116 the equal sign (=) instead of a white space to separate the name of an
117 option from its value.
118
119 -breakiterator
120 Computes the first sentence with BreakIterator. The first sen‐
121 tence is copied to the package, class, or member summary and to
122 the alphabetic index. The BreakIterator class is used to deter‐
123 mine the end of a sentence for all languages except for English.
124
125 · English default sentence-break algorithm --- Stops at a period
126 followed by a space or an HTML block tag, such as <P>.
127
128 · Breakiterator sentence-break algorithm --- Stops at a period,
129 question mark, or exclamation point followed by a space when
130 the next word starts with a capital letter. This is meant to
131 handle most abbreviations (such as "The serial no. is valid",
132 but will not handle "Mr. Smith"). The -breakiterator option
133 doesn't stop at HTML tags or sentences that begin with numbers
134 or symbols. The algorithm stops at the last period in
135 ../filename, even when embedded in an HTML tag.
136
137 -doclet class
138 Generates output by using an alternate doclet. Use the fully
139 qualified name. This doclet defines the content and formats the
140 output. If the -doclet option isn't used, then the javadoc tool
141 uses the standard doclet for generating the default HTML format.
142 This class must contain the start(Root) method. The path to
143 this starting class is defined by the -docletpath option.
144
145 -docletpath path
146 Specifies where to find doclet class files (specified with the
147 -doclet option) and any JAR files it depends on. If the start‐
148 ing class file is in a JAR file, then this option specifies the
149 path to that JAR file. You can specify an absolute path or a
150 path relative to the current directory. If classpathlist con‐
151 tains multiple paths or JAR files, then they should be separated
152 with a colon (:) on Oracle Solaris and a semi-colon (;) on Win‐
153 dows. This option isn't necessary when the doclet starting
154 class is already in the search path.
155
156 -exclude pkglist
157 Unconditionally, excludes the specified packages and their sub‐
158 packages from the list formed by -subpackages. It excludes
159 those packages even when they would otherwise be included by
160 some earlier or later -subpackages option.
161
162 The following example would include java.io, java.util, and ja‐
163 va.math (among others), but would exclude packages rooted at ja‐
164 va.net and java.lang. Notice that these examples exclude ja‐
165 va.lang.ref, which is a subpackage of java.lang.
166
167 · Oracle Solaris, Linux, and OS X:
168
169 javadoc -sourcepath /home/user/src -subpackages ja‐
170 va -exclude java.net:java.lang
171
172 · Windows:
173
174 javadoc -sourcepath \user\src -subpackages java -ex‐
175 clude java.net:java.lang
176
177 --expand-requires value
178 Instructs the javadoc tool to expand the set of modules to be
179 documented. By default, only the modules given explicitly on
180 the command line are documented. Supports the following values:
181
182 · transitive: additionally includes all the required transitive
183 dependencies of those modules.
184
185 · all: includes all dependencies.
186
187 -help or --help
188 Displays the online help, which lists all of the javadoc and do‐
189 clet command-line options.
190
191 --help-extra or -X
192 Prints a synopsis of non-standard options and exits.
193
194 -Jflag Passes flag directly to the Java Runtime Environment (JRE) that
195 runs the javadoc tool. For example, if you must ensure that the
196 system sets aside 32 MB of memory in which to process the gener‐
197 ated documentation, then you would call the -Xmx option as fol‐
198 lows: javadoc -J-Xmx32m -J-Xms32m com.mypackage. Be aware that
199 -Xms is optional because it only sets the size of initial memo‐
200 ry, which is useful when you know the minimum amount of memory
201 required.
202
203 There is no space between the J and the flag.
204
205 Use the -version option to report the version of the JRE being
206 used to run the javadoc tool.
207
208 javadoc -J-version
209 java version "10-ea" 2018-03-20
210 Java(TM) SE Runtime Environment 18.3 (build 10-ea+36)
211 Java HotSpot(TM) 64-Bit Server VM 18.3 (build 10-ea+36, mixed mode)
212
213 -locale name
214 Specifies the locale that the javadoc tool uses when it gener‐
215 ates documentation. The argument is the name of the locale, as
216 described in java.util.Locale documentation, such as en_US (Eng‐
217 lish, United States) or en_US_WIN (Windows variant).
218
219 Note:
220
221 The -locale option must be placed ahead (to the left) of any op‐
222 tions provided by the standard doclet or any other doclet. Oth‐
223 erwise, the navigation bars appear in English. This is the only
224 command-line option that depends on order.
225
226 Specifying a locale causes the javadoc tool to choose the re‐
227 source files of that locale for messages such as strings in the
228 navigation bar, headings for lists and tables, help file con‐
229 tents, comments in the stylesheet.css file, and so on. It also
230 specifies the sorting order for lists sorted alphabetically, and
231 the sentence separator to determine the end of the first sen‐
232 tence. The -locale option doesn't determine the locale of the
233 documentation comment text specified in the source files of the
234 documented classes.
235
236 -package
237 Shows only package, protected, and public classes and members.
238
239 -private
240 Shows all classes and members.
241
242 -protected
243 Shows only protected and public classes and members. This is
244 the default.
245
246 -public
247 Shows only the public classes and members.
248
249 -quiet Shuts off messages so that only the warnings and errors appear
250 to make them easier to view. It also suppresses the version
251 string.
252
253 --show-members value
254 Specifies which members (fields or methods) are documented,
255 where value can be any of the following:
256
257 · protected: The default value is protected.
258
259 · public: Shows only public values.
260
261 · package: Shows public, protected, and package members.
262
263 · private: Shows all members.
264
265 --show-module-contents value
266 Specifies the documentation granularity of module declarations,
267 where value can be api or all.
268
269 --show-packages value
270 Specifies which modules packages are documented, where value can
271 be exported or all packages.
272
273 --show-types value
274 Specifies which types (classes, interfaces, etc.) are document‐
275 ed, where value can be any of the following:
276
277 · protected: The default value. Shows public and protected
278 types.
279
280 · public: Shows only public values.
281
282 · package: Shows public, protected, and package types.
283
284 · private: Shows all types.
285
286 -subpackages subpkglist
287 Generates documentation from source files in the specified pack‐
288 ages and recursively in their subpackages. This option is use‐
289 ful when adding new subpackages to the source code because they
290 are automatically included. Each package argument is any
291 top-level subpackage (such as java) or fully qualified package
292 (such as javax.swing) that doesn't need to contain source files.
293 Arguments are separated by colons on all operating systems.
294 Wild cards aren't allowed. Use -sourcepath to specify where to
295 find the packages. This option doesn't process source files
296 that are in the source tree but don't belong to the packages.
297
298 For example, the following commands generates documentation for
299 packages named java and javax.swing and all of their subpack‐
300 ages.
301
302 · Oracle Solaris, Linux, and OS X:
303
304 javadoc -d docs -sourcepath /home/user/src -subpack‐
305 ages java:javax.swing
306
307 · Windows:
308
309 javadoc -d docs -sourcepath \user\src -subpackages ja‐
310 va:javax.swing
311
312 -verbose
313 Provides more detailed messages while the javadoc tool runs.
314 Without the -verbose option, messages appear for loading the
315 source files, generating the documentation (one message per
316 source file), and sorting. The -verbose option causes the
317 printing of additional messages that specify the number of mil‐
318 liseconds to parse each Java source file.
319
320 --version
321 Prints version information.
322
324 Note:
325
326 The extended options for javadoc are subject to change without notice.
327
328 The following extended javadoc options are equivalent to corresponding
329 javac options. See Extra Options in javac for the detailed descrip‐
330 tions of using these options:
331
332 · --add-exports
333
334 · --add-reads
335
336 · --patch-module
337
338 · -Xmaxerrs
339
340 · -Xmaxwarns
341
342 The following extended javadoc options are not equivalent to a corre‐
343 sponding javac option:
344
345 -Xmodule:module-name
346 Specifies a module to which the classes being compiled belong.
347
348 -Xold Invokes the legacy javadoc tool.
349
351 The following options are provided by the standard doclet.
352
353 --add-stylesheet file
354 Adds additional stylesheet file for the generated documentation.
355 This option can be used one or more times to specify additional
356 stylesheets included in the documentation.
357
358 Command-line example:
359
360 javadoc --add-stylesheet new_stylesheet_1.css --add-stylesheet new_stylesheet_2.css pkg_foo
361
362 --allow-script-in-comments
363 Allow JavaScript in options and comments
364
365 -author
366 Includes the @author text in the generated docs.
367
368 -bottom html-code
369 Specifies the text to be placed at the bottom of each output
370 file. The text is placed at the bottom of the page, underneath
371 the lower navigation bar. The text can contain HTML tags and
372 white space, but when it does, the text must be enclosed in quo‐
373 tation marks. Use escape characters for any internal quotation
374 marks within text.
375
376 -charset name
377 Specifies the HTML character set for this document. The name
378 should be a preferred MIME name as specified in the IANA Reg‐
379 istry, Character Sets [http://www.iana.org/assignments/charac‐
380 ter-sets].
381
382 For example:
383
384 javadoc -charset "iso-8859-1" mypackage
385
386 This command inserts the following line in the head of every
387 generated page:
388
389 <META http-equiv="Content-Type" con‐
390 tent="text/html; charset=ISO-8859-1">
391
392 The META tag is described in the HTML standard (4197265 and
393 4137321), HTML Document Representation
394 [http://www.w3.org/TR/REC-html40/charset.html#h-5.2.2].
395
396 -d directory
397 Specifies the destination directory where the javadoc tool saves
398 the generated HTML files. If you omit the -d option, then the
399 files are saved to the current directory. The directory value
400 can be absolute or relative to the current working directory.
401 The destination directory is automatically created when the
402 javadoc tool runs.
403
404 · Oracle Solaris, Linux, and OS X: For example, the following
405 command generates the documentation for the package com.my‐
406 package and saves the results in the /user/doc/ directory:
407
408 javadoc -d /user/doc/ com.mypackage
409
410 · Windows: For example, the following command generates the doc‐
411 umentation for the package com.mypackage and saves the results
412 in the \user\doc\ directory:
413
414 javadoc -d \user\doc\ com.mypackage
415
416 -docencoding name
417 Specifies the encoding of the generated HTML files. The name
418 should be a preferred MIME name as specified in the IANA Reg‐
419 istry, Character Sets [http://www.iana.org/assignments/charac‐
420 ter-sets].
421
422 Three options are available for use in a javadoc encoding com‐
423 mand. The -encoding option is used for encoding the files read
424 by the javadoc tool, while the -docencoding and -charset options
425 are used for encoding the files written by the tool. Of the
426 three available options, at most, only the input and an output
427 encoding option are used in a single encoding command. If you
428 specify both input and output encoding options in a command,
429 they must be the same value. If you specify neither output op‐
430 tion, it the tool defaults to the input encoding.
431
432 For example:
433
434 javadoc -docencoding "iso-8859-1" mypackage
435
436 -docfilessubdirs
437 Recursively copies doc-file subdirectories.
438
439 -doctitle html-code
440 Specifies the title to place near the top of the overview summa‐
441 ry file. The text specified in the title tag is placed as a
442 centered, level-one heading directly beneath the top navigation
443 bar. The title tag can contain HTML tags and white space, but
444 when it does, you must enclose the title in quotation marks.
445 Additional quotation marks within the title tag must be escaped.
446 For example, javadoc -header "<b>My Library</b><br>v1.0" com.my‐
447 package.
448
449 -excludedocfilessubdir name
450 Excludes any doc files sub directories with the given name. En‐
451 ables deep copying of doc-files directories. Subdirectories and
452 all contents are recursively copied to the destination. For ex‐
453 ample, the directory doc-files/example/images and all of its
454 contents are copied. There is also an option to exclude subdi‐
455 rectories.
456
457 -footer html-code
458 Specifies the footer text to be placed at the bottom of each
459 output file. Thehtml-code value is placed to the right of the
460 lower navigation bar. The html-code value can contain HTML tags
461 and white space, but when it does, the html-code value must be
462 enclosed in quotation marks. Use escape characters for any in‐
463 ternal quotation marks within a footer.
464
465 --frames
466 Enables the use of frames in the generated output (default).
467
468 -group namep1:p2
469 Group the specified packages together in the Overview page.
470
471 -header html-code
472 Specifies the header text to be placed at the top of each output
473 file. The header is placed to the right of the upper navigation
474 bar. The header can contain HTML tags and white space, but when
475 it does, the header must be enclosed in quotation marks. Use
476 escape characters for internal quotation marks within a header.
477 For example, javadoc -header "<b>My Library</b><br>v1.0" com.my‐
478 package.
479
480 -helpfile filename
481 Includes the file that links to the HELP link in the top and
482 bottom navigation bars . Without this option, the javadoc tool
483 creates a help file help-doc.html that is hard-coded in the
484 javadoc tool. This option lets you override the default. The
485 filename can be any name and isn't restricted to help-doc.html.
486 The javadoc tool adjusts the links in the navigation bar accord‐
487 ingly. For example:
488
489 · Oracle Solaris, Linux, and OS X:
490
491 javadoc -helpfile /home/user/myhelp.html java.awt.
492
493 · Windows:
494
495 javadoc -helpfile C:\user\myhelp.html java.awt.
496
497 -html4 Generates HTML 4.0.1 output. If the option is not used, -html4
498 is the default
499
500 -html5 Generates HTML 5 output. If the option is not used, -html4 is
501 the default.
502
503 --javafx or -javafx
504 Enables JavaFX functionality.
505
506 -keywords
507 Adds HTML keyword <META> tags to the generated file for each
508 class. These tags can help search engines that look for <META>
509 tags find the pages. Most search engines that search the entire
510 Internet don't look at <META> tags, because pages can misuse
511 them. Search engines offered by companies that confine their
512 searches to their own website can benefit by looking at <META>
513 tags. The <META> tags include the fully qualified name of the
514 class and the unqualified names of the fields and methods. Con‐
515 structors aren't included because they are identical to the
516 class name. For example, the class String starts with these
517 keywords:
518
519 <META NAME="keywords" CONTENT="java.lang.String class">
520 <META NAME="keywords" CONTENT="CASE_INSENSITIVE_ORDER">
521 <META NAME="keywords" CONTENT="length()">
522 <META NAME="keywords" CONTENT="charAt()">
523
524 -link url
525 Creates links to existing javadoc generated documentation of ex‐
526 ternally referenced classes. The url argument is the absolute
527 or relative URL of the directory that contains the external
528 javadoc generated documentation. You can specify multiple -link
529 options in a specified javadoc tool run to link to multiple doc‐
530 uments.
531
532 Either a package-list or an element-list file must be in this
533 url directory (otherwise, use the -linkoffline option).
534
535 Note:
536
537 The package-list and element-list files are generated by the
538 javadoc tool when generating the API documentation and should
539 not be modified by the user.
540
541 When you use the javadoc tool to document packages, it uses the
542 package-list file to determine the packages declared in an API.
543 When you generate API documents for modules, the javadoc tool
544 uses the element-list file to determine the modules and packages
545 declared in an API.
546
547 The javadoc tool reads the names from the appropriate list file
548 and then links to the packages or modules at that URL.
549
550 When the javadoc tool runs, the url value is copied into the
551 <A HREF> links that are created. Therefore, url must be the URL
552 to the directory and not to a file.
553
554 You can use an absolute link for url to enable your documents to
555 link to a document on any web site, or you can use a relative
556 link to link only to a relative location. If you use a relative
557 link, then the value you pass in should be the relative path
558 from the destination directory (specified with the -d option) to
559 the directory containing the packages being linked to. When you
560 specify an absolute link, you usually use an HTTP link. Howev‐
561 er, if you want to link to a file system that has no web server,
562 then you can use a file link. Use a file link only when every‐
563 one who wants to access the generated documentation shares the
564 same file system. In all cases, and on all operating systems,
565 use a slash as the separator, whether the URL is absolute or
566 relative, and https:, http:, or file: as specified in the URL
567 Memo: Uniform Resource Locators
568 [http://www.ietf.org/rfc/rfc1738.txt].
569
570 -link https://<host>/<directory>/<directory>/.../<name>
571 -link http://<host>/<directory>/<directory>/.../<name>
572 -link file://<host>/<directory>/<directory>/.../<name>
573 -link <directory>/<directory>/.../<name>
574
575 -linkoffline url1 url2
576 This option is a variation of the -link option. They both cre‐
577 ate links to javadoc generated documentation for externally ref‐
578 erenced classes. You can specify multiple -linkoffline options
579 in a specified javadoc tool run.
580
581 Use the -linkoffline option when:
582
583 · Linking to a document on the web that the javadoc tool can't
584 access through a web connection
585
586 · The package-list or element-list file of the external document
587 either isn't accessible or doesn't exist at the URL location,
588 but does exist at a different location and can be specified by
589 either the package-list or element-list file (typically lo‐
590 cal).
591
592 Note:
593
594 The package-list and element-list files are generated by the
595 javadoc tool when generating the API documentation and should
596 not be modified by the user.
597
598 If url1 is accessible only on the World Wide Web, then the
599 -linkoffline option removes the constraint that the javadoc tool
600 must have a web connection to generate documentation.
601
602 Another use of the -linkoffline option is as a work-around to
603 update documents. After you have run the javadoc tool on a full
604 set of packages or modules, you can run the javadoc tool again
605 on a smaller set of changed packages or modules, so that the up‐
606 dated files can be inserted back into the original set.
607
608 For example, the -linkoffline option takes two arguments. The
609 first is for the string to be embedded in the <a href> links,
610 and the second tells the javadoc tool where to find either the
611 package-list or element-list file.
612
613 The url1 or url2 value is the absolute or relative URL of the
614 directory that contains the external javadoc generated documen‐
615 tation that you want to link to. When relative, the value
616 should be the relative path from the destination directory
617 (specified with the -d option) to the root of the packages being
618 linked to. See url in the -link option.
619
620 -linksource
621 Creates an HTML version of each source file (with line numbers)
622 and adds links to them from the standard HTML documentation.
623 Links are created for classes, interfaces, constructors, meth‐
624 ods, and fields whose declarations are in a source file. Other‐
625 wise, links aren't created, such as for default constructors and
626 generated classes.
627
628 This option exposes all private implementation details in the
629 included source files, including private classes, private
630 fields, and the bodies of private methods, regardless of the
631 -public, -package, -protected, and -private options. Unless you
632 also use the -private option, not all private classes or inter‐
633 faces are accessible through links.
634
635 Each link appears on the name of the identifier in its declara‐
636 tion. For example, the link to the source code of the Button
637 class would be on the word Button:
638
639 public class Button extends Component implements Accessi‐
640 ble
641
642 The link to the source code of the getLabel method in the Button
643 class is on the word getLabel:
644
645 public String getLabel()
646
647 --main-stylesheet file or -stylesheetfile file
648 Specifies the path of an alternate stylesheet file that contains
649 the definitions for the CSS styles used in the generated docu‐
650 mentation. This option lets you override the default. If you
651 do not specify the option, the javadoc tool will create and use
652 a default stylesheet. The file name can be any name and isn't
653 restricted to stylesheet.css. The --main-stylesheet option is
654 the preferred form.
655
656 Command-line example:
657
658 javadoc --main-stylesheet main_stylesheet.css pkg_foo
659
660 -nocomment
661 Suppresses the entire comment body, including the main descrip‐
662 tion and all tags, and generate only declarations. This option
663 lets you reuse source files that were originally intended for a
664 different purpose so that you can produce skeleton HTML documen‐
665 tation during the early stages of a new project.
666
667 -nodeprecated
668 Prevents the generation of any deprecated API in the documenta‐
669 tion. This does what the -nodeprecatedlist option does, and it
670 doesn't generate any deprecated API throughout the rest of the
671 documentation. This is useful when writing code when you don't
672 want to be distracted by the deprecated code.
673
674 -nodeprecatedlist
675 Prevents the generation of the file that contains the list of
676 deprecated APIs (deprecated-list.html) and the link in the navi‐
677 gation bar to that page. The javadoc tool continues to generate
678 the deprecated API throughout the rest of the document. This is
679 useful when your source code contains no deprecated APIs, and
680 you want to make the navigation bar cleaner.
681
682 --no-frames
683 Disables the use of frames in the generated output.
684
685 -nohelp
686 Omits the HELP link in the navigation bars at the top and bottom
687 of each page of output.
688
689 -noindex
690 Omits the index from the generated documents. The index is pro‐
691 duced by default.
692
693 -nonavbar
694 Prevents the generation of the navigation bar, header, and foot‐
695 er, that are usually found at the top and bottom of the generat‐
696 ed pages. The -nonavbar option has no affect on the -bottom op‐
697 tion. The -nonavbar option is useful when you are interested
698 only in the content and have no need for navigation, such as
699 when you are converting the files to PostScript or PDF for
700 printing only.
701
702 -noqualifier name1:name2...
703 Excludes the list of qualifiers from the output. The package
704 name is removed from places where class or interface names ap‐
705 pear.
706
707 The following example omits all package qualifiers: -noqualifi‐
708 er all.
709
710 The following example omits java.lang and java.io package quali‐
711 fiers: -noqualifier java.lang:java.io.
712
713 The following example omits package qualifiers starting with ja‐
714 va and com.sun subpackages, but not javax: -noqualifier ja‐
715 va.*:com.sun.*.
716
717 Where a package qualifier would appear due to the previous be‐
718 havior, the name can be suitably shortened. This rule is in ef‐
719 fect whether or not the -noqualifier option is used.
720
721 -nosince
722 Omits from the generated documents the Since sections associated
723 with the @since tags.
724
725 -notimestamp
726 Suppresses the time stamp, which is hidden in an HTML comment in
727 the generated HTML near the top of each page. The -notimestamp
728 option is useful when you want to run the javadoc tool on two
729 source bases and get the differences between diff them, because
730 it prevents time stamps from causing a diff (which would other‐
731 wise be a diff on every page). The time stamp includes the
732 javadoc tool release number.
733
734 -notree
735 Omits the class and interface hierarchy pages from the generated
736 documents. These are the pages you reach using the Tree button
737 in the navigation bar. The hierarchy is produced by default.
738
739 --override-methods (detail|summary)
740 Documents overridden methods in the detail or summary sections.
741
742 -overview filename
743 Specifies that the javadoc tool should retrieve the text for the
744 overview documentation from the source file specified by file‐
745 name and place it on the Overview page (overview-summary.html).
746 A relative path specified with the file name is relative to the
747 current working directory.
748
749 While you can use any name you want for the filename value and
750 place it anywhere you want for the path, it is typical to name
751 it overview.html and place it in the source tree at the directo‐
752 ry that contains the topmost package directories. In this loca‐
753 tion, no path is needed when documenting packages, because the
754 -sourcepath option points to this file.
755
756 · Oracle Solaris, Linux, and OS X: For example, if the source
757 tree for the java.lang package is /src/classes/java/lang/,
758 then you could place the overview file at /src/classes/over‐
759 view.html.
760
761 · Windows: For example, if the source tree for the java.lang
762 package is \src\classes\java\lang\, then you could place the
763 overview file at \src\classes\overview.html
764
765 The overview page is created only when you pass two or more
766 package names to the javadoc tool. The title on the overview
767 page is set by -doctitle.
768
769 -serialwarn
770 Generates compile-time warnings for missing @serial tags. By
771 default, Javadoc generates no serial warnings. Use this option
772 to display the serial warnings, which helps to properly document
773 default serializable fields and writeExternal methods.
774
775 -sourcetab tablength
776 Specifies the number of spaces each tab uses in the source.
777
778 -splitindex
779 Splits the index file into multiple files, alphabetically, one
780 file per letter, plus a file for any index entries that start
781 with non-alphabetical symbols.
782
783 -tag name:locations:header
784 Specifies single argument custom tags. For the javadoc tool to
785 spell-check tag names, it is important to include a -tag option
786 for every custom tag that is present in the source code, dis‐
787 abling (with X) those that aren't being output in the current
788 run. The colon (:) is always the separator. The -tag option
789 outputs the tag heading, header, in bold, followed on the next
790 line by the text from its single argument. Similar to any block
791 tag, the argument text can contain inline tags, which are also
792 interpreted. The output is similar to standard one-argument
793 tags, such as the @return and @author tags. Omitting a header
794 value causes the name to be the heading.
795
796 -taglet class
797 Specifies the fully qualified name of the taglet used in gener‐
798 ating the documentation for that tag. Use the fully qualified
799 name for the class value. This taglet also defines the number
800 of text arguments that the custom tag has. The taglet accepts
801 those arguments, processes them, and generates the output.
802
803 Taglets are useful for block or inline tags. They can have any
804 number of arguments and implement custom behavior, such as mak‐
805 ing text bold, formatting bullets, writing out the text to a
806 file, or starting other processes. Taglets can only determine
807 where a tag should appear and in what form. All other decisions
808 are made by the doclet. A taglet can't do things such as remove
809 a class name from the list of included classes. However, it can
810 execute side effects, such as printing the tag's text to a file
811 or triggering another process. Use the -tagletpath option to
812 specify the path to the taglet. The following example inserts
813 the To Do taglet after Parameters and ahead of Throws in the
814 generated pages.
815
816 -taglet com.sun.tools.doclets.ToDoTaglet
817 -tagletpath /home/taglets
818 -tag return
819 -tag param
820 -tag todo
821 -tag throws
822 -tag see
823
824 Alternately, you can use the -taglet option in place of its -tag
825 option, but that might be difficult to read.
826
827 -tagletpath tagletpathlist
828 Specifies the search paths for finding taglet class files. The
829 tagletpathlist can contain multiple paths by separating them
830 with a colon (:). The javadoc tool searches all subdirectories
831 of the specified paths.
832
833 -top html-code
834 Specifies the text to be placed at the top of each output file.
835
836 -use Creates class and package usage pages. Includes one Use page
837 for each documented class and package. The page describes what
838 packages, classes, methods, constructors and fields use any API
839 of the specified class or package. Given class C, things that
840 use class C would include subclasses of C, fields declared as C,
841 methods that return C, and methods and constructors with parame‐
842 ters of type C. For example, you can look at the Use page for
843 the String type. Because the getName method in the ja‐
844 va.awt.Font class returns type String, the getName method uses
845 String and so the getName method appears on the Use page for
846 String. This documents only uses of the API, not the implemen‐
847 tation. When a method uses String in its implementation, but
848 doesn't take a string as an argument or return a string, that
849 isn't considered a use of String.To access the generated Use
850 page, go to the class or package and click the Use link in the
851 navigation bar.
852
853 -version
854 Includes the version text in the generated docs. This text is
855 omitted by default. To find out what version of the javadoc
856 tool you are using, use the -J-version option.
857
858 -windowtitle title
859 Specifies the title to be placed in the HTML <title> tag. The
860 text specified in the title tag appears in the window title and
861 in any browser bookmarks (favorite places) that someone creates
862 for this page. This title shouldn't contain any HTML tags be‐
863 cause the browser doesn't interpret them correctly. Use escape
864 characters on any internal quotation marks within the title tag.
865 If the -windowtitle option is omitted, then the javadoc tool us‐
866 es the value of the -doctitle option for the -windowtitle op‐
867 tion. For example, javadoc -windowtitle "My Library" com.my‐
868 package.
869
871 The following are additional options provided by the standard doclet
872 and are subject to change without notice. Additional options might are
873 less commonly used or are otherwise regarded as advanced.
874
875 -Xdoclint
876 Enables recommended checks for problems in Javadoc comments.
877
878 -Xdoclint:(all|none|[-]group)
879 Enable or disable specific checks for bad references, lack of
880 accessibility, missing Javadoc comments, and reports errors for
881 invalid Javadoc syntax and missing HTML tags.
882
883 This option enables the javadoc tool to check for all documenta‐
884 tion comments included in the generated output. You can select
885 which items to include in the generated output with the standard
886 options -public, -protected, -package and -private.
887
888 When the -Xdoclint is enabled, it reports issues with messages
889 similar to the javac command. The javadoc tool prints a mes‐
890 sage, a copy of the source line, and a caret pointing at the ex‐
891 act position where the error was detected. Messages may be ei‐
892 ther warnings or errors, depending on their severity and the
893 likelihood to cause an error if the generated documentation were
894 run through a validator. For example, bad references or missing
895 Javadoc comments don't cause the javadoc tool to generate in‐
896 valid HTML, so these issues are reported as warnings. Syntax
897 errors or missing HTML end tags cause the javadoc tool to gener‐
898 ate invalid output, so these issues are reported as errors.
899
900 -Xdoclint option validates input comments based upon the re‐
901 quested markup.
902
903 By default, the -Xdoclint option is enabled. Disable it with
904 the option -Xdoclint:none.
905
906 The following options change what the -Xdoclint option reports:
907
908 · -Xdoclint none: Disables the -Xdoclint option
909
910 · -Xdoclint group: Enables group checks
911
912 · -Xdoclint all: Enables all groups of checks
913
914 · -Xdoclint all,-group: Enables all checks except group checks
915
916 The group variable has one of the following values:
917
918 · accessibility: Checks for the issues to be detected by an ac‐
919 cessibility checker (for example, no caption or summary at‐
920 tributes specified in a <table> tag).
921
922 · html: Detects high-level HTML issues, such as putting block
923 elements inside inline elements, or not closing elements that
924 require an end tag. The rules are derived from the HTML 4
925 Specification [https://www.w3.org/TR/html4/] or the HTML 5
926 Specification [http://www.w3.org/TR/2014/REC-html5-20141028/]
927 based on the standard doclet html output generation selected.
928 This type of check enables the javadoc tool to detect HTML is‐
929 sues that some browsers might not interpret as intended.
930
931 · missing: Checks for missing Javadoc comments or tags (for ex‐
932 ample, a missing comment or class, or a missing @return tag or
933 similar tag on a method).
934
935 · reference: Checks for issues relating to the references to Ja‐
936 va API elements from Javadoc tags (for example, item not found
937 in @see, or a bad name after @param).
938
939 · syntax: Checks for low level issues like unescaped angle
940 brackets (< and >) and ampersands (&) and invalid Javadoc
941 tags.
942
943 You can specify the -Xdoclint option multiple times to enable
944 the option to check errors and warnings in multiple categories.
945 Alternatively, you can specify multiple error and warning cate‐
946 gories by using the preceding options. For example, use either
947 of the following commands to check for the HTML, syntax, and ac‐
948 cessibility issues in the file filename.
949
950 javadoc -Xdoclint:html -Xdoclint:syntax -Xdoclint:acces‐
951 sibility filename
952
953 javadoc -Xdoclint:html,syntax,accessibility filename
954
955 Note:
956
957 The javadoc tool doesn't guarantee the completeness of these
958 checks. In particular, it isn't a full HTML compliance checker.
959 The goal of the -Xdoclint option is to enable the javadoc tool
960 to report majority of common errors.
961
962 The javadoc tool doesn't attempt to fix invalid input, it just
963 reports it.
964
965 -Xdoclint/package:[-]packages
966 Enables or disables checks in specific packages. packages is a
967 comma separated list of package specifiers. A package specifier
968 is either a qualified name of a package or a package name prefix
969 followed by *, which expands to all sub packages of the given
970 package. Prefix the package specifier with - to disable checks
971 for the specified packages.
972
973 -Xdocrootparent url
974 Replaces all @docRoot items followed by/.. in Javadoc comments
975 with the url.
976
977
978
979JDK 13 2018 JAVADOC(1)