diagrams.doc 6.26 KB
Newer Older
1 2 3 4
/******************************************************************************
 *
 * 
 *
5
 * Copyright (C) 1997-2007 by Dimitri van Heesch.
6 7 8 9 10 11 12 13 14 15 16 17 18
 *
 * 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.
 *
 * Documents produced by Doxygen are derivative works derived from the
 * input used in their production; they are not affected by this license.
 *
 */
/*! \page diagrams Graphs and diagrams

19
  Doxygen has built-in support to generate inheritance diagrams for C++
20 21 22
  classes. 

  Doxygen can use the "dot" tool from graphviz 1.5 to generate
23
  more advanced diagrams and graphs. Graphviz is an "open-sourced", 
Dimitri van Heesch's avatar
Dimitri van Heesch committed
24 25
  cross-platform graph drawing toolkit and can be found 
  at http://www.graphviz.org/
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41

  If you have the "dot" tool available in the path, you can set
  \ref cfg_have_dot "HAVE_DOT" to \c YES in the configuration file to 
  let doxygen use it.

  Doxygen uses the "dot" tool to generate the following graphs:
  <ul>
  <li>if \ref cfg_graphical_hierarchy "GRAPHICAL_HIERARCHY" is set to \c YES, 
      a graphical representation of the class hierarchy will be drawn, along 
      with the textual one. Currently this feature is supported for HTML only.\n
      <b>Warning:</b> When you have a very large class hierarchy where many 
      classes derive from a common base class, the resulting image may become 
      too big to handle for some browsers.
  <li>if \ref cfg_class_graph "CLASS_GRAPH" is set to \c YES,
      a graph will be generated for each documented class showing the 
      direct and indirect inheritance relations. This disables the
42
      generation of the built-in class inheritance diagrams.
43 44 45 46 47 48 49 50
  <li>if \ref cfg_include_graph "INCLUDE_GRAPH" is set to \c YES, an include 
      dependency graph is generated for each documented file that includes at 
      least one other file. This feature is currently supported for HTML and RTF 
      only.
  <li>if \ref cfg_collaboration_graph "COLLABORATION_GRAPH" is set to YES, a 
      graph is drawn for each documented class and struct that shows:
      <ul>
      <li> the inheritance relations with base classes.
51
      <li> the usage relations with other structs and classes (e.g. 
52 53 54
           class \c A has a member variable \c m_a of type class \c B, then
           \c A has an arrow to \c B with \c m_a as label).
      </ul>
55 56 57
  <li>if \ref cfg_call_graph "CALL_GRAPH" is set to YES, a 
      graphical call graph is drawn for each function showing the 
      functions that the function directly or indirectly calls.
58 59 60
  <li>if \ref cfg_caller_graph "CALLER_GRAPH" is set to YES, a 
      graphical caller graph is drawn for each function showing the 
      functions that the function is directly or indirectly called by.
61 62 63 64 65 66 67 68 69
  </ul>

  The elements in the class diagrams in HTML and RTF 
  have the following meaning:
  <ul>
  <li> A \b yellow box indicates a class. A box can have a 
       little marker in the lower right corner to indicate that the class 
       contains base classes that are hidden. 
       For the class diagrams the maximum tree width is currently 8 elements. 
Dimitri van Heesch's avatar
Dimitri van Heesch committed
70
       If a tree is wider some nodes will be hidden.
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89
       If the box is filled with a 
       dashed pattern the inheritance relation is virtual.
  <li> A \b white box indicates that the documentation of the class
       is currently shown.
  <li> A \b grey box indicates an undocumented class.
  <li> A <b>solid dark blue</b> arrow indicates public inheritance.
  <li> A <b>dashed dark green</b> arrow indicates protected inheritance.
  <li> A <b>dotted dark green</b> arrow indicates private inheritance.
  </ul>

  The elements in the class diagram in \f$\mbox{\LaTeX}\f$ have the 
  following meaning:
  <ul>
  <li> A \b white box indicates a class.
       A \b marker in the lower right corner of the box indicates that the 
       class has base classes that are hidden. 
       If the box has a \b dashed border this indicates virtual inheritance.
  <li> A \b solid arrow indicates public inheritance.
  <li> A \b dashed arrow indicates protected inheritance.
Dimitri van Heesch's avatar
Dimitri van Heesch committed
90
  <li> A \b dotted arrow indicates private inheritance.
91 92 93 94 95 96 97 98
  </ul>

  The elements in the graphs generated by the dot tool have the following
  meaning:
  <ul>
  <li> A \b white box indicates a class or struct or file. 
  <li> A box with a \b red border indicates a node that has
       \e more arrows than are shown! 
Dimitri van Heesch's avatar
Dimitri van Heesch committed
99 100
       In other words: the graph is \e truncated with respect to this node.
       The reason why a graph is sometimes truncated is to prevent images
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
       from becoming too large. 
       For the graphs generated with dot doxygen tries
       to limit the width of the resulting image to 1024 pixels.  
  <li> A \b black box indicates that the class' documentation is currently shown.
  <li> A <b>dark blue</b> arrow indicates an include relation (for the 
       include dependency graph) or public inheritance (for the other graphs).
  <li> A <b>dark green</b> arrow indicates protected inheritance.
  <li> A <b>dark red</b> arrow indicates private inheritance.
  <li> A <b>purple dashed</b> arrow indicated a "usage" relation, the 
       edge of the arrow is labled with the variable(s) responsible for the
       relation.
       Class \c A uses class \c B, if class \c A has a member variable \c m 
       of type C, where B is a subtype of C (e.g. C could be \c B, \c B*, <code>T\<B\>*</code> ). 
  </ul>


Here are a couple of header files that together show the various diagrams
that doxygen can generate: 

<code>diagrams_a.h</code>
\verbinclude diagrams_a.h
<code>diagrams_b.h</code>
\verbinclude diagrams_b.h
<code>diagrams_c.h</code>
\verbinclude diagrams_c.h
<code>diagrams_d.h</code>
\verbinclude diagrams_d.h
<code>diagrams_e.h</code>
\verbinclude diagrams_e.h

 \htmlonly
 Click <a href="$(DOXYGEN_DOCDIR)/examples/diagrams/html/index.html">here</a>
 for the corresponding HTML documentation that is generated by doxygen<br>
 (<code>EXTRACT_ALL</code> = <code>YES</code> is used here).
 \endhtmlonly

\htmlonly
Go to the <a href="preprocessing.html">next</a> section or return to the
 <a href="index.html">index</a>.
\endhtmlonly

*/