outputgen.h 20.3 KB
Newer Older
Dimitri van Heesch's avatar
Dimitri van Heesch committed
1 2
/******************************************************************************
 *
3
 * 
Dimitri van Heesch's avatar
Dimitri van Heesch committed
4
 *
Dimitri van Heesch's avatar
Dimitri van Heesch committed
5
 * Copyright (C) 1997-2014 by Dimitri van Heesch.
Dimitri van Heesch's avatar
Dimitri van Heesch committed
6 7 8 9 10 11 12
 *
 * Permission to use, copy, modify, and distribute this software and its
 * documentation under the terms of the GNU General Public License is hereby 
 * granted. No representations are made about the suitability of this software 
 * for any purpose. It is provided "as is" without express or implied warranty.
 * See the GNU General Public License for more details.
 *
Dimitri van Heesch's avatar
Dimitri van Heesch committed
13 14
 * Documents produced by Doxygen are derivative works derived from the
 * input used in their production; they are not affected by this license.
Dimitri van Heesch's avatar
Dimitri van Heesch committed
15 16 17 18 19 20
 *
 */

#ifndef OUTPUTGEN_H
#define OUTPUTGEN_H

Dimitri van Heesch's avatar
Dimitri van Heesch committed
21
#include <qstack.h>
22

Dimitri van Heesch's avatar
Dimitri van Heesch committed
23
#include "index.h"
24
#include "section.h"
25
#include "ftextstream.h"
Dimitri van Heesch's avatar
Dimitri van Heesch committed
26 27

class ClassDiagram;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
28
class DotClassGraph;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
29
class DotInclDepGraph;
30
class DotCallGraph;
31
class DotDirDeps;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
32
class DotGfxHierarchyTable;
33
class DotGroupCollaboration;
34 35
class DocNode;
class MemberDef;
36
class GroupDef;
37
class Definition;
38
class QFile;
39

40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
struct DocLinkInfo
{
  QCString name;
  QCString ref;
  QCString url;
  QCString anchor;
};

struct SourceLinkInfo
{
  QCString file;
  int line;
  QCString ref;
  QCString url;
  QCString anchor;
};

Dimitri van Heesch's avatar
Dimitri van Heesch committed
57
/** Output interface for code parser. 
58
 */
59
class CodeOutputInterface
60 61
{
  public:
62
    virtual ~CodeOutputInterface() {}
63 64

    /*! Writes an code fragment to the output. This function should keep 
65 66 67 68 69 70
     *  spaces visible, should break lines at a newline and should convert 
     *  tabs to the right number of spaces.
     */
    virtual void codify(const char *s) = 0;

    /*! Writes a link to an object in a code fragment.
71 72 73 74 75 76 77
     *  \param ref      If this is non-zero, the object is to be found in
     *                  an external documentation file.
     *  \param file     The file in which the object is located.
     *  \param anchor   The anchor uniquely identifying the object within 
     *                  the file. 
     *  \param name     The text to display as a placeholder for the link.
     *  \param tooltip  The tooltip to display when the mouse is on the link.
78 79
     */
    virtual void writeCodeLink(const char *ref,const char *file,
80 81
                               const char *anchor,const char *name,
                               const char *tooltip) = 0;
82

83 84 85 86 87 88
    /*! Writes the line number of a source listing
     *  \param ref        External reference (when imported from a tag file)
     *  \param file       The file part of the URL pointing to the docs.
     *  \param anchor     The anchor part of the URL pointing to the docs.
     *  \param lineNumber The line number to write
     */
89 90
    virtual void writeLineNumber(const char *ref,const char *file,
                                 const char *anchor,int lineNumber) = 0;
91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107

    /*! Writes a tool tip definition 
     *  \param id       unique identifier for the tooltip
     *  \param docInfo  Info about the symbol's documentation.
     *  \param decl     full declaration of the symbol (for functions)
     *  \param desc     brief description for the symbol
     *  \param defInfo  Info about the symbol's definition in the source code
     *  \param declInfo Info about the symbol's declaration in the source code
     */
    virtual void writeTooltip(const char *id, 
                              const DocLinkInfo &docInfo,
                              const char *decl,
                              const char *desc,
                              const SourceLinkInfo &defInfo,
                              const SourceLinkInfo &declInfo
                             ) = 0;
                              
Dimitri van Heesch's avatar
Dimitri van Heesch committed
108
    virtual void startCodeLine(bool hasLineNumbers) = 0;
109 110

    /*! Ends a line of code started with startCodeLine() */
111
    virtual void endCodeLine() = 0;
112 113 114 115 116 117 118 119

    /*! Starts a block with a certain meaning. Used for syntax highlighting,
     *  which elements of the same type are rendered using the same 'font class'.
     *  \param clsName The category name.
     */
    virtual void startFontClass(const char *clsName) = 0;

    /*! Ends a block started with startFontClass() */
120
    virtual void endFontClass() = 0;
121 122 123 124

    /*! Write an anchor to a source listing.
     *  \param name The name of the anchor.
     */
125
    virtual void writeCodeAnchor(const char *name) = 0;
126

Dimitri van Heesch's avatar
Dimitri van Heesch committed
127 128
    virtual void setCurrentDoc(Definition *context,const char *anchor,bool isSourceFile) = 0;
    virtual void addWord(const char *word,bool hiPriority) = 0;
129
};
Dimitri van Heesch's avatar
Dimitri van Heesch committed
130

