1. Project Clover database Tue Dec 20 2016 21:24:09 CET
  2. Package org.xwiki.tree

File AbstractTree.java

 

Coverage histogram

../../../img/srcFileCovDistChart10.png
0% of files have more coverage

Code metrics

2
8
1
1
52
23
3
0.38
8
1
3

Classes

Class Line # Actions
AbstractTree 37 8 0% 3 0
1.0100%
 

Contributing tests

No tests hitting this source file were found.

Source view

1    /*
2    * See the NOTICE file distributed with this work for additional
3    * information regarding copyright ownership.
4    *
5    * This is free software; you can redistribute it and/or modify it
6    * under the terms of the GNU Lesser General Public License as
7    * published by the Free Software Foundation; either version 2.1 of
8    * the License, or (at your option) any later version.
9    *
10    * This software 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    * You should have received a copy of the GNU Lesser General Public
16    * License along with this software; if not, write to the Free
17    * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
18    * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
19    */
20    package org.xwiki.tree;
21   
22    import java.util.ArrayList;
23    import java.util.Collections;
24    import java.util.List;
25   
26    import org.apache.commons.lang3.StringUtils;
27    import org.xwiki.stability.Unstable;
28   
29    /**
30    * Base class for representing a tree structure.
31    *
32    * @version $Id: 726f74b1136c5f0a571218c9efc7e35cc4ae26e1 $
33    * @since 8.3M2
34    * @since 7.4.5
35    */
36    @Unstable
 
37    public abstract class AbstractTree extends AbstractTreeNode implements Tree
38    {
 
39  1 toggle @Override
40    public List<String> getPath(String nodeId)
41    {
42  1 List<String> path = new ArrayList<String>();
43  1 String rootId = (String) getProperties().get(PROPERTY_ROOT);
44  1 String parentId = nodeId;
45  6 while (!StringUtils.isEmpty(parentId) && !parentId.equals(rootId)) {
46  5 path.add(parentId);
47  5 parentId = getParent(parentId);
48    }
49  1 Collections.reverse(path);
50  1 return path;
51    }
52    }