Fix debug asserts when unequipping items (#38274)
This commit is contained in:
@@ -11,12 +11,11 @@ namespace Content.Shared.Clothing.Components;
|
||||
/// <summary>
|
||||
/// This handles entities which can be equipped.
|
||||
/// </summary>
|
||||
[NetworkedComponent]
|
||||
[RegisterComponent]
|
||||
[RegisterComponent, NetworkedComponent, AutoGenerateComponentState(true)]
|
||||
[Access(typeof(ClothingSystem), typeof(InventorySystem))]
|
||||
public sealed partial class ClothingComponent : Component
|
||||
{
|
||||
[DataField("clothingVisuals")]
|
||||
[DataField]
|
||||
public Dictionary<string, List<PrototypeLayerData>> ClothingVisuals = new();
|
||||
|
||||
/// <summary>
|
||||
@@ -25,8 +24,7 @@ public sealed partial class ClothingComponent : Component
|
||||
[DataField]
|
||||
public string? MappedLayer;
|
||||
|
||||
[ViewVariables(VVAccess.ReadWrite)]
|
||||
[DataField("quickEquip")]
|
||||
[DataField]
|
||||
public bool QuickEquip = true;
|
||||
|
||||
/// <summary>
|
||||
@@ -36,22 +34,18 @@ public sealed partial class ClothingComponent : Component
|
||||
/// <remarks>
|
||||
/// Note that this may be a combination of different slot flags, not a singular bit.
|
||||
/// </remarks>
|
||||
[ViewVariables(VVAccess.ReadWrite)]
|
||||
[DataField(required: true)]
|
||||
[Access(typeof(ClothingSystem), typeof(InventorySystem), Other = AccessPermissions.ReadExecute)]
|
||||
public SlotFlags Slots = SlotFlags.NONE;
|
||||
|
||||
[ViewVariables(VVAccess.ReadWrite)]
|
||||
[DataField("equipSound")]
|
||||
[DataField]
|
||||
public SoundSpecifier? EquipSound;
|
||||
|
||||
[ViewVariables(VVAccess.ReadWrite)]
|
||||
[DataField("unequipSound")]
|
||||
[DataField]
|
||||
public SoundSpecifier? UnequipSound;
|
||||
|
||||
[Access(typeof(ClothingSystem))]
|
||||
[ViewVariables(VVAccess.ReadWrite)]
|
||||
[DataField("equippedPrefix")]
|
||||
[DataField, AutoNetworkedField]
|
||||
public string? EquippedPrefix;
|
||||
|
||||
/// <summary>
|
||||
@@ -59,11 +53,9 @@ public sealed partial class ClothingComponent : Component
|
||||
/// useful when prototyping INNERCLOTHING items into OUTERCLOTHING items without duplicating/modifying RSIs etc.
|
||||
/// </summary>
|
||||
[Access(typeof(ClothingSystem))]
|
||||
[ViewVariables(VVAccess.ReadWrite)]
|
||||
[DataField("equippedState")]
|
||||
[DataField, AutoNetworkedField]
|
||||
public string? EquippedState;
|
||||
|
||||
[ViewVariables(VVAccess.ReadWrite)]
|
||||
[DataField("sprite")]
|
||||
public string? RsiPath;
|
||||
|
||||
@@ -72,7 +64,7 @@ public sealed partial class ClothingComponent : Component
|
||||
/// Note that this being non-null does not mean the clothing is considered "worn" or "equipped" unless the slot
|
||||
/// satisfies the <see cref="Slots"/> flags.
|
||||
/// </summary>
|
||||
[DataField]
|
||||
[DataField, AutoNetworkedField]
|
||||
public string? InSlot;
|
||||
// TODO CLOTHING
|
||||
// Maybe keep this null unless its in a valid slot?
|
||||
@@ -82,16 +74,16 @@ public sealed partial class ClothingComponent : Component
|
||||
/// <summary>
|
||||
/// Slot flags of the slot the clothing is currently in. See also <see cref="InSlot"/>.
|
||||
/// </summary>
|
||||
[DataField]
|
||||
[DataField, AutoNetworkedField]
|
||||
public SlotFlags? InSlotFlag;
|
||||
// TODO CLOTHING
|
||||
// Maybe keep this null unless its in a valid slot?
|
||||
// And when doing this, combine InSlot and InSlotFlag, as it'd be a breaking change for downstreams anyway
|
||||
|
||||
[DataField, ViewVariables(VVAccess.ReadWrite)]
|
||||
[DataField]
|
||||
public TimeSpan EquipDelay = TimeSpan.Zero;
|
||||
|
||||
[DataField, ViewVariables(VVAccess.ReadWrite)]
|
||||
[DataField]
|
||||
public TimeSpan UnequipDelay = TimeSpan.Zero;
|
||||
|
||||
/// <summary>
|
||||
@@ -102,17 +94,6 @@ public sealed partial class ClothingComponent : Component
|
||||
public TimeSpan StripDelay = TimeSpan.Zero;
|
||||
}
|
||||
|
||||
[Serializable, NetSerializable]
|
||||
public sealed class ClothingComponentState : ComponentState
|
||||
{
|
||||
public string? EquippedPrefix;
|
||||
|
||||
public ClothingComponentState(string? equippedPrefix)
|
||||
{
|
||||
EquippedPrefix = equippedPrefix;
|
||||
}
|
||||
}
|
||||
|
||||
public enum ClothingMask : byte
|
||||
{
|
||||
NoMask = 0,
|
||||
|
||||
Reference in New Issue
Block a user