/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common
* Development and Distribution License("CDDL") (collectively, the
* "License"). You may not use this file except in compliance with the
* License. You can obtain a copy of the License at
* http://www.netbeans.org/cddl-gplv2.html
* or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
* specific language governing permissions and limitations under the
* License. When distributing the software, include this License Header
* Notice in each file and include the License file at
* nbbuild/licenses/CDDL-GPL-2-CP. Sun designates this
* particular file as subject to the "Classpath" exception as provided
* by Sun in the GPL Version 2 section of the License file that
* accompanied this code. If applicable, add the following below the
* License Header, with the fields enclosed by brackets [] replaced by
* your own identifying information:
* "Portions Copyrighted [year] [name of copyright owner]"
*
* Contributor(s):
*
* The Original Software is NetBeans. The Initial Developer of the Original
* Software is Sun Microsystems, Inc. Portions Copyright 1997-2006 Sun
* Microsystems, Inc. All Rights Reserved.
*
* If you wish your version of this file to be governed by only the CDDL
* or only the GPL Version 2, indicate your decision by adding
* "[Contributor] elects to include this software in this distribution
* under the [CDDL or GPL Version 2] license." If you do not indicate a
* single choice of license, a recipient has the option to distribute
* your version of this file under either the CDDL, the GPL Version 2 or
* to extend the choice of license to its licensees as provided above.
* However, if you add GPL Version 2 code and therefore, elected the GPL
* Version 2 license, then the option applies only if the new code is
* made subject to such option by the copyright holder.
*/
package org.netbeans.modules.project.libraries;
import java.net.URL;
import org.netbeans.spi.project.libraries.LibraryImplementation;
import java.util.*;
import java.beans.PropertyChangeListener;
import java.beans.PropertyChangeEvent;
public final class DefaultLibraryImplementation implements LibraryImplementation {
private String description;
private Map<String,List<URL>> contents;
// library 'binding name' as given by user
private String name;
private String libraryType;
private String localizingBundle;
private List<PropertyChangeListener> listeners;
/**
* Create new LibraryImplementation supporting given <tt>library</tt>.
*/
public DefaultLibraryImplementation (String libraryType, String[] volumeTypes) {
assert libraryType != null && volumeTypes != null;
this.libraryType = libraryType;
this.contents = new HashMap<String,List<URL>>();
for (String vtype : volumeTypes) {
this.contents.put(vtype, Collections.<URL>emptyList());
}
}
public String getType() {
return libraryType;
}
public void setName(final String name) throws UnsupportedOperationException {
String oldName = this.name;
this.name = name;
this.firePropertyChange (PROP_NAME, oldName, this.name);
}
public String getName() {
return name;
}
public List<URL> getContent(String contentType) throws IllegalArgumentException {
List<URL> content = contents.get(contentType);
if (content == null)
throw new IllegalArgumentException ();
return Collections.unmodifiableList (content);
}
public void setContent(String contentType, List<URL> path) throws IllegalArgumentException {
if (path == null) {
throw new IllegalArgumentException ();
}
if (this.contents.keySet().contains(contentType)) {
this.contents.put(contentType, new ArrayList<URL>(path));
this.firePropertyChange(PROP_CONTENT,null,null);
} else {
throw new IllegalArgumentException ("Volume '"+contentType+
"' is not support by this library. The only acceptable values are: "+contents.keySet());
}
}
public String getDescription () {
return this.description;
}
public void setDescription (String text) {
String oldDesc = this.description;
this.description = text;
this.firePropertyChange (PROP_DESCRIPTION, oldDesc, this.description);
}
public String getLocalizingBundle() {
return this.localizingBundle;
}
public void setLocalizingBundle(String resourceName) {
this.localizingBundle = resourceName;
}
public synchronized void addPropertyChangeListener (PropertyChangeListener l) {
if (this.listeners == null)
this.listeners = new ArrayList<PropertyChangeListener>();
this.listeners.add (l);
}
public synchronized void removePropertyChangeListener (PropertyChangeListener l) {
if (this.listeners == null)
return;
this.listeners.remove (l);
}
public @Override String toString() {
return "DefaultLibraryImplementation[" + name + "]"; // NOI18N
}
private void firePropertyChange (String propName, Object oldValue, Object newValue) {
List<PropertyChangeListener> ls;
synchronized (this) {
if (this.listeners == null)
return;
ls = new ArrayList<PropertyChangeListener>(listeners);
}
PropertyChangeEvent event = new PropertyChangeEvent (this, propName, oldValue, newValue);
for (PropertyChangeListener l : ls) {
l.propertyChange(event);
}
}
}
|