00001 00002 /* 00003 | Author: Michael Schmidt; 00004 | Gunnar Jehl 00005 | 00006 | ************************* SOFTWARE LICENSE AGREEMENT *********************** 00007 | This source code is published under the BSD License. 00008 | 00009 | See file 'LICENSE.txt' that comes with this distribution or 00010 | http://dbis.informatik.uni-freiburg.de/index.php?project=GCX/license.php 00011 | for the full license agreement. 00012 | 00013 | THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00014 | AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00015 | IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00016 | ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 00017 | LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00018 | CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00019 | SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00020 | INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00021 | CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00022 | ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00023 | POSSIBILITY OF SUCH DAMAGE. 00024 | **************************************************************************** 00025 */ 00026 00035 #ifndef PROJECTIONTREE_H 00036 #define PROJECTIONTREE_H 00037 00038 #include "projectiontreenode.h" 00039 #include "variabletree.h" 00040 #include "dependencyset.h" 00041 #include "projectiontreelabels.h" 00042 00051 class ProjectionTree { 00052 00053 public: 00059 ProjectionTree(VariableTree * _vt, vector < DependencySet * >*_depset); 00060 00064 virtual ~ ProjectionTree(); 00065 00079 void insertNode(int parent_var, int introduced_var, 00080 PathExpression * path, bool dep, Role * role, 00081 bool direct_output); 00082 00089 void print(OutputStream & dos); 00090 00096 inline ProjectionTreeNode *getRootNode() { 00097 return root; 00098 } inline ProjectionTreeLabels *getLabels() { 00104 return labels; 00105 } 00106 00113 void labelTree(); 00114 00121 void removeUnneededNodes(PassiveProjectionTree * ppt); 00122 00129 void removeRedundantRoles(PassiveProjectionTree * ppt); 00130 00131 private: 00139 void createProjectionTree(VariableTreeNode * varnode, 00140 vector < DependencySet * >*depset); 00141 00146 ProjectionTreeNode *root; 00147 00152 RoleList *roleinfo; 00153 00158 ProjectionTreeLabels *labels; 00159 }; 00160 00161 #endif // PROJECTIONTREE_H