Fix dataloader with eclipse

This commit is contained in:
Melledy 2022-05-19 00:10:02 -07:00
parent bad853573c
commit 512021b234
2 changed files with 23 additions and 13 deletions

View File

@ -7,8 +7,10 @@ import emu.grasscutter.utils.FileUtils;
import emu.grasscutter.utils.Utils; import emu.grasscutter.utils.Utils;
import java.io.*; import java.io.*;
import java.nio.file.FileSystems;
import java.nio.file.Path; import java.nio.file.Path;
import java.util.List; import java.util.List;
import java.util.regex.Pattern;
import static emu.grasscutter.Configuration.DATA; import static emu.grasscutter.Configuration.DATA;
@ -46,17 +48,18 @@ public class DataLoader {
} }
public static void CheckAllFiles() { public static void CheckAllFiles() {
String pathSplitter = "defaults" + Pattern.quote(FileSystems.getDefault().getSeparator()) + "data" + Pattern.quote(FileSystems.getDefault().getSeparator());
try { try {
List<Path> filenames = FileUtils.getPathsFromResource("/defaults/data/"); List<Path> filenames = FileUtils.getPathsFromResource("/defaults/data/");
for (Path file : filenames) { for (Path file : filenames) {
String relativePath = String.valueOf(file).split("/defaults/data/")[1]; String relativePath = String.valueOf(file).split(pathSplitter)[1];
CheckAndCopyData(relativePath); CheckAndCopyData(relativePath);
} }
} catch (Exception e) { } catch (Exception e) {
Grasscutter.getLogger().error("An error occurred while trying to check the data folder. \n" + e); Grasscutter.getLogger().error("An error occurred while trying to check the data folder. \n", e);
} }
GenerateGachaMappings(); GenerateGachaMappings();

View File

@ -9,6 +9,7 @@ import java.net.URI;
import java.net.URISyntaxException; import java.net.URISyntaxException;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.nio.file.*; import java.nio.file.*;
import java.util.Arrays;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@ -76,21 +77,27 @@ public final class FileUtils {
// From https://mkyong.com/java/java-read-a-file-from-resources-folder/ // From https://mkyong.com/java/java-read-a-file-from-resources-folder/
public static List<Path> getPathsFromResource(String folder) throws URISyntaxException, IOException { public static List<Path> getPathsFromResource(String folder) throws URISyntaxException, IOException {
List<Path> result; List<Path> result = null;
// get path of the current running JAR // Get path of the current running JAR
String jarPath = Grasscutter.class.getProtectionDomain() String jarPath = Grasscutter.class.getProtectionDomain()
.getCodeSource() .getCodeSource()
.getLocation() .getLocation()
.toURI() .toURI()
.getPath(); .getPath();
// file walks JAR try {
URI uri = URI.create("jar:file:" + jarPath); // file walks JAR
try (FileSystem fs = FileSystems.newFileSystem(uri, Collections.emptyMap())) { URI uri = URI.create("jar:file:" + jarPath);
result = Files.walk(fs.getPath(folder)) try (FileSystem fs = FileSystems.newFileSystem(uri, Collections.emptyMap())) {
.filter(Files::isRegularFile) result = Files.walk(fs.getPath(folder))
.collect(Collectors.toList()); .filter(Files::isRegularFile)
.collect(Collectors.toList());
}
} catch (Exception e) {
// Eclipse puts resources in its bin folder
File f = new File(jarPath + "defaults/data/");
result = Arrays.stream(f.listFiles()).map(File::toPath).toList();
} }
return result; return result;