From a53a4abd442c99999bce3ce305b223af67949b22 Mon Sep 17 00:00:00 2001 From: =?utf8?q?David=20=E2=80=98Bombe=E2=80=99=20Roden?= Date: Sat, 3 May 2008 19:51:48 +0000 Subject: [PATCH] core interface git-svn-id: http://trooper/svn/projects/jSite/trunk@786 c3eda9e8-030b-0410-8277-bc7414b0a119 --- src/net/pterodactylus/jsite/core/Core.java | 83 ++++++++++++++++++++++++++++++ 1 file changed, 83 insertions(+) create mode 100644 src/net/pterodactylus/jsite/core/Core.java diff --git a/src/net/pterodactylus/jsite/core/Core.java b/src/net/pterodactylus/jsite/core/Core.java new file mode 100644 index 0000000..e6cad12 --- /dev/null +++ b/src/net/pterodactylus/jsite/core/Core.java @@ -0,0 +1,83 @@ +/* + * jSite2 - Core.java - + * Copyright © 2008 David Roden + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + */ + +package net.pterodactylus.jsite.core; + +import java.util.List; + +/** + * Interface for the core. + * + * @author David ‘Bombe’ Roden <bombe@freenetproject.org> + * @version $Id$ + */ +public interface Core { + + /** + * Adds the given listener to the list of registered listeners. + * + * @param coreListener + * The listener to add + */ + public void addCoreListener(CoreListener coreListener); + + /** + * Removes the given listener from the list of registered listeners. + * + * @param coreListener + * The listener to remove + */ + public void removeCoreListener(CoreListener coreListener); + + /** + * Returns the list of all configured nodes. + * + * @return All configured nodes + */ + public List getNodes(); + + /** + * Returns whether the core is currently connected to the given node. + * + * @param node + * The node to check + * @return true if the core is currently connected to the + * node, false otherwise + */ + public boolean isNodeConnected(Node node); + + /** + * Starts the core. + */ + public void start(); + + /** + * Stops the core. + */ + public void stop(); + + /** + * Connects to the given node. + * + * @param node + * The node to connect to + */ + public void connectToNode(Node node); + +} \ No newline at end of file -- 2.7.4