summaryrefslogtreecommitdiff
path: root/doc/invoke.texi
blob: 806066017c462dfda68bc3c2ab5da106412b97a3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
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
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
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
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
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
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
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
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
@c Copyright (C) 2005 Free Software Foundation, Inc.
@c For copying conditions, see the file gjdoc.texi.

@ignore
@c man begin COPYRIGHT
Copyright @copyright{} 2005 Free Software Foundation, Inc.

This documentation is dual-licensed under the GNU Free Documentation
License and the GNU General Public License.

@table @emph
@item GNU Free Documentation License

Permission is granted to copy, distribute and/or modify this document
under the terms of the GNU Free Documentation License, Version 1.2 or
any later version published by the Free Software Foundation; with the
Invariant Sections being ``GNU General Public License'' and ``Funding
Free Software'', the Front-Cover texts being (a) (see below), and with
the Back-Cover Texts being (b) (see below).  A copy of the license is
included in the section entitled ``GNU Free Documentation License''.

(a) The FSF's Front-Cover Text is:

     A GNU Manual

(b) The FSF's Back-Cover Text is:

     You have freedom to copy and modify this GNU Manual, like GNU
     software.  Copies published by the Free Software Foundation 
     raise funds for GNU development.

@item GNU General Public License

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or (at
your option) any later version.

This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
USA.

@end table
@c man end
@c Set file name and title for the man page.
@setfilename gjdoc
@settitle Documentation generation framework for Java source files.
@c man begin SYNOPSIS
gjdoc [@option{-sourcepath }@var{pathlist}]
      [@option{-all}] [@option{-subpackages }@var{pkg:pkg:@dots{}}] [@option{-exclude }@var{pkglist}]
      [@option{-encoding }@var{charset}] [@option{-locale }@var{name}] [@option{-source }@var{release}]
      [@option{-public}] [@option{-protected}] [@option{-package}] [@option{-private}] 
      [@option{-doctitle }@var{text}] [@option{-header }@var{text}] [@option{-footer }@var{text}] [@option{-bottom }@var{text}]
      [@option{-link }@var{url}] [@option{-linkoffline }@var{url} @var{path}] [@option{-noqualifier }@var{pkg:pkg:@dots{}}] 
      [@option{-tagletpath }@var{pathlist}] [@option{-taglet }@var{className}] [@option{-tag }@var{tagspec}]
      [@option{-use}] [@option{-linksource}] [@option{-splitindex}] [@option{-noindex}] [@option{-notree}] 
      [@option{-version}] [@option{-author}] [@option{-nosince}] [@option{-addstylesheet }@var{file}]
      [@option{-d }@var{targetdir}] 
      [@var{packages}@dots{}] [@var{sourcefiles}@dots{}] [@@@var{cmdfile}]

gjdoc [@option{-sourcepath }@var{pathlist}]
      [@option{-all}] [@option{-subpackages }@var{pkg:pkg:@dots{}}] [@option{-exclude }@var{pkglist}]
      [@option{-encoding }@var{charset}] [@option{-locale }@var{name}] [@option{-source }@var{release}]
      [@option{-public}] [@option{-protected}] [@option{-package}] [@option{-private}] 
      [@option{-docletpath }@var{pathlist}] [@option{-doclet }@var{className}]
      [@var{packages}@dots{}] [@var{sourcefiles}@dots{}] [@@@var{cmdfile}]
      [doclet options]

gjdoc @option{--help}

gjdoc @option{--version}

