Multiverse/Multiverse-Core

[Idea]: Folia support for Multiverse-Core

Agaloth opened this issue · 10 comments

Describe the feature

https://github.com/PaperMC/Folia

Here is a summary of everything made with ChatGPT to save some time:

For plugin developers, there are a few key takeaways from the given text:

  1. Folia introduces regionised multithreading, which means that plugins will require modification to function properly. Plugin developers should expect compatibility with existing plugins to be at zero.

  2. Folia introduces new API additions, such as the RegionisedScheduler and EntityScheduler, which can help plugins run on the correct thread context.

  3. To ensure compatibility with Folia, plugin developers must mark their plugin as compatible by placing "folia-supported: true" in the plugin.yml file. Additionally, plugins must take advantage of the RegionisedScheduler and EntityScheduler API to ensure correct behavior.

  4. Plugins should not assume that they can access or modify data in other regions, as Folia regions tick in parallel and do not share data. Plugin developers should take advantage of the upcoming thread-check API to ensure correct behavior.

  5. There are currently broken API, including the scoreboard API, and planned API changes, such as super aggressive thread checks, which may impact plugin development.

Overall, plugin developers should be prepared for significant changes in their plugins to ensure compatibility with Folia. They should take advantage of the new API additions and mark their plugin as compatible to ensure correct behavior. Additionally, they should be aware of the limitations and rules of Folia's regionised multithreading to avoid bugs and errors in their plugins.

How is the feature useful to all Multiverse users?

This will be really useful to server owners, as Folia is a game changer but most plugins don't support it yet since it just came out.

Agreements

  • I have searched for and ensured there isn't already an open issue regarding this.

I have taken a look at Folia, it looks amazing and promising, but its API is not stable enough for MV to add support. Fundamentally, world loading/unloading functions are still marked broken as of now.

I have taken a look at Folia, it looks amazing and promising, but its API is not stable enough for MV to add support. Fundamentally, world loading/unloading functions are still marked broken as of now.

In the end, will it be possible to add support?

zax71 commented

It depends if Foila adds world loading support. Then we could support it

world loading support

I think they are implementing it now from what I see here PaperMC/Folia#63

zax71 commented

world loading support

I think they are implementing it now from what I see here PaperMC/Folia#63

Yea it looks like they merged the method into the main

Just a draft for now, it isn’t merged yet

Oh, the plugin seems to rely on processing in the main thread, which makes adapting it for Folia a difficult task.

Are there plans or Updates on this ?

The PR was closed so I can’t see this happening any time soon

S0ly commented

reopen the PR please

reopen the PR please

This was waiting on a paper PR, which got closed. There has been no PR for MV. This was purely an "idea"