TreeP.h revision 5b16253f
1/* 2 3Copyright 1990, 1998 The Open Group 4 5Permission to use, copy, modify, distribute, and sell this software and its 6documentation for any purpose is hereby granted without fee, provided that 7the above copyright notice appear in all copies and that both that 8copyright notice and this permission notice appear in supporting 9documentation. 10 11The above copyright notice and this permission notice shall be included in 12all copies or substantial portions of the Software. 13 14THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 15IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 16FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 17OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN 18AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 19CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 20 21Except as contained in this notice, the name of The Open Group shall not be 22used in advertising or otherwise to promote the sale, use or other dealings 23in this Software without prior written authorization from The Open Group. 24 25 * Copyright 1989 Prentice Hall 26 * 27 * Permission to use, copy, modify, and distribute this software for any 28 * purpose and without fee is hereby granted, provided that the above 29 * copyright notice appear in all copies and that both the copyright notice 30 * and this permission notice appear in supporting documentation. 31 * 32 * Prentice Hall and the authors disclaim all warranties with regard 33 * to this software, including all implied warranties of merchantability and 34 * fitness. In no event shall Prentice Hall or the authors be liable 35 * for any special, indirect or cosequential damages or any damages whatsoever 36 * resulting from loss of use, data or profits, whether in an action of 37 * contract, negligence or other tortious action, arising out of or in 38 * connection with the use or performance of this software. 39 * 40 * Authors: Jim Fulton, MIT X Consortium, 41 * based on a version by Douglas Young, Prentice Hall 42 * 43 * This widget is based on the Tree widget described on pages 397-419 of 44 * Douglas Young's book "The X Window System, Programming and Applications 45 * with Xt OSF/Motif Edition." The layout code has been rewritten to use 46 * additional blank space to make the structure of the graph easier to see 47 * as well as to support vertical trees. 48 */ 49 50#ifndef _XawTreeP_h 51#define _XawTreeP_h 52 53#include <X11/Xaw/Tree.h> 54 55typedef struct _TreeClassPart { 56 XtPointer extension; 57} TreeClassPart; 58 59typedef struct _TreeClassRec { 60 CoreClassPart core_class; 61 CompositeClassPart composite_class; 62 ConstraintClassPart constraint_class; 63 TreeClassPart tree_class; 64} TreeClassRec; 65 66extern TreeClassRec treeClassRec; 67 68typedef struct { 69 /* fields available through resources */ 70 Dimension hpad; /* hSpace/HSpace */ 71 Dimension vpad; /* vSpace/VSpace */ 72 Dimension line_width; /* lineWidth/LineWidth */ 73 Pixel foreground; /* foreground/Foreground */ 74 XtGravity gravity; /* gravity/Gravity */ 75 Boolean auto_reconfigure; /* autoReconfigure/AutoReconfigure */ 76 /* private fields */ 77 GC gc; /* used to draw lines */ 78 Widget tree_root; /* hidden root off all children */ 79 Dimension *largest; /* list of largest per depth */ 80 int n_largest; /* number of elements in largest */ 81 Dimension maxwidth, maxheight; /* for shrink wrapping */ 82#ifndef OLDXAW 83 XawDisplayList *display_list; 84 XtPointer pad[4]; /* for future use and keep binary compatibility */ 85#endif 86} TreePart; 87 88 89typedef struct _TreeRec { 90 CorePart core; 91 CompositePart composite; 92 ConstraintPart constraint; 93 TreePart tree; 94} TreeRec; 95 96 97/* 98 * structure attached to all children 99 */ 100typedef struct _TreeConstraintsPart { 101 /* resources */ 102 Widget parent; /* treeParent/TreeParent */ 103 GC gc; /* treeGC/TreeGC */ 104 /* private data */ 105 Widget *children; 106 int n_children; 107 int max_children; 108 Dimension bbsubwidth, bbsubheight; /* bounding box of sub tree */ 109 Dimension bbwidth, bbheight; /* bounding box including node */ 110 Position x, y; 111#ifndef OLDXAW 112 XtPointer pad[2]; /* leave some space for future optimizations, and 113 * keep binary compatibility 114 */ 115#endif 116} TreeConstraintsPart; 117 118typedef struct _TreeConstraintsRec { 119 TreeConstraintsPart tree; 120} TreeConstraintsRec, *TreeConstraints; 121 122 123/* 124 * useful macros 125 */ 126 127#define TREE_CONSTRAINT(w) \ 128 ((TreeConstraints)((w)->core.constraints)) 129 130#define TREE_INITIAL_DEPTH 10 /* for allocating largest array */ 131#define TREE_HORIZONTAL_DEFAULT_SPACING 20 132#define TREE_VERTICAL_DEFAULT_SPACING 6 133 134#endif /* _XawTreeP_h */ 135 136 137 138