Dimitri van Heesch's avatar
Dimitri van Heesch committed
131
/** Base Interface used for generating output outside of the
132
 *  comment blocks.
133
 *
134 135
 *  This abstract class is used by output generation functions
 *  to generate the output for a specific format,
136
 *  or a list of formats (see OutputList). This interface
137
 *  contains functions that generate fragments of the output.
138
 */
139
class BaseOutputDocInterface : public CodeOutputInterface
Dimitri van Heesch's avatar
Dimitri van Heesch committed
140 141
{
  public:
142
    virtual ~BaseOutputDocInterface() {}
143
    enum ParamListTypes { Param, RetVal, Exception };
144
    enum SectionTypes { /*See, Return, Author, Version, 
145 146 147
                        Since, Date, Bug, Note,
                        Warning, Par, Deprecated, Pre, 
                        Post, Invar, Remark, Attention, 
148
                        Todo, Test, RCS, */ EnumValues, 
149 150
                        Examples 
                      };
Dimitri van Heesch's avatar
Dimitri van Heesch committed
151

152
    virtual bool parseText(const QCString &s)  { return s.isEmpty(); }
153
    
154
    /*! Start of a bullet list: e.g. \c \<ul\> in html. startItemListItem() is
155 156 157
     *  Used for the bullet items.
     */
    virtual void startItemList()  = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
158

159
    /*! Writes a list item for a bullet or enumerated 
160
     *  list: e.g. \c \<li\> in html 
161
     */
162 163 164 165 166 167
    virtual void startItemListItem()  = 0;

    /*! Writes a list item for a bullet or enumerated 
     *  list: e.g. \c \</li\> in html 
     */
    virtual void endItemListItem()  = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
168

169
    /*! Ends a bullet list: e.g. \c \</ul\> in html */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
170
    virtual void endItemList()    = 0;
171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187

    /*! Writes an ASCII string to the output. Converts characters that have
     *  A special meaning, like \c & in html. 
     */
    virtual void docify(const char *s) = 0;

    /*! Writes a single ASCII character to the output. Converts characters
     *  that have a special meaning.
     */
    virtual void writeChar(char c) = 0;

    /*! Writes an ASCII string to the output, \e without converting 
     *  special characters. 
     */
    virtual void writeString(const char *text) = 0;

    /*! Starts a new paragraph */
188
    //virtual void newParagraph()   = 0;
189

190 191
    /*! Starts a new paragraph */
    virtual void startParagraph() = 0;
192
    /*! Ends a paragraph */
193 194
    virtual void endParagraph() = 0;

195 196 197 198 199 200
    /*! Writes a link to an object in the documentation.
     *  \param ref    If this is non-zero, the object is to be found in
     *                an external documentation file.
     *  \param file   The file in which the object is located.
     *  \param anchor The anchor uniquely identifying the object within 
     *                the file. 
201
     *  \param name   The text to display as a placeholder for the link.
202
     */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
203
    virtual void writeObjectLink(const char *ref,const char *file,
204
                                 const char *anchor, const char *name) = 0;
205 206


Dimitri van Heesch's avatar
Dimitri van Heesch committed
207 208 209 210 211 212
    /*! Starts a (link to an) URL found in the documentation.
     *  \param url    The URL to link to.
     */
    virtual void startHtmlLink(const char *url) = 0;

    /*! Ends a link started by startHtmlLink().
213
     */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
214
    virtual void endHtmlLink() = 0;
215 216 217 218 219 220 221 222 223 224 225 226 227

    
    /*! Changes the text font to bold face. The bold section ends with
     *  endBold()
     */
    virtual void startBold()      = 0;

    /*! End a section of text displayed in bold face. */
    virtual void endBold()        = 0;

    /*! Changes the text font to fixed size. The section ends with
     *  endTypewriter()
     */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
228
    virtual void startTypewriter() = 0;
229 230

    /*! End a section of text displayed in typewriter style. */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
231 232
    virtual void endTypewriter() = 0;

233 234 235 236
    /*! Changes the text font to italic. The italic section ends with
     *  endEmphasis()
     */
    virtual void startEmphasis() = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
237

238 239 240 241 242 243 244 245
    /*! Ends a section of text displayed in italic. */
    virtual void endEmphasis() = 0;

    /*! Starts a source code fragment. The fragment will be
     *  fed to the code parser (see code.h) for syntax highlighting
     *  and cross-referencing. The fragment ends by a call to
     *  endCodeFragment()
     */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
246
    virtual void startCodeFragment() = 0;
247 248 249

    /*! Ends a source code fragment
     */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
250
    virtual void endCodeFragment() = 0;
251

252 253 254
    

    
255 256 257
    /*! Writes a horizontal ruler to the output */
    virtual void writeRuler() = 0;
    
258
    /*! Starts a description list: e.g. \c \<dl\> in HTML 
259 260
     *  Items are surrounded by startDescItem() and endDescItem()
     */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
261
    virtual void startDescription() = 0;
262

263
    /*! Ends a description list: e.g. \c \</dl\> in HTML */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
264
    virtual void endDescription() = 0;
265

266
    /*! Starts an item of a description list: e.g. \c \<dt\> in HTML. */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
267
    virtual void startDescItem() = 0;
268

269 270 271
    virtual void startDescForItem() = 0;
    virtual void endDescForItem() = 0;

272
    /*! Ends an item of a description list and starts the 
273
     *  description itself: e.g. \c \</dt\> in HTML. 
274
     */
Dimitri van Heesch's avatar
Dimitri van Heesch committed
275
    virtual void endDescItem() = 0;
276

Dimitri van Heesch's avatar
Dimitri van Heesch committed
277 278 279 280
    virtual void startCenter() = 0;
    virtual void endCenter() = 0;
    virtual void startSmall() = 0;
    virtual void endSmall() = 0;
281 282 283 284 285 286 287

    virtual void startSimpleSect(SectionTypes t,const char *file,
                                 const char *anchor,const char *title) = 0;
    virtual void endSimpleSect() = 0;
    virtual void startParamList(ParamListTypes t,const char *title) = 0;
    virtual void endParamList() = 0;

288
    //virtual void writeDescItem() = 0;
289 290 291 292 293 294 295
    virtual void startTitle() = 0;
    virtual void endTitle()   = 0;

    virtual void writeAnchor(const char *fileName,const char *name) = 0;
    virtual void startSection(const char *,const char *,SectionInfo::SectionType) = 0;
    virtual void endSection(const char *,SectionInfo::SectionType) = 0;

Dimitri van Heesch's avatar
Dimitri van Heesch committed
296
    virtual void lineBreak(const char *style) = 0;
297 298 299
    virtual void addIndexItem(const char *s1,const char *s2) = 0;

    virtual void writeNonBreakableSpace(int) = 0;
300
    virtual void startDescTable(const char *title) = 0;
301 302 303 304 305 306 307 308 309 310 311 312 313
    virtual void endDescTable() = 0;
    virtual void startDescTableTitle() = 0;
    virtual void endDescTableTitle() = 0;
    virtual void startDescTableData() = 0;
    virtual void endDescTableData() = 0;
    virtual void startTextLink(const char *file,const char *anchor) = 0;
    virtual void endTextLink() = 0;
    virtual void startPageRef() = 0;
    virtual void endPageRef(const char *,const char *) = 0;
    virtual void startSubsection() = 0;
    virtual void endSubsection() = 0;
    virtual void startSubsubsection() = 0;
    virtual void endSubsubsection() = 0;
314
};
315

