Fix registry progress bar going off end of screen in NeoForge
This commit is contained in:
parent
0a2299ee33
commit
e22f5caec7
|
|
@ -1,6 +1,7 @@
|
||||||
package org.embeddedt.modernfix.neoforge.mixin.feature.registry_event_progress;
|
package org.embeddedt.modernfix.neoforge.mixin.feature.registry_event_progress;
|
||||||
|
|
||||||
import net.neoforged.bus.api.Event;
|
import net.neoforged.bus.api.Event;
|
||||||
|
import net.neoforged.bus.api.EventPriority;
|
||||||
import net.neoforged.fml.ModList;
|
import net.neoforged.fml.ModList;
|
||||||
import net.neoforged.fml.ModLoader;
|
import net.neoforged.fml.ModLoader;
|
||||||
import net.neoforged.fml.ModLoadingContext;
|
import net.neoforged.fml.ModLoadingContext;
|
||||||
|
|
@ -36,17 +37,25 @@ public class GameDataMixin {
|
||||||
@Redirect(method = "postRegisterEvents", at = @At(value = "INVOKE", target = "Lnet/neoforged/fml/ModLoader;postEventWrapContainerInModOrder(Lnet/neoforged/bus/api/Event;)V"))
|
@Redirect(method = "postRegisterEvents", at = @At(value = "INVOKE", target = "Lnet/neoforged/fml/ModLoader;postEventWrapContainerInModOrder(Lnet/neoforged/bus/api/Event;)V"))
|
||||||
private static <T extends Event & IModBusEvent> void swapThreadAndPost(ModLoader loader, T event) {
|
private static <T extends Event & IModBusEvent> void swapThreadAndPost(ModLoader loader, T event) {
|
||||||
RegisterEvent registryEvent = (RegisterEvent)event;
|
RegisterEvent registryEvent = (RegisterEvent)event;
|
||||||
var pb = StartupMessageManager.addProgressBar(registryEvent.getRegistryKey().location().toString(), ModList.get().size());
|
// We control phases ourselves so we can make a separate progress bar for each phase.
|
||||||
try {
|
String registryName = registryEvent.getRegistryKey().location().toString();
|
||||||
loader.postEventWithWrapInModOrder(event, (mc, e) -> {
|
for(EventPriority phase : EventPriority.values()) {
|
||||||
ModLoadingContext.get().setActiveContainer(mc);
|
var pb = StartupMessageManager.addProgressBar(registryName, ModList.get().size());
|
||||||
pb.label(pb.name() + " - " + mc.getModInfo().getDisplayName());
|
try {
|
||||||
pb.increment();
|
ModList.get().forEachModInOrder(mc -> {
|
||||||
}, (mc, e) -> {
|
ModLoadingContext.get().setActiveContainer(mc);
|
||||||
ModLoadingContext.get().setActiveContainer(null);
|
pb.label(pb.name() + " - " + mc.getModInfo().getDisplayName());
|
||||||
});
|
pb.increment();
|
||||||
} finally {
|
var bus = mc.getEventBus();
|
||||||
pb.complete();
|
if(bus != null) {
|
||||||
|
bus.post(phase, event);
|
||||||
|
}
|
||||||
|
ModLoadingContext.get().setActiveContainer(null);
|
||||||
|
});
|
||||||
|
} finally {
|
||||||
|
pb.complete();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user