Only the most useful options are listed here; see below for the
remainder.
@c man end
@c man begin SEEALSO
Info entry for @file{gjdoc}.
@c man end
@c man begin BUGS
Please report bugs to @w{@uref{http://savannah.gnu.org/bugs/?group=classpath}}.
@c man end
@c man begin AUTHOR
Julian Scheid
@c man end
@end ignore

@node Invoking Gjdoc
@chapter Generating HTML Documentation
@cindex Gjdoc command options
@cindex command options
@cindex options, Gjdoc command

@c man begin DESCRIPTION
Gjdoc can be used in two ways: as a stand-alone documentation tool, or
as a driver for a user-specified Doclet. @xref{Other Doclets}.

In the default mode, Gjdoc will use the Standard Doclet
@samp{HtmlDoclet} to generate a set of HTML pages.  The canonical
usage is:

@smallexample
gjdoc -s src/java/ -all -d api-docs/
@end smallexample

Here, @samp{src/java/} is the root of your source code class
hierarchy, @option{-all} means that all valid Java files found under
this root directory should be processed, and @samp{api-docs/} is the
directory where the generated documentation should be placed.

To learn more about running Doclets other than the Standard Doclet,
refer to the manual.  @xref{Invoking a Custom Doclet}.

@menu
* Invoking the Standard Doclet::   How to generate HTML documentation.
* Invoking a Custom Doclet::       How to run third-party and other 
                                   built-in Doclets.

* Option Summary by Type::         Brief list of all options, grouped by type.
* Gjdoc Option Summary::           List of all options accepted by Gjdoc.

* Source Set Options::      Select the set of source codes to run Gjdoc on.
* Source Format Options::   Specify the format of the source codes to document.

* Interlinking Options::    Connection your documentation with other projects.
* Output Control Options::  Specify the target directory and locale, and more.
* Generation Options::       Select which pieces of information to generate.
* Decoration Options::      Add or modify some titles, headers and footers or
                              override/amend static resources like stylesheets.
* Taglet Options::          Define your own javadoc @@tags

* Virtual Machine Options::
* Verbosity Options::
* Doclet Options::

@end menu

@c man end

@node Invoking the Standard Doclet
@section Invoking the Standard Doclet
@cindex Gjdoc command options
@cindex command options
@cindex options, Gjdoc command

Running the Gjdoc Standard Doclet @samp{HtmlDoclet} is the default
mode of operation for Gjdoc.  This section lists the command line
options you can specify in this mode.  It doesn't distinguish between
general Gjdoc options and options specific to the Standard Doclet.

If you want to learn which options are accepted when Gjdoc is used as
a doclet driver, @xref{Invoking a Custom Doclet}.

@xref{Option Index}, for an index to Gjdoc's options.

@menu
* Source Set Options::      Select the set of source codes to run Gjdoc on.
* Source Format Options::   Specify the format of the source codes to document.

* Output Control Options::  Specify the target directory and locale, and more.
* Generation Options::       Select which pieces of information to generate.
* Decoration Options::      Add or modify some titles, headers and footers or
                              override/amend static resources like stylesheets.
* Taglet Options::          Define your own javadoc @@tags

* Virtual Machine Options::
* Doclet Options::

@end menu

@c man begin OPTIONS

@node Option Summary by Type
@section Option Summary by Type

Here is a summary of all the options of both Gjdoc and the Standard
Doclet, grouped by type.  Explanations are in the following sections.

@table @emph
@item Source Set Options
@xref{Source Set Options,,Options For Specifying the Source Files To Operate on}.
@gccoptlist{-sourcepath @var{pathlist}  -subpackages @var{pkglist}  -exclude @var{pkglist}}

@item Source Format Options
@xref{Source Format Options,,Options For Specifying the Source Format}.
@gccoptlist{-source @var{release}  -encoding @var{encoding}  -breakiterator}

@item Interlinking Options
@xref{Interlinking Options,,Options For Specifying the Source Files To Operate on}.
@gccoptlist{-link @var{url}  -linkoffline @var{url} @var{file}  -noqualifier @var{pkg:pkg:...}}

@item Generation Options
@xref{Generation Options,,Options Controlling What is Included in the Output}.
@gccoptlist{-author  -licensetext  -use  -version  -splitindex  -noindex
 -nodeprecated  -nodeprecatedlist  -nohelp  -nonavbar @gol
 -nosince  -notree  -public  -protected  -package  -private  @gol
 -docfilessubdirs  -excludedocfilessubdir @var{dirname}  @gol
 -linksource}

@item Output Options
@xref{Generation Options,,Options Controlling the Output}.
@gccoptlist{-d  -locale @var{name}  -charset @var{charset}  -docencoding @var{charset}
 -validhtml  -baseurl @var{url}}

@item Decoration Options
@gccoptlist{-windowtitle @var{text}  -doctitle @var{text} @gol  -title @var{text}  
 -header @var{text}  -footer @var{text}  -bottom @var{text} @gol
 -helpfile @var{file}  -stylesheetfile @var{file}  -addstylesheet @var{file} @gol
 -group @var{groupheading} @var{pkgpattern:pkgpattern:@dots{}}}

@item Taglet Options
@xref{Taglet Options,,Options For Specifying user-defined Taglets}.
@gccoptlist{-tagletpath  -taglet @var{classname}  -tag @var{tagspec}}

@item Doclet Options
@xref{Doclet Options,,Options For Specifying the Doclet to use}.
@gccoptlist{-docletpath  -doclet @var{classname}}

@item Verbosity Options
@xref{Verbosity Options,,Options Controlling Gjdoc Behavior}.
@gccoptlist{-quiet  -verbose}

@item Virtual Machine Options
@xref{Virtual Machine Options,,Options Controlling Gjdoc Behavior}.
@gccoptlist{-classpath}  @gccoptlist{-bootclasspath}  @gccoptlist{-J}@var{vmopt}

@end table

@menu
* Virtual Machine Options::     Controlling the kind of output:
                        an executable, object files, assembler files,
                        or preprocessed source.
@end menu

@node Source Set Options
@section Selecting which Source Files to Process

@table @gcctabopt
@item -s @var{pathlist}
@item -sourcepath @var{pathlist}
@opindex sourcepath
Look for source files in the specified directory or directories.

@var{pathlist} should be one or more directory paths separated by your
platform's path separator (usually @samp{:} or @samp{;}).

If this option is not given, @command{gjdoc} will look for source
files in the current directory.

The directories specified should be root directories in terms of the
Java package system.  For example, if you want to generate
documentation for classes in package @samp{foo.bar}, you must specify
the directory containing the top-level @samp{@file{foo}}
sub-directory, not the directory @samp{@file{foo/bar/}} in which the
Java source files reside.

The short-hand alias @option{-s} is specific to @command{gjdoc} and
not compatible to Sun @command{javadoc}.

@item -all
@opindex all
@emph{[EXPERIMENTAL]}
Process all valid Java source files found in the directories listed in
the source path and their sub-directories.

This is an option specific to @command{gjdoc} and not compatible to
Sun @command{javadoc}.

@item -subpackages @var{pkg:pkg:@dots{}}
@opindex subpackages
Process the classes in the given Java packages and all sub-packages,
recursively.  Note that multiple package names must be separated with
colons instead of whitespace.

@item -exclude @var{pkg:pkg:@dots{}}
@opindex exclude
Do not process classes in the given Java packages and all
sub-packages, recursively.  This option can be used in conjunction
with @option{-all} or @option{-subpackages} in order to exclude
individual packages or package sub-trees from the output.

@item @var{packages}@dots{}
@opindex packages
Process all classes in the given Java packages.

@item @var{sourcefiles}@dots{}
@opindex sourcefiles
Process the classes in the given Java source files.
@end table

@node Source Format Options
@section Specifying the Format of Input Files

@table @gcctabopt
@item -source @var{release}
@opindex source
Assume that the source files are targeted at the given release of the
Java platform.

@var{release} should be the version number of a Java platform release
in the format MAJOR.MINOR, for example @samp{1.4}.

This option is currently ignored except that an error is raised if a
release number other than @samp{1.2}, @samp{1.3} or @samp{1.4} is
specified.

@item -encoding @var{charset}
@opindex encoding
Assume that the source files are encoded using @var{charset}.

Examples for @var{charset} are @samp{US-ASCII}, @samp{ISO-8859-1} or
@samp{UTF-8}.

The semantics of @var{charset} are identical to those of @samp{java.nio.charset.Charset.forName(String)}.

@item -breakiterator
@opindex breakiterator
Use the locale's java.text.BreakIterator instead of the internal
first sentence detector.

By default, @command{gjdoc} uses an internal algorithm to determine
where a sentence ends. When this option is given, it will instead use
the @samp{java.text.BreakIterator} instance for the locale given with
@option{-locale} (or the default locale).

This option should be specified when applying @command{gjdoc} to
source code commented in a non-latin language for which the default
first sentence detector does not work. For all other cases, the
default (do not use BreakIterator) produces better results at the time
of this writing.
@end table


@node Interlinking Options
@section Interlinking with other Documentation Sets

@table @gcctabopt
@item -link @var{url}
@opindex link

Create hyperlinks to another documentation set.

By default, @command{gjdoc} will only create hyperlinks to classes in
the source set.  Use this option to additionally create hyperlinks to
classes covered by the specified documentation set.

@var{url} should be the root URL of the other documentation set. For
example, to add hyperlinks to GNU Classpath, specify the following:

@smallexample
-link http://developer.classpath.org/doc/
@end smallexample

The @option{-link} option can be specified multiple times.

Note that specifying the @option{-link} option will cause an HTTP
access every time gjdoc is invoked. You can use @option{-linkoffline}
instead to avoid this access.

@item -linkoffline @var{url} @var{file}
@opindex linkoffline

Create hyperlinks to another documentation set which is also present
on the local file system.

This option works exactly like @option{-link}, except that it accesses
the local file system instead of the network for determining which
classes are covered by the linked documentation set.

When using @option{-linkoffline} the remote documentation set is not
accessed at all, which can significantly speed up generation time
depending on your network connection.  The generated hyperlinks to the
documentation set however refer to the remote set, not to the local
one, so that you can distribute the documentation without any further
dependencies.

The @option{-linkoffline} option can be specified multiple times.

@item -noqualifier @var{pkg:pkg:@dots{}}
@opindex noqualifier

Do not qualify names of classes in the given packages with their
package name.

By default, a class name is displayed unqualified only if the class is
part of the source set or a linked documentation set, and qualified
with the name of its containing package if it is not. You can use this
option to force unqualified names for classes even if they are not
part of the documentation set.

For example, usually a reference to the String class is represented
fully-qualified as @samp{java.lang.String} (unless you link to the
appropriate documentation set using @option{-link}) because it isn't
part of the documentation set.  You can specify @samp{-noqualifier
java.lang} to render the same references just as @samp{String}.

Note that for all unqualified class names, a tooltip is provided when
you place your mouse pointer over it in the HTML documentation.

@item -noqualifier @samp{all}
@opindex noqualifier
Omit package name qualifier from all class names.

Specify this option to omit package name qualifiers altogether,

@end table

@node Generation Options
@section Selecting which Information to Generate

@table @gcctabopt
@item -public
@opindex public
Only include public members of public classes in the output.  By
default, protected class members are included as well.

@item -protected
@opindex protected

Include public or protected members of public classes in the output.
This is the default.

@item -package
@opindex package

Include public, protected and package-private members of public and
package-private classes.

@item -private
@opindex private

Include all classes and class members regardless of their access
level.

@item -splitindex
@opindex splitindex
Generate one index page per letter instead of a single, monolithic
index page.

By default, the index created by the Standard Doclet contains all
entries on a single page.  This is fine for small documentation sets,
but for large sets you should specify this option.

@item -nosince
@opindex nosince
Ignore @samp{@@since} tags in javadoc comments.

By default, the generated output contains sections listing the version
of your API since which the package, class or class member in question
exists when this tag is encountered.  Specify this option to omit this
information.

@item -notree
@opindex notree
Do not generate any tree pages.

By default, the generated output includes one inheritance tree per
package, and - if the documentation set consists of multiple packages
- a page with the full inheritance tree.  Specify this option to omit
generation of these pages.

@item -noindex
@opindex noindex
Do not output the alphabetical index.

By default, gjdoc generates an alphabetical index of all program
elements in the documentation set (packages, classes, inner classes,
constructors, methods, and fields).  Specify this option to omit this
information.

@item -nohelp
@opindex nohelp
Do not generate the help page.

This option is currently ignored as the Standard Doclet doesn't
provide a help page.

@item -nodeprecated
@opindex nodeprecated
Do not output inline information about deprecated packages, classes or
class members.

By default, the Standard Doclet adds a highlighted paragraph with
deprecation information to the description of each deprecated program
element.  Specify this option to omit this information.

@item -nodeprecatedlist
@opindex nodeprecatedlist
Do not output the summary page for deprecated API elements.

By default, the Standard Doclet generates a page listing all
deprecated API elements along with a deprecation description which
usually includes the reason for deprecation and possible
alternatives.  Specify this option to omit this information.

@item -nonavbar
@opindex nonavbar
Do not output the navigation bar, header, and footer.

By default, each output page is equipped with a top navigation bar
(which may include a user-specified header) and a bottom navigation
bar (which may include a user-specified footer).  Specify this option
to omit this decoration.

@item -nocomment
@opindex nocomment

Omit all documentation text from the generated files and output only
declarations and program element relationships.

This option is here for compatibility with @command{javadoc}.  If you
plan on extracting information about your project via @command{gjdoc},
you should consider using a different Doclet for your purposes
instead, for example XmlDoclet.  You could also use the Doclet API
directly by implementing a new Doclet.

@item -linksource
@opindex linksource

Generate a page with syntax-highlighted source code for each class.
By default, this page is not generated.

The source code can be accessed by clicking on the button labelled
"Source" in the navigation bar, or by clicking on the name of a
constructor, field, method, or inner class in the detail section of a
class documentation page.

@item -use
@opindex use

Generate a page with cross-reference information. By default, this
page is not generated.

The cross-reference information can be accessed by clicking on the
button labelled `Use' in the navigation bar.

The `Use' page lists all classes/interfaces in the documentation set
that extend/implement the class (type) in question; fields of the
type; methods or constructors accepting a parameter of the type;
methods returning the type; and methods or constructors throwing the
type.

@item -author
@opindex author
Include author information in the output.

When specified, author information as specified using the
@samp{@@author} tag in javadoc comments is incorporated into the
output. By default, @samp{@@author} tags are ignored.

@item -version
@opindex version
Include version information in the output.

When specified, version information as specified using the
@samp{@@version} tag in javadoc comments is incorporated into the
output. By default, @samp{@@version} tags are ignored.

@item -licensetext
@opindex licensetext

Assume that the first comment in each source file contains the license
text, and add license information to the footer of each generated
class page.

This is an option specific to @command{gjdoc} and not compatible to
Sun @command{javadoc}.

This option is intended for use with free and open source projects
where source code is typically prefixed with a boilerplate license
comment, when there are legal reasons for including the license in the
documentation.

@item -docfilessubdirs
@opindex docfilessubdirs

Recursively copy all files in the @file{doc-files} sub-directory of each
package directory.

Usually, only the files in the @file{doc-files} sub-directory are copied
without descending recursively.

@xref{Adding Custom Resources}.

@item -excludedocfilessubdir @var{name}:@var{name}:@dots{}
@opindex excludedocfilessubdir

Do not copy some directories directly under the @file{doc-files}
sub-directories when descending recursively.

The argument to this option should be a colon-separated list of
directory names.

This option only makes sense if @option{-docfilessubdirs} is also
specified.  In this case, any sub-directory located directly beneath a
@file{doc-files} directory is omitted if listed.

@end table

@node Taglet Options
@section Custom Documentation Tags

@table @gcctabopt
@item -tagletpath @var{pathlist}
@opindex tagletpath
Search @var{pathlist} when loading subsequent Taglet classes specified
using @option{-taglet}.

@var{pathlist} should be one or more paths to a directory or jar file,
separated by your platform's path separator (usually @samp{:} or
@samp{;}).

@item -taglet @var{classname}
@opindex taglet
Register a Taglet.

@var{classname} should be the fully-qualified name of a Java class
implementing @samp{com.sun.tools.doclets.Taglet}.

The Taglet classes will be loaded from the classpath specified using
@option{-tagletpath}, from the classpath specified using
@option{-classpath} and from the default classpath.

See the documentation of @samp{com.sun.tools.doclets.Taglet} for
further information.

Note that for simple tags, there is also @option{-tag}.

@item -tag @var{tagspec}
@opindex tag
Register a generic Taglet.

The format of @var{tagspec} must be @samp{<tagname>:<flags>:"<taghead>"}.

@var{tagname} is the tag name to match, without the leading @@ sign. 

@var{flags} is one or more of the following characters, where each
character specifies a source code context in which the tag is to be
recognized.

@table @gcctabopt
@item a  
all contexts
@item c  
constructors
@item f  
fields
@item m  
methods
@item o  
overview
@item p  
packages
@item t  
types (classes, interfaces, exceptions, errors)
@item X  
special character which temporarily disables the
Taglet altogether.
@end table

@var{taghead} is the string to display in the header of the section
devoted to the tag in question.

For example, to define a tag matching @samp{@@cvsid} which is to be
accepted in overview, package and type pages and which is labelled
with the header @samp{CVS ID}, you would specify:

@smallexample
-tag cvsid:tpo:"CVS ID"
@end smallexample

Let's say that a class javadoc comment contains

@smallexample
@@cvsid $Id: invoke.texi,v 1.1 2008-05-27 19:25:31 jsumali Exp $
@end smallexample

Then the HTML output will contain something like

@smallexample
CVS ID:
  $Id: invoke.texi,v 1.1 2008-05-27 19:25:31 jsumali Exp $
@end smallexample
@end table

@node Doclet Options
@section Running Other Doclets

@table @gcctabopt

@item -docletpath @var{pathlist}
@opindex docletpath
Search @var{pathlist} when loading classes for the Doclet specified
using @option{-doclet}.

@var{pathlist} should be one or more paths to a directory or jar file,
separated by your platform's path separator (usually @samp{:} or
@samp{;}).

