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

org.netbeans.api.project.libraries.Library Maven / Gradle / Ivy

There is a newer version: RELEASE240
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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.netbeans.api.project.libraries;

import java.beans.PropertyChangeListener;
import java.beans.PropertyChangeEvent;
import java.net.URI;
import java.net.URL;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.MissingResourceException;
import java.util.ResourceBundle;
import java.util.logging.Logger;
import org.netbeans.api.annotations.common.NonNull;
import org.netbeans.modules.project.libraries.LibraryAccessor;
import org.netbeans.spi.project.libraries.LibraryImplementation;
import org.netbeans.spi.project.libraries.LibraryImplementation2;
import org.netbeans.spi.project.libraries.LibraryImplementation3;
import org.netbeans.spi.project.libraries.LibraryStorageArea;
import org.netbeans.spi.project.libraries.support.LibrariesSupport;
import org.openide.util.NbBundle;
import org.openide.util.WeakListeners;

/**
 * Library models typed bundle of typed volumes.
 * 

* Library volumes are typed and query-able by their type. The type is * represented by type string. Strictly speaking volumes are * named rather then typed but the name express their type. * The volume is a list of resoruces. *

* For more details see {@linkplain org.netbeans.api.project.libraries the overview}. * @author Petr Kuzel, Tomas Zezula */ public final class Library { public static final String PROP_NAME = "name"; //NOI18N public static final String PROP_DESCRIPTION = "description"; //NOI18N public static final String PROP_CONTENT = "content"; //NOI18N /** * Name of the display name property. * @since 1.35 */ public static final String PROP_DISPLAY_NAME = "displayName"; //NOI18N /** * Name of the properties property. * @since 1.35 */ public static final String PROP_PROPERTIES = "properties"; //NOI18N private static final Logger LOG = Logger.getLogger(Library.class.getName()); // delegating peer private final LibraryImplementation impl; private List listeners; private final LibraryManager manager; private final PropertyChangeListener listener; Library(LibraryImplementation impl, LibraryManager manager) { this.impl = impl; this.listener = new PropertyChangeListener () { public void propertyChange(PropertyChangeEvent evt) { String propName = evt.getPropertyName(); Library.this.fireChange (propName,evt.getOldValue(),evt.getNewValue()); } }; this.impl.addPropertyChangeListener (WeakListeners.propertyChange(listener, this.impl)); this.manager = manager; } // end create /** * Gets the associated library manager. * @return the manager (may be the "default" global manager, or a local manager) * @since org.netbeans.modules.project.libraries/1 1.15 */ public LibraryManager getManager() { return manager; } /** * Access typed raw library data as URLs. *

* The contents are defined by SPI providers and identified * by the volume types. For example the j2se library supports the following * volume types: classpath - the library classpath roots, src - the library sources, javadoc - the library javadoc. * Your module must have contract with a particular provider's module to be able to query it effectively. *

* * @param volumeType which resources to return. * @return list of URLs of given volume type (possibly empty but never null) */ public List getContent(final String volumeType) { return impl.getContent (volumeType); } // end getContent /** * Access typed raw library data as possibly relative URIs. *

* The contents are defined by SPI providers and identified * by the volume types. For example the j2se library supports the following * volume types: classpath - the library classpath roots, src - the library sources, javadoc - the library javadoc. * Your module must have contract with a particular provider's module to be able to query it effectively. *

* * @param volumeType which resources to return. * @return list of URIs of given volume type (possibly empty but never null) * @since org.netbeans.modules.project.libraries/1 1.18 */ public List getURIContent(final String volumeType) { if (LibrariesSupport.supportsURIContent(impl)) { return LibrariesSupport.getURIContent(impl, volumeType, LibrariesSupport.ConversionMode.FAIL); } else { return LibrariesSupport.convertURLsToURIs( impl.getContent(volumeType), LibrariesSupport.ConversionMode.WARN); } } // end getContent /** * Returns properties associated with this library. Returned properties * object should be considered readonly and any changes to it will not be * propagated back to the library itself. * @return never null but can be empty if library does not have any properties * or does not support concept of properties * @since 1.34 */ @NonNull public Map getProperties() { if (LibrariesSupport.supportsProperties(impl)) { return Collections.unmodifiableMap(LibrariesSupport.getProperties(impl)); } else { return Collections.emptyMap(); } } /** * Get library binding name. The name identifies library * in scope of one libraries storage. *

* * @return String with library name */ public String getName() { return impl.getName(); } // end getName /** * Returns description of the library. * The description provides more detailed information about the library. * @return String the description or null if the description is not available */ public String getDescription () { return this.getLocalizedString(this.impl.getLocalizingBundle(),this.impl.getDescription()); } /** * Returns the display name of the library. * The display name is either equal to the name or * is a localized version of the name. * @return String the display name, never returns null. */ public String getDisplayName () { return LibrariesSupport.getLocalizedName(this.impl); } /** * Gets the type of library. The library type identifies * the provider which has created the library and implies * the volues contained in it. * @return String (e.g. j2se for J2SE library) */ public String getType () { return this.impl.getType(); } // delegated identity @Override public boolean equals(Object obj) { if (obj == this) return true; if (obj instanceof Library) { Library peer = (Library) obj; return peer.impl.equals(impl); } return false; } // delegated identity @Override public int hashCode() { return impl.hashCode(); } /** * Adds PropertyChangeListener * @param listener */ public synchronized void addPropertyChangeListener (PropertyChangeListener listener) { if (this.listeners == null) this.listeners = new ArrayList(); this.listeners.add (listener); } /** * Removes PropertyChangeListener * @param listener */ public synchronized void removePropertyChangeListener (PropertyChangeListener listener) { if (this.listeners == null) return; this.listeners.remove (listener); } LibraryImplementation getLibraryImplementation () { return this.impl; } private void fireChange (String propertyName, Object oldValue, Object newValue) { List ls; synchronized (this) { if (this.listeners == null) return; ls = new ArrayList(listeners); } PropertyChangeEvent event = new PropertyChangeEvent (this, propertyName, oldValue, newValue); for (PropertyChangeListener l : ls) { l.propertyChange(event); } } private String getLocalizedString (String bundleName, String key) { if (key == null) { return null; } if (bundleName == null) { return key; } ResourceBundle bundle; try { bundle = NbBundle.getBundle(bundleName); } catch (MissingResourceException mre) { LOG.warning("No such bundle " + bundleName + " for " + getName()); return key; } try { return bundle.getString(key); } catch (MissingResourceException mre) { LOG.warning("No such key " + key + " in " + bundleName + " for " + getName()); return key; } } @Override public String toString() { return "Library[" + getName() + "]"; // NOI18N } static { LibraryAccessor.setInstance( new LibraryAccessor () { @NonNull public Library createLibrary (@NonNull final LibraryImplementation impl) { return new Library(impl, LibraryManager.getDefault()); } @NonNull public LibraryStorageArea getArea(@NonNull final LibraryManager manager) { return manager.getArea(); } @NonNull public LibraryImplementation getLibraryImplementation(@NonNull final Library library) { return library.getLibraryImplementation(); } }); } } // end Library





© 2015 - 2025 Weber Informatics LLC | Privacy Policy