/* * CraftBook Copyright (C) 2010-2017 sk89q <http://www.sk89q.com> * CraftBook Copyright (C) 2011-2017 me4502 <http://www.me4502.com> * CraftBook Copyright (C) Contributors * * 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 3 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, * see <http://www.gnu.org/licenses/>. */ package com.sk89q.craftbook.core; import com.sk89q.craftbook.core.st.SelfTriggerManager; import org.slf4j.Logger; import java.io.File; import java.util.Optional; /** * The core class for all implementations of the CraftBook Core. */ public abstract class CraftBookAPI { private static CraftBookAPI instance; /** * Gets the current instance of the plugin. * * @param <T> The base plugin type. * @return The instance */ @SuppressWarnings("unchecked") public static <T extends CraftBookAPI> T inst() { return (T) instance; } public static <T extends CraftBookAPI> void setInstance(T api) { instance = api; } /** * Called to discover available mechanics. */ public abstract void discoverMechanics(); /** * Gets the {@link SelfTriggerManager}. * * @return The SelfTriggerManager. */ public abstract Optional<SelfTriggerManager> getSelfTriggerManager(); /** * Gets the working directory of CraftBook. * * @return The working directory */ public abstract File getWorkingDirectory(); /** * Gets the logger. * * @return The logger */ public abstract Logger getLogger(); /** * Gets the version as a string. This should be identifiable * with build information. * * @return The version string */ public abstract String getVersionString(); }