Dimitri van Heesch's avatar
Dimitri van Heesch committed
316
/** Abstract output generator.
317 318 319 320 321 322
 *
 *  Subclass this class to add support for a new output format
 */
class OutputGenerator : public BaseOutputDocInterface
{
  public:
323
    enum OutputType { Html, Latex, Man, RTF, XML, DEF, Perl };
324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339

    OutputGenerator();
    virtual ~OutputGenerator();

    ///////////////////////////////////////////////////////////////
    // generic generator methods
    ///////////////////////////////////////////////////////////////
    virtual void enable() = 0;
    virtual void disable() = 0;
    virtual void enableIf(OutputType o) = 0;
    virtual void disableIf(OutputType o) = 0;
    virtual void disableIfNot(OutputType o) = 0;
    virtual bool isEnabled(OutputType o) = 0;
    virtual OutputGenerator *get(OutputType o) = 0;
    void startPlainFile(const char *name);
    void endPlainFile();
340
    //QCString getContents() const;
341 342 343
    bool isEnabled() const { return active; }
    void pushGeneratorState();
    void popGeneratorState();
344 345
    //void setEncoding(const QCString &enc) { encoding = enc; }
    //virtual void postProcess(QByteArray &) { }
346

Dimitri van Heesch's avatar
Dimitri van Heesch committed
347
    virtual void writeDoc(DocNode *,Definition *ctx,MemberDef *md) = 0;
348

349 350 351
    ///////////////////////////////////////////////////////////////
    // structural output interface
    ///////////////////////////////////////////////////////////////
352
    virtual void startFile(const char *name,const char *manName,
353
                           const char *title) = 0;
354
    virtual void writeSearchInfo() = 0;
355
    virtual void writeFooter(const char *navPath) = 0;
356 357 358
    virtual void endFile() = 0;
    virtual void startIndexSection(IndexSections) = 0;
    virtual void endIndexSection(IndexSections) = 0;
359
    virtual void writePageLink(const char *,bool) = 0;
360 361 362 363 364
    virtual void startProjectNumber() = 0;
    virtual void endProjectNumber() = 0;
    virtual void writeStyleInfo(int part) = 0;
    virtual void startTitleHead(const char *) = 0;
    virtual void endTitleHead(const char *fileName,const char *name) = 0;
365 366
    virtual void startIndexListItem() = 0;
    virtual void endIndexListItem()   = 0;
367 368
    virtual void startIndexList() = 0;
    virtual void endIndexList()   = 0;
369 370
    virtual void startIndexKey() = 0;
    virtual void endIndexKey()   = 0;
371 372
    virtual void startIndexValue(bool) = 0;
    virtual void endIndexValue(const char *,bool) = 0;
373 374
    virtual void startIndexItem(const char *ref,const char *file) = 0;
    virtual void endIndexItem(const char *ref,const char *file) = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
375 376
    virtual void startGroupHeader(int) = 0;
    virtual void endGroupHeader(int) = 0;
377 378
    virtual void startMemberSections() = 0;
    virtual void endMemberSections() = 0;
379 380 381
    virtual void startHeaderSection() = 0;
    virtual void endHeaderSection() = 0;
    virtual void startMemberHeader(const char *anchor) = 0;
382 383 384
    virtual void endMemberHeader() = 0;
    virtual void startMemberSubtitle() = 0;
    virtual void endMemberSubtitle() = 0;
385 386 387 388
    virtual void startMemberDocList() = 0;
    virtual void endMemberDocList() = 0;
    virtual void startMemberList() = 0;
    virtual void endMemberList() = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
389 390
    virtual void startInlineHeader() = 0;
    virtual void endInlineHeader() = 0;
391 392
    virtual void startAnonTypeScope(int) = 0;
    virtual void endAnonTypeScope(int) = 0;
393
    virtual void startMemberItem(const char *,int,const char *) = 0;
394
    virtual void endMemberItem() = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
395
    virtual void startMemberTemplateParams() = 0;
396
    virtual void endMemberTemplateParams(const char *,const char *) = 0;
397 398 399 400 401 402
    virtual void startMemberGroupHeader(bool) = 0;
    virtual void endMemberGroupHeader() = 0;
    virtual void startMemberGroupDocs() = 0;
    virtual void endMemberGroupDocs() = 0;
    virtual void startMemberGroup() = 0;
    virtual void endMemberGroup(bool) = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
403
    virtual void insertMemberAlign(bool) = 0;
404
    virtual void startMemberDoc(const char *,const char *,
Dimitri van Heesch's avatar
Dimitri van Heesch committed
405
                                const char *,const char *,bool) = 0;
406
    virtual void endMemberDoc(bool) = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
407
    virtual void startDoxyAnchor(const char *fName,const char *manName,
408 409
                                 const char *anchor,const char *name,
                                 const char *args) = 0;
410 411 412 413 414
    virtual void endDoxyAnchor(const char *fileName,const char *anchor) = 0;
    virtual void writeLatexSpacing() = 0;
    virtual void writeStartAnnoItem(const char *type,const char *file,
                                    const char *path,const char *name) = 0;
    virtual void writeEndAnnoItem(const char *name) = 0;
415
    virtual void startMemberDescription(const char *anchor,const char *inheritId) = 0;
416
    virtual void endMemberDescription() = 0;
417 418
    virtual void startMemberDeclaration() = 0;
    virtual void endMemberDeclaration(const char *anchor,const char *inheritId) = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
419 420 421
    virtual void writeInheritedSectionTitle(const char *id,const char *ref,
                                            const char *file,const char *anchor,
                                            const char *title,const char *name) = 0;
422 423 424 425
    virtual void startIndent() = 0;
    virtual void endIndent() = 0;
    virtual void writeSynopsis() = 0;
    virtual void startClassDiagram() = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
426
    virtual void endClassDiagram(const ClassDiagram &,const char *,const char *) = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
427
    virtual void startDotGraph() = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
428
    virtual void endDotGraph(const DotClassGraph &g) = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
429
    virtual void startInclDepGraph() = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
430
    virtual void endInclDepGraph(const DotInclDepGraph &g) = 0;
431
    virtual void startGroupCollaboration() = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
432
    virtual void endGroupCollaboration(const DotGroupCollaboration &g) = 0;
433
    virtual void startCallGraph() = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
434
    virtual void endCallGraph(const DotCallGraph &g) = 0;
435
    virtual void startDirDepGraph() = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
436 437
    virtual void endDirDepGraph(const DotDirDeps &g) = 0;
    virtual void writeGraphicalHierarchy(const DotGfxHierarchyTable &g) = 0;
438 439
    virtual void startQuickIndices() = 0;
    virtual void endQuickIndices() = 0;
440
    virtual void writeSplitBar(const char *) = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
441
    virtual void writeNavigationPath(const char *) = 0;
442
    virtual void writeLogo() = 0;
443
    virtual void writeQuickLinks(bool compact,HighlightedItem hli,const char *file) = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
444
    virtual void writeSummaryLink(const char *file,const char *anchor,const char *title,bool first) = 0;
445 446
    virtual void startContents() = 0;
    virtual void endContents() = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
447
    virtual void startTextBlock(bool) = 0;
448
    virtual void endTextBlock(bool) = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
449
    virtual void lastIndexPage() = 0;
450 451
    virtual void startMemberDocPrefixItem() = 0;
    virtual void endMemberDocPrefixItem() = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
452
    virtual void startMemberDocName(bool) = 0;
453
    virtual void endMemberDocName() = 0;
454
    virtual void startParameterType(bool,const char *key) = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
455
    virtual void endParameterType() = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
456
    virtual void startParameterName(bool) = 0;
457
    virtual void endParameterName(bool,bool,bool) = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
458
    virtual void startParameterList(bool) = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
459
    virtual void endParameterList() = 0;
460
    virtual void exceptionEntry(const char*,bool) = 0;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
461

462 463 464 465 466 467 468 469 470
    virtual void startConstraintList(const char *) = 0;
    virtual void startConstraintParam() = 0;
    virtual void endConstraintParam() = 0;
    virtual void startConstraintType() = 0;
    virtual void endConstraintType() = 0;
    virtual void startConstraintDocs() = 0;
    virtual void endConstraintDocs() = 0;
    virtual void endConstraintList() = 0;

471 472 473 474 475 476 477 478 479
    virtual void startMemberDocSimple() = 0;
    virtual void endMemberDocSimple() = 0;
    virtual void startInlineMemberType() = 0;
    virtual void endInlineMemberType() = 0;
    virtual void startInlineMemberName() = 0;
    virtual void endInlineMemberName() = 0;
    virtual void startInlineMemberDoc() = 0;
    virtual void endInlineMemberDoc() = 0;

480

481 482 483 484
    virtual void startLabels() = 0;
    virtual void writeLabel(const char *,bool) = 0;
    virtual void endLabels() = 0;

Dimitri van Heesch's avatar
Dimitri van Heesch committed
485
  protected:
486
    FTextStream t;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
487
    QFile *file;
488
    QCString fileName;
489
    QCString dir;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
490
    bool active;
491
    QStack<bool> *genStack;
Dimitri van Heesch's avatar
Dimitri van Heesch committed
492 493 494 495 496 497

