/* * Project Info: http://jcae.sourceforge.net * * This program is free software; you can redistribute it and/or modify it under * the terms of the GNU Lesser General Public License as published by the Free * Software Foundation; either version 2.1 of the License, or (at your option) * any later version. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more * details. * * You should have received a copy of the GNU Lesser General Public License * along with this program; if not, write to the Free Software Foundation, Inc., * 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA. * * (C) Copyright 2005-2011, by EADS France */ package org.jcae.netbeans.mesh; import java.util.ArrayList; import java.util.Arrays; import java.util.Collection; import java.util.Comparator; import org.jcae.mesh.xmldata.Group; import org.jcae.mesh.xmldata.Groups; import org.openide.filesystems.FileObject; import org.openide.nodes.Children.Array; import org.openide.nodes.Node; /** * Children class. His associated node has a lookup to it. * @author ibarz */ public class GroupChildren extends Array { private final Groups groups; private final FileObject fileObject; // fileObject is need to ensure that the node is visible in the favorites // tab public GroupChildren(Groups groups, FileObject fileObject) { this.groups=groups; this.fileObject = fileObject; } @Override protected Collection<Node> initCollection() { Group[] gps=groups.getGroups(); Arrays.sort(gps, new Comparator<Group>(){ public int compare(Group o1, Group o2) { return o1.getName().compareTo(o2.getName()); } }); ArrayList<Node> toReturn = new ArrayList<Node>(gps.length); for(int i=0; i<gps.length; i++) { toReturn.add(GroupNode.create(gps[i], groups, fileObject)); } return toReturn; } }