Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Generic Plugin Support #147

Open
BadMagic100 opened this issue Jul 16, 2023 · 3 comments
Open

Generic Plugin Support #147

BadMagic100 opened this issue Jul 16, 2023 · 3 comments
Labels
enhancement New feature or request mid priority The "default" priority. Made it into a label to be explicit. needs investigation Further information is requested server-side This request or change involves work on the Archipelago Server as well

Comments

@BadMagic100
Copy link
Contributor

Rando4 provides a system for "connections," mods which can add their own items and locations to the randomization pool. Many feature requests we receive are for things which rando4 connections have implemented already, and most well-implemented connections allow any mod to reuse those items and locations.

We should include support for connections in the HK client using a plug-and-play model. This will involve:

  1. A way to fail out of file creation if the required mods are not installed
  2. A way to ingest connection settings on the generator side (likely this means getting the logic extractor running again)
  3. An API for connections with special requirements (e.g. TRJR) to make changes to IC savedata during file creation based on the Archipelago settings
@BadMagic100 BadMagic100 added enhancement New feature or request needs investigation Further information is requested mid priority The "default" priority. Made it into a label to be explicit. server-side This request or change involves work on the Archipelago Server as well labels Jul 16, 2023
@BadMagic100
Copy link
Contributor Author

I'm very keen on taking this up but won't assign myself until prereqs are met

@KonoTyran
Copy link
Contributor

KonoTyran commented Jul 26, 2023

related to this, I'm currently avoiding the bit of code in the map mod that deals with logic overrides. probably just going to disable this bit until its figured out how plugin support will work.
Just a thought to keep in mind that the APmm will need access to the logic overrides somehow.

@BadMagic100
Copy link
Contributor Author

Logic-wise I am considering a few possibilities:

  1. All supported connections perform logic edits (somehow) which collects all logic in one place statically which can be pulled in by both the extractor and the map mod
  2. Now that APworlds are a thing that exist we might be able to take an approach closer to rando4, where connections dynamically make their logic edits, and then an APWorld is generated locally with their own variations of static logic

Both of these have pretty major downsides, but even without the map consolidation of logic rules is very concerning (and I think whatever solution gets landed on, whether it's one of those or something else, will probably end up being able to easily accommodate the map just by accident)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request mid priority The "default" priority. Made it into a label to be explicit. needs investigation Further information is requested server-side This request or change involves work on the Archipelago Server as well
Projects
None yet
Development

No branches or pull requests

2 participants