fix: spellbooks can have infinite charges (#38376)

* fix: spellbooks can have infinite charges

* refactor: indicate infinite spellbook charges with null

Not sure if I like this much better...
This commit is contained in:
Perry Fraser
2025-07-05 02:28:56 -04:00
committed by GitHub
parent 78e8d98137
commit 6cefc412a3
3 changed files with 20 additions and 15 deletions

View File

@@ -16,12 +16,14 @@ public sealed partial class SpellbookComponent : Component
[ViewVariables]
public readonly List<EntityUid> Spells = new();
// The three fields below are just used for initialization.
/// <summary>
/// The three fields below is just used for initialization.
/// Dictionary of spell prototypes to charge counts.
/// If the charge count is null, it means the spell has infinite charges.
/// </summary>
[DataField]
[ViewVariables(VVAccess.ReadWrite)]
public Dictionary<EntProtoId, int> SpellActions = new();
public Dictionary<EntProtoId, int?> SpellActions = new();
[DataField]
[ViewVariables(VVAccess.ReadWrite)]

View File

@@ -33,7 +33,9 @@ public sealed class SpellbookSystem : EntitySystem
if (spell == null)
continue;
_sharedCharges.SetCharges(spell.Value, charges);
// Null means infinite charges.
if (charges is { } count)
_sharedCharges.SetCharges(spell.Value, count);
ent.Comp.Spells.Add(spell.Value);
}
}
@@ -73,8 +75,9 @@ public sealed class SpellbookSystem : EntitySystem
foreach (var (id, charges) in ent.Comp.SpellActions)
{
EntityUid? actionId = null;
if (_actions.AddAction(args.Args.User, ref actionId, id))
_sharedCharges.SetCharges(actionId.Value, charges);
if (_actions.AddAction(args.Args.User, ref actionId, id)
&& charges is { } count) // Null means infinite charges
_sharedCharges.SetCharges(actionId.Value, count);
}
}

View File

@@ -69,7 +69,7 @@
components:
- type: Spellbook
spellActions:
ActionSpawnMagicarpSpell: -1
ActionSpawnMagicarpSpell: null
- type: entity
id: ForceWallSpellbook
@@ -92,7 +92,7 @@
color: gold
- type: Spellbook
spellActions:
ActionForceWall: -1
ActionForceWall: null
- type: entity
id: BlinkBook
@@ -113,7 +113,7 @@
color: gold
- type: Spellbook
spellActions:
ActionBlink: -1
ActionBlink: null
- type: entity
id: SmiteBook
@@ -136,7 +136,7 @@
- state: overlay_blood
- type: Spellbook
spellActions:
ActionSmiteNoReq: -1
ActionSmiteNoReq: null
- type: entity
id: KnockSpellbook
@@ -158,7 +158,7 @@
color: "#98c495"
- type: Spellbook
spellActions:
ActionKnock: -1
ActionKnock: null
- type: entity
id: FireballSpellbook
@@ -182,7 +182,7 @@
shader: unshaded
- type: Spellbook
spellActions:
ActionFireball: -1
ActionFireball: null
- type: entity
id: ScrollRunes
@@ -197,7 +197,7 @@
- state: spell_default
- type: Spellbook
spellActions:
ActionFlashRune: -1
ActionExplosionRune: -1
ActionIgniteRune: -1
ActionStunRune: -1
ActionFlashRune: null
ActionExplosionRune: null
ActionIgniteRune: null
ActionStunRune: null