diff options
author | cflip <cflip@cflip.net> | 2023-08-24 08:44:43 -0600 |
---|---|---|
committer | cflip <cflip@cflip.net> | 2023-08-24 08:44:54 -0600 |
commit | 5a7d6a1d7efb249fe3360330704e8ae647ae3a8f (patch) | |
tree | a00e1965cc5a9788e4229c9ee87f736bc5b6bc71 /src/net/minecraft/MinecraftLauncher.java |
Import decompiled source from 2010 launcher jar
Diffstat (limited to 'src/net/minecraft/MinecraftLauncher.java')
-rw-r--r-- | src/net/minecraft/MinecraftLauncher.java | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/src/net/minecraft/MinecraftLauncher.java b/src/net/minecraft/MinecraftLauncher.java new file mode 100644 index 0000000..14d2e5f --- /dev/null +++ b/src/net/minecraft/MinecraftLauncher.java @@ -0,0 +1,40 @@ +package net.minecraft; + +import java.util.ArrayList; + +public class MinecraftLauncher { + private static final int MIN_HEAP = 511; + private static final int RECOMMENDED_HEAP = 1024; + + public static void main(String[] args) throws Exception { + float heapSizeMegs = (float) (Runtime.getRuntime().maxMemory() / 1024L / 1024L); + + if (heapSizeMegs > 511.0F) { + LauncherFrame.main(args); + } else { + try { + String pathToJar = MinecraftLauncher.class.getProtectionDomain().getCodeSource().getLocation().toURI().getPath(); + + ArrayList<String> params = new ArrayList<String>(); + + params.add("javaw"); + params.add("-Xmx1024m"); + params.add("-Dsun.java2d.noddraw=true"); + params.add("-Dsun.java2d.d3d=false"); + params.add("-Dsun.java2d.opengl=false"); + params.add("-Dsun.java2d.pmoffscreen=false"); + + params.add("-classpath"); + params.add(pathToJar); + params.add("net.minecraft.LauncherFrame"); + ProcessBuilder pb = new ProcessBuilder(params); + Process process = pb.start(); + if (process == null) throw new Exception("!"); + System.exit(0); + } catch (Exception e) { + e.printStackTrace(); + LauncherFrame.main(args); + } + } + } +} |