Open Inventor Reference
SoCompactPathList.h
Go to the documentation of this file.
1/*
2 *
3 * Copyright (C) 2000 Silicon Graphics, Inc. All Rights Reserved.
4 *
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either
8 * version 2.1 of the License, or (at your option) any later version.
9 *
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
14 *
15 * Further, this software is distributed without any warranty that it is
16 * free of the rightful claim of any third person regarding infringement
17 * or the like. Any license provided herein, whether implied or
18 * otherwise, applies only to this software file. Patent licenses, if
19 * any, provided herein do not apply to combinations of this program with
20 * other software, or any other product whatsoever.
21 *
22 * You should have received a copy of the GNU Lesser General Public
23 * License along with this library; if not, write to the Free Software
24 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
25 *
26 * Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
27 * Mountain View, CA 94043, or:
28 *
29 * http://www.sgi.com
30 *
31 * For further information regarding this notice, see:
32 *
33 * http://oss.sgi.com/projects/GenInfo/NoticeExplan/
34 *
35 */
36
37
38/*
39 * Copyright (C) 1990,91 Silicon Graphics, Inc.
40 *
41 _______________________________________________________________________
42 ______________ S I L I C O N G R A P H I C S I N C . ____________
43 |
44 | $Revision: 1.1.1.1 $
45 |
46 | Description:
47 | This file contains the definition of the SoCompactPathList class.
48 |
49 | Author(s) : Paul S. Strauss
50 |
51 ______________ S I L I C O N G R A P H I C S I N C . ____________
52 _______________________________________________________________________
53 */
54
55
56#ifndef _SO_COMPACT_PATH_LIST_
57#define _SO_COMPACT_PATH_LIST_
58
59#include <Inventor/SoLists.h>
60
84
86
87 public:
91
94 void reset();
95
100 void getChildren(int &numIndices, const int *&indices);
101
108 bool push(int childIndex);
109
111 void pop();
112
113 private:
114 int *array;
115 int curNode;
116 int *stack;
117 int stackDepth;
118
120 int getNumIndices() { return array[curNode]; }
121
123 int getStartIndex() { return curNode + 1; }
124
126 int getChild(int i)
127 { return array[getStartIndex() + getNumIndices() + i]; }
128
130 void pushCurNode() { stack[stackDepth++] = curNode; }
131
133 void popCurNode() { curNode = stack[--stackDepth - 1]; }
134
136 int computeArraySize(const SoPathList &list);
137
139 int compactPaths(int curSlot, int depth,
140 const SoPathList &list,
141 int firstPath, int numPaths);
142};
143
144#endif /* _SO_COMPACT_PATH_LIST_ */
#define SoINTERNAL
Definition SbBasic.h:155
#define INVENTOR_API
Disable some annoying warnings on MSVC 6.
Definition SbSystem.h:77
This class represents a list of paths (like an SoPathList) in a more compact form.
void getChildren(int &numIndices, const int *&indices)
Returns the indices of the current node that are in paths in the list.
SoCompactPathList(const SoPathList &list)
Constructor given path list.
void pop()
Restores current node to what it was before the most recent push()
bool push(int childIndex)
Traverses the child with given index of the current node.
void reset()
Resets traversal to the beginning.
Maintains a list of pointers to paths.
Definition SoLists.h:212