ViaLoader/src/main/java/net/raphimc/vialoader/ViaLoader.java

80 lines
3.3 KiB
Java

/*
* This file is part of ViaLoader - https://github.com/RaphiMC/ViaLoader
* Copyright (C) 2020-2024 RK_01/RaphiMC and 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 net.raphimc.vialoader;
import com.viaversion.viaversion.ViaManagerImpl;
import com.viaversion.viaversion.api.Via;
import com.viaversion.viaversion.api.platform.ViaInjector;
import com.viaversion.viaversion.api.platform.ViaPlatform;
import com.viaversion.viaversion.api.platform.ViaPlatformLoader;
import com.viaversion.viaversion.commands.ViaCommandHandler;
import com.viaversion.viaversion.protocol.ProtocolManagerImpl;
import net.raphimc.vialoader.impl.platform.ViaVersionPlatformImpl;
import net.raphimc.vialoader.impl.viaversion.VLCommandHandler;
import net.raphimc.vialoader.impl.viaversion.VLInjector;
import net.raphimc.vialoader.impl.viaversion.VLLoader;
import net.raphimc.vialoader.util.JLoggerToSLF4J;
import org.slf4j.LoggerFactory;
import java.util.function.Supplier;
import java.util.logging.Level;
import java.util.logging.Logger;
public class ViaLoader {
public static final String VERSION = "${version}";
private static final Logger LOGGER = new JLoggerToSLF4J(LoggerFactory.getLogger("ViaLoader"));
@SuppressWarnings("ReassignedVariable")
public static void init(ViaPlatform<?> platform, ViaPlatformLoader loader, ViaInjector injector, ViaCommandHandler commandHandler, final Supplier<?>... platformSuppliers) {
if (platform == null) platform = new ViaVersionPlatformImpl(null);
if (loader == null) loader = new VLLoader();
if (injector == null) injector = new VLInjector();
if (commandHandler == null) commandHandler = new VLCommandHandler();
Via.init(ViaManagerImpl.builder()
.platform(platform)
.loader(loader)
.injector(injector)
.commandHandler(commandHandler)
.build());
if (platformSuppliers != null) {
Via.getManager().addEnableListener(() -> {
for (Supplier<?> additionalPlatformSupplier : platformSuppliers) {
try {
additionalPlatformSupplier.get();
} catch (Throwable e) {
LOGGER.log(Level.SEVERE, "Platform failed to load", e);
}
}
});
}
final ViaManagerImpl viaManager = (ViaManagerImpl) Via.getManager();
viaManager.init();
viaManager.onServerLoaded();
Via.getManager().getProtocolManager().setMaxProtocolPathSize(Integer.MAX_VALUE);
Via.getManager().getProtocolManager().setMaxPathDeltaIncrease(-1);
((ProtocolManagerImpl) Via.getManager().getProtocolManager()).refreshVersions();
}
}