forked from External/mage
* fixed https://sonarcloud.io/project/issues?id=org.xmage%3Amage-root&issues=AWIlv32RgrzAwlaaQ7rP&open=AWIlv32RgrzAwlaaQ7rP * ensure closing of scanner if it was opened * Refactored method in EmpyrialArchAngel to not always return same value. * Refactored method in FalkenrathAristocrat to not always return same value. * Refactored method in GilderBairn to not always return the same value. * fixed left open resources, ensured quiet closing of the streams * Refactored method in IceCave to not always return same value. * Refactored method in KjeldoranRoyalGuard to not always return same value. * Refactored method in LegionsInitiative to not always return same value. * Refactored method in NaturesWill to not always return same value. * added quiet closing method in new streamutils class, used to clean up the connectdialog * Fix small typo * added quiet closing to saveobjectutil * closed resources in savegame method of gamecontroller * properly close resources in loadGame method of GameReplay class * further proper resource closing in ServerMessagesUtil * fixed unclosed resources in copy method in mage framework Copier * closed unclosed resources in copyCompressed method in Copier * ensure closing of filewriter in manasymbols * ensure proper closing of Stream in arcane UI * ensure closing of datagram socket in arcane Util * ensure resource closing in deckimport from clipboard * ensure closing of plugin classloader * ensured closing of zipinputstream resource * ensure closing of fileoutputstream in ScryfallSymbolsSource * ensure closing resources after finishing/canceling download of pictures * remove commented code * move locks to try block to ensure unlocking along all execution paths * remove dangerous instance of double-checked locking * removed dangerous instance of double checked locking in settingsmanager * Removed dangerous instance of double-checked locking in ThemePluginImpl * close resource which did not happen certainly * close another stream * ensure closing of inputstream
75 lines
3.5 KiB
Java
75 lines
3.5 KiB
Java
/*
|
|
* Copyright 2016 Lymia <lymia@lymiahugs.com>. All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without modification, are
|
|
* permitted provided that the following conditions are met:
|
|
*
|
|
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
|
* conditions and the following disclaimer.
|
|
*
|
|
* 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
|
* of conditions and the following disclaimer in the documentation and/or other materials
|
|
* provided with the distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
|
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
|
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
|
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
* The views and conclusions contained in the software and documentation are those of the
|
|
* authors and should not be interpreted as representing official policies, either expressed
|
|
* or implied, of BetaSteward_at_googlemail.com.
|
|
*/
|
|
|
|
package mage.server;
|
|
|
|
import mage.server.util.PluginClassLoader;
|
|
import mage.util.StreamUtils;
|
|
|
|
import java.io.File;
|
|
import java.io.IOException;
|
|
import java.util.Scanner;
|
|
|
|
/**
|
|
* @author Lymia
|
|
*/
|
|
public final class ExtensionPackageLoader {
|
|
public static ExtensionPackage loadExtension(File directory) throws IOException {
|
|
if(!directory.exists ()) throw new RuntimeException("File not found "+directory);
|
|
if(!directory.isDirectory()) throw new RuntimeException(directory+" is not a directory");
|
|
|
|
File entryPointFile = new File(directory, "entryPoint");
|
|
if(!entryPointFile.exists() || !entryPointFile.isFile())
|
|
throw new RuntimeException("Entry point definition not found.");
|
|
|
|
File packagesDirectory = new File(directory, "packages");
|
|
if(!packagesDirectory.exists() || !packagesDirectory.isDirectory())
|
|
throw new RuntimeException("Packages directory not found.");
|
|
|
|
Scanner entryPointReader = new Scanner(entryPointFile);
|
|
String entryPoint = entryPointReader.nextLine().trim();
|
|
entryPointReader.close();
|
|
|
|
PluginClassLoader classLoader = null;
|
|
try {
|
|
classLoader = new PluginClassLoader();
|
|
for(File f : packagesDirectory.listFiles()) {
|
|
classLoader.addURL(f.toURI().toURL());
|
|
}
|
|
return (ExtensionPackage) Class.forName(entryPoint, false, classLoader).newInstance();
|
|
} catch (InstantiationException | IllegalAccessException e) {
|
|
throw new RuntimeException(e);
|
|
} catch (ClassNotFoundException e) {
|
|
throw new RuntimeException("Entry point class not found!", e);
|
|
} catch (ClassCastException e) {
|
|
throw new RuntimeException("Entry point not an instance of ExtensionPackage.", e);
|
|
} finally {
|
|
StreamUtils.closeQuietly(classLoader);
|
|
}
|
|
}
|
|
}
|