-
Notifications
You must be signed in to change notification settings - Fork 49
RFC: Entrypoint reworks #119
Comments
What if we used loader's method reference system and instead of consolidating all of the registrations, passing around directly to each class in a given mod? |
This is essentially what I've proposed, I think:
Yup, this is why |
Ah okay, i skimmed too much. |
Just noticed something really important: this.options.addResourcePackProfilesToManager(this.resourcePackManager); // line 507
// Construct Forge mods here
// Forge and Forge mods: register custom modelloaders
this.resourcePackManager.scanPacks(); // line 508 For example, forge mods may access MinecraftClient.getInstance().getResourceManager() in their constructor, they will get a null and eventually crash. I would suggest that we should not use ModInitializer.onInitialize for client-side mod construction, we should have our own callback inject to the correct location in We may need further discussion on how this change will affect our existing code, but at this stage, I dont think this change will break anything existing code. We have a lot of ModInitializer and ClientModInitializer, all of them are used for fabric event registration, and those events will never be fired so early. |
Patchwork's current entrypoint system needs a rework. I've drafted up some ideas on what that might look like. Please tell me what you think about them!
Introduction
One of the future refactors I have in mind for Patchwork Patcher is to rework the entrypoint system. However, Patchwork API (more specifically, patchwork-dispatcher) would need to be modified to support and use these entrypoints, which is why I'm posting this here. The current single, unsided entrypoint system introduced back in September 2019 is showing its age, and has a few definite limitations:
@ObjectHolder
and@CapabilityInject
annotations are potentially loaded too early (during mod construction rather than after registry creation)When implementing these entrypoints in Patcher, I intend on adding the methods to existing classes, and then using method references, as opposed to generating separate entrypoint classes.
As such, I propose adding a few different entrypoints:
patchwork:mod_instance
A marker entrypoint to denote classes originally annotated with
@Mod
. Used get the mod instance. This would be an alternate approach to solve the same problem as PatchworkMC/patchwork-patcher#53. As a side effect, fabric-loader will construct the mod for us when we query the entrypoint, which is convenient.patchwork:common_automatic_subscribers
Register unsided
@EventBusSubscriber
s. UsesModInitializer
. Method name used in method references:patchwork$onInitialize
. TODO: Should the automatic subscriber entrypoints use a custom interface that e.g. provides the MOD / FORGE bus in the entrypoint method?patchwork:client_automatic_subscribers
Register client-only
@EventBusSubscriber
s. UsesClientModInitializer
. Method name used in method references:patchwork$onInitializeClient
.patchwork:server_automatic_subscribers
Register dedicated-server-only
@EventBusSubscriber
s. UsesDedicatedServerModInitializer
. Method name used in method references:patchwork$onInitializeServer
.patchwork:object_holders
Register all object holders with the ObjectHolderRegistry here. Fired after new registries have been created, but before registry events have been dispatched.
patchwork:capability_injections
Basically the same thing as
patchwork:register_object_holders
(and fired right afterwards) but for@CapabilityInject
.The text was updated successfully, but these errors were encountered: