From ae48e8e2f95610a6ebc0f04a5390f05d47735812 Mon Sep 17 00:00:00 2001 From: Maksim Belov Date: Wed, 17 Jul 2024 22:53:53 +0300 Subject: [PATCH] Fix[gui_launcher]: general fixes - Re-add missing return - Add comment on why Java version is limited to 17 or below - Allow null javaArgs - Remove excessive logging --- .../pojavlaunch/JavaGUILauncherActivity.java | 17 +++++++---------- 1 file changed, 7 insertions(+), 10 deletions(-) diff --git a/app_pojavlauncher/src/main/java/net/kdt/pojavlaunch/JavaGUILauncherActivity.java b/app_pojavlauncher/src/main/java/net/kdt/pojavlaunch/JavaGUILauncherActivity.java index e09c7c1d72..9e7d99c97d 100644 --- a/app_pojavlauncher/src/main/java/net/kdt/pojavlaunch/JavaGUILauncherActivity.java +++ b/app_pojavlauncher/src/main/java/net/kdt/pojavlaunch/JavaGUILauncherActivity.java @@ -210,8 +210,10 @@ public Runtime selectRuntime(File modFile) { } Runtime selectedRuntime = MultiRTUtils.forceReread(nearestRuntime); int selectedJavaVersion = Math.max(javaVersion, selectedRuntime.javaVersion); + // Don't allow versions higher than Java 17 because our caciocavallo implementation does not allow for it if(selectedJavaVersion > 17) { finalErrorDialog(getString(R.string.execute_jar_incompatible_runtime, selectedJavaVersion)); + return null; } return selectedRuntime; } @@ -233,9 +235,9 @@ private File findModPath(List argList) { private void startModInstaller(File modFile, String javaArgs) { new Thread(() -> { // Maybe replace with more advanced arg parsing logic later - List argList = Arrays.asList(javaArgs.split(" ")); + List argList = javaArgs != null ? Arrays.asList(javaArgs.split(" ")) : null; File selectedMod = modFile; - if(selectedMod == null) { + if(selectedMod == null && argList != null) { // If modFile is not specified directly, try to extract the -jar argument from the javaArgs selectedMod = findModPath(argList); } @@ -356,8 +358,9 @@ public void launchJavaRuntime(Runtime runtime, File modFile, List javaAr // Enable Caciocavallo Tools.getCacioJavaArgs(javaArgList,runtime.javaVersion == 8); - - javaArgList.addAll(javaArgs); + if(javaArgs != null) { + javaArgList.addAll(javaArgs); + } if(modFile != null) { javaArgList.add("-jar"); javaArgList.add(modFile.getAbsolutePath()); @@ -397,30 +400,24 @@ public void performPaste(View view) { public int getJavaVersion(File modFile) { try (ZipFile zipFile = new ZipFile(modFile)){ ZipEntry manifest = zipFile.getEntry("META-INF/MANIFEST.MF"); - Log.i("JavaVersion", "Mf entry: "+manifest); if(manifest == null) return -1; - Log.i("JavaVersion", "Found manifest entry"); String manifestString = Tools.read(zipFile.getInputStream(manifest)); String mainClass = Tools.extractUntilCharacter(manifestString, "Main-Class:", '\n'); if(mainClass == null) return -1; - Log.i("JavaVersion", "Found main class: "+mainClass); mainClass = mainClass.trim().replace('.', '/') + ".class"; ZipEntry mainClassFile = zipFile.getEntry(mainClass); if(mainClassFile == null) return -1; - Log.i("JavaVersion", "Found main class entry: "+mainClass); InputStream classStream = zipFile.getInputStream(mainClassFile); byte[] bytesWeNeed = new byte[8]; int readCount = classStream.read(bytesWeNeed); classStream.close(); if(readCount < 8) return -1; - Log.i("JavaVersion", "File is long enough!"); ByteBuffer byteBuffer = ByteBuffer.wrap(bytesWeNeed); if(byteBuffer.getInt() != 0xCAFEBABE) return -1; - Log.i("JavaVersion", "File is Java class!"); short minorVersion = byteBuffer.getShort(); short majorVersion = byteBuffer.getShort(); Log.i("JavaGUILauncher", majorVersion+","+minorVersion);