Conditionally add DH import command

This commit is contained in:
mcrcortex
2025-04-18 20:51:54 +10:00
parent 432d078212
commit 3b2614631d
3 changed files with 43 additions and 26 deletions

View File

@@ -211,8 +211,13 @@ dependencies {
include(implementation 'org.apache.commons:commons-pool2:2.12.0')
include(implementation 'org.lz4:lz4-java:1.8.0')
compileOnly('org.tukaani:xz:1.10')
if (true) {
minecraftRuntimeLibraries('org.tukaani:xz:1.10')
minecraftRuntimeLibraries('org.xerial:sqlite-jdbc:3.49.1.0')
} else {
include(implementation('org.tukaani:xz:1.10'))
include(implementation('org.xerial:sqlite-jdbc:3.49.1.0'))
}
//implementation 'org.rocksdb:rocksdbjni:8.10.0'
//implementation 'redis.clients:jedis:5.1.0'
}

View File

@@ -25,10 +25,7 @@ import java.util.concurrent.CompletableFuture;
public class VoxyCommands {
public static LiteralArgumentBuilder<FabricClientCommandSource> register() {
return ClientCommandManager.literal("voxy").requires((ctx)-> VoxyCommon.getInstance() != null)
.then(ClientCommandManager.literal("reload")
.executes(VoxyCommands::reloadInstance))
.then(ClientCommandManager.literal("import")
var imports = ClientCommandManager.literal("import")
.then(ClientCommandManager.literal("world")
.then(ClientCommandManager.argument("world_name", StringArgumentType.string())
.suggests(VoxyCommands::importWorldSuggester)
@@ -45,12 +42,20 @@ public class VoxyCommands {
.executes(VoxyCommands::importZip)
.then(ClientCommandManager.argument("innerPath", StringArgumentType.string())
.executes(VoxyCommands::importZip))))
.then(ClientCommandManager.literal("cancel")
.executes(VoxyCommands::cancelImport));
if (DHImporter.HasRequiredLibraries) {
imports = imports
.then(ClientCommandManager.literal("distant_horizons")
.then(ClientCommandManager.argument("sqlDbPath", StringArgumentType.string())
.executes(VoxyCommands::importDistantHorizons)))
.then(ClientCommandManager.literal("cancel")
.executes(VoxyCommands::cancelImport))
);
.executes(VoxyCommands::importDistantHorizons)));
}
return ClientCommandManager.literal("voxy").requires((ctx)-> VoxyCommon.getInstance() != null)
.then(ClientCommandManager.literal("reload")
.executes(VoxyCommands::reloadInstance))
.then(imports);
}
private static int reloadInstance(CommandContext<FabricClientCommandSource> ctx) {

View File

@@ -376,13 +376,20 @@ public class DHImporter implements IDataImporter {
private static VarHandle create(Class<?> viewArrayClass) {
return MethodHandles.byteArrayViewVarHandle(viewArrayClass, ByteOrder.BIG_ENDIAN);
}
public static final boolean HasRequiredLibraries;
private static final VarHandle LONG = create(long[].class);
static {
boolean hasJDBC = false;
try {
Class.forName("org.sqlite.JDBC");
hasJDBC = true;
} catch (ClassNotFoundException e) {
throw new RuntimeException(e);
//throw new RuntimeException(e);
Logger.error("Unable to load sqlite JDBC, DHImporting wont be available", e);
}
HasRequiredLibraries = hasJDBC;
}
}