From 4cd1e5485b76be039248f257a2578fc9911d5aa0 Mon Sep 17 00:00:00 2001 From: Michael Hillcox Date: Sat, 3 Aug 2024 16:01:04 +0100 Subject: [PATCH] fix: only de-duplicate libraries on modern neoforge --- .../pack/InstanceLauncher.java | 29 +++++++++++++++++-- 1 file changed, 26 insertions(+), 3 deletions(-) diff --git a/subprocess/src/main/java/net/creeperhost/creeperlauncher/pack/InstanceLauncher.java b/subprocess/src/main/java/net/creeperhost/creeperlauncher/pack/InstanceLauncher.java index 4d25a0ad..7c24febe 100644 --- a/subprocess/src/main/java/net/creeperhost/creeperlauncher/pack/InstanceLauncher.java +++ b/subprocess/src/main/java/net/creeperhost/creeperlauncher/pack/InstanceLauncher.java @@ -695,18 +695,41 @@ private List collectLibraries(Set features) { .collect(Collectors.toList()); } - private List collectClasspath(Path librariesDir, Path versionsDir, List libraries) { + private List collectClasspath(Path librariesDir, Path versionsDir, List libraries) { List classpath = createUniqueLibraryList(libraries).stream() .filter(e -> e.natives == null) .map(e -> e.name.toPath(librariesDir)) .collect(Collectors.toList()); - classpath.add(getGameJar(versionsDir)); + classpath.add(getGameJar(versionsDir)); return classpath; } - // TODO: Make this less jank + private boolean isModernNeoForge() { + var neoId = manifests.stream() + .map(e -> e.id) + .filter(e -> e.contains("neoforge")) + .findFirst(); + + if (neoId.isEmpty()) { + return false; + } + + var parted = neoId.get().split("-"); + if (parted.length < 2) { + return false; + } + + // Modern neo is any version higher than 20.1, this is a safe enough check as it's never going to start with 20.1 if it's higher. + var version = parted[1]; + return !version.startsWith("20.1"); + } + private List createUniqueLibraryList(List libraries) { + if (!isModernNeoForge()) { + return libraries; + } + // Deduplicate libraries List uniqueLibraries = new ArrayList<>(); Set seen = new HashSet<>();