diff options
Diffstat (limited to 'AnodyneArchipelago')
| -rw-r--r-- | AnodyneArchipelago/ArchipelagoManager.cs | 9 | ||||
| -rw-r--r-- | AnodyneArchipelago/Menu/ConnectionState.cs | 10 | ||||
| -rw-r--r-- | AnodyneArchipelago/Menu/MenuState.cs | 6 | ||||
| -rw-r--r-- | AnodyneArchipelago/Patches/GameplayPatches.cs | 9 |
4 files changed, 33 insertions, 1 deletions
| diff --git a/AnodyneArchipelago/ArchipelagoManager.cs b/AnodyneArchipelago/ArchipelagoManager.cs index 34ca75a..e4ccf36 100644 --- a/AnodyneArchipelago/ArchipelagoManager.cs +++ b/AnodyneArchipelago/ArchipelagoManager.cs | |||
| @@ -20,10 +20,13 @@ namespace AnodyneArchipelago | |||
| 20 | private ArchipelagoSession _session; | 20 | private ArchipelagoSession _session; |
| 21 | private int _itemIndex = 0; | 21 | private int _itemIndex = 0; |
| 22 | private string _seedName; | 22 | private string _seedName; |
| 23 | private long _endgameCardRequirement = 36; | ||
| 23 | 24 | ||
| 24 | private readonly Queue<NetworkItem> _itemsToCollect = new(); | 25 | private readonly Queue<NetworkItem> _itemsToCollect = new(); |
| 25 | private readonly Queue<string> _messages = new(); | 26 | private readonly Queue<string> _messages = new(); |
| 26 | 27 | ||
| 28 | public long EndgameCardRequirement => _endgameCardRequirement; | ||
| 29 | |||
| 27 | public async Task<LoginResult> Connect(string url, string slotName, string password) | 30 | public async Task<LoginResult> Connect(string url, string slotName, string password) |
| 28 | { | 31 | { |
| 29 | LoginResult result; | 32 | LoginResult result; |
| @@ -45,6 +48,12 @@ namespace AnodyneArchipelago | |||
| 45 | _itemIndex = 0; | 48 | _itemIndex = 0; |
| 46 | _itemsToCollect.Clear(); | 49 | _itemsToCollect.Clear(); |
| 47 | 50 | ||
| 51 | LoginSuccessful login = result as LoginSuccessful; | ||
| 52 | if (login.SlotData.ContainsKey("endgame_card_requirement")) | ||
| 53 | { | ||
| 54 | _endgameCardRequirement = (long)login.SlotData["endgame_card_requirement"]; | ||
| 55 | } | ||
| 56 | |||
| 48 | return result; | 57 | return result; |
| 49 | } | 58 | } |
| 50 | 59 | ||
| diff --git a/AnodyneArchipelago/Menu/ConnectionState.cs b/AnodyneArchipelago/Menu/ConnectionState.cs index 877213f..3eac618 100644 --- a/AnodyneArchipelago/Menu/ConnectionState.cs +++ b/AnodyneArchipelago/Menu/ConnectionState.cs | |||
| @@ -50,6 +50,16 @@ namespace AnodyneArchipelago.Menu | |||
| 50 | { | 50 | { |
| 51 | if (_connectionTask != null && _connectionTask.IsCompleted) | 51 | if (_connectionTask != null && _connectionTask.IsCompleted) |
| 52 | { | 52 | { |
| 53 | if (_connectionTask.IsFaulted) | ||
| 54 | { | ||
| 55 | _text = _connectionTask.Exception.ToString(); | ||
| 56 | _connectionTask = null; | ||
| 57 | |||
| 58 | UpdateDisplay(); | ||
| 59 | |||
| 60 | return; | ||
| 61 | } | ||
| 62 | |||
| 53 | LoginResult result = _connectionTask.Result; | 63 | LoginResult result = _connectionTask.Result; |
| 54 | 64 | ||
| 55 | if (result.Successful) | 65 | if (result.Successful) |
| diff --git a/AnodyneArchipelago/Menu/MenuState.cs b/AnodyneArchipelago/Menu/MenuState.cs index c7be02a..7e8020e 100644 --- a/AnodyneArchipelago/Menu/MenuState.cs +++ b/AnodyneArchipelago/Menu/MenuState.cs | |||
| @@ -135,7 +135,11 @@ namespace AnodyneArchipelago.Menu | |||
| 135 | { | 135 | { |
| 136 | if (!_hide) | 136 | if (!_hide) |
| 137 | { | 137 | { |
| 138 | _selector.Draw(); | 138 | if (_substate == null) |
| 139 | { | ||
| 140 | _selector.Draw(); | ||
| 141 | } | ||
| 142 | |||
| 139 | _versionLabel1.Draw(); | 143 | _versionLabel1.Draw(); |
| 140 | _versionLabel2.Draw(); | 144 | _versionLabel2.Draw(); |
| 141 | _serverLabel.Draw(); | 145 | _serverLabel.Draw(); |
| diff --git a/AnodyneArchipelago/Patches/GameplayPatches.cs b/AnodyneArchipelago/Patches/GameplayPatches.cs index ec04451..056a855 100644 --- a/AnodyneArchipelago/Patches/GameplayPatches.cs +++ b/AnodyneArchipelago/Patches/GameplayPatches.cs | |||
| @@ -148,6 +148,15 @@ namespace AnodyneArchipelago.Patches | |||
| 148 | [HarmonyPatch(typeof(EntityPreset), nameof(EntityPreset.Create))] | 148 | [HarmonyPatch(typeof(EntityPreset), nameof(EntityPreset.Create))] |
| 149 | class EntityPresetCreatePatch | 149 | class EntityPresetCreatePatch |
| 150 | { | 150 | { |
| 151 | static void Prefix(EntityPreset __instance) | ||
| 152 | { | ||
| 153 | if (__instance.EntityID == new Guid("C8CE6E18-CF07-180B-A550-9DC808A2F7E3")) | ||
| 154 | { | ||
| 155 | PropertyInfo frameProperty = typeof(EntityPreset).GetProperty("Frame"); | ||
| 156 | frameProperty.SetValue(__instance, (int)Plugin.ArchipelagoManager.EndgameCardRequirement); | ||
| 157 | } | ||
| 158 | } | ||
| 159 | |||
| 151 | static void Postfix(EntityPreset __instance, Entity __result) | 160 | static void Postfix(EntityPreset __instance, Entity __result) |
| 152 | { | 161 | { |
| 153 | if (__instance.Type.FullName == "AnodyneSharp.Entities.Interactive.DungeonStatue") | 162 | if (__instance.Type.FullName == "AnodyneSharp.Entities.Interactive.DungeonStatue") |