@item -doclet @var{className}
@opindex doclet
Run the specified doclet instead of the standard HtmlDoclet.

@var{className} should be the fully-qualified name of a class which
has a public default constructor and contain a method with the
following signature:

@smallexample
   import com.sun.javadoc.RootDoc;
   public static boolean start(RootDoc rootDoc) 
@end smallexample

The Doclet classes will be loaded from the classpath specified using
@option{-docletpath}, from the classpath specified using
@option{-classpath} and from the default classpath.

The @samp{start} method should process the information exposed by the
Doclet API via @samp{rootDoc} and return @samp{true} on success,
@samp{false} on failure.

If you are using a third-party doclet, refer to its documentation for
further instructions.  Note that support for third-party doclets is
experimental.  Please report any problems you encounter, or provide
feedback when successfully running third-party applets.

This option can be specified multiple times, in which case all doclets
are executed with the same information tree exposed via the Doclet API
for each Doclet run.

@end table


@node Decoration Options
@section Adding Information to the Output

@table @gcctabopt
@item -windowtitle @var{text}
@opindex windowtitle
Use @var{text} as the browser window title prefix.

When specified, the browser window title for each page will be
prefixed with @var{text} instead of the default string @samp{Generated
API Documentation}.

@var{text} should be plain text (it should not contain HTML tags).

