-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathGTBMMixinLoader.java
More file actions
66 lines (52 loc) · 2.34 KB
/
GTBMMixinLoader.java
File metadata and controls
66 lines (52 loc) · 2.34 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package com.github.gtexpert.gtbm.mixins;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.stream.Collectors;
import net.minecraftforge.fml.common.Loader;
import com.google.common.collect.ImmutableMap;
import com.github.gtexpert.gtbm.api.ModValues;
import com.github.gtexpert.gtbm.api.util.ModLog;
import com.github.gtexpert.gtbm.api.util.Mods;
import zone.rong.mixinbooter.ILateMixinLoader;
@SuppressWarnings("unused")
public class GTBMMixinLoader implements ILateMixinLoader {
public static final Map<String, Boolean> modMixinsConfig = new ImmutableMap.Builder<String, Boolean>()
.put(Mods.Names.GREGTECH, true)
.put(Mods.Names.GREGICALITY_MULTIBLOCKS, true)
.put(Mods.Names.FORESTRY, true)
.build();
@SuppressWarnings("SimplifyStreamApiCallChains")
@Override
public List<String> getMixinConfigs() {
return modMixinsConfig.keySet().stream().map(mod -> "mixins." + ModValues.MODID + "." + mod + ".json")
.collect(Collectors.toList());
}
@Override
public boolean shouldMixinConfigQueue(String mixinConfig) {
String[] parts = mixinConfig.split("\\.");
if (parts.length != 4 && parts.length != 5) {
ModLog.logger.fatal("Mixin Config Check Failed! Invalid Length.");
ModLog.logger.fatal("Mixin Config: {}", mixinConfig);
return true;
}
if (!Objects.equals(parts[1], ModValues.MODID)) {
ModLog.logger.error("Non GTBeesMatrix Mixin Found in Mixin Queue. This is probably an error. Skipping...");
ModLog.logger.error("Mixin Config: {}", mixinConfig);
return true;
}
if (!Loader.isModLoaded(parts[2])) {
ModLog.logger.error(
"Mod '{}' is not loaded. If this is a normal GTBeesMatrix instance, this is probably an error.",
parts[2]);
ModLog.logger.error("Not Loading Mixin Config {}", mixinConfig);
return false;
}
if (!modMixinsConfig.containsKey(parts[2]) || !modMixinsConfig.get(parts[2])) {
ModLog.logger.info("Integration for Mod '{}' is not enabled, or does not exist.", parts[2]);
ModLog.logger.info("Not Loading Mixin Config {}", mixinConfig);
return false;
}
return true;
}
}