Skip to content

Commit 3c20243

Browse files
committed
basically done :D
1 parent 321ac49 commit 3c20243

File tree

8 files changed

+69
-60
lines changed

8 files changed

+69
-60
lines changed

build.gradle

+5-11
Original file line numberDiff line numberDiff line change
@@ -1,21 +1,20 @@
11
plugins {
22
id 'java'
3-
id 'maven-publish'
43
id "com.github.johnrengelman.shadow" version "7.0.0"
54
id "de.undercouch.download" version "4.1.2"
65
}
76

7+
sourceCompatibility = JavaVersion.VERSION_1_8
8+
targetCompatibility = JavaVersion.VERSION_1_8
9+
810
group = 'com.nexia'
9-
version = '1.0-SNAPSHOT'
11+
version = '1.0.0'
1012

1113
repositories {
1214
mavenCentral()
1315
}
1416

1517
dependencies {
16-
testImplementation platform('org.junit:junit-bom:5.9.1')
17-
testImplementation 'org.junit.jupiter:junit-jupiter'
18-
1918
implementation ('org.sharegov:mjson:1.4.1') {
2019
transitive false
2120
}
@@ -33,9 +32,4 @@ shadowJar {
3332
exclude('icon.ico')
3433
}
3534

36-
build.dependsOn shadowJar
37-
test {
38-
useJUnitPlatform()
39-
}
40-
sourceCompatibility = JavaVersion.VERSION_11
41-
targetCompatibility = JavaVersion.VERSION_11
35+
build.dependsOn shadowJar

src/main/java/com/nexia/installer/InstallerGUI.java

+2-3
Original file line numberDiff line numberDiff line change
@@ -11,9 +11,8 @@
1111
public class InstallerGUI extends JFrame {
1212
public static InstallerGUI instance;
1313

14-
private InstallerHelper helper = new InstallerHelper();
15-
1614
public InstallerGUI() {
15+
InstallerHelper helper = new InstallerHelper();
1716
JPanel panel = helper.setPanel(this);
1817

1918
setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
@@ -46,7 +45,7 @@ public static void load() throws UnsupportedLookAndFeelException, ClassNotFoundE
4645
InstallerGUI gui = new InstallerGUI();
4746
gui.updateSize(true);
4847
gui.setTitle(Main.BUNDLE.getString("installer.title"));
49-
gui.setIconImage(Toolkit.getDefaultToolkit().getImage(ClassLoader.getSystemClassLoader().getResource("icon.png")));
48+
gui.setIconImage(Main.icon);
5049
gui.setLocationRelativeTo(null);
5150
gui.setVisible(true);
5251
}

src/main/java/com/nexia/installer/Main.java

+4
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,7 @@
11
package com.nexia.installer;
22

33
import javax.swing.*;
4+
import java.awt.*;
45
import java.io.IOException;
56
import java.io.InputStream;
67
import java.io.InputStreamReader;
@@ -13,6 +14,8 @@ public class Main {
1314

1415
public static OS os = null;
1516

17+
public static Image icon;
18+
1619
public static final ResourceBundle BUNDLE = ResourceBundle.getBundle("lang/installer", Locale.getDefault(), new ResourceBundle.Control() {
1720
@Override
1821
public ResourceBundle newBundle(String baseName, Locale locale, String format, ClassLoader loader, boolean reload) throws IllegalAccessException, InstantiationException, IOException {
@@ -44,6 +47,7 @@ public static void main(String[] args) throws UnsupportedLookAndFeelException, C
4447
if(System.getProperty("os.name").startsWith("mac"))
4548
os = OS.MAC;
4649

50+
icon = Toolkit.getDefaultToolkit().getImage(ClassLoader.getSystemClassLoader().getResource("icon.png"));
4751
InstallerGUI.load();
4852
}
4953

src/main/java/com/nexia/installer/game/VersionHandler.java

+16-3
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,28 @@
11
package com.nexia.installer.game;
2+
23
import java.util.ArrayList;
34
import java.util.List;
45

56
public class VersionHandler {
67
public static List<GameVersion> versions = new ArrayList<>();
78

8-
public static GameVersion CombatTest8c = new GameVersion("Combat Test 8c", "1.16_combat-6", new Download("9879e6ba375eda28ab8fc3b83ca9febe5c11d54b", (long) 7.463, "https://www.rizecookey.net/dl/file/combat-test-patched/1_16_combat-6.zip"));
9+
public static GameVersion CombatTest8c = new GameVersion("Combat Test 8c", "1.16_combat-6", new Download("f76157734ee0611fbef7d636156f20fa67c34514", 7463, "https://www.rizecookey.net/dl/file/combat-test-patched/1_16_combat-6.zip"));
10+
11+
public static GameVersion CombatTest8b = new GameVersion("Combat Test 8b", "1.16_combat-5", new Download("9b2b984d635d373564b50803807225c75d7fd447", 7044, "https://launcher.mojang.com/experiments/combat/9b2b984d635d373564b50803807225c75d7fd447/1_16_combat-5.zip"));
12+
13+
public static GameVersion CombatTest8 = new GameVersion("Combat Test 8", "1.16_combat-4", new Download("b4306b421183bd084b2831bd8d33a5db05ae9f9c", 7046, "https://cdn.discordapp.com/attachments/369990015096455168/947864881028272198/1_16_combat-4.zip"));
14+
15+
public static GameVersion CombatTest7c = new GameVersion("Combat Test 7c", "1.16_combat-3", new Download("2557b99d95588505e988886220779087d7d6b1e9", 7049, "https://piston-data.mojang.com/experiments/combat/2557b99d95588505e988886220779087d7d6b1e9/1_16_combat-3.zip"));
916

10-
public static GameVersion CombatTest8b = new GameVersion("Combat Test 8b", "1.16_combat-5", new Download("05b81ee7c117524580c477900277c316d3436e94", (long) 7.044, "https://launcher.mojang.com/experiments/combat/9b2b984d635d373564b50803807225c75d7fd447/1_16_combat-5.zip"));
17+
public static GameVersion CombatTest7b = new GameVersion("Combat Test 7b", "1.16_combat-2", new Download("43266ea8f2c20601d9fb264d5aa85df8052abc9e", 7051, "https://archive.org/download/Combat_Test_7ab/1_16_combat-2.zip"));
18+
public static GameVersion CombatTest7 = new GameVersion("Combat Test 7", "1.16_combat-1", new Download("47bb5be6cb3ba215539ee97dfae66724c73c3dd5", 7045, "https://archive.org/download/Combat_Test_7ab/1_16_combat-1.zip"));
1119

12-
public static GameVersion CombatTest8 = new GameVersion("Combat Test 8", "1.16_combat-4", new Download("d8d9dd198d0a46435c3d1eac75633a387392d793", (long) 7.046, "https://cdn.discordapp.com/attachments/369990015096455168/947864881028272198/1_16_combat-4.zip"));
20+
public static GameVersion CombatTest6 = new GameVersion("Combat Test 6", "1.16_combat-0", new Download("5a8ceec8681ed96ab6ecb9607fb5d19c8a755559", 7049, "https://piston-data.mojang.com/experiments/combat/5a8ceec8681ed96ab6ecb9607fb5d19c8a755559/1_16_combat-0.zip"));
21+
public static GameVersion CombatTest5 = new GameVersion("Combat Test 5", "1.15_combat-6", new Download("52263d42a626b40c947e523128f7a195ec5af76a", 7061, "https://piston-data.mojang.com/experiments/combat/52263d42a626b40c947e523128f7a195ec5af76a/1_15_combat-6.zip"));
22+
public static GameVersion CombatTest4 = new GameVersion("Combat Test 4", "1.15_combat-1", new Download("ac11ea96f3bb2fa2b9b76ab1d20cacb1b1f7ef60", 7059, "https://piston-data.mojang.com/experiments/combat/ac11ea96f3bb2fa2b9b76ab1d20cacb1b1f7ef60/1_15_combat-1.zip"));
23+
public static GameVersion CombatTest3 = new GameVersion("Combat Test 3", "1.14_combat-3", new Download("0f209c9c84b81c7d4c88b4632155b9ae550beb89", 6433, "https://piston-data.mojang.com/experiments/combat/0f209c9c84b81c7d4c88b4632155b9ae550beb89/1_14_combat-3.zip"));
24+
public static GameVersion CombatTest2 = new GameVersion("Combat Test 2", "1.14_combat-0", new Download("d164bb6ecc5fca9ac02878c85f11befae61ac1ca", 6287, "https://piston-data.mojang.com/experiments/combat/d164bb6ecc5fca9ac02878c85f11befae61ac1ca/1_14_combat-0.zip"));
25+
public static GameVersion CombatTest1 = new GameVersion("1.14.3 - Combat Test", "1.14_combat-212796", new Download("610f5c9874ba8926d5ae1bcce647e5f0e6e7c889",4843, "https://piston-data.mojang.com/experiments/combat/610f5c9874ba8926d5ae1bcce647e5f0e6e7c889/1_14_combat-212796.zip"));
1326

1427
public static class GameVersion {
1528
String version;

src/main/java/com/nexia/installer/util/InstallerUtils.java

+37-11
Original file line numberDiff line numberDiff line change
@@ -4,18 +4,17 @@
44
import com.nexia.installer.game.VersionHandler;
55

66
import javax.swing.*;
7+
import java.awt.*;
78
import java.io.File;
9+
import java.io.IOException;
810
import java.net.URI;
11+
import java.net.URISyntaxException;
912
import java.nio.file.Files;
1013
import java.nio.file.Path;
1114
import java.nio.file.Paths;
1215
import java.nio.file.StandardCopyOption;
13-
import java.nio.file.attribute.FileAttribute;
14-
import java.nio.file.attribute.FileAttributeView;
15-
import java.nio.file.attribute.PosixFilePermission;
16-
import java.nio.file.attribute.PosixFilePermissions;
16+
import java.text.MessageFormat;
1717
import java.util.List;
18-
import java.util.Set;
1918

2019
public class InstallerUtils {
2120
public static Path findDefaultInstallDir() {
@@ -73,20 +72,31 @@ public static void install(Path mcDir, VersionHandler.GameVersion gameVersion) {
7372

7473
String alternativeCodeName = gameVersion.getCodeName().replaceAll("\\.", "_");
7574

75+
System.out.println("Installing " + gameVersion.getVersion() + " (" + gameVersion.getCodeName() + ")");
76+
7677
Path versionsDir = mcDir.resolve("versions");
77-
Path profileDir = versionsDir.resolve(alternativeCodeName);
78-
Path profileJson = profileDir.resolve(alternativeCodeName + ".json");
78+
Path profileDir = versionsDir.resolve(gameVersion.getCodeName());
79+
Path profileJson = profileDir.resolve(gameVersion.getCodeName() + ".json");
7980

80-
if (!Files.exists(profileDir)) {
81-
Files.createDirectory(profileDir);
82-
Files.createFile(profileJson);
83-
}
81+
Path aProfileDir = versionsDir.resolve(alternativeCodeName);
82+
Path aProfileJson = aProfileDir.resolve(alternativeCodeName + ".json");
83+
84+
if(!Files.exists(profileDir)) Files.createDirectory(profileDir);
85+
if(!Files.exists(profileJson)) Files.createFile(profileJson);
86+
87+
if(!Files.exists(aProfileDir)) Files.createDirectory(aProfileDir);
88+
if(!Files.exists(aProfileJson)) Files.createFile(aProfileJson);
8489

8590
File zipFile = new File(versionsDir + "/" + gameVersion.getCodeName() + ".zip");
8691

8792
Utils.downloadFile(URI.create(gameVersion.getDownload().url).toURL(), zipFile.toPath());
8893
Utils.extractZip(zipFile.toPath(), versionsDir);
8994

95+
Files.copy(aProfileJson, profileJson, StandardCopyOption.REPLACE_EXISTING);
96+
97+
98+
aProfileJson.toFile().delete();
99+
aProfileDir.toFile().delete();
90100
zipFile.delete();
91101

92102
if (InstallerHelper.createProfile.isSelected()) {
@@ -96,6 +106,7 @@ public static void install(Path mcDir, VersionHandler.GameVersion gameVersion) {
96106

97107
profileInstaller.setupProfile(gameVersion.getCodeName(), gameVersion.getVersion(), launcherType);
98108
}
109+
showDone(gameVersion);
99110
} catch (Exception e) {
100111
e.printStackTrace();
101112
} finally {
@@ -123,4 +134,19 @@ private static ProfileInstaller.LauncherType showLauncherTypeSelection() {
123134

124135
return result == JOptionPane.YES_OPTION ? ProfileInstaller.LauncherType.MICROSOFT_STORE : ProfileInstaller.LauncherType.WIN32;
125136
}
137+
138+
private static void showDone(VersionHandler.GameVersion gameVersion) throws URISyntaxException, IOException {
139+
Object[] options = {"OK", "Install Fabric"};
140+
int result = JOptionPane.showOptionDialog(null,
141+
MessageFormat.format(Main.BUNDLE.getString("installer.prompt.install.done"), gameVersion.getVersion()),
142+
Main.BUNDLE.getString("installer.title"),
143+
JOptionPane.YES_NO_OPTION,
144+
JOptionPane.INFORMATION_MESSAGE,
145+
null,
146+
options,
147+
options[0]
148+
);
149+
150+
if(result == JOptionPane.NO_OPTION && Desktop.isDesktopSupported() && Desktop.getDesktop().isSupported(Desktop.Action.BROWSE)) Desktop.getDesktop().browse(new URI("https://github.com/rizecookey/fabric-installer/releases"));
151+
}
126152
}

src/main/java/com/nexia/installer/util/ProfileInstaller.java

+3-5
Original file line numberDiff line numberDiff line change
@@ -58,16 +58,14 @@ public void setupProfile(String name, String gameVersion, LauncherType launcherT
5858
jsonObject.set("profiles", profiles);
5959
}
6060

61-
String profileName = "pending " + name;
62-
63-
Json profile = profiles.at(profileName);
61+
Json profile = profiles.at(name);
6462

6563
if (profile == null) {
6664
profile = createProfile(gameVersion);
67-
profiles.set(profileName, profile);
65+
profiles.set(name, profile);
6866
}
6967

70-
profile.set("lastVersionId", profileName);
68+
profile.set("lastVersionId", name);
7169

7270
Utils.writeToFile(launcherProfiles, jsonObject.toString());
7371
}

src/main/java/com/nexia/installer/util/Utils.java

+1-27
Original file line numberDiff line numberDiff line change
@@ -20,13 +20,8 @@
2020
public class Utils {
2121

2222
public static final DateFormat ISO_8601 = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ssZ");
23-
public static String readString(URL url) throws IOException {
24-
try (InputStream is = openUrl(url)) {
25-
return readString(is);
26-
}
27-
}
2823

29-
public static File extractZip(Path file, Path path) throws IOException {
24+
public static void extractZip(Path file, Path path) throws IOException {
3025
ZipInputStream zipIn = new ZipInputStream(Files.newInputStream(Paths.get(file.toString())));
3126
ZipEntry entry = zipIn.getNextEntry();
3227
String filePath = "";
@@ -50,33 +45,12 @@ public static File extractZip(Path file, Path path) throws IOException {
5045
entry = zipIn.getNextEntry();
5146
}
5247
zipIn.close();
53-
return new File(filePath);
5448
}
5549

5650
public static String readString(Path path) throws IOException {
5751
return new String(Files.readAllBytes(path), StandardCharsets.UTF_8);
5852
}
5953

60-
public static String readString(InputStream is) throws IOException {
61-
byte[] data = new byte[Math.max(1000, is.available())];
62-
int offset = 0;
63-
int len;
64-
65-
while ((len = is.read(data, offset, data.length - offset)) >= 0) {
66-
offset += len;
67-
68-
if (offset == data.length) {
69-
int next = is.read();
70-
if (next < 0) break;
71-
72-
data = Arrays.copyOf(data, data.length * 2);
73-
data[offset++] = (byte) next;
74-
}
75-
}
76-
77-
return new String(data, 0, offset, StandardCharsets.UTF_8);
78-
}
79-
8054
public static void writeToFile(Path path, String string) throws IOException {
8155
Files.write(path, string.getBytes(StandardCharsets.UTF_8));
8256
}

src/main/resources/lang/installer.properties

+1
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,7 @@
11
installer.prompt.game.version=Minecraft Version:
22
installer.prompt.select.location=Select Install Location:
33
installer.button.install=Install
4+
installer.prompt.install.done={0} has been installed, if you want to install fabric then click on the "Install Fabric" button.
45
installer.exception.no.launcher.directory=No launcher directory found!
56
installer.prompt.launcher.type.body=The Combat Test Installer has detected 2 different installations of the Minecraft Launcher, which launcher do you wish to install Fabric to?\n\n- Select Microsoft Store if you are playing Minecraft through the Xbox App or the Windows Store.\n- Select Standalone if you downloaded the Minecraft launcher directly from the Minecraft.net website.\n\nIf you are unsure try the Microsoft Store option first, you can always re-run the installer.
67
installer.prompt.launcher.type.xbox=Microsoft Store / Xbox

0 commit comments

Comments
 (0)