Fork of Archipelago Multi-Game Randomizer and Server that runs on https://ap.hollymcfarland.com
Go to file
Hussein Farran 9599f54b06 Merge branch 'main' into docs_consolidation
# Conflicts:
#	WebHostLib/static/assets/tutorial/archipelago/advanced_settings_en.md
#	WebHostLib/static/assets/tutorial/archipelago/plando_en.md
#	WebHostLib/static/assets/tutorial/archipelago/triggers_en.md
#	WebHostLib/static/assets/tutorial/timespinner/setup_en.md
2022-01-17 15:37:03 -05:00
.github GitHub Hooks: update python 2021-11-21 17:50:20 +01:00
WebHostLib Merge branch 'main' into docs_consolidation 2022-01-17 15:37:03 -05:00
data WebHost: allow switching out "/tracker/" for "/generic_tracker/" in a tracker url to get the generic tracker for that slot. 2021-12-03 02:41:56 +01:00
docs [Docs] More Links (#179) 2022-01-01 20:29:38 +01:00
test WebHost: fix is_zipfile check for flask FileStorage objects 2022-01-06 06:09:15 +01:00
worlds MultiServer: remove location hinting from !hint and /hint; add /hint_location 2022-01-16 02:20:37 +01:00
.gitignore Add Rogue Legacy to Archipelago (#180) 2022-01-03 19:12:32 +01:00
BaseClasses.py WebHost: fix is_zipfile check for flask FileStorage objects 2022-01-06 06:09:15 +01:00
CommonClient.py CommonClient: add docstring to /ready 2021-12-03 07:04:17 +01:00
FF1Client.py FF1: update some client texts 2021-12-02 07:14:55 +01:00
FactorioClient.py Client UI: allow auto filling !getitem 2021-11-29 21:35:06 +01:00
Fill.py Core: undo change that made Python 3.9 required 2021-12-31 15:08:30 +01:00
Generate.py Options: fix verify_keys breaking options containing lists of dicts 2022-01-15 21:20:34 +01:00
LICENSE Update my copyright notice in the LICENSE 2021-04-29 21:09:26 -04:00
LttPAdjuster.py LttPAdjuster: ignore alttpr cert 2021-12-17 19:17:41 +01:00
Main.py Docs: improve "sending_visible" comment 2022-01-14 19:27:54 +01:00
MinecraftClient.py Minecraft client: more general search for mod name 2021-12-19 19:15:09 +00:00
ModuleUpdate.py allow requirements to point to urls 2021-11-07 15:39:58 +01:00
MultiServer.py MultiServer: remove location hinting from !hint and /hint; add /hint_location 2022-01-16 02:20:37 +01:00
NetUtils.py Docs: add missed JSONMessagePart types 2021-11-30 06:41:50 +01:00
OoTAdjuster.py OoT updates (#160) 2022-01-04 17:16:09 +01:00
Options.py User-specified random range (#203) 2022-01-16 01:59:40 +01:00
Patch.py SNIClient: fix apsoe handling 2021-12-01 01:01:41 +01:00
README.md Add Rogue Legacy to Archipelago (#180) 2022-01-03 19:12:32 +01:00
SNIClient.py SNIClient: make SNI finder a bit smarter 2022-01-01 15:46:08 +01:00
Utils.py 0.2.3 2022-01-08 16:12:56 +01:00
WebHost.py WebHost: split autolaunch and autogen services 2021-12-13 05:48:33 +01:00
host.yaml Generate: allow meta to log-fail as opposed to exception-fail if category is missing in target 2022-01-06 22:01:18 +01:00
inno_setup_38.iss FF1: add to setup 2021-12-01 02:47:08 +01:00
inno_setup_310.iss FF1: add to setup 2021-12-01 02:47:08 +01:00
kvui.py Clients: compatibility change for old Intel graphics. 2021-12-10 09:29:59 +01:00
meta.yaml Generate: return of the meta mystery 2021-11-21 18:09:06 +01:00
playerSettings.yaml Initial FF1R implementation (#123) 2021-11-28 22:32:08 +01:00
pytest.ini use pytest for github unittests 2020-04-29 18:44:03 +02:00
requirements.txt Requirements: remove no longer used appdirs and move kivy to core 2021-12-20 23:10:04 +01:00
setup.py Clients: compatibility change for old Intel graphics. 2021-12-10 09:29:59 +01:00

README.md

Archipelago Discord Shield | Install

Archipelago provides a generic framework for developing multiworld capability for game randomizers. In all cases, presently, Archipelago is also the randomizer itself.

Currently, the following games are supported:

  • The Legend of Zelda: A Link to the Past
  • Factorio
  • Minecraft
  • Subnautica
  • Slay the Spire
  • Risk of Rain 2
  • The Legend of Zelda: Ocarina of Time
  • Timespinner
  • Super Metroid
  • Secret of Evermore
  • Final Fantasy
  • Rogue Legacy

For setup and instructions check out our tutorials page. Downloads can be found at Releases, including compiled windows binaries.

History

Archipelago is built upon a strong legacy of brilliant hobbyists. We want to honor that legacy by showing it here. The repositories which Archipelago is built upon, inspired by, or otherwise owes its gratitude to are:

We recognize that there is a strong community of incredibly smart people that have come before us and helped pave the path. Just because one person's name may be in a repository title does not mean that only one person made that project happen. We can't hope to perfectly cover every single contribution that lead up to Archipelago but we hope to honor them fairly.

Path to the Archipelago

Archipelago was directly forked from bonta0's multiworld_31 branch of ALttPEntranceRandomizer (this project has a long legacy of its own, please check it out linked above) on January 12, 2020. The repository was then named to MultiWorld-Utilities to better encompass its intended function. As Archipelago matured, then known as "Berserker's MultiWorld" by some, we found it necessary to transform our repository into a root level repository (as opposed to a 'forked repo') and change the name (which came later) to better reflect our project.

Running Archipelago

For most people all you need to do is head over to the releases page then download and run the appropriate installer. The installers function on Windows only.

If you are running Archipelago from a non-Windows system then the likely scenario is that you are comfortable running source code directly. Please see our wiki page on running Archipelago from source.

This project makes use of multiple other projects. We wouldn't be here without these other repositories and the contributions of their developers, past and present.

Contributing

Contributions are welcome. We have a few asks of any new contributors.

  • Ensure that all changes which affect logic are covered by unit tests.
  • Do not introduce any unit test failures/regressions.

Otherwise, we tend to judge code on a case to case basis. It is a generally good idea to stick to PEP-8 guidelines to ensure consistency with existing code. (And to make the linter happy.)

Code of Conduct

We conduct ourselves openly and inclusively here. Please do not contribute to an environment which makes other people uncomfortable. This means that we expect all contributors or participants here to:

  • Be welcoming and inclusive in tone and language.
  • Be respectful of others and their abilities.
  • Show empathy when speaking with others.
  • Be gracious and accept feedback and constructive criticism.

These guidelines apply to all channels of communication within this GitHub repository. Please be respectful in both public channels, such as issues, and private, such as private messaging or emails.

Any incidents of abuse may be reported directly to Ijwu at hmfarran@gmail.com.