alvinalexander.com | career | drupal | java | mac | mysql | perl | scala | uml | unix  

What this is

This file is included in the DevDaily.com "Java Source Code Warehouse" project. The intent of this project is to help you "Learn Java by Example" TM.

Other links

The source code

/*
 *                 Sun Public License Notice
 *
 * The contents of this file are subject to the Sun Public License
 * Version 1.0 (the "License"). You may not use this file except in
 * compliance with the License. A copy of the License is available at
 * http://www.sun.com/
 *
 * The Original Code is NetBeans. The Initial Developer of the Original
 * Code is Sun Microsystems, Inc. Portions Copyright 1997-2004 Sun
 * Microsystems, Inc. All Rights Reserved.
 */

package org.netbeans.api.project;

import java.beans.PropertyChangeListener;
import javax.swing.Icon;
import javax.swing.ImageIcon;
import org.netbeans.spi.project.support.GenericSources;
import org.openide.filesystems.FileStateInvalidException;
import org.openide.util.Utilities;
import org.openide.util.Mutex;

import java.util.HashSet;

import java.util.Set;

import java.util.Iterator;

import org.netbeans.spi.project.SubprojectProvider;

/**
 * Utility methods to get information about {@link Project}s.
 * @author Jesse Glick
 */
public class ProjectUtils {
    
    private ProjectUtils() {}
    
    /**
     * Get basic information about a project.
     * If the project has a {@link ProjectInformation} instance in its lookup,
     * that is used. Otherwise, a basic dummy implementation is returned.
     * @param p a project
     * @return some information about it
     * @see Project#getLookup
     */
    public static ProjectInformation getInformation(Project p) {
        ProjectInformation pi = (ProjectInformation)p.getLookup().lookup(ProjectInformation.class);
        if (pi != null) {
            return pi;
        } else {
            return new BasicInformation(p);
        }
    }
    
    /**
     * Get a list of sources for a project.
     * If the project has a {@link Sources} instance in its lookup,
     * that is used. Otherwise, a basic implementation is returned
     * using {@link GenericSources#genericOnly}.
     * @param p a project
     * @return a list of sources for it
     * @see Project#getLookup
     */
    public static Sources getSources(Project p) {
        Sources s = (Sources)p.getLookup().lookup(Sources.class);
        if (s != null) {
            return s;
        } else {
            return GenericSources.genericOnly(p);
        }
    }
    
    /**
     * Check whether a project has, or might have, cycles in its subproject graph.
     * 

* If the candidate parameter is null, this simply checks whether the master * project's current directed graph of (transitive) subprojects contains any * cycles. If the candidate is also passed, this checks whether the master * project's subproject graph would contain cycles if the candidate were added * as a (direct) subproject of the master project. *

*

* All cycles are reported even if they do not contain the master project. *

*

* If the master project already contains the candidate as a (direct) subproject, * the effect is as if the candidate were null. *

*

* Projects with no {@link SubprojectProvider} are considered to have no * subprojects, just as if the provider returned an empty set. *

*

* Acquires read access. *

*

* Project types which let the user somehow configure subprojects in the GUI * (perhaps indirectly, e.g. via a classpath) should use this call to check * for possible cycles before adding new subprojects. *

* @param master a project to root the subproject graph from * @param candidate a potential direct subproject of the master project, or null * @return true if the master project currently has a cycle somewhere in its * subproject graph, regardless of the candidate parameter, or if the * candidate is not null and the master project does not currently have * a cycle but would have one if the candidate were added as a subproject * @see Issue #43845 */ public static boolean hasSubprojectCycles(final Project master, final Project candidate) { return ((Boolean) ProjectManager.mutex().readAccess(new Mutex.Action() { public Object run() { return Boolean.valueOf(visit(new HashSet(), master, master, candidate)); } })).booleanValue(); } /** * Do a DFS traversal checking for cycles. * @param encountered projects already encountered in the DFS (added and removed as you go) * @param curr current node to visit * @param master the original master project (for use with candidate param) * @param candidate a candidate added subproject for master, or null */ private static boolean visit(Set/**/ encountered, Project curr, Project master, Project candidate) { if (!encountered.add(curr)) { return true; } SubprojectProvider spp = (SubprojectProvider) curr.getLookup().lookup(SubprojectProvider.class); if (spp != null) { Iterator/**/ children = spp.getSubprojects().iterator(); while (children.hasNext()) { Project child = (Project) children.next(); if (candidate == child) { candidate = null; } if (visit(encountered, child, master, candidate)) { return true; } } } if (candidate != null && curr == master) { if (visit(encountered, candidate, master, candidate)) { return true; } } assert encountered.contains(curr); encountered.remove(curr); return false; } private static final class BasicInformation implements ProjectInformation { private final Project p; public BasicInformation(Project p) { this.p = p; } public String getName() { try { return p.getProjectDirectory().getURL().toExternalForm(); } catch (FileStateInvalidException e) { return e.toString(); } } public String getDisplayName() { return p.getProjectDirectory().getNameExt(); } public Icon getIcon() { return new ImageIcon(Utilities.loadImage("org/netbeans/modules/projectapi/resources/empty.gif")); // NOI18N } public void addPropertyChangeListener(PropertyChangeListener listener) { // never changes } public void removePropertyChangeListener(PropertyChangeListener listener) { // never changes } public Project getProject() { return p; } } }
... this post is sponsored by my books ...

#1 New Release!

FP Best Seller

 

new blog posts

 

Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.

A percentage of advertising revenue from
pages under the /java/jwarehouse URI on this website is
paid back to open source projects.