@item -doctitle @var{text}
@opindex doctitle
Set the header text of the overview page to @var{text}.

@var{text} should be a short plain text string.

When generating documentation for a single package, specifying this
option forces generation of the overview page.

@item -header @var{htmltext}
@opindex header

Add @var{htmltext} to the right upper corner of every generated page.
@var{htmltext} is usually set to the name of the project being
documented.

@item -footer @var{htmltext}
@opindex footer

Add @var{htmltext} to the right bottom corner of every generated page.
@var{htmltext} is often set to the same value as for @option{-header}.

@item -bottom @var{htmltext}
@opindex bottom

Add @var{htmltext} to the very bottom of every generated page,
spanning the whole width of the page.  When specified, @var{htmltext}
usually consists of a copyright notice and/or links to other project
pages.

@item -addstylesheet @var{file}
@opindex addstylesheet

Augment the default CSS style sheets with the user-specified
stylesheet @var{file}.

The given stylesheet is simply loaded by each HTML page in addition to
the default ones, as the last stylesheet.

Note that the CSS cascading rules apply.  That is, your style
properties will only be assigned if they have a higher cascading order
than @command{gjdoc}'s default style.  One simple way to make sure
that this is the case is to declare your overrides @samp{!important}.

See @w{@uref{http://www.w3.org/TR/REC-CSS2/cascade.html#cascading-order}}.

@item -group @var{heading} @var{pkgwildcard}:@var{pkgwildcard}:@dots{}
@opindex group

Arrange the given packages in a separate group on the overview page.

The first argument should be a short plain text which is used as the
title of the package group.  The second argument should be a
colon-separated list of package wildcards.  The group will consist of
all packages in the documentation set whose name matches any of the
given wildcards.

There is only one wildcard character, @samp{*}, which matches both
letters in package name components and the @samp{.} separating package
name components.  For example, @samp{j*regex} would match package
@samp{java.util.regex}.  A more useful example would be
@samp{javax.swing*} to match @samp{javax.swing} and all of its
sub-packages.

This option can be given multiple times.  

FIXME: Information about group nesting here.

@smallexample
gjdoc -group "Core Classes" 'java*' \
      -group "Swing" 'javax.swing*' \
      -group "XML APIs" 'javax.xml*' \
      -group "Other Extensions" javax* \
      @dots{}
@end smallexample

@item -overview @var{file}
@opindex overview

Add the XHTML body fragment from @var{file} to the overview page.

@var{file} should contain an XHTML fragment with the HTML @samp{body}
tag as the root node.  @xref{XHTML Fragments}.

This option can be used to supply a description of the documentation
set as a whole.

When specified, the first sentence of the fragment will be put above
the tables listing the documented packages, along with a link to the
full copy of the fragment which is put below the tables.
@xref{First Sentence Detector}.

When generating documentation for a single package, specifying this
option forces generation of the overview page.

@item -stylesheetfile @var{file}
@opindex stylesheetfile

Use the CSS stylesheet in @var{file} instead of the default CSS
stylesheets.

If you only want to override parts of the default stylesheets, use
@option{-addstylesheet} instead.

@item -title @var{text}
@opindex title

@emph{Deprecated.} Use @option{-doctitle} @var{text} instead.

@item -helpfile @var{file}
@opindex helpfile

This option is currently ignored.

When implemented, it will use the XHTML fragment in @var{file} for the
help page contents instead of the default help text.

@end table

@node Output Control Options
@section Controlling the Output.

@table @gcctabopt
@item -d @var{directory}
@opindex d
Place all output files into @var{directory} (and
sub-directories). @var{directory} will be created if it does not
exist, including all non-existing parent directories and all required
sub-directories.

If not specified, output will be placed into the current directory.

@item -locale @var{name}
@opindex locale

Use locale @var{name} instead of the default locale for all purposes.

@var{name} should be a locale specifier in the form @samp{ll_CC[_VAR]}
where @samp{ll} is a lowercase two-letter ISO-639 language code,
@samp{CC} is an optional uppercase two-letter ISO-3166 country code,
and @samp{VAR} is an optional variant code.  For example, @samp{en}
specifies English, @samp{en_US} specifies US English, and
@samp{en_US_WIN} specifies a deviant variant of the US English locale.

Note that the semantics of this option correspond exactly to those of
the constructors of class @samp{java.util.Locale}.

This option currently only determines which Collator is being used for
sorting output elements.  This means that the locale will only have an
effect when you are using non-ASCII characters in identifiers.

@item -charset @var{charset}
@opindex charset

@emph{Deprecated.} Override the specified encoding in output XHTML
files with the one given by @samp{charset}.

If this option is not given, the encoding specification in output
XHTML is chosen to match the encoding used when writing the file (the
encoding given with @option{-docencoding}, or your platform's default
encoding).

The semantics for @var{charset} are specified here:
@w{@uref{http://www.w3.org/TR/2000/REC-xml-20001006#NT-EncName}}.  For
all practical purposes, they are identical to those of the other
options accepting charset parameters.

This option is here for compatibility with @command{javadoc} and
should be avoided.

@item -docencoding @var{charset}
@opindex docencoding

Use the given charset encoding when writing output files instead of
your platform's default encoding.

Examples for @var{charset} are @samp{US-ASCII}, @samp{ISO-8859-1} or
@samp{UTF-8}.

The semantics of this option correspond exactly to those of the
constructors of class @samp{java.util.Locale}.

@item -validhtml
@opindex validhtml

Force generation of valid XHTML code.  This breaks compatibility to
the traditional Javadoc tool to some extent.

If this option is specified, anchor names will be mangled so that they
are valid according to the XHTML 1.1 specification.  However, a
documentation set generated with this option cannot be linked to
properly using the traditional Javadoc tool.  It can be linked to just
fine using Gjdoc, though.

Without this option, anchor names for executable class members use the
traditional format, for example: ``foo(String,int[])''.  This is
compatible to the traditional Javadoc tool, but according to both the
HTML 4.0 and XHTML 1.0 and 1.1 specifications, this format includes
illegal characters.  Parentheses, square brackets, and the comma are
not allowed in anchor names.

@item -baseurl @var{url}
@opindex validhtml

Hardwire a page URL relative to @var{url} into each generated page.

If you are generating documentation which will exclusively be
available at a certain URL, you should use this option to specify this
URL.

This can help avoid certain redirect attacks used by spammers, and it
can be helpful for certain web clients.

@end table

@node Verbosity Options
@section Verbosity Options

@table @gcctabopt
@item -quiet
@opindex quiet
Suppress all output except for warnings and error messages.

@item -verbose
@opindex verbose
Be very verbose about what @command{gjdoc} is doing.

This option is currently ignored.

@end table

@node Virtual Machine Options
@section Virtual Machine Options

Sun's @command{javadoc} tool seems to be based on @command{javac} and
as such it seems to operate on the VM level.  @command{gjdoc}, in
contrast, is a pure Java application.

Therefore, @command{gjdoc} can only fake, or simulate, the following
VM-level options.

@table @gcctabopt

@item -classpath @var{pathlist}
@opindex classpath
Set the Virtual Machine @samp{classpath} to @var{pathlist}.

In most cases you should use @option{-docletpath} or
@option{-tagletpath} instead of this option.

@var{pathlist} should be one or more paths to a directory or jar file,
separated by your platform's path separator (usually @samp{:} or
@samp{;}).

If this option is not intercepted at the wrapper level,
@command{gjdoc} currently fakes it by calling
@samp{System.setProperty("java.class.path", @var{pathlist});} and
outputs a warning.

@item -bootclasspath @var{pathlist}
@opindex bootclasspath
Set the Virtual Machine @samp{bootclasspath} to @var{pathlist}.

If this option is not intercepted at the wrapper level,
@command{gjdoc} outputs a warning.

@item -J@var{vmopt}
@opindex J

Pass an arbitrary parameter to the Virtual Machine @command{gjdoc}
runs on.

If this option is not intercepted at the wrapper level,
@command{gjdoc} tries to emulate the option and outputs a warning.

Currently, only the VM option @option{-D} for setting system
properties is emulated.

@end table

@c man end

@node Invoking a Custom Doclet
@section Invoking a Custom Doclet

For invoking one of the other doclets shipping with @command{gjdoc} or
a third-party doclet, the canonical usage is:

@smallexample
gjdoc -s src/java/ -all \
  -docletpath /path/to/doclet.jar -doclet foo.BarDoclet \
  (more Gjdoc core options and Doclet-specific options here)
@end smallexample

@samp{/path/to/doclet.jar} is a placeholder for a class path
specifying where the Doclet classes and dependencies can be found and
@samp{foo.BarDoclet} is the fully-qualified name of the Doclet's main
class.

@node Gjdoc Option Summary
@section Gjdoc Option Summary
@cindex Gjdoc Options

@node Other Doclets
@chapter Generating Other Output Types

@menu
* Built-in Doclets::
* Third-party Doclets::
@end menu

@node Built-in Doclets
@section Using the Built-in Doclets
@cindex Built-in Doclets

@menu
* Using XmlDoclet::
* Using TexiDoclet::
* Using IspellDoclet::
* Using DebugDoclet::
@end menu

@node Using TexiDoclet
@subsection TexiDoclet: Generating Info, PDF, and other formats
@cindex TexiDoclet

Missing.

@node Using XmlDoclet
@subsection XmlDoclet: Generating XML Documentation
@cindex HtmlDoclet

Missing.

@node Using IspellDoclet
@subsection IspellDoclet: Spell-checking Source Code
@cindex IspellDoclet

Missing.

@node Using DebugDoclet
@subsection DebugDoclet: Inspecting the Doclet API
@cindex HtmlDoclet

Missing.

@node Third-party Doclets
@section Using Third-Party Doclets
@cindex Third-party Doclets

@menu
* DocBook Doclet::
* PDFDoclet::
* JUnitDoclet::
@end menu

@node DocBook Doclet
@subsection DocBook Doclet
@cindex DocBook Doclet

Missing.

@node PDFDoclet
@subsection PDFDoclet
@cindex PDFDoclet

Missing.

@node JUnitDoclet
@subsection JUnitDoclet
@cindex JUnitDoclet

Missing.

@node Gjdoc Concepts
@chapter Advanced Concepts

@menu
* Writing Doclets::
* Taglets::
* XHTML Fragments::
* First Sentence Detector::
* Adding Custom Resources::
@end menu


@node Taglets
@section Adding Custom Tags to the Documentation
@cindex Taglet

Missing.

@node Writing Doclets
@section Writing Doclets
@cindex Taglet

If the various Doclets already available don't suit your needs, you
can write a custom Doclet yourself.  

@menu
* Doclet Invocation Interface::
* Using AbstractDoclet::
* GNU Doclet SPI::
@end menu

@node Doclet Invocation Interface
@subsection Implementing the Doclet Invocation Interface

A Doclet is a class that contains a method with the following
signature:

@smallexample
public static boolean start(RootDoc rootDoc);
@end smallexample

@var{rootDoc} is the root of an object hierarchy containing the
information @command{gjdoc} extracted from the source files.  See the
Doclet API for more details.

@samp{start} should process all the information and return
@samp{true} on success, @samp{false} on failure.

For printing status information, the Doclet should use methods
@samp{printNotice}, @samp{printWarning} and @samp{printError} instead
of @samp{System.err}.  The Doclet can opt to use @samp{System.out} for
redirectable output.

@node Using AbstractDoclet
@subsection Deriving Your Doclet from AbstractDoclet
@cindex AbstractDoclet

You may want your Doclet to provide functionality similar to
HtmlDoclet.  For example, you may want it to support Taglets, generate
Index, Tree, and Uses pages, or show other cross-reference information
like @samp{Overrides} and @samp{All Implementing Classes}.

This information is not directly provided by the Doclet API, so your
Doclet would normally have to assemble it itself.  For example, it
would have to add the names of all program elements to a list and sort
this list in order to create the Index page.

If you want to provide this information or part of it, you should
consider deriving your class from
@samp{gnu.classpath.tools.doclets.AbstractDoclet}.  This class
provides the following benefits:

@itemize @bullet

@item 
Handles options @option{-tag}, @option{-taglet}, @option{-tagletpath}
(Taglets)

@item 
Provides standard taglets for @@version, @@author, @@since, @@serial,
@@deprecated, @@see, @@param, @@return and handles all related options
(@option{-version}, @option{-author}, @option{-nosince},
@option{-nodeprecated})

@item 
Handles option @option{-d} (destination directory)

@item 
Handles option @option{-noqualifier} (classes to omit qualifier for)

@item 
Handles options @option{-docfilessubdirs} and
@option{-excludedocfilessubdir} (resource copying)

@item 
Can generate a full index or an index split by first letter

@item 
Can generate a full tree and package trees

@item 
Can generate cross-reference information

@item 
Can aggregate interface information (all superinterfaces, all
subinterfaces, all implementing classes)

@item 
Provides convenient access to constructors, fields, methods, and inner
classes sorted by name/signature instead of the default sort order.

@item 
Provides various other convenience methods

@end itemize

If you derive from @samp{AbstractDoclet}, there are a number of things
you need to take care of:

@itemize @bullet

@item 

@end itemize

you should not implement the
@samp{start(RootDoc)} method as it is already defined by
@samp{AbstractDoclet} so that it can care about parsing the options.

Instead, you implement method @samp{run()}, @samp{getOptions()} and
the other abstract methods to define your Doclet's behavior.

Note that all information provided by @samp{AbstractDoclet} is
evaluated lazily.  That is, if your Doclet doesn't need to create an
Index page, then @samp{AbstractDoclet} will not spend resources on
creating the corresponding information.

See the API documentation for
@samp{gnu.classpath.tools.doclets.AbstractDoclet} for more details.

You should be aware that if you base your Doclet on
@samp{AbstractDoclet} then you have to bundle this and all related
classes with your Doclet, with all implications such as possible
licensing issues.  Otherwise, your Doclet will only be runnable on
@samp{gjdoc} and not on other documentation systems.  Also note that
@samp{AbstractDoclet} has not been extensively tested in environments
other than @samp{gjdoc}.

@node GNU Doclet SPI
@subsection Preparing for the GNU Doclet Service Provider Interface
@cindex GNU Doclet SPI, Service Provider, SPI

In addition to the standard Doclet invocation interface described
above, @command{gjdoc} also offers a Service Provider Interface
conforming to the Java standard.  Adding support for this interface to
your Doclet simplifies usage for @command{gjdoc} users because it
makes your Doclet ``discoverable''.

In order to provide the alternate interface, you have to add a class
implementing @samp{gnu.classpath.tools.gjdoc.spi.DocletSpi} to your
Doclet classes, and bundle all Doclet classes in a Jar file along with
a file named
@samp{META_INF/services/gnu.classpath.tools.gjdoc.spi.DocletSpi} which
contains the name of your class implementing DocletSpi on a single
line.

Note that if your Doclet depends on third-party classes bundled in
separate Jar files, you can link in these classes using the
@samp{Class-path:} Manifest attribute of your Doclet Jar.

Your Doclet can then be invoked in one of the following ways:
@smallexample
gjdoc -docletjar /path/to/doclet.jar
gjdoc -docletpath /path/to/doclet.jar -docletname @var{docletname}
gjdoc -docletname @var{docletname}
@end smallexample

Here, @var{docletname} is the name of your doclet as returned by
@samp{DocletSpi.getDocletName()}.

The last example will only work if your Doclet Jar is in
@command{gjdoc}'s @file{doclets} directory or if it is on the
classpath.

@node XHTML Fragments
@section Well-formed Documentation Fragments
@cindex XHTML Fragments

For many Doclets it is advantagous if the HTML code in the comments
and HTML code passed via the command line is well-formed.  For
example, HtmlDoclet outputs XHTML code, and XmlDoclet XML code, both
of which results in invalid files if the user-specified HTML isn't
wellformed.

Unfortunately, comments were never required to contain well-formed
HTML code, which means that every Doclet must deal with non-wellformed
code as well.

The @command{gjdoc} built-in Doclets deal with this problem by
``fixing'' the HTML code - making sure that all tags are closed,
attribute values are provided and quoted, tags are properly nested,
etc.

This approach works OK in most instances, but since it uses some crude
heuristics it can sometimes produce undesirable result.

Therefore, in order to make sure that your comments are always
properly formatted, make sure they are well-formed as described in
@w{@uref{http://www.w3.org/TR/xhtml1/#h-4.1, XHTML 1.0: Documents must
be well-formed}}.

In addition, you should use meaningful tags instead of text formatting
tags to make your output look better in other output formats derived
from your HTML code.  For example, you should use the <em> tag instead
of <b> if you want to emphasize text.

@node First Sentence Detector
@section How Gjdoc Determines where the First Sentence Ends
@cindex First Sentence Detector

For a package, class or member summary, @command{gjdoc} only shows the
first sentence of the documentation comment in question.  Because
@command{gjdoc} is not human, it is not always obvious to
@command{gjdoc} where the first sentence ends.

You might be tempted to say that the first sentence ends at the first
occurrence of a punctuation character like @samp{.} or
@samp{!}. However, consider examples like this:
@smallexample
This work, by Thomas J. Shahan et al., is about the middle ages.
@end smallexample

As you can see, it is not trivial to determine the end of the
sentence.

@command{gjdoc} gives you the choice between two approaches.  By
default it uses built-in heuristics which should be compatible to
Sun's @command{javadoc} tool.  This approach works quiet well in most
cases, at least for english comments.

Alternatively, you can specify option @option{-breakiterator} in which
case @command{gjdoc} will use
@samp{java.text.BreakIterator.getSentenceInstance(@var{locale}).next()}
to find the end of sentence, where @var{locale} is the locale
specified by option @samp{-locale} or the default locale if none
specified.

@emph{NOT YET IMPLEMENTED:}

@command{gjdoc} also allows you to explicitly delineate the first
sentence by putting it in a @samp{<span>} tag with the CSS class
@samp{first-sentence}.  For example:
@smallexample
/**
 *  <span class="first-sentence">This. is. the. first. 
 *  sentence.</span> This is the second sentence.
 */
@end smallexample

Note that this will only work with @command{gjdoc}, but shouldn't hurt
when using another documentation system since the @samp{<span>} tag
usually doesn't show up in the output.

@node Adding Custom Resources
@section Adding Images and Other Resources
@cindex First Sentence Detector

Sometimes you want to decorate your documentation with secondary
resources such as images, SVG graphics, applets, and so on.  To do so,
simply put the required files in a subdirectory 'doc-files' in the
package directory corresponding to the documentation entry you want to
decorate, and refer to it with the URL
@samp{doc-files/@var{filename}}.

For example, if you want to add an image to the description of class
@samp{baz.FooBar}, create a directory @file{doc-files} in the
directory @file{baz} containing @file{FooBar.java} and put your file,
say @file{diagram.png}, into that directory.  Then, add the HTML code
like this to a comment in @file{FooBar.java}:
@smallexample
<img src="doc-files/diagram.png" width="200" height="150"
  alt="Foo Diagram"/>
@end smallexample

This works because the @file{doc-files} subdirectories will be copied
to the target documentation directory every time you generate the
documentation.  

Note however that by default, the @file{doc-files} directory will not
be copied deeply.  In other words, if you create subdirectories under
@file{doc-files} they will not be copied and any resources located in
these subdirectories will not be accessible in your generated
documentation.  You can specify option @option{-docfilessubdirs} to
remove this limitation.

Sometimes you want to use option @option{-docfilessubdirs}, but there
are certain directories which you don't want to be copied, for example
because they contain source files for the resources in
@file{doc-files}.  For cases like this, use
@option{-excludedocfilessubdir} to specify directories to be omitted.

@c       --version       
@c       -help, --help