From ce23369b0b6e4a82c4bba2c89c0ea1294249ad29 Mon Sep 17 00:00:00 2001 From: Edos512 <30857677+Edos512@users.noreply.github.com> Date: Fri, 4 Dec 2020 23:42:09 +0100 Subject: [PATCH] Revert "Merge branch 'pr/151'" This reverts commit ffdaed9ea97bdc49d7d81f74f0c2e6462c6a9bdf, reversing changes made to 1ea9197976b6f2ad2626fb453dc52acc787f9ddc. --- .gitignore | 2 - Adjuster.py | 9 +- AdjusterMain.py | 2 +- BaseClasses.py | 38 +------ EntranceRandomizer.py | 29 +---- Fill.py | 3 +- GuiUtils.py | 8 +- Main.py | 40 +------ Mystery.py | 24 +--- Regions.py | 107 +----------------- Rules.py | 6 +- Text.py | 5 +- WebHostLib/__init__.py | 2 - WebHostLib/downloads.py | 7 +- WebHostLib/models.py | 2 +- WebHostLib/requirements.txt | 2 +- .../static/static/weightedSettings.yaml | 30 ++--- WebHostLib/templates/tracker.html | 2 +- WebHostLib/tracker.py | 61 +--------- data/sprites/alttpr/.gitignore | 2 - data/sprites/alttpr/001.link.1.zspr | Bin 0 -> 28862 bytes data/sprites/alttpr/4slink-armors.1.zspr | Bin 0 -> 28903 bytes data/sprites/alttpr/abigail.1.zspr | Bin 0 -> 28883 bytes data/sprites/alttpr/adol.1.zspr | Bin 0 -> 28855 bytes data/sprites/alttpr/aggretsuko.1.zspr | Bin 0 -> 28874 bytes data/sprites/alttpr/alice.1.zspr | Bin 0 -> 28861 bytes .../alttpr/angry-video-game-nerd.1.zspr | Bin 0 -> 28902 bytes data/sprites/alttpr/arcane.1.zspr | Bin 0 -> 28857 bytes data/sprites/alttpr/ark.2.zspr | Bin 0 -> 28864 bytes data/sprites/alttpr/arrghus.2.zspr | Bin 0 -> 28880 bytes data/sprites/alttpr/astronaut.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/badeline.1.zspr | Bin 0 -> 28855 bytes data/sprites/alttpr/bananas-in-pyjamas.1.zspr | Bin 0 -> 28893 bytes data/sprites/alttpr/bandit.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/batman.1.zspr | Bin 0 -> 28869 bytes data/sprites/alttpr/beau.1.zspr | Bin 0 -> 28850 bytes data/sprites/alttpr/bewp.1.zspr | Bin 0 -> 28857 bytes data/sprites/alttpr/bigkey.1.zspr | Bin 0 -> 28862 bytes data/sprites/alttpr/birb.1.zspr | Bin 0 -> 28866 bytes data/sprites/alttpr/birdo.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/blackmage.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/blacksmithlink.1.zspr | Bin 0 -> 28872 bytes data/sprites/alttpr/blossom.1.zspr | Bin 0 -> 28865 bytes data/sprites/alttpr/bob.1.zspr | Bin 0 -> 28872 bytes data/sprites/alttpr/boo-two.1.zspr | Bin 0 -> 28852 bytes data/sprites/alttpr/boo.2.zspr | Bin 0 -> 28857 bytes data/sprites/alttpr/bottle_o_goo.1.zspr | Bin 0 -> 28895 bytes data/sprites/alttpr/botw-zelda.1.zspr | Bin 0 -> 28830 bytes data/sprites/alttpr/bowser.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/branch.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/brian.1.zspr | Bin 0 -> 28861 bytes data/sprites/alttpr/broccoli.1.zspr | Bin 0 -> 28882 bytes data/sprites/alttpr/bronzor.1.zspr | Bin 0 -> 28880 bytes data/sprites/alttpr/bsboy.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/bsgirl.1.zspr | Bin 0 -> 28875 bytes data/sprites/alttpr/bubbles.1.zspr | Bin 0 -> 28865 bytes data/sprites/alttpr/bullet_bill.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/buttercup.1.zspr | Bin 0 -> 28869 bytes data/sprites/alttpr/cactuar.1.zspr | Bin 0 -> 28865 bytes data/sprites/alttpr/cadence.1.zspr | Bin 0 -> 28883 bytes data/sprites/alttpr/carlsagan42.1.zspr | Bin 0 -> 28882 bytes data/sprites/alttpr/casual-zelda.1.zspr | Bin 0 -> 28893 bytes data/sprites/alttpr/cat.3.zspr | Bin 0 -> 28897 bytes data/sprites/alttpr/catboo.1.zspr | Bin 0 -> 28868 bytes data/sprites/alttpr/cdilink.1.zspr | Bin 0 -> 28872 bytes data/sprites/alttpr/celes.1.zspr | Bin 0 -> 28861 bytes data/sprites/alttpr/charizard.1.zspr | Bin 0 -> 28887 bytes data/sprites/alttpr/cheepcheep.1.zspr | Bin 0 -> 28861 bytes data/sprites/alttpr/chibity.1.zspr | Bin 0 -> 28859 bytes data/sprites/alttpr/cirno.1.zspr | Bin 0 -> 28852 bytes data/sprites/alttpr/clifford.1.zspr | Bin 0 -> 28876 bytes data/sprites/alttpr/clyde.1.zspr | Bin 0 -> 28861 bytes data/sprites/alttpr/conker.1.zspr | Bin 0 -> 28891 bytes data/sprites/alttpr/cornelius.1.zspr | Bin 0 -> 28860 bytes data/sprites/alttpr/corona.1.zspr | Bin 0 -> 28867 bytes data/sprites/alttpr/cucco.1.zspr | Bin 0 -> 28879 bytes data/sprites/alttpr/cursor.1.zspr | Bin 0 -> 28872 bytes data/sprites/alttpr/d_owls.1.zspr | Bin 0 -> 28860 bytes data/sprites/alttpr/dark-panda.1.zspr | Bin 0 -> 28865 bytes data/sprites/alttpr/darkboy.1.zspr | Bin 0 -> 28864 bytes data/sprites/alttpr/darkgirl.1.zspr | Bin 0 -> 28866 bytes data/sprites/alttpr/darklink-tunic.1.zspr | Bin 0 -> 28879 bytes data/sprites/alttpr/darklink.1.zspr | Bin 0 -> 28866 bytes data/sprites/alttpr/darkswatchy.1.zspr | Bin 0 -> 28895 bytes data/sprites/alttpr/darkzelda.1.zspr | Bin 0 -> 28868 bytes data/sprites/alttpr/darkzora.2.zspr | Bin 0 -> 28866 bytes data/sprites/alttpr/deadpool-mythic.1.zspr | Bin 0 -> 28882 bytes data/sprites/alttpr/deadpool.1.zspr | Bin 0 -> 28887 bytes data/sprites/alttpr/deadrock.1.zspr | Bin 0 -> 28858 bytes data/sprites/alttpr/decidueye.1.zspr | Bin 0 -> 28860 bytes data/sprites/alttpr/demonlink.1.zspr | Bin 0 -> 28871 bytes data/sprites/alttpr/dragonite.2.zspr | Bin 0 -> 28887 bytes data/sprites/alttpr/drake.1.zspr | Bin 0 -> 28916 bytes data/sprites/alttpr/eggplant.1.zspr | Bin 0 -> 28876 bytes data/sprites/alttpr/emosaru.1.zspr | Bin 0 -> 28856 bytes data/sprites/alttpr/ezlo.1.zspr | Bin 0 -> 28859 bytes data/sprites/alttpr/fierce-deity-link.1.zspr | Bin 0 -> 28906 bytes data/sprites/alttpr/finn.3.zspr | Bin 0 -> 28875 bytes data/sprites/alttpr/finny_bear.1.zspr | Bin 0 -> 28874 bytes data/sprites/alttpr/fish_floodgate.1.zspr | Bin 0 -> 28888 bytes data/sprites/alttpr/flavor_guy.1.zspr | Bin 0 -> 28880 bytes data/sprites/alttpr/foxlink.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/freya.1.zspr | Bin 0 -> 28888 bytes data/sprites/alttpr/frisk.1.zspr | Bin 0 -> 28944 bytes data/sprites/alttpr/froglink.3.zspr | Bin 0 -> 28890 bytes data/sprites/alttpr/fujin.2.zspr | Bin 0 -> 28870 bytes data/sprites/alttpr/future_trunks.1.zspr | Bin 0 -> 28880 bytes data/sprites/alttpr/gamer.1.zspr | Bin 0 -> 28871 bytes data/sprites/alttpr/ganon.1.zspr | Bin 0 -> 28891 bytes data/sprites/alttpr/ganondorf.1.zspr | Bin 0 -> 28879 bytes data/sprites/alttpr/garfield.2.zspr | Bin 0 -> 28867 bytes data/sprites/alttpr/garnet.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/garomaster.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/gbc-link.1.zspr | Bin 0 -> 28870 bytes data/sprites/alttpr/geno.1.zspr | Bin 0 -> 28874 bytes data/sprites/alttpr/gobli.1.zspr | Bin 0 -> 28858 bytes data/sprites/alttpr/goomba.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/goose.1.zspr | Bin 0 -> 28849 bytes data/sprites/alttpr/grandpoobear.2.zspr | Bin 0 -> 28896 bytes data/sprites/alttpr/grunclestan.1.zspr | Bin 0 -> 28875 bytes data/sprites/alttpr/guiz.1.zspr | Bin 0 -> 28860 bytes data/sprites/alttpr/hardhat_beetle.1.zspr | Bin 0 -> 28879 bytes data/sprites/alttpr/hat-kid.1.zspr | Bin 0 -> 28868 bytes data/sprites/alttpr/headlesslink.1.zspr | Bin 0 -> 28892 bytes data/sprites/alttpr/hello_kitty.1.zspr | Bin 0 -> 28867 bytes data/sprites/alttpr/hidari.1.zspr | Bin 0 -> 28860 bytes data/sprites/alttpr/hint_tile.1.zspr | Bin 0 -> 28878 bytes data/sprites/alttpr/hitsuyan.1.zspr | Bin 0 -> 28879 bytes data/sprites/alttpr/hoarder-bush.1.zspr | Bin 0 -> 28882 bytes data/sprites/alttpr/hoarder-pot.1.zspr | Bin 0 -> 28880 bytes data/sprites/alttpr/hoarder-rock.1.zspr | Bin 0 -> 28882 bytes data/sprites/alttpr/homer.1.zspr | Bin 0 -> 28877 bytes data/sprites/alttpr/hyruleknight.1.zspr | Bin 0 -> 28883 bytes data/sprites/alttpr/ibazly.1.zspr | Bin 0 -> 28854 bytes data/sprites/alttpr/ignignokt.2.zspr | Bin 0 -> 28884 bytes data/sprites/alttpr/informant_woman.1.zspr | Bin 0 -> 28881 bytes data/sprites/alttpr/inkling.1.zspr | Bin 0 -> 28865 bytes data/sprites/alttpr/invisibleman.1.zspr | Bin 0 -> 28899 bytes data/sprites/alttpr/jack-frost.1.zspr | Bin 0 -> 28874 bytes data/sprites/alttpr/jason_frudnick.1.zspr | Bin 0 -> 28879 bytes data/sprites/alttpr/jasp.1.zspr | Bin 0 -> 28862 bytes data/sprites/alttpr/jogurt.1.zspr | Bin 0 -> 28860 bytes data/sprites/alttpr/katsura.1.zspr | Bin 0 -> 28885 bytes data/sprites/alttpr/kecleon.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/kenny_mccormick.1.zspr | Bin 0 -> 28881 bytes data/sprites/alttpr/ketchup.1.zspr | Bin 0 -> 28865 bytes data/sprites/alttpr/kholdstare.1.zspr | Bin 0 -> 28886 bytes data/sprites/alttpr/king_gothalion.1.zspr | Bin 0 -> 28885 bytes data/sprites/alttpr/king_graham.1.zspr | Bin 0 -> 28892 bytes data/sprites/alttpr/kirby-meta.1.zspr | Bin 0 -> 28861 bytes data/sprites/alttpr/kore8.1.zspr | Bin 0 -> 28858 bytes data/sprites/alttpr/lakitu.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/lapras.1.zspr | Bin 0 -> 28881 bytes data/sprites/alttpr/lest.1.zspr | Bin 0 -> 28874 bytes data/sprites/alttpr/lily.1.zspr | Bin 0 -> 28870 bytes data/sprites/alttpr/linja.1.zspr | Bin 0 -> 28864 bytes data/sprites/alttpr/linkhatcolor.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/linktuniccolor.1.zspr | Bin 0 -> 28877 bytes data/sprites/alttpr/littlepony.1.zspr | Bin 0 -> 28859 bytes data/sprites/alttpr/locke_merchant.1.zspr | Bin 0 -> 28881 bytes data/sprites/alttpr/lucario.1.zspr | Bin 0 -> 28856 bytes data/sprites/alttpr/luigi.1.zspr | Bin 0 -> 28852 bytes data/sprites/alttpr/madeline.1.zspr | Bin 0 -> 28855 bytes data/sprites/alttpr/magus.1.zspr | Bin 0 -> 28870 bytes data/sprites/alttpr/maiden.1.zspr | Bin 0 -> 28854 bytes data/sprites/alttpr/mallow-cat.1.zspr | Bin 0 -> 28884 bytes data/sprites/alttpr/mangalink.1.zspr | Bin 0 -> 28886 bytes data/sprites/alttpr/maplequeen.2.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/marin.2.zspr | Bin 0 -> 28885 bytes data/sprites/alttpr/mario-classic.2.zspr | Bin 0 -> 28875 bytes data/sprites/alttpr/mario_tanooki.1.zspr | Bin 0 -> 28902 bytes data/sprites/alttpr/mariocappy.1.zspr | Bin 0 -> 28875 bytes data/sprites/alttpr/marisa.1.zspr | Bin 0 -> 28872 bytes data/sprites/alttpr/matthias.1.zspr | Bin 0 -> 28881 bytes data/sprites/alttpr/meatwad.1.zspr | Bin 0 -> 28880 bytes data/sprites/alttpr/medallions.1.zspr | Bin 0 -> 28892 bytes data/sprites/alttpr/medli.1.zspr | Bin 0 -> 28864 bytes data/sprites/alttpr/megaman-x.2.zspr | Bin 0 -> 28878 bytes data/sprites/alttpr/metroid.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/mew.1.zspr | Bin 0 -> 28853 bytes data/sprites/alttpr/mike-jones.2.zspr | Bin 0 -> 28889 bytes data/sprites/alttpr/minish_link.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/minishcaplink.2.zspr | Bin 0 -> 28887 bytes data/sprites/alttpr/missingno.1.zspr | Bin 0 -> 28848 bytes data/sprites/alttpr/modernlink.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/mog.2.zspr | Bin 0 -> 28857 bytes data/sprites/alttpr/momiji.1.zspr | Bin 0 -> 28884 bytes data/sprites/alttpr/moosh.1.zspr | Bin 0 -> 28870 bytes data/sprites/alttpr/mouse.1.zspr | Bin 0 -> 28864 bytes data/sprites/alttpr/ms-paintdog.1.zspr | Bin 0 -> 28889 bytes data/sprites/alttpr/mushy.1.zspr | Bin 0 -> 28898 bytes data/sprites/alttpr/naturelink.1.zspr | Bin 0 -> 28870 bytes data/sprites/alttpr/navi.1.zspr | Bin 0 -> 28868 bytes data/sprites/alttpr/navirou.1.zspr | Bin 0 -> 28856 bytes data/sprites/alttpr/ned-flanders.1.zspr | Bin 0 -> 28878 bytes data/sprites/alttpr/negativelink.1.zspr | Bin 0 -> 28874 bytes data/sprites/alttpr/neosad.1.zspr | Bin 0 -> 28870 bytes data/sprites/alttpr/neslink.1.zspr | Bin 0 -> 28913 bytes data/sprites/alttpr/ness.1.zspr | Bin 0 -> 28882 bytes data/sprites/alttpr/nia.1.zspr | Bin 0 -> 28857 bytes data/sprites/alttpr/niko.1.zspr | Bin 0 -> 28870 bytes data/sprites/alttpr/oldman.2.zspr | Bin 0 -> 28865 bytes data/sprites/alttpr/ori.2.zspr | Bin 0 -> 28851 bytes data/sprites/alttpr/outlinelink.1.zspr | Bin 0 -> 28860 bytes data/sprites/alttpr/parallelworldslink.1.zspr | Bin 0 -> 28912 bytes data/sprites/alttpr/paula.1.zspr | Bin 0 -> 28879 bytes data/sprites/alttpr/peach.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/penguinlink.1.zspr | Bin 0 -> 28885 bytes data/sprites/alttpr/pete.1.zspr | Bin 0 -> 28886 bytes data/sprites/alttpr/phoenix-wright.1.zspr | Bin 0 -> 28882 bytes data/sprites/alttpr/pikachu.1.zspr | Bin 0 -> 28870 bytes data/sprites/alttpr/pinkribbonlink.2.zspr | Bin 0 -> 28898 bytes data/sprites/alttpr/piranha_plant.1.zspr | Bin 0 -> 28883 bytes data/sprites/alttpr/plagueknight.1.zspr | Bin 0 -> 28877 bytes data/sprites/alttpr/pokey.1.zspr | Bin 0 -> 28876 bytes data/sprites/alttpr/popoi.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/poppy.1.zspr | Bin 0 -> 28861 bytes data/sprites/alttpr/porg_knight.1.zspr | Bin 0 -> 28891 bytes data/sprites/alttpr/powerpuff_girl.1.zspr | Bin 0 -> 28879 bytes data/sprites/alttpr/pridelink.2.zspr | Bin 0 -> 28892 bytes data/sprites/alttpr/primm.1.zspr | Bin 0 -> 28861 bytes data/sprites/alttpr/princess_bubblegum.1.zspr | Bin 0 -> 28889 bytes data/sprites/alttpr/psyduck.2.zspr | Bin 0 -> 28868 bytes data/sprites/alttpr/pug.1.zspr | Bin 0 -> 28856 bytes data/sprites/alttpr/purplechest-bottle.1.zspr | Bin 0 -> 28895 bytes data/sprites/alttpr/pyro.1.zspr | Bin 0 -> 28853 bytes data/sprites/alttpr/rainbowlink.1.zspr | Bin 0 -> 28890 bytes data/sprites/alttpr/remeer.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/rick.1.zspr | Bin 0 -> 28930 bytes data/sprites/alttpr/robotlink.1.zspr | Bin 0 -> 28894 bytes data/sprites/alttpr/rocko.1.zspr | Bin 0 -> 28866 bytes data/sprites/alttpr/rottytops.1.zspr | Bin 0 -> 28878 bytes data/sprites/alttpr/roykoopa.1.zspr | Bin 0 -> 28860 bytes data/sprites/alttpr/rumia.1.zspr | Bin 0 -> 28852 bytes data/sprites/alttpr/rydia.1.zspr | Bin 0 -> 28849 bytes data/sprites/alttpr/ryu.1.zspr | Bin 0 -> 28866 bytes data/sprites/alttpr/sailormoon.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/saitama.1.zspr | Bin 0 -> 28911 bytes data/sprites/alttpr/samus-sm.1.zspr | Bin 0 -> 28887 bytes data/sprites/alttpr/samus.2.zspr | Bin 0 -> 28879 bytes data/sprites/alttpr/samus_classic.1.zspr | Bin 0 -> 28899 bytes data/sprites/alttpr/santalink.2.zspr | Bin 0 -> 28868 bytes data/sprites/alttpr/scholar.1.zspr | Bin 0 -> 28859 bytes data/sprites/alttpr/selan.1.zspr | Bin 0 -> 28881 bytes data/sprites/alttpr/sevens1ns.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/shadow.1.zspr | Bin 0 -> 28869 bytes data/sprites/alttpr/shadowsaku.2.zspr | Bin 0 -> 28874 bytes data/sprites/alttpr/shantae.1.zspr | Bin 0 -> 28868 bytes data/sprites/alttpr/shuppet.1.zspr | Bin 0 -> 28880 bytes data/sprites/alttpr/shy-gal.1.zspr | Bin 0 -> 28874 bytes data/sprites/alttpr/shy-guy.1.zspr | Bin 0 -> 28868 bytes data/sprites/alttpr/sighn_waive.1.zspr | Bin 0 -> 28868 bytes data/sprites/alttpr/snes-controller.1.zspr | Bin 0 -> 28884 bytes data/sprites/alttpr/sodacan.1.zspr | Bin 0 -> 28867 bytes data/sprites/alttpr/solaire.1.zspr | Bin 0 -> 28882 bytes data/sprites/alttpr/soldiersprite.1.zspr | Bin 0 -> 28885 bytes data/sprites/alttpr/sonic.1.zspr | Bin 0 -> 28881 bytes data/sprites/alttpr/sora.1.zspr | Bin 0 -> 28862 bytes data/sprites/alttpr/sora_kh1.1.zspr | Bin 0 -> 28882 bytes data/sprites/alttpr/squall.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/squirrel.1.zspr | Bin 0 -> 28885 bytes data/sprites/alttpr/squirtle.1.zspr | Bin 0 -> 28876 bytes data/sprites/alttpr/stalfos.1.zspr | Bin 0 -> 28865 bytes data/sprites/alttpr/stan.1.zspr | Bin 0 -> 28847 bytes data/sprites/alttpr/staticlink.1.zspr | Bin 0 -> 28888 bytes data/sprites/alttpr/stick_man.1.zspr | Bin 0 -> 28872 bytes data/sprites/alttpr/superbomb.1.zspr | Bin 0 -> 28877 bytes data/sprites/alttpr/superbunny.2.zspr | Bin 0 -> 28882 bytes data/sprites/alttpr/supermeatboy.1.zspr | Bin 0 -> 28870 bytes data/sprites/alttpr/swatchy.1.zspr | Bin 0 -> 28885 bytes data/sprites/alttpr/tasbot.1.zspr | Bin 0 -> 28860 bytes data/sprites/alttpr/teatime.1.zspr | Bin 0 -> 28867 bytes data/sprites/alttpr/terra.1.zspr | Bin 0 -> 28907 bytes data/sprites/alttpr/tetra.1.zspr | Bin 0 -> 28877 bytes data/sprites/alttpr/tgh.1.zspr | Bin 0 -> 28900 bytes data/sprites/alttpr/thief.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/thomcrow.1.zspr | Bin 0 -> 28858 bytes data/sprites/alttpr/tile.2.zspr | Bin 0 -> 28874 bytes data/sprites/alttpr/tingle.1.zspr | Bin 0 -> 28866 bytes data/sprites/alttpr/tmnt.1.zspr | Bin 0 -> 28859 bytes data/sprites/alttpr/toad.2.zspr | Bin 0 -> 28859 bytes data/sprites/alttpr/toadette.2.zspr | Bin 0 -> 28869 bytes data/sprites/alttpr/toadette_captain.1.zspr | Bin 0 -> 28885 bytes data/sprites/alttpr/totem-links.1.zspr | Bin 0 -> 28871 bytes data/sprites/alttpr/trogdor.1.zspr | Bin 0 -> 28927 bytes .../alttpr/twilightprincesszelda.2.zspr | Bin 0 -> 28885 bytes data/sprites/alttpr/two_faced.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/ty.1.zspr | Bin 0 -> 28913 bytes data/sprites/alttpr/ultros.1.zspr | Bin 0 -> 28872 bytes data/sprites/alttpr/valeera.1.zspr | Bin 0 -> 28856 bytes data/sprites/alttpr/vanillalink.1.zspr | Bin 0 -> 28873 bytes data/sprites/alttpr/vaporeon.1.zspr | Bin 0 -> 28864 bytes data/sprites/alttpr/vegeta.1.zspr | Bin 0 -> 28866 bytes data/sprites/alttpr/vera.1.zspr | Bin 0 -> 28871 bytes data/sprites/alttpr/vitreous.1.zspr | Bin 0 -> 28858 bytes data/sprites/alttpr/vivi.1.zspr | Bin 0 -> 28859 bytes data/sprites/alttpr/vivian.1.zspr | Bin 0 -> 28863 bytes data/sprites/alttpr/wario.1.zspr | Bin 0 -> 28861 bytes data/sprites/alttpr/will.1.zspr | Bin 0 -> 28862 bytes data/sprites/alttpr/wizzrobe.2.zspr | Bin 0 -> 28864 bytes data/sprites/alttpr/wolf_link.1.zspr | Bin 0 -> 28910 bytes data/sprites/alttpr/wolf_link_tp.1.zspr | Bin 0 -> 28877 bytes data/sprites/alttpr/yoshi.1.zspr | Bin 0 -> 28861 bytes data/sprites/alttpr/yunica.1.zspr | Bin 0 -> 28885 bytes data/sprites/alttpr/zandra.1.zspr | Bin 0 -> 28878 bytes data/sprites/alttpr/zebraunicorn.1.zspr | Bin 0 -> 28883 bytes data/sprites/alttpr/zeck.1.zspr | Bin 0 -> 28881 bytes data/sprites/alttpr/zelda.1.zspr | Bin 0 -> 28867 bytes data/sprites/alttpr/zerosuitsamus.2.zspr | Bin 0 -> 28899 bytes data/sprites/alttpr/zora.2.zspr | Bin 0 -> 28886 bytes host.yaml | 9 +- inno_setup.iss | 4 +- meta.yaml | 17 +-- playerSettings.yaml | 54 +++------ setup.py | 3 - 315 files changed, 70 insertions(+), 398 deletions(-) delete mode 100644 data/sprites/alttpr/.gitignore create mode 100644 data/sprites/alttpr/001.link.1.zspr create mode 100644 data/sprites/alttpr/4slink-armors.1.zspr create mode 100644 data/sprites/alttpr/abigail.1.zspr create mode 100644 data/sprites/alttpr/adol.1.zspr create mode 100644 data/sprites/alttpr/aggretsuko.1.zspr create mode 100644 data/sprites/alttpr/alice.1.zspr create mode 100644 data/sprites/alttpr/angry-video-game-nerd.1.zspr create mode 100644 data/sprites/alttpr/arcane.1.zspr create mode 100644 data/sprites/alttpr/ark.2.zspr create mode 100644 data/sprites/alttpr/arrghus.2.zspr create mode 100644 data/sprites/alttpr/astronaut.1.zspr create mode 100644 data/sprites/alttpr/badeline.1.zspr create mode 100644 data/sprites/alttpr/bananas-in-pyjamas.1.zspr create mode 100644 data/sprites/alttpr/bandit.1.zspr create mode 100644 data/sprites/alttpr/batman.1.zspr create mode 100644 data/sprites/alttpr/beau.1.zspr create mode 100644 data/sprites/alttpr/bewp.1.zspr create mode 100644 data/sprites/alttpr/bigkey.1.zspr create mode 100644 data/sprites/alttpr/birb.1.zspr create mode 100644 data/sprites/alttpr/birdo.1.zspr create mode 100644 data/sprites/alttpr/blackmage.1.zspr create mode 100644 data/sprites/alttpr/blacksmithlink.1.zspr create mode 100644 data/sprites/alttpr/blossom.1.zspr create mode 100644 data/sprites/alttpr/bob.1.zspr create mode 100644 data/sprites/alttpr/boo-two.1.zspr create mode 100644 data/sprites/alttpr/boo.2.zspr create mode 100644 data/sprites/alttpr/bottle_o_goo.1.zspr create mode 100644 data/sprites/alttpr/botw-zelda.1.zspr create mode 100644 data/sprites/alttpr/bowser.1.zspr create mode 100644 data/sprites/alttpr/branch.1.zspr create mode 100644 data/sprites/alttpr/brian.1.zspr create mode 100644 data/sprites/alttpr/broccoli.1.zspr create mode 100644 data/sprites/alttpr/bronzor.1.zspr create mode 100644 data/sprites/alttpr/bsboy.1.zspr create mode 100644 data/sprites/alttpr/bsgirl.1.zspr create mode 100644 data/sprites/alttpr/bubbles.1.zspr create mode 100644 data/sprites/alttpr/bullet_bill.1.zspr create mode 100644 data/sprites/alttpr/buttercup.1.zspr create mode 100644 data/sprites/alttpr/cactuar.1.zspr create mode 100644 data/sprites/alttpr/cadence.1.zspr create mode 100644 data/sprites/alttpr/carlsagan42.1.zspr create mode 100644 data/sprites/alttpr/casual-zelda.1.zspr create mode 100644 data/sprites/alttpr/cat.3.zspr create mode 100644 data/sprites/alttpr/catboo.1.zspr create mode 100644 data/sprites/alttpr/cdilink.1.zspr create mode 100644 data/sprites/alttpr/celes.1.zspr create mode 100644 data/sprites/alttpr/charizard.1.zspr create mode 100644 data/sprites/alttpr/cheepcheep.1.zspr create mode 100644 data/sprites/alttpr/chibity.1.zspr create mode 100644 data/sprites/alttpr/cirno.1.zspr create mode 100644 data/sprites/alttpr/clifford.1.zspr create mode 100644 data/sprites/alttpr/clyde.1.zspr create mode 100644 data/sprites/alttpr/conker.1.zspr create mode 100644 data/sprites/alttpr/cornelius.1.zspr create mode 100644 data/sprites/alttpr/corona.1.zspr create mode 100644 data/sprites/alttpr/cucco.1.zspr create mode 100644 data/sprites/alttpr/cursor.1.zspr create mode 100644 data/sprites/alttpr/d_owls.1.zspr create mode 100644 data/sprites/alttpr/dark-panda.1.zspr create mode 100644 data/sprites/alttpr/darkboy.1.zspr create mode 100644 data/sprites/alttpr/darkgirl.1.zspr create mode 100644 data/sprites/alttpr/darklink-tunic.1.zspr create mode 100644 data/sprites/alttpr/darklink.1.zspr create mode 100644 data/sprites/alttpr/darkswatchy.1.zspr create mode 100644 data/sprites/alttpr/darkzelda.1.zspr create mode 100644 data/sprites/alttpr/darkzora.2.zspr create mode 100644 data/sprites/alttpr/deadpool-mythic.1.zspr create mode 100644 data/sprites/alttpr/deadpool.1.zspr create mode 100644 data/sprites/alttpr/deadrock.1.zspr create mode 100644 data/sprites/alttpr/decidueye.1.zspr create mode 100644 data/sprites/alttpr/demonlink.1.zspr create mode 100644 data/sprites/alttpr/dragonite.2.zspr create mode 100644 data/sprites/alttpr/drake.1.zspr create mode 100644 data/sprites/alttpr/eggplant.1.zspr create mode 100644 data/sprites/alttpr/emosaru.1.zspr create mode 100644 data/sprites/alttpr/ezlo.1.zspr create mode 100644 data/sprites/alttpr/fierce-deity-link.1.zspr create mode 100644 data/sprites/alttpr/finn.3.zspr create mode 100644 data/sprites/alttpr/finny_bear.1.zspr create mode 100644 data/sprites/alttpr/fish_floodgate.1.zspr create mode 100644 data/sprites/alttpr/flavor_guy.1.zspr create mode 100644 data/sprites/alttpr/foxlink.1.zspr create mode 100644 data/sprites/alttpr/freya.1.zspr create mode 100644 data/sprites/alttpr/frisk.1.zspr create mode 100644 data/sprites/alttpr/froglink.3.zspr create mode 100644 data/sprites/alttpr/fujin.2.zspr create mode 100644 data/sprites/alttpr/future_trunks.1.zspr create mode 100644 data/sprites/alttpr/gamer.1.zspr create mode 100644 data/sprites/alttpr/ganon.1.zspr create mode 100644 data/sprites/alttpr/ganondorf.1.zspr create mode 100644 data/sprites/alttpr/garfield.2.zspr create mode 100644 data/sprites/alttpr/garnet.1.zspr create mode 100644 data/sprites/alttpr/garomaster.1.zspr create mode 100644 data/sprites/alttpr/gbc-link.1.zspr create mode 100644 data/sprites/alttpr/geno.1.zspr create mode 100644 data/sprites/alttpr/gobli.1.zspr create mode 100644 data/sprites/alttpr/goomba.1.zspr create mode 100644 data/sprites/alttpr/goose.1.zspr create mode 100644 data/sprites/alttpr/grandpoobear.2.zspr create mode 100644 data/sprites/alttpr/grunclestan.1.zspr create mode 100644 data/sprites/alttpr/guiz.1.zspr create mode 100644 data/sprites/alttpr/hardhat_beetle.1.zspr create mode 100644 data/sprites/alttpr/hat-kid.1.zspr create mode 100644 data/sprites/alttpr/headlesslink.1.zspr create mode 100644 data/sprites/alttpr/hello_kitty.1.zspr create mode 100644 data/sprites/alttpr/hidari.1.zspr create mode 100644 data/sprites/alttpr/hint_tile.1.zspr create mode 100644 data/sprites/alttpr/hitsuyan.1.zspr create mode 100644 data/sprites/alttpr/hoarder-bush.1.zspr create mode 100644 data/sprites/alttpr/hoarder-pot.1.zspr create mode 100644 data/sprites/alttpr/hoarder-rock.1.zspr create mode 100644 data/sprites/alttpr/homer.1.zspr create mode 100644 data/sprites/alttpr/hyruleknight.1.zspr create mode 100644 data/sprites/alttpr/ibazly.1.zspr create mode 100644 data/sprites/alttpr/ignignokt.2.zspr create mode 100644 data/sprites/alttpr/informant_woman.1.zspr create mode 100644 data/sprites/alttpr/inkling.1.zspr create mode 100644 data/sprites/alttpr/invisibleman.1.zspr create mode 100644 data/sprites/alttpr/jack-frost.1.zspr create mode 100644 data/sprites/alttpr/jason_frudnick.1.zspr create mode 100644 data/sprites/alttpr/jasp.1.zspr create mode 100644 data/sprites/alttpr/jogurt.1.zspr create mode 100644 data/sprites/alttpr/katsura.1.zspr create mode 100644 data/sprites/alttpr/kecleon.1.zspr create mode 100644 data/sprites/alttpr/kenny_mccormick.1.zspr create mode 100644 data/sprites/alttpr/ketchup.1.zspr create mode 100644 data/sprites/alttpr/kholdstare.1.zspr create mode 100644 data/sprites/alttpr/king_gothalion.1.zspr create mode 100644 data/sprites/alttpr/king_graham.1.zspr create mode 100644 data/sprites/alttpr/kirby-meta.1.zspr create mode 100644 data/sprites/alttpr/kore8.1.zspr create mode 100644 data/sprites/alttpr/lakitu.1.zspr create mode 100644 data/sprites/alttpr/lapras.1.zspr create mode 100644 data/sprites/alttpr/lest.1.zspr create mode 100644 data/sprites/alttpr/lily.1.zspr create mode 100644 data/sprites/alttpr/linja.1.zspr create mode 100644 data/sprites/alttpr/linkhatcolor.1.zspr create mode 100644 data/sprites/alttpr/linktuniccolor.1.zspr create mode 100644 data/sprites/alttpr/littlepony.1.zspr create mode 100644 data/sprites/alttpr/locke_merchant.1.zspr create mode 100644 data/sprites/alttpr/lucario.1.zspr create mode 100644 data/sprites/alttpr/luigi.1.zspr create mode 100644 data/sprites/alttpr/madeline.1.zspr create mode 100644 data/sprites/alttpr/magus.1.zspr create mode 100644 data/sprites/alttpr/maiden.1.zspr create mode 100644 data/sprites/alttpr/mallow-cat.1.zspr create mode 100644 data/sprites/alttpr/mangalink.1.zspr create mode 100644 data/sprites/alttpr/maplequeen.2.zspr create mode 100644 data/sprites/alttpr/marin.2.zspr create mode 100644 data/sprites/alttpr/mario-classic.2.zspr create mode 100644 data/sprites/alttpr/mario_tanooki.1.zspr create mode 100644 data/sprites/alttpr/mariocappy.1.zspr create mode 100644 data/sprites/alttpr/marisa.1.zspr create mode 100644 data/sprites/alttpr/matthias.1.zspr create mode 100644 data/sprites/alttpr/meatwad.1.zspr create mode 100644 data/sprites/alttpr/medallions.1.zspr create mode 100644 data/sprites/alttpr/medli.1.zspr create mode 100644 data/sprites/alttpr/megaman-x.2.zspr create mode 100644 data/sprites/alttpr/metroid.1.zspr create mode 100644 data/sprites/alttpr/mew.1.zspr create mode 100644 data/sprites/alttpr/mike-jones.2.zspr create mode 100644 data/sprites/alttpr/minish_link.1.zspr create mode 100644 data/sprites/alttpr/minishcaplink.2.zspr create mode 100644 data/sprites/alttpr/missingno.1.zspr create mode 100644 data/sprites/alttpr/modernlink.1.zspr create mode 100644 data/sprites/alttpr/mog.2.zspr create mode 100644 data/sprites/alttpr/momiji.1.zspr create mode 100644 data/sprites/alttpr/moosh.1.zspr create mode 100644 data/sprites/alttpr/mouse.1.zspr create mode 100644 data/sprites/alttpr/ms-paintdog.1.zspr create mode 100644 data/sprites/alttpr/mushy.1.zspr create mode 100644 data/sprites/alttpr/naturelink.1.zspr create mode 100644 data/sprites/alttpr/navi.1.zspr create mode 100644 data/sprites/alttpr/navirou.1.zspr create mode 100644 data/sprites/alttpr/ned-flanders.1.zspr create mode 100644 data/sprites/alttpr/negativelink.1.zspr create mode 100644 data/sprites/alttpr/neosad.1.zspr create mode 100644 data/sprites/alttpr/neslink.1.zspr create mode 100644 data/sprites/alttpr/ness.1.zspr create mode 100644 data/sprites/alttpr/nia.1.zspr create mode 100644 data/sprites/alttpr/niko.1.zspr create mode 100644 data/sprites/alttpr/oldman.2.zspr create mode 100644 data/sprites/alttpr/ori.2.zspr create mode 100644 data/sprites/alttpr/outlinelink.1.zspr create mode 100644 data/sprites/alttpr/parallelworldslink.1.zspr create mode 100644 data/sprites/alttpr/paula.1.zspr create mode 100644 data/sprites/alttpr/peach.1.zspr create mode 100644 data/sprites/alttpr/penguinlink.1.zspr create mode 100644 data/sprites/alttpr/pete.1.zspr create mode 100644 data/sprites/alttpr/phoenix-wright.1.zspr create mode 100644 data/sprites/alttpr/pikachu.1.zspr create mode 100644 data/sprites/alttpr/pinkribbonlink.2.zspr create mode 100644 data/sprites/alttpr/piranha_plant.1.zspr create mode 100644 data/sprites/alttpr/plagueknight.1.zspr create mode 100644 data/sprites/alttpr/pokey.1.zspr create mode 100644 data/sprites/alttpr/popoi.1.zspr create mode 100644 data/sprites/alttpr/poppy.1.zspr create mode 100644 data/sprites/alttpr/porg_knight.1.zspr create mode 100644 data/sprites/alttpr/powerpuff_girl.1.zspr create mode 100644 data/sprites/alttpr/pridelink.2.zspr create mode 100644 data/sprites/alttpr/primm.1.zspr create mode 100644 data/sprites/alttpr/princess_bubblegum.1.zspr create mode 100644 data/sprites/alttpr/psyduck.2.zspr create mode 100644 data/sprites/alttpr/pug.1.zspr create mode 100644 data/sprites/alttpr/purplechest-bottle.1.zspr create mode 100644 data/sprites/alttpr/pyro.1.zspr create mode 100644 data/sprites/alttpr/rainbowlink.1.zspr create mode 100644 data/sprites/alttpr/remeer.1.zspr create mode 100644 data/sprites/alttpr/rick.1.zspr create mode 100644 data/sprites/alttpr/robotlink.1.zspr create mode 100644 data/sprites/alttpr/rocko.1.zspr create mode 100644 data/sprites/alttpr/rottytops.1.zspr create mode 100644 data/sprites/alttpr/roykoopa.1.zspr create mode 100644 data/sprites/alttpr/rumia.1.zspr create mode 100644 data/sprites/alttpr/rydia.1.zspr create mode 100644 data/sprites/alttpr/ryu.1.zspr create mode 100644 data/sprites/alttpr/sailormoon.1.zspr create mode 100644 data/sprites/alttpr/saitama.1.zspr create mode 100644 data/sprites/alttpr/samus-sm.1.zspr create mode 100644 data/sprites/alttpr/samus.2.zspr create mode 100644 data/sprites/alttpr/samus_classic.1.zspr create mode 100644 data/sprites/alttpr/santalink.2.zspr create mode 100644 data/sprites/alttpr/scholar.1.zspr create mode 100644 data/sprites/alttpr/selan.1.zspr create mode 100644 data/sprites/alttpr/sevens1ns.1.zspr create mode 100644 data/sprites/alttpr/shadow.1.zspr create mode 100644 data/sprites/alttpr/shadowsaku.2.zspr create mode 100644 data/sprites/alttpr/shantae.1.zspr create mode 100644 data/sprites/alttpr/shuppet.1.zspr create mode 100644 data/sprites/alttpr/shy-gal.1.zspr create mode 100644 data/sprites/alttpr/shy-guy.1.zspr create mode 100644 data/sprites/alttpr/sighn_waive.1.zspr create mode 100644 data/sprites/alttpr/snes-controller.1.zspr create mode 100644 data/sprites/alttpr/sodacan.1.zspr create mode 100644 data/sprites/alttpr/solaire.1.zspr create mode 100644 data/sprites/alttpr/soldiersprite.1.zspr create mode 100644 data/sprites/alttpr/sonic.1.zspr create mode 100644 data/sprites/alttpr/sora.1.zspr create mode 100644 data/sprites/alttpr/sora_kh1.1.zspr create mode 100644 data/sprites/alttpr/squall.1.zspr create mode 100644 data/sprites/alttpr/squirrel.1.zspr create mode 100644 data/sprites/alttpr/squirtle.1.zspr create mode 100644 data/sprites/alttpr/stalfos.1.zspr create mode 100644 data/sprites/alttpr/stan.1.zspr create mode 100644 data/sprites/alttpr/staticlink.1.zspr create mode 100644 data/sprites/alttpr/stick_man.1.zspr create mode 100644 data/sprites/alttpr/superbomb.1.zspr create mode 100644 data/sprites/alttpr/superbunny.2.zspr create mode 100644 data/sprites/alttpr/supermeatboy.1.zspr create mode 100644 data/sprites/alttpr/swatchy.1.zspr create mode 100644 data/sprites/alttpr/tasbot.1.zspr create mode 100644 data/sprites/alttpr/teatime.1.zspr create mode 100644 data/sprites/alttpr/terra.1.zspr create mode 100644 data/sprites/alttpr/tetra.1.zspr create mode 100644 data/sprites/alttpr/tgh.1.zspr create mode 100644 data/sprites/alttpr/thief.1.zspr create mode 100644 data/sprites/alttpr/thomcrow.1.zspr create mode 100644 data/sprites/alttpr/tile.2.zspr create mode 100644 data/sprites/alttpr/tingle.1.zspr create mode 100644 data/sprites/alttpr/tmnt.1.zspr create mode 100644 data/sprites/alttpr/toad.2.zspr create mode 100644 data/sprites/alttpr/toadette.2.zspr create mode 100644 data/sprites/alttpr/toadette_captain.1.zspr create mode 100644 data/sprites/alttpr/totem-links.1.zspr create mode 100644 data/sprites/alttpr/trogdor.1.zspr create mode 100644 data/sprites/alttpr/twilightprincesszelda.2.zspr create mode 100644 data/sprites/alttpr/two_faced.1.zspr create mode 100644 data/sprites/alttpr/ty.1.zspr create mode 100644 data/sprites/alttpr/ultros.1.zspr create mode 100644 data/sprites/alttpr/valeera.1.zspr create mode 100644 data/sprites/alttpr/vanillalink.1.zspr create mode 100644 data/sprites/alttpr/vaporeon.1.zspr create mode 100644 data/sprites/alttpr/vegeta.1.zspr create mode 100644 data/sprites/alttpr/vera.1.zspr create mode 100644 data/sprites/alttpr/vitreous.1.zspr create mode 100644 data/sprites/alttpr/vivi.1.zspr create mode 100644 data/sprites/alttpr/vivian.1.zspr create mode 100644 data/sprites/alttpr/wario.1.zspr create mode 100644 data/sprites/alttpr/will.1.zspr create mode 100644 data/sprites/alttpr/wizzrobe.2.zspr create mode 100644 data/sprites/alttpr/wolf_link.1.zspr create mode 100644 data/sprites/alttpr/wolf_link_tp.1.zspr create mode 100644 data/sprites/alttpr/yoshi.1.zspr create mode 100644 data/sprites/alttpr/yunica.1.zspr create mode 100644 data/sprites/alttpr/zandra.1.zspr create mode 100644 data/sprites/alttpr/zebraunicorn.1.zspr create mode 100644 data/sprites/alttpr/zeck.1.zspr create mode 100644 data/sprites/alttpr/zelda.1.zspr create mode 100644 data/sprites/alttpr/zerosuitsamus.2.zspr create mode 100644 data/sprites/alttpr/zora.2.zspr diff --git a/.gitignore b/.gitignore index 1b54572f..ecd316cb 100644 --- a/.gitignore +++ b/.gitignore @@ -30,5 +30,3 @@ weights/ _persistent_storage.yaml mystery_result_*.yaml /db.db3 -*-errors.txt -success.txt diff --git a/Adjuster.py b/Adjuster.py index 661381a9..49b4259d 100755 --- a/Adjuster.py +++ b/Adjuster.py @@ -6,7 +6,7 @@ import textwrap import sys from AdjusterMain import adjust -from Rom import Sprite +from Rom import get_sprite_from_name class ArgumentDefaultsHelpFormatter(argparse.RawTextHelpFormatter): @@ -55,7 +55,7 @@ def main(): input( 'Could not find valid rom for patching at expected path %s. Please run with -h to see help for further information. \nPress Enter to exit.' % args.rom) sys.exit(1) - if args.sprite is not None and not os.path.isfile(args.sprite) and not Sprite.get_sprite_from_name(args.sprite): + if args.sprite is not None and not os.path.isfile(args.sprite) and not get_sprite_from_name(args.sprite): input('Could not find link sprite sheet at given location. \nPress Enter to exit.') sys.exit(1) @@ -65,10 +65,7 @@ def main(): logging.basicConfig(format='%(message)s', level=loglevel) args, path = adjust(args=args) from Utils import persistent_store - from Rom import Sprite - if isinstance(args.sprite, Sprite): - args.sprite = args.sprite.name - persistent_store("adjuster", "last_settings_3", args) + persistent_store("adjuster", "last_settings", args) if __name__ == '__main__': main() diff --git a/AdjusterMain.py b/AdjusterMain.py index f26c669b..28a72d9c 100644 --- a/AdjusterMain.py +++ b/AdjusterMain.py @@ -27,7 +27,7 @@ def adjust(args): palettes_options['hud']=args.hud_palettes palettes_options['sword']=args.sword_palettes palettes_options['shield']=args.shield_palettes - # palettes_options['link']=args.link_palettesvera + palettes_options['link']=args.link_palettes apply_rom_settings(rom, args.heartbeep, args.heartcolor, args.quickswap, args.fastmenu, args.disablemusic, args.sprite, palettes_options) diff --git a/BaseClasses.py b/BaseClasses.py index eb5a4741..49563d4c 100644 --- a/BaseClasses.py +++ b/BaseClasses.py @@ -119,19 +119,13 @@ class World(object): set_player_attr('treasure_hunt_icon', 'Triforce Piece') set_player_attr('treasure_hunt_count', 0) set_player_attr('clock_mode', False) - set_player_attr('countdown_start_time', 10) - set_player_attr('red_clock_time', -2) - set_player_attr('blue_clock_time', 2) - set_player_attr('green_clock_time', 4) set_player_attr('can_take_damage', True) set_player_attr('glitch_boots', True) set_player_attr('progression_balancing', True) set_player_attr('local_items', set()) - set_player_attr('non_local_items', set()) set_player_attr('triforce_pieces_available', 30) set_player_attr('triforce_pieces_required', 20) set_player_attr('shop_shuffle', 'off') - set_player_attr('shop_shuffle_slots', 0) set_player_attr('shuffle_prizes', "g") set_player_attr('sprite_pool', []) set_player_attr('dark_room_logic', "lamp") @@ -341,27 +335,6 @@ class World(object): if collect: self.state.collect(item, location.event, location) - # TODO: Prevents fast_filling certain items. Move this to a proper filter. - if location.parent_region.shop is not None and location.name != 'Potion Shop': # includes potion shop slots but not potion shop powder - slot_num = int(location.name[-1]) - 1 - my_item = location.parent_region.shop.inventory[slot_num] - if (my_item is not None and my_item['item'] == item.name) or 'Rupee' in item.name or ('Bee' in item.name and 'Trap' not in item.name): - # this will filter items that match the item in the shop or Rupees, or single bees - # really not a way for the player to know a renewable item from a player pool item - # bombs can be sitting on top of arrows or a potion refill, but dunno if that's a big deal - logging.debug('skipping item shop {}'.format(item.name)) - else: - if my_item is None: - location.parent_region.shop.add_inventory(slot_num, 'None', 0) - my_item = location.parent_region.shop.inventory[slot_num] - else: - my_item['replacement'] = my_item['item'] - my_item['replacement_price'] = my_item['price'] - my_item['item'] = item.name - my_item['price'] = self.random.randrange(1, 61) * 5 # can probably replace this with a price chart - my_item['max'] = 1 - my_item['player'] = item.player if item.player != location.player else 0 - logging.debug('Placed %s at %s', item, location) else: raise RuntimeError('Cannot assign item %s to location %s.' % (item, location)) @@ -1162,8 +1135,7 @@ class Shop(): 'max': max, 'replacement': replacement, 'replacement_price': replacement_price, - 'create_location': create_location, - 'player': 0 + 'create_location': create_location } def push_inventory(self, slot: int, item: str, price: int, max: int = 1): @@ -1176,8 +1148,7 @@ class Shop(): 'max': max, 'replacement': self.inventory[slot]["item"], 'replacement_price': self.inventory[slot]["price"], - 'create_location': self.inventory[slot]["create_location"], - 'player': self.inventory[slot]["player"] + 'create_location': self.inventory[slot]["create_location"] } @@ -1263,10 +1234,6 @@ class Spoiler(object): if item is None: continue shopdata['item_{}'.format(index)] = "{} — {}".format(item['item'], item['price']) if item['price'] else item['item'] - - if item['player'] > 0: - shopdata['item_{}'.format(index)] = shopdata['item_{}'.format(index)].replace('—', '(Player {}) — '.format(item['player'])) - if item['max'] == 0: continue shopdata['item_{}'.format(index)] += " x {}".format(item['max']) @@ -1340,7 +1307,6 @@ class Spoiler(object): 'triforce_pieces_available': self.world.triforce_pieces_available, 'triforce_pieces_required': self.world.triforce_pieces_required, 'shop_shuffle': self.world.shop_shuffle, - 'shop_shuffle_slots': self.world.shop_shuffle_slots, 'shuffle_prizes': self.world.shuffle_prizes, 'sprite_pool': self.world.sprite_pool, 'restrict_dungeon_item_on_boss': self.world.restrict_dungeon_item_on_boss diff --git a/EntranceRandomizer.py b/EntranceRandomizer.py index b94ed0db..042d54bc 100755 --- a/EntranceRandomizer.py +++ b/EntranceRandomizer.py @@ -8,7 +8,7 @@ import shlex import sys from Main import main, get_seed -from Rom import Sprite +from Rom import get_sprite_from_name from Utils import is_bundled, close_console @@ -129,14 +129,6 @@ def parse_arguments(argv, no_defaults=False): Timed mode. If time runs out, you lose (but can still keep playing). ''') - parser.add_argument('--countdown_start_time', default=defval(10), type=int, - help='''Set amount of time, in minutes, to start with in Timed Countdown and Timed OHKO modes''') - parser.add_argument('--red_clock_time', default=defval(-2), type=int, - help='''Set amount of time, in minutes, to add from picking up red clocks; negative removes time instead''') - parser.add_argument('--blue_clock_time', default=defval(2), type=int, - help='''Set amount of time, in minutes, to add from picking up blue clocks; negative removes time instead''') - parser.add_argument('--green_clock_time', default=defval(4), type=int, - help='''Set amount of time, in minutes, to add from picking up green clocks; negative removes time instead''') parser.add_argument('--dungeon_counters', default=defval('default'), const='default', nargs='?', choices=['default', 'on', 'pickup', 'off'], help='''\ Select dungeon counter display settings. (default: %(default)s) @@ -181,7 +173,7 @@ def parse_arguments(argv, no_defaults=False): slightly biased to placing progression items with less restrictions. ''') - parser.add_argument('--shuffle', default=defval('vanilla'), const='vanilla', nargs='?', choices=['vanilla', 'simple', 'restricted', 'full', 'crossed', 'insanity', 'restricted_legacy', 'full_legacy', 'madness_legacy', 'insanity_legacy', 'dungeonsfull', 'dungeonssimple'], + parser.add_argument('--shuffle', default=defval('full'), const='full', nargs='?', choices=['vanilla', 'simple', 'restricted', 'full', 'crossed', 'insanity', 'restricted_legacy', 'full_legacy', 'madness_legacy', 'insanity_legacy', 'dungeonsfull', 'dungeonssimple'], help='''\ Select Entrance Shuffling Algorithm. (default: %(default)s) Full: Mix cave and dungeon entrances freely while limiting @@ -266,8 +258,6 @@ def parse_arguments(argv, no_defaults=False): help='Specifies a list of items that will be in your starting inventory (separated by commas)') parser.add_argument('--local_items', default=defval(''), help='Specifies a list of items that will not spread across the multiworld (separated by commas)') - parser.add_argument('--non_local_items', default=defval(''), - help='Specifies a list of items that will spread across the multiworld (separated by commas)') parser.add_argument('--custom', default=defval(False), help='Not supported.') parser.add_argument('--customitemarray', default=defval(False), help='Not supported.') parser.add_argument('--accessibility', default=defval('items'), const='items', nargs='?', choices=['items', 'locations', 'none'], help='''\ @@ -330,11 +320,6 @@ def parse_arguments(argv, no_defaults=False): p: randomize the prices of the items in shop inventories u: shuffle capacity upgrades into the item pool ''') - parser.add_argument('--shop_shuffle_slots', default=defval(0), - type=lambda value: min(max(int(value), 1), 96), - help=''' - Maximum amount of shop slots able to be filled by items from the item pool. - ''') parser.add_argument('--shuffle_prizes', default=defval('g'), choices=['', 'g', 'b', 'gb']) parser.add_argument('--sprite_pool', help='''\ Specifies a colon separated list of sprites used for random/randomonevent. If not specified, the full sprite pool is used.''') @@ -381,16 +366,14 @@ def parse_arguments(argv, no_defaults=False): for name in ['logic', 'mode', 'swords', 'goal', 'difficulty', 'item_functionality', 'shuffle', 'crystals_ganon', 'crystals_gt', 'open_pyramid', 'timer', - 'countdown_start_time', 'red_clock_time', 'blue_clock_time', 'green_clock_time', 'mapshuffle', 'compassshuffle', 'keyshuffle', 'bigkeyshuffle', 'startinventory', - 'local_items', 'non_local_items', 'retro', 'accessibility', 'hints', 'beemizer', + 'local_items', 'retro', 'accessibility', 'hints', 'beemizer', 'shufflebosses', 'enemy_shuffle', 'enemy_health', 'enemy_damage', 'shufflepots', 'ow_palettes', 'uw_palettes', 'sprite', 'disablemusic', 'quickswap', 'fastmenu', 'heartcolor', 'heartbeep', "skip_progression_balancing", "triforce_pieces_available", - "triforce_pieces_required", "shop_shuffle", "shop_shuffle_slots", + "triforce_pieces_required", "shop_shuffle", 'remote_items', 'progressive', 'dungeon_counters', 'glitch_boots', 'killable_thieves', - 'tile_shuffle', 'bush_shuffle', 'shuffle_prizes', 'sprite_pool', 'dark_room_logic', 'restrict_dungeon_item_on_boss', - 'hud_palettes', 'sword_palettes', 'shield_palettes', 'link_palettes']: + 'tile_shuffle', 'bush_shuffle', 'shuffle_prizes', 'sprite_pool', 'dark_room_logic', 'restrict_dungeon_item_on_boss']: value = getattr(defaults, name) if getattr(playerargs, name) is None else getattr(playerargs, name) if player == 1: setattr(ret, name, {1: value}) @@ -417,7 +400,7 @@ def start(): input( 'Could not find valid base rom for patching at expected path %s. Please run with -h to see help for further information. \nPress Enter to exit.' % args.rom) sys.exit(1) - if any([sprite is not None and not os.path.isfile(sprite) and not Sprite.get_sprite_from_name(sprite) for sprite in + if any([sprite is not None and not os.path.isfile(sprite) and not get_sprite_from_name(sprite) for sprite in args.sprite.values()]): input('Could not find link sprite sheet at given location. \nPress Enter to exit.') sys.exit(1) diff --git a/Fill.py b/Fill.py index 1212f6e0..9051f93a 100644 --- a/Fill.py +++ b/Fill.py @@ -54,9 +54,8 @@ def fill_restrictive(world, base_state: CollectionState, locations, itempool, si for location in region.locations: if location.item and not location.event: placements.append(location) - raise FillError(f'No more spots to place {item_to_place}, locations {locations} are invalid. ' - f'Already placed {len(placements)}: {", ".join(str(place) for place in placements)}') + f'Already placed {len(placements)}: {", ".join(placements)}') world.push_item(spot_to_fill, item_to_place, False) locations.remove(spot_to_fill) diff --git a/GuiUtils.py b/GuiUtils.py index c0542076..0bebfda6 100644 --- a/GuiUtils.py +++ b/GuiUtils.py @@ -14,12 +14,12 @@ def set_icon(window): # some which may be platform specific, or depend on if the TCL library was compiled without # multithreading support. Therefore I will assume it is not thread safe to avoid any possible problems class BackgroundTask(object): - def __init__(self, window, code_to_run, *args): + def __init__(self, window, code_to_run): self.window = window self.queue = queue.Queue() self.running = True self.process_queue() - self.task = threading.Thread(target=code_to_run, args=(self, *args)) + self.task = threading.Thread(target=code_to_run, args=(self,)) self.task.start() def stop(self): @@ -45,7 +45,7 @@ class BackgroundTask(object): self.window.after(100, self.process_queue) class BackgroundTaskProgress(BackgroundTask): - def __init__(self, parent, code_to_run, title, *args): + def __init__(self, parent, code_to_run, title): self.parent = parent self.window = tk.Toplevel(parent) self.window['padx'] = 5 @@ -65,7 +65,7 @@ class BackgroundTaskProgress(BackgroundTask): set_icon(self.window) self.window.focus() - super().__init__(self.window, code_to_run, *args) + super().__init__(self.window, code_to_run) #safe to call from worker thread def update_status(self, text): diff --git a/Main.py b/Main.py index e66e2181..e96b4bbc 100644 --- a/Main.py +++ b/Main.py @@ -10,7 +10,7 @@ import zlib import concurrent.futures from BaseClasses import World, CollectionState, Item, Region, Location, Shop -from Items import ItemFactory, item_table +from Items import ItemFactory from Regions import create_regions, create_shops, mark_light_world_regions, lookup_vanilla_location_to_entrance from InvertedRegions import create_inverted_regions, mark_dark_world_regions from EntranceShuffle import link_entrances, link_inverted_entrances @@ -72,10 +72,6 @@ def main(args, seed=None): world.tile_shuffle = args.tile_shuffle.copy() world.beemizer = args.beemizer.copy() world.timer = args.timer.copy() - world.countdown_start_time = args.countdown_start_time.copy() - world.red_clock_time = args.red_clock_time.copy() - world.blue_clock_time = args.blue_clock_time.copy() - world.green_clock_time = args.green_clock_time.copy() world.shufflepots = args.shufflepots.copy() world.progressive = args.progressive.copy() world.dungeon_counters = args.dungeon_counters.copy() @@ -83,7 +79,6 @@ def main(args, seed=None): world.triforce_pieces_available = args.triforce_pieces_available.copy() world.triforce_pieces_required = args.triforce_pieces_required.copy() world.shop_shuffle = args.shop_shuffle.copy() - world.shop_shuffle_slots = args.shop_shuffle_slots.copy() world.progression_balancing = {player: not balance for player, balance in args.skip_progression_balancing.items()} world.shuffle_prizes = args.shuffle_prizes.copy() world.sprite_pool = args.sprite_pool.copy() @@ -111,13 +106,7 @@ def main(args, seed=None): item = ItemFactory(tok.strip(), player) if item: world.push_precollected(item) - # item in item_table gets checked in mystery, but not CLI - so we double-check here - world.local_items[player] = {item.strip() for item in args.local_items[player].split(',') if - item.strip() in item_table} - world.non_local_items[player] = {item.strip() for item in args.non_local_items[player].split(',') if - item.strip() in item_table} - # items can't be both local and non-local, prefer local - world.non_local_items[player] -= world.local_items[player] + world.local_items[player] = {item.strip() for item in args.local_items[player].split(',')} world.triforce_pieces_available[player] = max(world.triforce_pieces_available[player], world.triforce_pieces_required[player]) @@ -308,30 +297,6 @@ def main(args, seed=None): if lookup_vanilla_location_to_entrance[location.address] != main_entrance.name: er_hint_data[region.player][location.address] = main_entrance.name - ordered_areas = ('Light World', 'Dark World', 'Hyrule Castle', 'Agahnims Tower', 'Eastern Palace', 'Desert Palace', - 'Tower of Hera', 'Palace of Darkness', 'Swamp Palace', 'Skull Woods', 'Thieves Town', 'Ice Palace', - 'Misery Mire', 'Turtle Rock', 'Ganons Tower', "Total") - - checks_in_area = {player: {area: list() for area in ordered_areas} - for player in range(1, world.players + 1)} - - for player in range(1, world.players + 1): - checks_in_area[player]["Total"] = 0 - - for location in [loc for loc in world.get_filled_locations() if type(loc.address) is int]: - main_entrance = get_entrance_to_region(location.parent_region) - if location.parent_region.dungeon: - dungeonname = {'Inverted Agahnims Tower': 'Agahnims Tower', - 'Inverted Ganons Tower': 'Ganons Tower'}\ - .get(location.parent_region.dungeon.name, location.parent_region.dungeon.name) - checks_in_area[location.player][dungeonname].append(location.address) - elif main_entrance.parent_region.type == RegionType.LightWorld: - checks_in_area[location.player]["Light World"].append(location.address) - elif main_entrance.parent_region.type == RegionType.DarkWorld: - checks_in_area[location.player]["Dark World"].append(location.address) - checks_in_area[location.player]["Total"] += 1 - - precollected_items = [[] for player in range(world.players)] for item in world.precollected_items: precollected_items[item.player - 1].append(item.code) @@ -358,7 +323,6 @@ def main(args, seed=None): (location.item.code, location.item.player)) for location in world.get_filled_locations() if type(location.address) is int], - "checks_in_area": checks_in_area, "server_options": get_options()["server_options"], "er_hint_data": er_hint_data, "precollected_items": precollected_items, diff --git a/Mystery.py b/Mystery.py index c8261f03..aebc38e7 100644 --- a/Mystery.py +++ b/Mystery.py @@ -11,7 +11,7 @@ import ModuleUpdate ModuleUpdate.update() from Utils import parse_yaml -from Rom import Sprite +from Rom import get_sprite_from_name from EntranceRandomizer import parse_arguments from Main import main as ERmain from Main import get_seed, seeddigits @@ -167,7 +167,7 @@ def main(args=None, callback=ERmain): if path: try: settings = settings_cache[path] if settings_cache[path] else roll_settings(weights_cache[path]) - if settings.sprite and not os.path.isfile(settings.sprite) and not Sprite.get_sprite_from_name( + if settings.sprite and not os.path.isfile(settings.sprite) and not get_sprite_from_name( settings.sprite): logging.warning( f"Warning: The chosen sprite, \"{settings.sprite}\", for yaml \"{path}\", does not exist.") @@ -238,8 +238,6 @@ def convert_to_on_off(value): def get_choice(option, root, value=None) -> typing.Any: if option not in root: return value - if type(root[option]) is list: - return interpret_on_off(random.choices(root[option])[0]) if type(root[option]) is not dict: return interpret_on_off(root[option]) if not root[option]: @@ -362,8 +360,6 @@ def roll_settings(weights): # change minimum to required pieces to avoid problems ret.triforce_pieces_available = min(max(ret.triforce_pieces_required, int(ret.triforce_pieces_available)), 90) - ret.shop_shuffle_slots = int(get_choice('shop_shuffle_slots', weights, '0')) - ret.shop_shuffle = get_choice('shop_shuffle', weights, '') if not ret.shop_shuffle: ret.shop_shuffle = '' @@ -452,11 +448,6 @@ def roll_settings(weights): 'timed_countdown': 'timed-countdown', 'display': 'display'}[get_choice('timer', weights, False)] - ret.countdown_start_time = int(get_choice('countdown_start_time', weights, 10)) - ret.red_clock_time = int(get_choice('red_clock_time', weights, -2)) - ret.blue_clock_time = int(get_choice('blue_clock_time', weights, 2)) - ret.green_clock_time = int(get_choice('green_clock_time', weights, 4)) - ret.dungeon_counters = get_choice('dungeon_counters', weights, 'default') ret.progressive = convert_to_on_off(get_choice('progressive', weights, 'on')) @@ -496,17 +487,6 @@ def roll_settings(weights): ret.local_items = ",".join(ret.local_items) - ret.non_local_items = set() - for item_name in weights.get('non_local_items', []): - items = item_name_groups.get(item_name, {item_name}) - for item in items: - if item in item_table: - ret.non_local_items.add(item) - else: - raise Exception(f"Could not force item {item} to be world-non-local, as it was not recognized.") - - ret.non_local_items = ",".join(ret.non_local_items) - if 'rom' in weights: romweights = weights['rom'] diff --git a/Regions.py b/Regions.py index 11968766..58049039 100644 --- a/Regions.py +++ b/Regions.py @@ -368,17 +368,7 @@ def create_shops(world, player: int): cls_mapping = {ShopType.UpgradeShop: UpgradeShop, ShopType.Shop: Shop, ShopType.TakeAny: TakeAny} - option = world.shop_shuffle[player] - my_shop_table = dict(shop_table) - - num_slots = int(world.shop_shuffle_slots[player]) - - my_shop_slots = ([True] * num_slots + [False] * (len(shop_table) * 3))[:len(shop_table)*3 - 2] - - world.random.shuffle(my_shop_slots) - - from Items import ItemFactory - for region_name, (room_id, type, shopkeeper, custom, locked, inventory) in my_shop_table.items(): + for region_name, (room_id, type, shopkeeper, custom, locked, inventory) in shop_table.items(): if world.mode[player] == 'inverted' and region_name == 'Dark Lake Hylia Shop': locked = True inventory = [('Blue Potion', 160), ('Blue Shield', 50), ('Bombs (10)', 50)] @@ -388,19 +378,6 @@ def create_shops(world, player: int): world.shops.append(shop) for index, item in enumerate(inventory): shop.add_inventory(index, *item) - if region_name == 'Potion Shop': - pass - elif region_name == 'Capacity Upgrade': - pass - else: - if my_shop_slots.pop(): - additional_item = world.random.choice(['Rupees (20)', 'Rupees (50)', 'Rupees (100)']) - world.itempool.append(ItemFactory(additional_item, player)) - loc = Location(player, "{} Slot Item {}".format(shop.region.name, index+1), parent=shop.region) - shop.region.locations.append(loc) - world.dynamic_locations.append(loc) - - world.clear_location_cache() # (type, room_id, shopkeeper, custom, locked, [items]) # item = (item, price, max=0, replacement=None, replacement_price=0) @@ -416,63 +393,10 @@ shop_table = { 'Light World Death Mountain Shop': (0x00FF, ShopType.Shop, 0xA0, True, False, _basic_shop_defaults), 'Kakariko Shop': (0x011F, ShopType.Shop, 0xA0, True, False, _basic_shop_defaults), 'Cave Shop (Lake Hylia)': (0x0112, ShopType.Shop, 0xA0, True, False, _basic_shop_defaults), - 'Potion Shop': (0x0109, ShopType.Shop, 0xA0, True, False, [('Red Potion', 120), ('Green Potion', 60), ('Blue Potion', 160)]), + 'Potion Shop': (0x0109, ShopType.Shop, 0xFF, False, True, [('Red Potion', 120), ('Green Potion', 60), ('Blue Potion', 160)]), 'Capacity Upgrade': (0x0115, ShopType.UpgradeShop, 0x04, True, True, [('Bomb Upgrade (+5)', 100, 7), ('Arrow Upgrade (+5)', 100, 7)]) } -old_location_address_to_new_location_address = { - 0x2eb18: 0x18001b, # Bottle Merchant - 0x33d68: 0x18001a, # Purple Chest - 0x2df45: 0x18001d, # Link's Uncle - 0x2f1fc: 0x180008, # Sahasrahla - 0x18002a: 0x18001c, # Black Smith - 0x339cf: 0x180009, # Sick Kid - 0x33e7d: 0x180019, # Hobo - 0x180160: 0x18000b, # Desert Palace - Desert Torch - 0x289b0: 0x180018, # Master Sword Pedestal - 0xf69fa: 0x180007, # Old Man - 0x180162: 0x18000d, # Tower of Hera - Basement Cage - 0x330c7: 0x18000a, # Stumpy - 0x180161: 0x18000c # Ganons Tower - Bob's Torch -} - - -key_drop_data = { - 'Hyrule Castle - Map Guard Key Drop': [0x140036, 0x140037], - 'Hyrule Castle - Boomerang Guard Key Drop': [0x140033, 0x140034], - 'Hyrule Castle - Key Rat Key Drop': [0x14000c, 0x14000d], - 'Hyrule Castle - Big Key Drop': [0x14003c, 0x14003d], - 'Eastern Palace - Dark Square Pot Key': [0x14005a, 0x14005b], - 'Eastern Palace - Dark Eyegore Key Drop': [0x140048, 0x140049], - 'Desert Palace - Desert Tiles 1 Pot Key': [0x140030, 0x140031], - 'Desert Palace - Beamos Hall Pot Key': [0x14002a, 0x14002b], - 'Desert Palace - Desert Tiles 2 Pot Key': [0x140027, 0x140028], - 'Castle Tower - Dark Archer Key Drop': [0x140060, 0x140061], - 'Castle Tower - Circle of Pots Key Drop': [0x140051, 0x140052], - 'Swamp Palace - Pot Row Pot Key': [0x140018, 0x140019], - 'Swamp Palace - Trench 1 Pot Key': [0x140015, 0x140016], - 'Swamp Palace - Hookshot Pot Key': [0x140012, 0x140013], - 'Swamp Palace - Trench 2 Pot Key': [0x14000f, 0x140010], - 'Swamp Palace - Waterway Pot Key': [0x140009, 0x14000a], - 'Skull Woods - West Lobby Pot Key': [0x14002d, 0x14002e], - 'Skull Woods - Spike Corner Key Drop': [0x14001b, 0x14001c], - 'Thieves\' Town - Hallway Pot Key': [0x14005d, 0x14005e], - 'Thieves\' Town - Spike Switch Pot Key': [0x14004e, 0x14004f], - 'Ice Palace - Jelly Key Drop': [0x140003, 0x140004], - 'Ice Palace - Conveyor Key Drop': [0x140021, 0x140022], - 'Ice Palace - Hammer Block Key Drop': [0x140024, 0x140025], - 'Ice Palace - Many Pots Pot Key': [0x140045, 0x140046], - 'Misery Mire - Spikes Pot Key': [0x140054, 0x140055], - 'Misery Mire - Fishbone Pot Key': [0x14004b, 0x14004c], - 'Misery Mire - Conveyor Crystal Key Drop': [0x140063, 0x140064], - 'Turtle Rock - Pokey 1 Key Drop': [0x140057, 0x140058], - 'Turtle Rock - Pokey 2 Key Drop': [0x140006, 0x140007], - 'Ganons Tower - Conveyor Cross Pot Key': [0x14003f, 0x140040], - 'Ganons Tower - Double Switch Pot Key': [0x140042, 0x140043], - 'Ganons Tower - Conveyor Star Pits Pot Key': [0x140039, 0x14003a], - 'Ganons Tower - Mini Helmasaur Key Drop': [0x14001e, 0x14001f] -} - location_table = {'Mushroom': (0x180013, 0x186338, False, 'in the woods'), 'Bottle Merchant': (0x2eb18, 0x186339, False, 'with a merchant'), 'Flute Spot': (0x18014a, 0x18633d, False, 'underground'), @@ -716,9 +640,7 @@ location_table = {'Mushroom': (0x180013, 0x186338, False, 'in the woods'), [0x120A7, 0x53F24, 0x53F25, 0x18005C, 0x180079, 0xC708], None, True, 'Turtle Rock')} lookup_id_to_name = {data[0]: name for name, data in location_table.items() if type(data[0]) == int} -lookup_id_to_name = {**lookup_id_to_name, **{data[1]: name for name, data in key_drop_data.items()}, -1: "cheat console"} -lookup_name_to_id = {name: data[0] for name, data in location_table.items() if type(data[0]) == int} -lookup_name_to_id = {**lookup_name_to_id, **{name: data[1] for name, data in key_drop_data.items()}, "cheat console": -1} +lookup_id_to_name[-1] = "cheat console" lookup_vanilla_location_to_entrance = {1572883: 'Kings Grave Inner Rocks', 191256: 'Kings Grave Inner Rocks', 1573194: 'Kings Grave Inner Rocks', 1573189: 'Kings Grave Inner Rocks', @@ -823,28 +745,7 @@ lookup_vanilla_location_to_entrance = {1572883: 'Kings Grave Inner Rocks', 19125 60103: 'Ganons Tower', 60106: 'Ganons Tower', 60109: 'Ganons Tower', 60127: 'Ganons Tower', 60118: 'Ganons Tower', 60148: 'Ganons Tower', 60151: 'Ganons Tower', 60145: 'Ganons Tower', 60157: 'Ganons Tower', - 60160: 'Ganons Tower', 60163: 'Ganons Tower', 60166: 'Ganons Tower', - 0x140037: 'Hyrule Castle Entrance (South)', - 0x140034: 'Hyrule Castle Entrance (South)', - 0x14000d: 'Hyrule Castle Entrance (South)', - 0x14003d: 'Hyrule Castle Entrance (South)', - 0x14005b: 'Eastern Palace', 0x140049: 'Eastern Palace', - 0x140031: 'Desert Palace Entrance (North)', - 0x14002b: 'Desert Palace Entrance (North)', - 0x140028: 'Desert Palace Entrance (North)', - 0x140061: 'Agahnims Tower', 0x140052: 'Agahnims Tower', - 0x140019: 'Swamp Palace', 0x140016: 'Swamp Palace', 0x140013: 'Swamp Palace', - 0x140010: 'Swamp Palace', 0x14000a: 'Swamp Palace', - 0x14002e: 'Skull Woods Second Section Door (East)', - 0x14001c: 'Skull Woods Final Section', - 0x14005e: 'Thieves Town', 0x14004f: 'Thieves Town', - 0x140004: 'Ice Palace', 0x140022: 'Ice Palace', - 0x140025: 'Ice Palace', 0x140046: 'Ice Palace', - 0x140055: 'Misery Mire', 0x14004c: 'Misery Mire', - 0x140064: 'Misery Mire', - 0x140058: 'Turtle Rock', 0x140007: 'Dark Death Mountain Ledge (West)', - 0x140040: 'Ganons Tower', 0x140043: 'Ganons Tower', - 0x14003a: 'Ganons Tower', 0x14001f: 'Ganons Tower'} + 60160: 'Ganons Tower', 60163: 'Ganons Tower', 60166: 'Ganons Tower'} lookup_prizes = {location for location in location_table if location.endswith(" - Prize")} lookup_boss_drops = {location for location in location_table if location.endswith(" - Boss")} \ No newline at end of file diff --git a/Rules.py b/Rules.py index 3c12d9b3..3fb96c9a 100644 --- a/Rules.py +++ b/Rules.py @@ -104,7 +104,7 @@ def mirrorless_path_to_castle_courtyard(world, player): else: queue.append((entrance.connected_region, new_path)) - raise Exception(f"Could not find mirrorless path to castle courtyard for Player {player} ({world.get_player_names(player)})") + raise Exception(f"Could not find mirrorless path to castle courtyard for Player {player}") def set_rule(spot, rule): spot.access_rule = rule @@ -179,10 +179,6 @@ def locality_rules(world, player): for location in world.get_locations(): if location.player != player: forbid_items_for_player(location, world.local_items[player], player) - if world.non_local_items[player]: - for location in world.get_locations(): - if location.player == player: - forbid_items_for_player(location, world.non_local_items[player], player) non_crossover_items = (item_name_groups["Small Keys"] | item_name_groups["Big Keys"] | progression_items) - { diff --git a/Text.py b/Text.py index 4c723afb..83a7400b 100644 --- a/Text.py +++ b/Text.py @@ -266,7 +266,7 @@ junk_texts = [ "{C:GREEN}\n>Secret power\nis said to be\nin the arrow.", "{C:GREEN}\nAim at the\neyes of Gohma.\n >", "{C:GREEN}\nGrumble,\ngrumble…\n >", - # "{C:GREEN}\n10th enemy\nhas the bomb.\n >", removed as people may assume it applies to this game + "{C:GREEN}\n10th enemy\nhas the bomb.\n >", "{C:GREEN}\nGo to the\nnext room.\n >", "{C:GREEN}\n>Thanks, @\nYou’re the\nhero of Hyrule", "{C:GREEN}\nThere’s always\nmoney in the\nBanana Stand>", @@ -1228,8 +1228,7 @@ class GoldCreditMapper(CharTextMapper): class GreenCreditMapper(CharTextMapper): char_map = {' ': 0x9F, - '·': 0x52, - '.': 0x52} + '·': 0x52} alpha_offset = -0x29 class RedCreditMapper(CharTextMapper): diff --git a/WebHostLib/__init__.py b/WebHostLib/__init__.py index c392990b..98d3aea4 100644 --- a/WebHostLib/__init__.py +++ b/WebHostLib/__init__.py @@ -47,8 +47,6 @@ app.config["PONY"] = { } app.config["MAX_ROLL"] = 20 app.config["CACHE_TYPE"] = "simple" -app.config["JSON_AS_ASCII"] = False - app.autoversion = True av = Autoversion(app) cache = Cache(app) diff --git a/WebHostLib/downloads.py b/WebHostLib/downloads.py index e8c32b83..5dc71788 100644 --- a/WebHostLib/downloads.py +++ b/WebHostLib/downloads.py @@ -37,10 +37,9 @@ def download_raw_patch(seed_id, player_id): return "Patch not found" else: import io - if patch.seed.multidata: - pname = patch.seed.multidata["names"][0][patch.player - 1] - else: - pname = "unknown" + + pname = patch.seed.multidata["names"][0][patch.player - 1] + patch_data = update_patch_data(patch.data, server="") patch_data = io.BytesIO(patch_data) diff --git a/WebHostLib/models.py b/WebHostLib/models.py index 77bd6f2f..d5e0f2b8 100644 --- a/WebHostLib/models.py +++ b/WebHostLib/models.py @@ -50,5 +50,5 @@ class Generation(db.Entity): id = PrimaryKey(UUID, default=uuid4) owner = Required(UUID) options = Required(bytes, lazy=True) # these didn't work as JSON on mariaDB, so they're getting pickled now - meta = Required(bytes, lazy=True) # if state is -1 (error) this will contain an utf-8 encoded error message + meta = Required(bytes, lazy=True) state = Required(int, default=0, index=True) diff --git a/WebHostLib/requirements.txt b/WebHostLib/requirements.txt index f7a97f65..fc34a2dd 100644 --- a/WebHostLib/requirements.txt +++ b/WebHostLib/requirements.txt @@ -3,5 +3,5 @@ pony>=0.7.14 waitress>=1.4.4 flask-caching>=1.9.0 Flask-Autoversion>=0.2.0 -Flask-Compress>=1.8.0 +Flask-Compress>=1.7.0 Flask-Limiter>=1.4 diff --git a/WebHostLib/static/static/weightedSettings.yaml b/WebHostLib/static/static/weightedSettings.yaml index b6e7747f..ddd21714 100644 --- a/WebHostLib/static/static/weightedSettings.yaml +++ b/WebHostLib/static/static/weightedSettings.yaml @@ -165,6 +165,7 @@ item_pool: normal: 50 # Item availability remains unchanged from vanilla game hard: 0 # Reduced upgrade availability (max: 14 hearts, blue mail, tempered sword, fire shield, no silvers unless swordless) expert: 0 # Minimum upgrade availability (max: 8 hearts, green mail, master sword, fighter shield, no silvers unless swordless) + crowd_control: 0 # Sets up the item pool for the crowd control extension. Do not use it without crowd control item_functionality: easy: 0 # Allow Hammer to damage ganon, Allow Hammer tablet collection, Allow swordless medallion use everywhere. normal: 50 # Vanilla item functionality @@ -231,22 +232,6 @@ timer: ohko: 0 # Timer always at zero. Permanent OHKO. timed_countdown: 0 # Starts the clock with forty minutes. Same clocks as timed mode, but if the clock hits zero you lose. You can still keep playing, though. display: 0 # Displays a timer, but otherwise does not affect gameplay or the item pool. -countdown_start_time: # For timed_ohko and timed_countdown timer modes, the amount of time in minutes to start with - 0: 0 # For timed_ohko, starts in OHKO mode when starting the game - 10: 50 - 20: 0 - 30: 0 - 60: 0 -red_clock_time: # For all timer modes, the amount of time in minutes to gain or lose when picking up a red clock - -2: 50 - 1: 0 -blue_clock_time: # For all timer modes, the amount of time in minutes to gain or lose when picking up a blue clock - 1: 0 - 2: 50 -green_clock_time: # For all timer modes, the amount of time in minutes to gain or lose when picking up a green clock - 4: 50 - 10: 0 - 15: 0 # Can be uncommented to use it # local_items: # Force certain items to appear in your world only, not across the multiworld. Recognizes some group names, like "Swords" # - "Moon Pearl" @@ -304,9 +289,6 @@ intensity: # Only available if the host uses the doors branch, it is ignored oth 2: 0 # And shuffles open edges and straight staircases 3: 0 # And shuffles dungeon lobbies random: 0 # Picks one of those at random -key_drop_shuffle: # Only available if the host uses the doors branch, it is ignored otherwise - on: 0 # Enables the small keys dropped by enemies or under pots, and the big key dropped by the Ball & Chain guard to be shuffled into the pool. This extends the number of checks to 249. - off: 50 experimental: # Only available if the host uses the doors branch, it is ignored otherwise on: 0 # Enables experimental features. Currently, this is just the dungeon keys in chest counter. off: 50 @@ -409,3 +391,13 @@ rom: dizzy: 0 sick: 0 puke: 0 + uw_palettes: # Change the colors of shields + default: 50 # No changes + random: 0 # Shuffle the colors + blackout: 0 # Never use this + grayscale: 0 + negative: 0 + classic: 0 + dizzy: 0 + sick: 0 + puke: 0 \ No newline at end of file diff --git a/WebHostLib/templates/tracker.html b/WebHostLib/templates/tracker.html index 3a528c16..27211ede 100644 --- a/WebHostLib/templates/tracker.html +++ b/WebHostLib/templates/tracker.html @@ -124,7 +124,7 @@
Dm4Ra&AO34Ib@(TKy?{0+KjKn)NgvmA}II
zcmG%GD=(bHjsY&u>&Fr=CpdB^Fz>ycg`7G2Me^R;S;01YV+HZv+t(9gm7O=d_x7dD
zW0l=_e>|I`){p>Y|3zwkdPaIi1UgapFD4Ol?$5?5Gd6f0dh2w@+~Z|?zZd6TY;ERM
zeB6?7sh;$T^tAQ2#c);(Yt=>GbAd+&*!C0S4R*ywW5c^&N{0n*#~F9l8ECLUJZP`@
zRS$GHe4s%qCozXr-kub4n4m!~pgx(+Ckv_mp|~$}fia(pHMKvy&Ncl9l24>w3zsN1
zELJf2WHFWbZu~@06DycBaxa7rL&y*v@=vpTki!2TGy|sap$Zw`hWz-KWPs(t)>9IO
zWEGwB=QisV!-7wjsz-dsE+V?_R&C6`e?9(Ijo-5c&KWFr;n~L-EH)Ou`3=^V+V~q&
zI8#%}6z<+{U*PeNYSs9;HGZ7IXV-IYwu7tK^5F9)D3>JUN1tXRXaXgPJ@i%V28CMr
z!KeCF{hw?H^l6;$C<@yFIK!`UfBOV9yB_b)Iswhb(7d2 f*c&uXkUp3s1JSgg>zu_NBgYHKl$K6|}uj#O&Q7nfy>eY(9;DmCU)
z+L|Jimy$;LKX_Wy!(u=0*fZc6!KX2Y6j0){k6t!xs{7#?LY)iqZ!C%UcfKU+aG$
z)q~z|x5A=6g!b>cJ4b?+!0v#5ssE~PTq!d4P{`TWmhf!wf5MhO9-8I)U^wd8>CM@v
zTeQoV8ku2z%9h^*&VAl0n^)EI!KczQnr13~P{7CL-*(6JrsgRg$OFOuyY`N0%q<07
zxB2(Xk&(gCp+de;<^N^sa(CR3i#!nB5{TkzUDG2?QFqqyBs3P|GCrAnvBql?yLRmB
zSr@fwap(T(!Q-2^SI0i%LQ~Pb&F%>!qKY$dvW#oVlFR!eakGxgjw>x0S3+y|@@PQ&
z?dR8}yfK#;EkwEe+JU%PQb!{^nuz>Y@0#k1#7r^T&_BnHmKfS6yg|FZuy%(YLHh&=
zoXbD5KZCn9?OL?I@`%zON#!MuJF>GkMG^sVHc`*C9p1D@wkFzeB!;WougRvcfxPzB
ztK{giw$mGQ`D;(WT5C+#yi)oR^$m_`nS7msQs^4&kMI)}Wt;w3B+(J{V*K0kcZ2K0
z?s+twRE!apzaga@yfkt;KYXBQS-_pv+w>;J;s^z5Pc=&YkuPr5+{a#%Ge6#
{
zcB5o}2rQZcQz&BItD8J#k+T2_dsD1?7zd#H7EIe|kG}-25cXgP!KwFaJpLGSUK#Je
z89!O}mVmJf<=K&;ld2E)KjWxp5$`r!+rOZ@J>ug1FYEgkVBFxjk4D7$T6kg42D^nk
zu+Tn@m6}We{m1OZMJec0&fw#_XZ+~i3i20%kQPS%2<{*>8ouDe`n&xG_aFKcJjeTY
zKIzP9ITf3PfakhBv!{L5mLE~tx_@tq_thO&OB%oZ^!{S1sE-Ym(0j&T+LIMHf!*V~YNgf!
nMI3x
zaNZiV(D#9&IV$iqpgHuxR~wWvunYYcHcU{;Ku8Z`AP-4nYkYZs<{t~K{rXGD7uKr1
zRhk|Mh|cgk$4A3E5x9_ow3~@h#_sPSj9WaD&nUdyC-~+4_m1T8l%D1Lu_R~zy$?TZ
zal-GQ71Tg00~~*ldP|4*&+!MM6wRd4)
%ow~~K0Qj`-tx|e?=M?+qsZ=g3DH1VRQ&vCR$&=GFJ6NG
z?t#W*o%i1P&&$ofcE`6K(u$vO$G6hq2_ZmKeCvzpz2~_<9I4~@T5JBkJlkFSZ+mCe
zyN6j1e;_XHu2sh2N!G*hxDLB(&&W&PUA(d6FLuvlbgJ==(04sIR`~th-I>gC-`}P3
z_olLiiCI_vUK;Nl62VgWdt3c2$Xet0m&_vEhS`4^|B^VKmJx=L)Bk=%d`ShEw?v05yUx3Ia_!LjZ(i}(u=hWqe$hI(xpwIN3tX3C{4?*b
zcM3mzR4Te{tVW)ERGjOyxDDi_$Ar|zt!gBL=~gw;nl!Lp-Zett@62xcsKB0YjDbLT
zLQ2@JB>fSMv}!>R_%S26bUE99rjL}e!bEcsu6
z{6Fxu^8e+3wmjcI97h+76r*mXv)n|CPi_kxsK{Vl@8}thZ(hi-1yq=iIZ+I47RPpr
z=