  private:
    OutputGenerator(const OutputGenerator &o);
    OutputGenerator &operator=(const OutputGenerator &o);
};

Dimitri van Heesch's avatar
Dimitri van Heesch committed
498
/** Interface used for generating documentation.
499
 *
500 501
 *  This abstract class is used by several functions
 *  to generate the output for a specific format. 
502 503 504 505 506 507
 *  This interface contains some state saving and changing
 *  functions for dealing with format specific output.
 */
class OutputDocInterface : public BaseOutputDocInterface
{
  public:
Dimitri van Heesch's avatar
Dimitri van Heesch committed
508 509
    virtual ~OutputDocInterface() {}

510 511 512
    /*! Create a new output generator. This can later by appended
     *  to the current one using append().
     */
513
    //virtual OutputDocInterface *clone() = 0;
514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533

    /*! Disables all output formats except format \a o 
     *  (useful for OutputList only) 
     */
    virtual void disableAllBut(OutputGenerator::OutputType o) = 0;

    /*! Enables all output formats as far as they have been enabled in
     *  the config file. (useful for OutputList only) 
     */
    virtual void enableAll() = 0;

    /*! Disables all output formats (useful for OutputList only) */
    virtual void disableAll()= 0;

    /*! Disables a specific output format (useful for OutputList only) */
    virtual void disable(OutputGenerator::OutputType o) = 0;

    /*! Enables a specific output format (useful for OutputList only) */
    virtual void enable(OutputGenerator::OutputType o) = 0;

534
    /*! Check whether a specific output format is currently enabled 
535 536 537 538 539 540 541
     *  (useful for OutputList only) 
     */
    virtual bool isEnabled(OutputGenerator::OutputType o) = 0;

    /*! Appends the output generated by generator \a g to this
     *  generator.
     */ 
542
    //virtual void append(const OutputDocInterface *g) = 0;
543 544 545 546 547 548 549 550 551 552 553 554 555 556

    /*! Pushes the state of the current generator (or list of 
     *  generators) on a stack.
     */
    virtual void pushGeneratorState() = 0;

    /*! Pops the state of the current generator (or list of 
     *  generators) on a stack. Should be preceded by a call
     *  the pushGeneratorState().
     */
    virtual void popGeneratorState() = 0;
};


Dimitri van Heesch's avatar
Dimitri van Heesch committed
557
#endif