fix Modpack::acceptFile (#1972)

* fix Modpack::acceptFile

* fix separator
This commit is contained in:
Glavo 2023-01-07 21:25:36 +08:00 committed by GitHub
parent 9e6d6ff95a
commit 3f0e8138b1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 7 additions and 16 deletions

View File

@ -25,6 +25,7 @@ import org.jackhuang.hmcl.Metadata;
import org.jackhuang.hmcl.download.LibraryAnalyzer; import org.jackhuang.hmcl.download.LibraryAnalyzer;
import org.jackhuang.hmcl.event.Event; import org.jackhuang.hmcl.event.Event;
import org.jackhuang.hmcl.event.EventManager; import org.jackhuang.hmcl.event.EventManager;
import org.jackhuang.hmcl.mod.ModAdviser;
import org.jackhuang.hmcl.mod.Modpack; import org.jackhuang.hmcl.mod.Modpack;
import org.jackhuang.hmcl.mod.ModpackConfiguration; import org.jackhuang.hmcl.mod.ModpackConfiguration;
import org.jackhuang.hmcl.mod.ModpackProvider; import org.jackhuang.hmcl.mod.ModpackProvider;
@ -172,17 +173,7 @@ public class HMCLGameRepository extends DefaultGameRepository {
File srcGameDir = getRunDirectory(srcId); File srcGameDir = getRunDirectory(srcId);
File dstGameDir = getRunDirectory(dstId); File dstGameDir = getRunDirectory(dstId);
List<String> blackList = new ArrayList<>(Arrays.asList( List<String> blackList = new ArrayList<>(ModAdviser.MODPACK_BLACK_LIST);
"regex:(.*?)\\.log",
"usernamecache.json", "usercache.json", // Minecraft
"launcher_profiles.json", "launcher.pack.lzma", // Minecraft Launcher
"backup", "pack.json", "launcher.jar", "cache", // HMCL
".curseclient", // Curse
".fabric", ".mixin.out", // Fabric
"jars", "logs", "versions", "assets", "libraries", "crash-reports", "NVIDIA", "AMD", "screenshots", "natives", "native", "$native", "server-resource-packs", // Minecraft
"downloads", // Curse
"asm", "backups", "TCNodeTracker", "CustomDISkins", "data", "CustomSkinLoader/caches" // Mods
));
blackList.add(srcId + ".jar"); blackList.add(srcId + ".jar");
blackList.add(srcId + ".json"); blackList.add(srcId + ".json");
if (!copySaves) if (!copySaves)

View File

@ -19,6 +19,7 @@ package org.jackhuang.hmcl.mod;
import org.jackhuang.hmcl.util.Lang; import org.jackhuang.hmcl.util.Lang;
import java.io.File;
import java.util.List; import java.util.List;
/** /**
@ -61,7 +62,7 @@ public interface ModAdviser {
"optionsof.txt" /* OptiFine */, "optionsof.txt" /* OptiFine */,
"journeymap" /* JourneyMap */, "journeymap" /* JourneyMap */,
"optionsshaders.txt", "optionsshaders.txt",
"mods/VoxelMods"); "mods" + File.separator + "VoxelMods");
static ModAdviser.ModSuggestion suggestMod(String fileName, boolean isDirectory) { static ModAdviser.ModSuggestion suggestMod(String fileName, boolean isDirectory) {
if (match(MODPACK_BLACK_LIST, fileName, isDirectory)) if (match(MODPACK_BLACK_LIST, fileName, isDirectory))
@ -75,7 +76,7 @@ public interface ModAdviser {
static boolean match(List<String> l, String fileName, boolean isDirectory) { static boolean match(List<String> l, String fileName, boolean isDirectory) {
for (String s : l) for (String s : l)
if (isDirectory) { if (isDirectory) {
if (fileName.startsWith(s + "/")) if (fileName.startsWith(s + File.separator))
return true; return true;
} else { } else {
if (s.startsWith("regex:")) { if (s.startsWith("regex:")) {

View File

@ -119,8 +119,7 @@ public abstract class Modpack {
public static boolean acceptFile(String path, List<String> blackList, List<String> whiteList) { public static boolean acceptFile(String path, List<String> blackList, List<String> whiteList) {
if (path.isEmpty()) if (path.isEmpty())
return true; return true;
for (String s : blackList) if (ModAdviser.match(blackList, path, false))
if (path.equals(s))
return false; return false;
if (whiteList == null || whiteList.isEmpty()) if (whiteList == null || whiteList.isEmpty())
return true; return true;