All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.redmine.ta.RedmineIssuesMap Maven / Gradle / Ivy

Go to download

Free open-source Java API for Redmine and Chiliproject bug/task management systems.

There is a newer version: 1.10.0
Show newest version
/*
   Copyright 2010-2011 Alexey Skorokhodov.

   Licensed under the Apache License, Version 2.0 (the "License");
   you may not use this file except in compliance with the License.
   You may obtain a copy of the License at

       http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing, software
   distributed under the License is distributed on an "AS IS" BASIS,
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   See the License for the specific language governing permissions and
   limitations under the License.
*/
package org.redmine.ta;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;

import org.redmine.ta.beans.Issue;

/** 
 * Utility class to help convert flat list of Redmine issues to a tree-like structure.
 *  
 * @author Alexey Skorokhodov
 */
public class RedmineIssuesMap {

	/**
	 * map: issueID -> Issue
	 */
	private HashMap issuesMap = new HashMap();

	public RedmineIssuesMap(List list) {
		Iterator it = list.iterator();
		while (it.hasNext()) {
			Issue issue = it.next();
			issuesMap.put(issue.getId(), issue);
		}
	}

	protected HashMap getIssuesMap() {
		return issuesMap;
	}

	public List getRootLevelTasks() {
		return getChildren(null);
	}

	// XXX rewrite this to use issue.getChildren method().
	// TODO add junit test for this new method
	public List getChildren(Issue redmineParentIssue) {
		List rootIssues = new ArrayList();
		Iterator it = issuesMap.values().iterator();
		Integer parentID = null; // look for root level by default
		boolean lookingForRootTasks = true;
		if (redmineParentIssue != null) {
			parentID = redmineParentIssue.getId();
			lookingForRootTasks = false;
		}
		while (it.hasNext()) {
			Issue issue = it.next();
			if (lookingForRootTasks
					&& (issue.getParentId() == null)
					|| (!lookingForRootTasks && (issue.getParentId() != null) && (issue
							.getParentId().equals(parentID)))) {
				rootIssues.add(issue);
			}
		}
		return rootIssues;
	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy