X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fnet%2Fpterodactylus%2Fjsite%2Fcore%2FNode.java;h=5a8ec89332037846a83879ad0104b8fde7114ef7;hb=464bd5d54b6b55a84dd7245f48164ec0a72cd49c;hp=2058d99850b5d80966188c410fcae1165c3520a1;hpb=d25f54965e42ad0ab1aedd1fdc3243c41731f718;p=jSite2.git diff --git a/src/net/pterodactylus/jsite/core/Node.java b/src/net/pterodactylus/jsite/core/Node.java index 2058d99..5a8ec89 100644 --- a/src/net/pterodactylus/jsite/core/Node.java +++ b/src/net/pterodactylus/jsite/core/Node.java @@ -19,25 +19,17 @@ package net.pterodactylus.jsite.core; -import java.beans.PropertyChangeEvent; import java.beans.PropertyChangeListener; -import java.util.ArrayList; -import java.util.Collections; -import java.util.List; -import net.pterodactylus.util.beans.Comparer; +import net.pterodactylus.util.beans.AbstractBean; /** * Container for a Freenet node. A Node is capable of notifying * {@link PropertyChangeListener}s if any of the contained properties change. * * @author David ‘Bombe’ Roden <bombe@freenetproject.org> - * @version $Id$ */ -public class Node { - - /** Property change listeners. */ - private final List propertyChangeListeners = Collections.synchronizedList(new ArrayList()); +public class Node extends AbstractBean { /** Name of the “name” property. */ public static final String PROPERTY_NAME = "name"; @@ -48,6 +40,9 @@ public class Node { /** Name of the “port” property. */ public static final String PROPERTY_PORT = "port"; + /** Internal ID. */ + private String id; + /** The name of the node. */ private String name; @@ -57,52 +52,25 @@ public class Node { /** The port number of the node. */ private int port; - // - // EVENT MANAGEMENT - // - - /** - * Adds a property change listener. - * - * @param propertyChangeListener - * The property change listener to add - */ - public void addPropertyChangeListener(PropertyChangeListener propertyChangeListener) { - propertyChangeListeners.add(propertyChangeListener); - } - /** - * Removes a property change listener. + * Returns the internal ID of the node. * - * @param propertyChangeListener - * The property change listener to remove + * @return The internal ID of the node */ - public void removePropertyChangeListener(PropertyChangeListener propertyChangeListener) { - propertyChangeListeners.remove(propertyChangeListener); + String getId() { + return id; } /** - * Notifies all listeners that a property has changed. + * Sets the internal ID of the node. * - * @param property - * The name of the property - * @param oldValue - * The old value of the property - * @param newValue - * The new value of the property + * @param id + * The internal ID of the node */ - private void firePropertyChange(String property, Object oldValue, Object newValue) { - PropertyChangeEvent propertyChangeEvent = new PropertyChangeEvent(this, property, oldValue, newValue); - for (PropertyChangeListener propertyChangeListener: propertyChangeListeners) { - propertyChangeListener.propertyChange(propertyChangeEvent); - } - + void setId(String id) { + this.id = id; } - // - // ACCESSORS - // - /** * Returns the user-given name of the node. * @@ -121,9 +89,7 @@ public class Node { public void setName(String name) { String oldName = this.name; this.name = name; - if (!Comparer.equal(oldName, name)) { - firePropertyChange(PROPERTY_NAME, oldName, name); - } + fireIfPropertyChanged(PROPERTY_NAME, oldName, name); } /** @@ -144,9 +110,7 @@ public class Node { public void setHostname(String hostname) { String oldHostname = this.hostname; this.hostname = hostname; - if (!Comparer.equal(oldHostname, hostname)) { - firePropertyChange(PROPERTY_HOSTNAME, oldHostname, hostname); - } + fireIfPropertyChanged(PROPERTY_HOSTNAME, oldHostname, hostname); } /** @@ -167,9 +131,7 @@ public class Node { public void setPort(int port) { int oldPort = this.port; this.port = port; - if (oldPort != port) { - firePropertyChange(PROPERTY_PORT, oldPort, port); - } + fireIfPropertyChanged(PROPERTY_PORT, oldPort, port); } /**