package net.pterodactylus.jsite.core;
-import net.pterodactylus.jsite.project.Project;
+import java.util.EventListener;
/**
* Interface definition for user interfaces.
- *
+ *
* @author David ‘Bombe’ Roden <bombe@freenetproject.org>
*/
-public interface CoreListener {
+public interface CoreListener extends EventListener {
//
// project configuration
/**
* Notifies a listener that loading the projects finished successfully.
- *
+ *
* @param directory
* The directory the nodes were loaded from
*/
/**
* Notifies all listeners that loading the projects has failed.
- *
+ *
* @param directory
* The directory the projects were tried to load from
* @param throwable
/**
* Notifies a listener that the projects were successfully saved to the
* given directory.
- *
+ *
* @param directory
* The directory the projects were saved to
*/
/**
* Notifies a listener that saving the projects has failed.
- *
+ *
* @param directory
* The directory the projects were to be saved to
* @param throwable
/**
* Notifies a listener that the given project was added.
- *
+ *
* @param project
* The project that was added.
*/
public void projectAdded(Project project);
/**
+ * Notifies a listener that a project was cloned.
+ *
+ * @param clonedProject
+ * The clones project
+ * @param projectClone
+ * The clone of the project
+ */
+ public void projectCloned(Project clonedProject, Project projectClone);
+
+ /**
* Notifies a listener that the given project was removed.
- *
+ *
* @param project
* The project that was removed.
*/
/**
* Notifies a listener that the nodes were successfully loaded.
- *
+ *
* @param directory
* The directory the nodes were loaded from
*/
/**
* Notifies a listener that loading the nodes has failed.
- *
+ *
* @param directory
* The directory the nodes were loaded from
* @param throwable
/**
* Notifies a listener that the nodes were successfully saved.
- *
+ *
* @param directory
* The directory the nodes were saved to
*/
/**
* Notifies a listener that saving the nodes has failed.
- *
+ *
* @param directory
* The directory the nodes were saved to
* @param throwable
/**
* Notifies a listener that a node was added to the core.
- *
+ *
* @param node
* The node that was added.
*/
* Notifies a listener that a node was removed from the core. Before a node
* is removed, it will be disconnected (and
* {@link #nodeDisconnected(Node, Throwable)} will be called).
- *
+ *
* @param node
* The node that was removed
*/
* Notifies all listeners that the core started connecting to the given
* node. Before a node is connected, it will be added (and
* {@link #nodeAdded(Node)} will be called).
- *
+ *
* @param node
* The node that is being connected
*/
/**
* Notifies all listeners that the core connected to the given node.
- *
+ *
* @param node
* The node that is connected
*/
/**
* Notifies a listener that a connection to a node has failed.
- *
+ *
* @param node
* The node that could not be connected
* @param cause
/**
* Notifies all listeners that the core disconnected from the given node.
- *
+ *
* @param node
* The node that was diconnected
* @param throwable
/**
* Notifies a listener that a project insert started.
- *
+ *
* @param project
* The project that is now inserting
*/
/**
* Notifies a listener that a project insert made progress.
- *
+ *
* @param project
* The project that made progress
* @param totalBlocks
/**
* Notifies a listener that a project insert has generated a URI.
- *
+ *
* @param project
* The project that generated a URI
* @param uri
/**
* Notifies a listener that a project insert has finished.
- *
+ *
* @param project
* The project that has finished
* @param success