|
ILIAS
release_5-0 Revision 5.0.0-1144-gc4397b1f870
|
Tree class data representation in hierachical trees using the Nested Set Model with Gaps by Joe Celco. More...
Inheritance diagram for ilTree:
Collaboration diagram for ilTree:Public Member Functions | |
| ilTree ($a_tree_id, $a_root_id=0) | |
| Constructor @access public. More... | |
| initTreeImplementation () | |
| Init tree implementation. More... | |
| getTreeImplementation () | |
| Get tree implementation. More... | |
| useCache ($a_use=true) | |
| Use Cache (usually activated) More... | |
| isCacheUsed () | |
| Check if cache is active. More... | |
| getDepthCache () | |
| Get depth cache. More... | |
| getParentCache () | |
| Get parent cache. More... | |
| initLangCode () | |
| Store user language. More... | |
| getTreeTable () | |
| Get tree table name. More... | |
| getObjectDataTable () | |
| Get object data table. More... | |
| getTreePk () | |
| Get tree primary key. More... | |
| getTableReference () | |
| Get reference table if available. More... | |
| getGap () | |
| Get default gap *. More... | |
| resetInTreeCache () | |
| setTableNames ($a_table_tree, $a_table_obj_data, $a_table_obj_reference="") | |
| set table names The primary key of the table containing your object_data must be 'obj_id' You may use a reference table. More... | |
| setReferenceTablePK ($a_column_name) | |
| set column containing primary key in reference table @access public More... | |
| setObjectTablePK ($a_column_name) | |
| set column containing primary key in object table @access public More... | |
| setTreeTablePK ($a_column_name) | |
| set column containing primary key in tree table @access public More... | |
| buildJoin () | |
| build join depending on table settings @access private More... | |
| getRelation ($a_node_a, $a_node_b) | |
| Get relation of two nodes. More... | |
| getRelationOfNodes ($a_node_a_arr, $a_node_b_arr) | |
| get relation of two nodes by node data More... | |
| getChildIds ($a_node) | |
| Get node child ids @global type $ilDB. More... | |
| getChilds ($a_node_id, $a_order="", $a_direction="ASC") | |
| get child nodes of given node @access public More... | |
| getFilteredChilds ($a_filter, $a_node, $a_order="", $a_direction="ASC") | |
| get child nodes of given node (exclude filtered obj_types) @access public More... | |
| getChildsByType ($a_node_id, $a_type) | |
| get child nodes of given node by object type @access public More... | |
| getChildsByTypeFilter ($a_node_id, $a_types, $a_order="", $a_direction="ASC") | |
| get child nodes of given node by object type @access public More... | |
| insertNode ($a_node_id, $a_parent_id, $a_pos=IL_LAST_NODE, $a_reset_deletion_date=false) | |
| insert new node with node_id under parent node with parent_id @access public More... | |
| getFilteredSubTree ($a_node_id, $a_filter=array()) | |
| get filtered subtree More... | |
| getSubTreeIds ($a_ref_id) | |
| Get all ids of subnodes. More... | |
| getSubTree ($a_node, $a_with_data=true, $a_type="") | |
| get all nodes in the subtree under specified node More... | |
| getSubTreeTypes ($a_node, $a_filter=0) | |
| get types of nodes in the subtree under specified node More... | |
| deleteTree ($a_node) | |
| delete node and the whole subtree under this node @access public More... | |
| getPathFull ($a_endnode_id, $a_startnode_id=0) | |
| get path from a given startnode to a given endnode if startnode is not given the rootnode is startnode. More... | |
| preloadDepthParent ($a_node_ids) | |
| Preload depth/parent. More... | |
| getPathId ($a_endnode_id, $a_startnode_id=0) | |
| get path from a given startnode to a given endnode if startnode is not given the rootnode is startnode @access public More... | |
| getNodePathForTitlePath ($titlePath, $a_startnode_id=null) | |
| Converts a path consisting of object titles into a path consisting of tree nodes. More... | |
| getNodePath ($a_endnode_id, $a_startnode_id=0) | |
| Returns the node path for the specified object reference. More... | |
| checkTree () | |
| check consistence of tree all left & right values are checked if they are exists only once @access public More... | |
| checkTreeChilds ($a_no_zero_child=true) | |
| check, if all childs of tree nodes exist in object table More... | |
| getMaximumDepth () | |
| Return the current maximum depth in the tree @access public. More... | |
| getDepth ($a_node_id) | |
| return depth of a node in tree @access private More... | |
| getNodeTreeData ($a_node_id) | |
| return all columns of tabel tree More... | |
| getNodeData ($a_node_id, $a_tree_pk=null) | |
| get all information of a node. More... | |
| fetchNodeData ($a_row) | |
| get data of parent node from tree and object_data @access private More... | |
| isInTree ($a_node_id) | |
| get all information of a node. More... | |
| getParentNodeData ($a_node_id) | |
| get data of parent node from tree and object_data @access public More... | |
| isGrandChild ($a_startnode_id, $a_querynode_id) | |
| checks if a node is in the path of an other node @access public More... | |
| addTree ($a_tree_id, $a_node_id=-1) | |
| create a new tree to do: ??? More... | |
| getNodeDataByType ($a_type) | |
| get nodes by type More... | |
| removeTree ($a_tree_id) | |
| remove an existing tree More... | |
| moveToTrash ($a_node_id, $a_set_deleted=false) | |
| Wrapper for saveSubTree. More... | |
| saveSubTree ($a_node_id, $a_set_deleted=false) | |
| Use the wrapper moveToTrash save subtree: delete a subtree (defined by node_id) to a new tree with $this->tree_id -node_id. More... | |
| isDeleted ($a_node_id) | |
| This is a wrapper for isSaved() with a more useful name. More... | |
| isSaved ($a_node_id) | |
| Use method isDeleted check if node is saved. More... | |
| preloadDeleted ($a_node_ids) | |
| Preload deleted information. More... | |
| getSavedNodeData ($a_parent_id) | |
| get data saved/deleted nodes More... | |
| getSavedNodeObjIds (array $a_obj_ids) | |
| get object id of saved/deleted nodes More... | |
| getParentId ($a_node_id) | |
| get parent id of given node @access public More... | |
| getLeftValue ($a_node_id) | |
| get left value of given node @access public More... | |
| getChildSequenceNumber ($a_node, $type="") | |
| get sequence number of node in sibling sequence @access public More... | |
| readRootId () | |
| read root id from database More... | |
| getRootId () | |
| get the root id of tree @access public More... | |
| setRootId ($a_root_id) | |
| getTreeId () | |
| get tree id @access public More... | |
| setTreeId ($a_tree_id) | |
| set tree id @access public More... | |
| fetchSuccessorNode ($a_node_id, $a_type="") | |
| get node data of successor node More... | |
| fetchPredecessorNode ($a_node_id, $a_type="") | |
| get node data of predecessor node More... | |
| renumber ($node_id=1, $i=1) | |
| Wrapper for renumber. More... | |
| __renumber ($node_id=1, $i=1) | |
| This method is private. More... | |
| checkForParentType ($a_ref_id, $a_type, $a_exclude_source_check=false) | |
| Check for parent type e.g check if a folder (ref_id 3) is in a parent course obj => checkForParentType(3,'crs');. More... | |
| _removeEntry ($a_tree, $a_child, $a_db_table="tree") | |
| STATIC METHOD Removes a single entry from a tree. More... | |
| __isMainTree () | |
| Check if operations are done on main tree. More... | |
| __checkDelete ($a_node) | |
| Check for deleteTree() compares a subtree of a given node by checking lft, rgt against parent relation. More... | |
| __getSubTreeByParentRelation ($a_node_id, &$parent_childs) | |
| @global type $ilDB More... | |
| __validateSubtrees (&$lft_childs, $parent_childs) | |
| moveTree ($a_source_id, $a_target_id, $a_location=self::POS_LAST_NODE) | |
| Move Tree Implementation. More... | |
| getRbacSubtreeInfo ($a_endnode_id) | |
| This method is used for change existing objects and returns all necessary information for this action. More... | |
| getSubTreeQuery ($a_node_id, $a_fields=array(), $a_types='', $a_force_join_reference=false) | |
| Get tree subtree query. More... | |
| getSubTreeFilteredByObjIds ($a_node_id, array $a_obj_ids, array $a_fields=array()) | |
| get all node ids in the subtree under specified node id, filter by object ids More... | |
| deleteNode ($a_tree_id, $a_node_id) | |
Data Fields | |
| const | POS_LAST_NODE = -2 |
| const | POS_FIRST_NODE = -1 |
| const | RELATION_CHILD = 1 |
| const | RELATION_PARENT = 2 |
| const | RELATION_SIBLING = 3 |
| const | RELATION_EQUALS = 4 |
| const | RELATION_NONE = 5 |
| $ilias | |
| $log | |
| $root_id | |
| $tree_id | |
| $table_tree | |
| $table_obj_data | |
| $table_obj_reference | |
| $ref_pk | |
| $obj_pk | |
| $tree_pk | |
| $gap | |
Protected Member Functions | |
| fetchTranslationFromObjectDataCache ($a_obj_ids) | |
| Get translation data from object cache (trigger in object cache on preload) More... | |
Protected Attributes | |
| $depth_cache = array() | |
| $parent_cache = array() | |
| $in_tree_cache = array() | |
Private Attributes | |
| $tree_impl = NULL | |
Tree class data representation in hierachical trees using the Nested Set Model with Gaps by Joe Celco.
Definition at line 24 of file class.ilTree.php.
| ilTree::__checkDelete | ( | $a_node | ) |
Check for deleteTree() compares a subtree of a given node by checking lft, rgt against parent relation.
@access private
| array | node data from ilTree::getNodeData() |
Definition at line 2504 of file class.ilTree.php.
References $GLOBALS, $ilDB, $query, $res, $row, __getSubTreeByParentRelation(), __validateSubtrees(), and getTreeImplementation().
Referenced by deleteTree().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::__getSubTreeByParentRelation | ( | $a_node_id, | |
| & | $parent_childs | ||
| ) |
@global type $ilDB
| type | $a_node_id | |
| type | $parent_childs |
Definition at line 2546 of file class.ilTree.php.
References $ilDB, $query, $res, $row, and __getSubTreeByParentRelation().
Referenced by __checkDelete(), and __getSubTreeByParentRelation().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::__isMainTree | ( | ) |
Check if operations are done on main tree.
@access private
Definition at line 2489 of file class.ilTree.php.
Referenced by addTree(), checkForParentType(), deleteTree(), getChilds(), getNodeData(), getPathFull(), getPathId(), getSubTree(), initTreeImplementation(), insertNode(), isCacheUsed(), isInTree(), isSaved(), preloadDeleted(), preloadDepthParent(), removeTree(), renumber(), and saveSubTree().
Here is the caller graph for this function:| ilTree::__renumber | ( | $node_id = 1, |
|
$i = 1 |
|||
| ) |
This method is private.
Always call ilTree->renumber() since it locks the tree table renumber left/right values and close the gaps in numbers (recursive) @access private
| integer | node_id where to start (usually the root node) |
| integer | first left value of start node (usually 1) |
Definition at line 2353 of file class.ilTree.php.
References $ilDB, $query, $res, __renumber(), and getChilds().
Referenced by __renumber(), and renumber().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::__validateSubtrees | ( | & | $lft_childs, |
| $parent_childs | |||
| ) |
Definition at line 2587 of file class.ilTree.php.
References $GLOBALS.
Referenced by __checkDelete().
Here is the caller graph for this function:| ilTree::_removeEntry | ( | $a_tree, | |
| $a_child, | |||
$a_db_table = "tree" |
|||
| ) |
STATIC METHOD Removes a single entry from a tree.
The tree structure is NOT updated!
@access public
| integer | tree id |
| integer | child id |
| string | db_table name. default is 'tree' (optional) |
Definition at line 2457 of file class.ilTree.php.
References $ilDB, $ilErr, $ilLog, $query, and $res.
Referenced by ilValidator\purgeObjects().
Here is the caller graph for this function:| ilTree::addTree | ( | $a_tree_id, | |
$a_node_id = -1 |
|||
| ) |
create a new tree to do: ???
| integer | a_tree_id: obj_id of object where tree belongs to |
| integer | a_node_id: root node of tree (optional; default is tree_id itself) |
Definition at line 1699 of file class.ilTree.php.
References $ilDB, $query, $res, and __isMainTree().
Referenced by ilWorkspaceExplorer\__construct(), and ilWorkspaceTree\createTreeForUser().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::buildJoin | ( | ) |
build join depending on table settings @access private
Definition at line 451 of file class.ilTree.php.
Referenced by fetchPredecessorNode(), fetchSuccessorNode(), getChildsByTypeFilter(), getChildSequenceNumber(), getNodeData(), getNodeDataByType(), getPathFull(), getSavedNodeData(), and getSavedNodeObjIds().
Here is the caller graph for this function:| ilTree::checkForParentType | ( | $a_ref_id, | |
| $a_type, | |||
$a_exclude_source_check = false |
|||
| ) |
Check for parent type e.g check if a folder (ref_id 3) is in a parent course obj => checkForParentType(3,'crs');.
@access public
| integer | ref_id |
| string | type |
Definition at line 2395 of file class.ilTree.php.
References $path, __isMainTree(), getPathFull(), isCacheUsed(), and isInTree().
Here is the call graph for this function:| ilTree::checkTree | ( | ) |
check consistence of tree all left & right values are checked if they are exists only once @access public
Definition at line 1239 of file class.ilTree.php.
| ilTree::checkTreeChilds | ( | $a_no_zero_child = true | ) |
check, if all childs of tree nodes exist in object table
Definition at line 1272 of file class.ilTree.php.
| ilTree::deleteNode | ( | $a_tree_id, | |
| $a_node_id | |||
| ) |
Definition at line 2725 of file class.ilTree.php.
| ilTree::deleteTree | ( | $a_node | ) |
delete node and the whole subtree under this node @access public
| array | node_data of a node |
| InvalidArgumentException,InvalidTreeStructureException |
Definition at line 907 of file class.ilTree.php.
References $GLOBALS, $ilDB, __checkDelete(), __isMainTree(), getTreeImplementation(), and resetInTreeCache().
Referenced by ilWorkspaceTree\cascadingDelete().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::fetchNodeData | ( | $a_row | ) |
get data of parent node from tree and object_data @access private
| object | db db result object containing node_data |
Definition at line 1470 of file class.ilTree.php.
References $data, $ilBench, $ilDB, $lng, $query, $res, $row, ilContainerReference\_lookupTitle(), ilObject\DESC_LENGTH, isCacheUsed(), and ilUtil\shortenText().
Referenced by fetchPredecessorNode(), fetchSuccessorNode(), ilSCORMTree\getChilds(), getChilds(), getChildsByType(), getChildsByTypeFilter(), getNodeData(), getNodeDataByType(), getParentNodeData(), getPathFull(), getSavedNodeData(), and getSubTree().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::fetchPredecessorNode | ( | $a_node_id, | |
$a_type = "" |
|||
| ) |
get node data of predecessor node
@access public
| integer | node id |
Definition at line 2244 of file class.ilTree.php.
References $ilDB, $query, $res, $row, buildJoin(), and fetchNodeData().
Here is the call graph for this function:| ilTree::fetchSuccessorNode | ( | $a_node_id, | |
$a_type = "" |
|||
| ) |
get node data of successor node
@access public
| integer | node id |
Definition at line 2181 of file class.ilTree.php.
References $ilDB, $query, $res, $row, buildJoin(), and fetchNodeData().
Here is the call graph for this function:
|
protected |
Get translation data from object cache (trigger in object cache on preload)
| array | $a_obj_ids | object ids |
Definition at line 1566 of file class.ilTree.php.
References isCacheUsed().
Referenced by getChilds().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::getChildIds | ( | $a_node | ) |
Get node child ids @global type $ilDB.
| type | $a_node |
Definition at line 496 of file class.ilTree.php.
References $ilDB, $query, $res, $row, and DB_FETCHMODE_OBJECT.
| ilTree::getChilds | ( | $a_node_id, | |
$a_order = "", |
|||
$a_direction = "ASC" |
|||
| ) |
get child nodes of given node @access public
| integer | node_id |
| string | sort order of returned childs, optional (possible values: 'title','desc','last_update' or 'type') |
| string | sort direction, optional (possible values: 'DESC' or 'ASC'; defalut is 'ASC') |
Reimplemented in ilSCORMTree.
Definition at line 521 of file class.ilTree.php.
References $ilBench, $ilDB, $ilUser, $query, $res, $row, __isMainTree(), fetchNodeData(), fetchTranslationFromObjectDataCache(), and isCacheUsed().
Referenced by __renumber(), and getFilteredChilds().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::getChildsByType | ( | $a_node_id, | |
| $a_type | |||
| ) |
get child nodes of given node by object type @access public
| integer | node_id |
| string | object type |
Definition at line 630 of file class.ilTree.php.
References $ilDB, $query, $res, $row, and fetchNodeData().
Here is the call graph for this function:| ilTree::getChildsByTypeFilter | ( | $a_node_id, | |
| $a_types, | |||
$a_order = "", |
|||
$a_direction = "ASC" |
|||
| ) |
get child nodes of given node by object type @access public
| integer | node_id |
| array | array of object type |
Definition at line 684 of file class.ilTree.php.
References $ilDB, $query, $res, $row, buildJoin(), fetchNodeData(), and ilUtil\quoteArray().
Here is the call graph for this function:| ilTree::getChildSequenceNumber | ( | $a_node, | |
$type = "" |
|||
| ) |
get sequence number of node in sibling sequence @access public
| array | node |
Definition at line 2077 of file class.ilTree.php.
References $ilDB, $query, $res, $row, and buildJoin().
Here is the call graph for this function:| ilTree::getDepth | ( | $a_node_id | ) |
return depth of a node in tree @access private
| integer | node_id of parent's node_id |
Definition at line 1368 of file class.ilTree.php.
| ilTree::getDepthCache | ( | ) |
Get depth cache.
Definition at line 279 of file class.ilTree.php.
References $depth_cache.
| ilTree::getFilteredChilds | ( | $a_filter, | |
| $a_node, | |||
$a_order = "", |
|||
$a_direction = "ASC" |
|||
| ) |
get child nodes of given node (exclude filtered obj_types) @access public
| array | objects to filter (e.g array('rolf')) |
| integer | node_id |
| string | sort order of returned childs, optional (possible values: 'title','desc','last_update' or 'type') |
| string | sort direction, optional (possible values: 'DESC' or 'ASC'; defalut is 'ASC') |
Definition at line 608 of file class.ilTree.php.
References getChilds().
Here is the call graph for this function:| ilTree::getFilteredSubTree | ( | $a_node_id, | |
$a_filter = array() |
|||
| ) |
get filtered subtree
get all subtree nodes beginning at a specific node excluding specific object types and their child nodes.
E.g getFilteredSubTreeNodes()
@access public
return
Definition at line 789 of file class.ilTree.php.
References getNodeData(), and getSubTree().
Here is the call graph for this function:| ilTree::getGap | ( | ) |
| ilTree::getLeftValue | ( | $a_node_id | ) |
get left value of given node @access public
| integer | node id |
Definition at line 2052 of file class.ilTree.php.
| ilTree::getMaximumDepth | ( | ) |
Return the current maximum depth in the tree @access public.
Definition at line 1351 of file class.ilTree.php.
| ilTree::getNodeData | ( | $a_node_id, | |
$a_tree_pk = null |
|||
| ) |
get all information of a node.
get data of a specific node from tree and object_data @access public
| integer | node id |
Definition at line 1425 of file class.ilTree.php.
References $GLOBALS, $ilDB, $query, $res, $row, $tree_id, $tree_pk, __isMainTree(), buildJoin(), and fetchNodeData().
Referenced by ilWorkspaceTree\cascadingDelete(), getFilteredSubTree(), ilWorkspaceTree\getObjectsFromType(), getSubTreeFilteredByObjIds(), and getSubTreeTypes().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::getNodeDataByType | ( | $a_type | ) |
get nodes by type
| integer | a_tree_id: obj_id of object where tree belongs to |
| integer | a_type_id: type of object @access public |
| InvalidArgumentException |
Definition at line 1747 of file class.ilTree.php.
References $data, $GLOBALS, $ilDB, $query, $res, $row, buildJoin(), fetchNodeData(), and ilDB\quote().
Here is the call graph for this function:| ilTree::getNodePath | ( | $a_endnode_id, | |
$a_startnode_id = 0 |
|||
| ) |
Returns the node path for the specified object reference.
Note: this function returns the same result as getNodePathForTitlePath, but takes ref-id's as parameters.
This function differs from getPathFull, in the following aspects:
@access public
| integer | node_id of endnode |
| integer | node_id of startnode (optional) |
Definition at line 1194 of file class.ilTree.php.
References $data, $ilDB, $query, $res, $row, and getPathId().
Referenced by getNodePathForTitlePath().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::getNodePathForTitlePath | ( | $titlePath, | |
$a_startnode_id = null |
|||
| ) |
Converts a path consisting of object titles into a path consisting of tree nodes.
The comparison is non-case sensitive.
Note: this function returns the same result as getNodePath, but takes a title path as parameter.
@access public
| Array | Path array with object titles. e.g. array('ILIAS','English','Course A') |
| ref_id | Startnode of the relative path. Specify null, if the title path is an absolute path. Specify a ref id, if the title path is a relative path starting at this ref id. |
Definition at line 1071 of file class.ilTree.php.
References $ilDB, $log, $obj_pk, $row, DB_FETCHMODE_ASSOC, getNodePath(), ilStr\strToLower(), and UtfNormal\toNFC().
Here is the call graph for this function:| ilTree::getNodeTreeData | ( | $a_node_id | ) |
return all columns of tabel tree
| type | $a_node_id |
| InvalidArgumentException |
Definition at line 1395 of file class.ilTree.php.
References $GLOBALS, $ilDB, $query, $res, $row, and DB_FETCHMODE_ASSOC.
Referenced by getRelation(), getSubTreeQuery(), and saveSubTree().
Here is the caller graph for this function:| ilTree::getObjectDataTable | ( | ) |
Get object data table.
Definition at line 325 of file class.ilTree.php.
References $table_obj_data.
Referenced by getSubTreeFilteredByObjIds().
Here is the caller graph for this function:| ilTree::getParentCache | ( | ) |
Get parent cache.
Definition at line 288 of file class.ilTree.php.
References $parent_cache.
| ilTree::getParentId | ( | $a_node_id | ) |
get parent id of given node @access public
| integer | node id |
Definition at line 2026 of file class.ilTree.php.
| ilTree::getParentNodeData | ( | $a_node_id | ) |
get data of parent node from tree and object_data @access public
| integer | node id |
| InvalidArgumentException |
Definition at line 1642 of file class.ilTree.php.
References $ilDB, $ilLog, $query, $res, $row, and fetchNodeData().
Here is the call graph for this function:| ilTree::getPathFull | ( | $a_endnode_id, | |
$a_startnode_id = 0 |
|||
| ) |
get path from a given startnode to a given endnode if startnode is not given the rootnode is startnode.
This function chooses the algorithm to be used.
@access public
| integer | node_id of endnode |
| integer | node_id of startnode (optional) |
Definition at line 948 of file class.ilTree.php.
References $ilDB, $row, __isMainTree(), buildJoin(), DB_FETCHMODE_ASSOC, fetchNodeData(), getPathId(), and ilDB\quote().
Referenced by checkForParentType(), and ilSkillTree\getSkillTreePath().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::getPathId | ( | $a_endnode_id, | |
$a_startnode_id = 0 |
|||
| ) |
get path from a given startnode to a given endnode if startnode is not given the rootnode is startnode @access public
| integer | node_id of endnode |
| integer | node_id of startnode (optional) |
| InvalidArgumentException |
Definition at line 1028 of file class.ilTree.php.
References $GLOBALS, __isMainTree(), getTreeImplementation(), and isCacheUsed().
Referenced by getNodePath(), getPathFull(), and ilSkillTree\getTopParentNodeId().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::getRbacSubtreeInfo | ( | $a_endnode_id | ) |
This method is used for change existing objects and returns all necessary information for this action.
The former use of ilTree::getSubtree needs to much memory.
| ref_id | ref_id of source node |
Definition at line 2660 of file class.ilTree.php.
References getTreeImplementation().
Here is the call graph for this function:| ilTree::getRelation | ( | $a_node_a, | |
| $a_node_b | |||
| ) |
Get relation of two nodes.
| int | $a_node_a | |
| int | $a_node_b |
Definition at line 471 of file class.ilTree.php.
References getNodeTreeData(), and getRelationOfNodes().
Referenced by isGrandChild().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::getRelationOfNodes | ( | $a_node_a_arr, | |
| $a_node_b_arr | |||
| ) |
get relation of two nodes by node data
| array | $a_node_a_arr | |
| array | $a_node_b_arr |
Definition at line 485 of file class.ilTree.php.
References getTreeImplementation().
Referenced by getRelation().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::getRootId | ( | ) |
get the root id of tree @access public
Definition at line 2145 of file class.ilTree.php.
References $root_id.
Referenced by ilWorkspaceTree\getObjectsFromType().
Here is the caller graph for this function:| ilTree::getSavedNodeData | ( | $a_parent_id | ) |
get data saved/deleted nodes
| integer | id of parent object of saved object @access public |
Definition at line 1972 of file class.ilTree.php.
References $ilDB, $query, $res, $row, buildJoin(), and fetchNodeData().
Here is the call graph for this function:| ilTree::getSavedNodeObjIds | ( | array | $a_obj_ids | ) |
get object id of saved/deleted nodes
| array | object ids to check @access public |
Definition at line 2003 of file class.ilTree.php.
References $ilDB, $query, $res, $row, and buildJoin().
Here is the call graph for this function:| ilTree::getSubTree | ( | $a_node, | |
$a_with_data = true, |
|||
$a_type = "" |
|||
| ) |
get all nodes in the subtree under specified node
@access public
| array | node_data |
| boolean | with data: default is true otherwise this function return only a ref_id array |
| InvalidArgumentException |
Definition at line 834 of file class.ilTree.php.
References $GLOBALS, $ilDB, $query, $res, $row, __isMainTree(), fetchNodeData(), and getTreeImplementation().
Referenced by ilWorkspaceTree\cascadingDelete(), getFilteredSubTree(), and ilWorkspaceTree\getObjectsFromType().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::getSubTreeFilteredByObjIds | ( | $a_node_id, | |
| array | $a_obj_ids, | ||
| array | $a_fields = array() |
||
| ) |
get all node ids in the subtree under specified node id, filter by object ids
| int | $a_node_id | |
| array | $a_obj_ids | |
| array | $a_fields |
Definition at line 2691 of file class.ilTree.php.
References $ilDB, $query, $res, $row, getNodeData(), getObjectDataTable(), and getTreeImplementation().
Here is the call graph for this function:| ilTree::getSubTreeIds | ( | $a_ref_id | ) |
Get all ids of subnodes.
| object | $a_ref_id |
Definition at line 819 of file class.ilTree.php.
References getTreeImplementation().
Here is the call graph for this function:| ilTree::getSubTreeQuery | ( | $a_node_id, | |
$a_fields = array(), |
|||
$a_types = '', |
|||
$a_force_join_reference = false |
|||
| ) |
Get tree subtree query.
| type | $a_node_id | |
| type | $a_types | |
| type | $a_force_join_reference |
Definition at line 2673 of file class.ilTree.php.
References getNodeTreeData(), and getTreeImplementation().
Here is the call graph for this function:| ilTree::getSubTreeTypes | ( | $a_node, | |
$a_filter = 0 |
|||
| ) |
get types of nodes in the subtree under specified node
@access public
| array | node_id |
| array | object types to filter e.g array('rolf') |
Definition at line 886 of file class.ilTree.php.
References getNodeData().
Here is the call graph for this function:| ilTree::getTableReference | ( | ) |
Get reference table if available.
Definition at line 342 of file class.ilTree.php.
References $table_obj_reference.
| ilTree::getTreeId | ( | ) |
get tree id @access public
Definition at line 2159 of file class.ilTree.php.
References $tree_id.
Referenced by ilWorkspaceExplorer\__construct().
Here is the caller graph for this function:| ilTree::getTreeImplementation | ( | ) |
Get tree implementation.
Definition at line 253 of file class.ilTree.php.
References $tree_impl.
Referenced by __checkDelete(), deleteTree(), getPathId(), getRbacSubtreeInfo(), getRelationOfNodes(), getSubTree(), getSubTreeFilteredByObjIds(), getSubTreeIds(), getSubTreeQuery(), insertNode(), moveTree(), and saveSubTree().
Here is the caller graph for this function:| ilTree::getTreePk | ( | ) |
Get tree primary key.
Definition at line 334 of file class.ilTree.php.
References $tree_pk.
| ilTree::getTreeTable | ( | ) |
Get tree table name.
Definition at line 316 of file class.ilTree.php.
References $table_tree.
| ilTree::ilTree | ( | $a_tree_id, | |
$a_root_id = 0 |
|||
| ) |
Constructor @access public.
| integer | $a_tree_id | tree_id |
| integer | $a_root_id | root_id (optional) |
Definition at line 147 of file class.ilTree.php.
References $ilDB, $ilErr, $ilias, $ilLog, initTreeImplementation(), and PEAR_ERROR_CALLBACK.
Here is the call graph for this function:| ilTree::initLangCode | ( | ) |
Store user language.
This function is used by the "main" tree only (during initialisation).
Definition at line 297 of file class.ilTree.php.
References $ilUser.
| ilTree::initTreeImplementation | ( | ) |
Init tree implementation.
Definition at line 211 of file class.ilTree.php.
References $GLOBALS, $ilDB, and __isMainTree().
Referenced by ilTree(), and setTableNames().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::insertNode | ( | $a_node_id, | |
| $a_parent_id, | |||
$a_pos = IL_LAST_NODE, |
|||
$a_reset_deletion_date = false |
|||
| ) |
insert new node with node_id under parent node with parent_id @access public
| integer | node_id |
| integer | parent_id |
| integer | IL_LAST_NODE | IL_FIRST_NODE | node id of preceding child |
Definition at line 733 of file class.ilTree.php.
References $GLOBALS, $ilDB, __isMainTree(), ilObject\_resetDeletedDate(), getTreeImplementation(), and isInTree().
Referenced by ilWorkspaceTree\insertObject().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::isCacheUsed | ( | ) |
Check if cache is active.
Reimplemented in ilLMTree.
Definition at line 270 of file class.ilTree.php.
References __isMainTree().
Referenced by checkForParentType(), fetchNodeData(), fetchTranslationFromObjectDataCache(), getChilds(), getPathId(), isInTree(), isSaved(), preloadDeleted(), and preloadDepthParent().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::isDeleted | ( | $a_node_id | ) |
This is a wrapper for isSaved() with a more useful name.
| int | $a_node_id |
Definition at line 1883 of file class.ilTree.php.
References isSaved().
Here is the call graph for this function:| ilTree::isGrandChild | ( | $a_startnode_id, | |
| $a_querynode_id | |||
| ) |
checks if a node is in the path of an other node @access public
| integer | object id of start node |
| integer | object id of query node |
Definition at line 1686 of file class.ilTree.php.
References getRelation(), and RELATION_PARENT.
Here is the call graph for this function:| ilTree::isInTree | ( | $a_node_id | ) |
get all information of a node.
get data of a specific node from tree and object_data @access public
| integer | node id |
Definition at line 1590 of file class.ilTree.php.
References $ilDB, $query, $res, __isMainTree(), and isCacheUsed().
Referenced by checkForParentType(), and insertNode().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::isSaved | ( | $a_node_id | ) |
Use method isDeleted check if node is saved.
Definition at line 1893 of file class.ilTree.php.
References $ilDB, $query, $res, $row, __isMainTree(), and isCacheUsed().
Referenced by isDeleted().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::moveToTrash | ( | $a_node_id, | |
$a_set_deleted = false |
|||
| ) |
Wrapper for saveSubTree.
| type | $a_node_id | |
| type | $a_set_deleted |
| InvalidArgumentException |
Definition at line 1807 of file class.ilTree.php.
References saveSubTree().
Here is the call graph for this function:| ilTree::moveTree | ( | $a_source_id, | |
| $a_target_id, | |||
$a_location = self::POS_LAST_NODE |
|||
| ) |
Move Tree Implementation.
@access public
| int | source ref_id |
| int | target ref_id |
| int | location IL_LAST_NODE or IL_FIRST_NODE (IL_FIRST_NODE not implemented yet) |
Definition at line 2636 of file class.ilTree.php.
References $GLOBALS, and getTreeImplementation().
Here is the call graph for this function:| ilTree::preloadDeleted | ( | $a_node_ids | ) |
Preload deleted information.
| array | nodfe ids |
Definition at line 1933 of file class.ilTree.php.
References $ilDB, $query, $res, $row, __isMainTree(), and isCacheUsed().
Here is the call graph for this function:| ilTree::preloadDepthParent | ( | $a_node_ids | ) |
Preload depth/parent.
return
Definition at line 999 of file class.ilTree.php.
References $ilDB, $res, $row, __isMainTree(), and isCacheUsed().
Here is the call graph for this function:| ilTree::readRootId | ( | ) |
read root id from database
| root_id | @access public |
Definition at line 2125 of file class.ilTree.php.
References $ilDB, $query, $res, $root_id, and $row.
Referenced by ilWorkspaceTree\__construct(), ilWorkspaceExplorer\__construct(), ilWorkspaceTree\cascadingDelete(), and ilWorkspaceAccessHandler\checkAccessOfUser().
Here is the caller graph for this function:| ilTree::removeTree | ( | $a_tree_id | ) |
remove an existing tree
| integer | a_tree_id: tree to be removed |
Definition at line 1779 of file class.ilTree.php.
References $GLOBALS, $ilDB, $query, and __isMainTree().
Here is the call graph for this function:| ilTree::renumber | ( | $node_id = 1, |
|
$i = 1 |
|||
| ) |
Wrapper for renumber.
This method locks the table tree (recursive) @access public
| integer | node_id where to start (usually the root node) |
| integer | first left value of start node (usually 1) |
Definition at line 2309 of file class.ilTree.php.
References $ilDB, __isMainTree(), __renumber(), and ilDB\LOCK_WRITE.
Here is the call graph for this function:| ilTree::resetInTreeCache | ( | ) |
Definition at line 358 of file class.ilTree.php.
Referenced by deleteTree().
Here is the caller graph for this function:| ilTree::saveSubTree | ( | $a_node_id, | |
$a_set_deleted = false |
|||
| ) |
Use the wrapper moveToTrash save subtree: delete a subtree (defined by node_id) to a new tree with $this->tree_id -node_id.
This is neccessary for undelete functionality
| integer | node_id |
| InvalidArgumentException |
Definition at line 1822 of file class.ilTree.php.
References $GLOBALS, $ilDB, $query, $res, $row, __isMainTree(), DB_FETCHMODE_ASSOC, getNodeTreeData(), getTreeImplementation(), ilDB\LOCK_WRITE, and ilObject\setDeletedDates().
Referenced by moveToTrash().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::setObjectTablePK | ( | $a_column_name | ) |
set column containing primary key in object table @access public
| string | column name |
Definition at line 418 of file class.ilTree.php.
Referenced by ilECSCmsTree\__construct(), and ilWorkspaceTree\__construct().
Here is the caller graph for this function:| ilTree::setReferenceTablePK | ( | $a_column_name | ) |
set column containing primary key in reference table @access public
| string | column name |
Definition at line 401 of file class.ilTree.php.
Referenced by ilWorkspaceTree\__construct().
Here is the caller graph for this function:| ilTree::setRootId | ( | $a_root_id | ) |
Definition at line 2149 of file class.ilTree.php.
Referenced by ilWorkspaceExplorer\__construct(), and ilWorkspaceTree\createTreeForUser().
Here is the caller graph for this function:| ilTree::setTableNames | ( | $a_table_tree, | |
| $a_table_obj_data, | |||
$a_table_obj_reference = "" |
|||
| ) |
set table names The primary key of the table containing your object_data must be 'obj_id' You may use a reference table.
If no reference table is specified the given tree table is directly joined with the given object_data table. The primary key in object_data table and its foreign key in reference table must have the same name!
| string | table name of tree table |
| string | table name of object_data table |
| string | table name of object_reference table (optional) @access public |
Definition at line 378 of file class.ilTree.php.
References initTreeImplementation().
Referenced by ilSCORM2004Tree\__construct(), ilTaxonomyTree\__construct(), ilLMTree\__construct(), ilECSCmsTree\__construct(), ilWorkspaceTree\__construct(), ilBookmarkTree\__construct(), ilSkillTree\__construct(), ilAICCTree\ilAICCTree(), and ilSCORMTree\ilSCORMTree().
Here is the call graph for this function:
Here is the caller graph for this function:| ilTree::setTreeId | ( | $a_tree_id | ) |
set tree id @access public
Definition at line 2169 of file class.ilTree.php.
| ilTree::setTreeTablePK | ( | $a_column_name | ) |
set column containing primary key in tree table @access public
| string | column name |
Definition at line 435 of file class.ilTree.php.
Referenced by ilSCORM2004Tree\__construct(), ilTaxonomyTree\__construct(), ilLMTree\__construct(), ilWorkspaceTree\__construct(), ilSkillTree\__construct(), ilAICCTree\ilAICCTree(), and ilSCORMTree\ilSCORMTree().
Here is the caller graph for this function:| ilTree::useCache | ( | $a_use = true | ) |
Use Cache (usually activated)
Definition at line 261 of file class.ilTree.php.
Referenced by ilLMTree\__construct(), and ilECSCmsTree\__construct().
Here is the caller graph for this function:
|
protected |
Definition at line 134 of file class.ilTree.php.
Referenced by getDepthCache().
| ilTree::$gap |
Size of the gaps to be created in the nested sets sequence numbering of the
tree nodes. Having gaps in the tree greatly improves performance on all operations that add or remove tree nodes.
Setting this to zero will leave no gaps in the tree. Setting this to a value larger than zero will create gaps in the tree. Each gap leaves room in the sequence numbering for the specified number of nodes. (The gap is expressed as the number of nodes. Since each node consumes two sequence numbers, specifying a gap of 1 will leave space for 2 sequence numbers.)
A gap is created, when a new child is added to a node, and when not enough room between node.rgt and the child with the highest node.rgt value of the node is available. A gap is closed, when a node is removed and when (node.rgt - node.lft) is bigger than gap * 2. @var integer @access private
Definition at line 132 of file class.ilTree.php.
Referenced by getGap().
| ilTree::$ilias |
Definition at line 42 of file class.ilTree.php.
Referenced by ilTree().
|
protected |
Definition at line 136 of file class.ilTree.php.
| ilTree::$log |
Definition at line 50 of file class.ilTree.php.
Referenced by getNodePathForTitlePath().
| ilTree::$obj_pk |
Definition at line 99 of file class.ilTree.php.
Referenced by getNodePathForTitlePath(), and ilWorkspaceTree\lookupObjectId().
|
protected |
Definition at line 135 of file class.ilTree.php.
Referenced by getParentCache().
| ilTree::$ref_pk |
Definition at line 92 of file class.ilTree.php.
Referenced by ilWorkspaceTree\lookupNodeId().
| ilTree::$root_id |
Definition at line 57 of file class.ilTree.php.
Referenced by ilWorkspaceTree\cascadingDelete(), ilWorkspaceTree\createTreeForUser(), getRootId(), and readRootId().
| ilTree::$table_obj_data |
Definition at line 78 of file class.ilTree.php.
Referenced by getObjectDataTable().
| ilTree::$table_obj_reference |
Definition at line 85 of file class.ilTree.php.
Referenced by getTableReference().
| ilTree::$table_tree |
Definition at line 71 of file class.ilTree.php.
Referenced by getTreeTable().
| ilTree::$tree_id |
Definition at line 64 of file class.ilTree.php.
Referenced by getNodeData(), and getTreeId().
|
private |
Definition at line 138 of file class.ilTree.php.
Referenced by getTreeImplementation().
| ilTree::$tree_pk |
Definition at line 106 of file class.ilTree.php.
Referenced by getNodeData(), and getTreePk().
| const ilTree::POS_FIRST_NODE = -1 |
Definition at line 27 of file class.ilTree.php.
Referenced by ilNestedSetTree\insertNode().
| const ilTree::POS_LAST_NODE = -2 |
Definition at line 26 of file class.ilTree.php.
| const ilTree::RELATION_CHILD = 1 |
Definition at line 30 of file class.ilTree.php.
Referenced by ilObjRole\adjustPermissions(), ilMaterializedPathTree\getRelation(), and ilNestedSetTree\getRelation().
| const ilTree::RELATION_EQUALS = 4 |
Definition at line 33 of file class.ilTree.php.
Referenced by ilObjRole\adjustPermissions(), ilMaterializedPathTree\getRelation(), and ilNestedSetTree\getRelation().
| const ilTree::RELATION_NONE = 5 |
Definition at line 34 of file class.ilTree.php.
Referenced by ilObjRole\adjustPermissions(), ilMaterializedPathTree\getRelation(), and ilNestedSetTree\getRelation().
| const ilTree::RELATION_PARENT = 2 |
Definition at line 31 of file class.ilTree.php.
Referenced by ilObjRole\adjustPermissions(), ilMaterializedPathTree\getRelation(), ilNestedSetTree\getRelation(), and isGrandChild().
| const ilTree::RELATION_SIBLING = 3 |
Definition at line 32 of file class.ilTree.php.
Referenced by ilObjRole\adjustPermissions(), ilMaterializedPathTree\getRelation(), and ilNestedSetTree\getRelation().