Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Upstream sync #302

Merged
merged 117 commits into from
Nov 9, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
117 commits
Select commit Hold shift + click to select a range
ef8ecf8
Move "id" clothing layer above gloves, shoes, ears, outerclothing, ey…
DrSmugleaf Nov 5, 2023
8b11c4f
Cleanup chemistry-bottles.yml (#21459)
lzk228 Nov 5, 2023
670f745
fix susbox slots (#21435)
deltanedas Nov 5, 2023
cfaac4b
wintercoats fit small items (#21463)
joshepvodka Nov 5, 2023
c54febc
Stop mice eating soap (#21446)
crazybrain23 Nov 5, 2023
34e03d1
Automatic changelog update
PJBot Nov 5, 2023
488433c
give chemistry bag better storage (#21447)
deltanedas Nov 5, 2023
77d49ea
:trollface: (#21470)
deltanedas Nov 5, 2023
e5fd5cc
Automatic changelog update
PJBot Nov 5, 2023
b1eb5d4
Convert license.txt to attributions.yml in misc folder (#21465)
RieBi Nov 6, 2023
10c7363
Convert license.txt to attributions.yml in Items folder (#21466)
RieBi Nov 6, 2023
13d412e
Convert license.txt to attributions.yml in Animals folder (#21471)
RieBi Nov 6, 2023
f6f73aa
Converted weapons license.txts to attributions.ymls (#21444)
RieBi Nov 6, 2023
2c87c53
hide medibot messages from chat and logs (#21468)
deltanedas Nov 6, 2023
196be3c
Adds more sources for sheet paper material (#21364)
SpaceRox1244 Nov 6, 2023
3a430f3
Automatic changelog update
PJBot Nov 6, 2023
79cd2a7
Significantly nerf chemvomit and give it a reasonable default. (#21453)
IProduceWidgets Nov 6, 2023
b79607b
Automatic changelog update
PJBot Nov 6, 2023
95a651e
Bicaridine metabolism bandaid (#21443)
themias Nov 6, 2023
36c82ca
Notice board (#21410)
Tunguso4ka Nov 6, 2023
9c9a3f7
Automatic changelog update
PJBot Nov 6, 2023
c540b61
Fix erase verb not removing chat messages in some cases (#21355)
DrSmugleaf Nov 6, 2023
1c497db
Artifact fragments can now stack. (#21232)
c0rigin Nov 6, 2023
fd7db80
sprite change (#21423)
UbaserB Nov 6, 2023
2b08889
Automatic changelog update
PJBot Nov 6, 2023
3d13332
The Mobs of the Living Light (#21338)
Nimfar11 Nov 6, 2023
f103a38
Automatic changelog update
PJBot Nov 6, 2023
e35cd61
allow network payload data to inherit nullability (#21327)
graevy Nov 6, 2023
f9369db
Made livestock crates not airtight. (#21315)
IProduceWidgets Nov 6, 2023
284547e
Automatic changelog update
PJBot Nov 6, 2023
615f15e
Nukeops hud (#21260)
IntegerTempest Nov 6, 2023
3079b38
:trollface: (#21182)
JoeHammad1844 Nov 6, 2023
f87152a
Automatic changelog update
PJBot Nov 6, 2023
5af97da
diagonal window glass and pirate shuttle improvements (#21174)
brainfood1183 Nov 6, 2023
d07ea20
Use object-spaced bounding boxes for putting stuff in crates (#21427)
ChrisThirtle Nov 6, 2023
b1f39ad
Automatic changelog update
PJBot Nov 6, 2023
4cacb7b
Ice anomaly spawns ice underneath it (#21227)
YuriyKiss Nov 6, 2023
40b36d1
Roller Skates (#20257)
brainfood1183 Nov 6, 2023
3be6c5b
Microreactor power cell research (#21473)
deltanedas Nov 6, 2023
71ec51b
Replicate the PDA belt slot sprite in the IDSLOT (#21457)
QuietlyWhisper Nov 6, 2023
8302bef
Automatic changelog update
PJBot Nov 6, 2023
96e2781
add ied (#20966)
deltanedas Nov 6, 2023
db1eba1
Automatic changelog update
PJBot Nov 6, 2023
f0f54b5
mech nitrogen filtering 2 (#19868)
deltanedas Nov 6, 2023
dd0ab19
Freelance Radio Channel and Encryption Key (#20904)
LordEclipse Nov 6, 2023
e0a11f9
(Reagent) Minor blood and uncooked protein rework (#20891)
QuietlyWhisper Nov 6, 2023
ad1a280
Automatic changelog update
PJBot Nov 6, 2023
8b3adf6
Anomaly Synchronizer (#20945)
TheShuEd Nov 6, 2023
18eae13
Automatic changelog update
PJBot Nov 6, 2023
525d8e3
Add map info to status HTTP API (#21089)
Morb0 Nov 6, 2023
3890490
ninja stun change (#20503)
deltanedas Nov 6, 2023
4729024
Convert ItemSize to prototypes (#21481)
EmoGarbage404 Nov 6, 2023
df46c52
Automatic changelog update
PJBot Nov 6, 2023
3455e97
New Corvax Terminal (#1554)
poeMota Nov 6, 2023
b8a8efd
Locale fix (#1556)
lapatison Nov 6, 2023
b9c3887
Port python packaging to Content.Packaging (#21458)
metalgearsloth Nov 6, 2023
2a9e08b
Update submodule to 176.0.0 (#21500)
metalgearsloth Nov 6, 2023
4b1e593
Update rule time cvar for servers
Morb0 Nov 6, 2023
ce89349
Add nebula config preset
Morb0 Nov 6, 2023
7e06ecd
Change update publish to 6:00 UTC
Morb0 Nov 6, 2023
fb60a56
Guardian bugfixes (#21467)
ElectroJr Nov 7, 2023
778d3e9
eek (penis) (#21498)
Emisse Nov 7, 2023
8e1f231
Update nebula name config
Morb0 Nov 7, 2023
651dffb
Fix map renderer (#21515)
DrSmugleaf Nov 7, 2023
dc3b6e3
Fix Client RoleSystem not inheriting SharedRoleSystem, network job co…
DrSmugleaf Nov 7, 2023
c90316d
Lockers for clown, mime and NT Representative (#21504)
Tunguso4ka Nov 7, 2023
201fe5f
Automatic changelog update
PJBot Nov 7, 2023
64b8975
Add nebula to queue server system
Morb0 Nov 7, 2023
b1fd313
Minor rule change to include disability slurs in rules (#21518)
Titian3 Nov 7, 2023
611bfea
Merge remote-tracking branch 'upstream/master' into update-sposnors
Morb0 Nov 8, 2023
5d2f429
Apply changes
Morb0 Nov 8, 2023
104300b
uwu (#21521)
VasilisThePikachu Nov 8, 2023
45ddc30
Make the cloning pod and medical scanner fit through verical doors (#…
VasilisThePikachu Nov 8, 2023
3953257
Add method to clear an action's cooldown (#21517)
DrSmugleaf Nov 8, 2023
a6985e5
Automatic changelog update
PJBot Nov 8, 2023
94368f1
Speed Boots [Tier 3 Civ-Service] (#21438)
EmoGarbage404 Nov 8, 2023
d8a88d0
Origin Station Update 06.11.2023 (notice boards and gasgiant parallax…
brainfood1183 Nov 8, 2023
fb7afe4
Automatic changelog update
PJBot Nov 8, 2023
490ebdc
No more passive zombies (#21506)
VasilisThePikachu Nov 8, 2023
932c5db
content (#21505)
KingFroozy Nov 8, 2023
2f296dc
Allows reptilians to eat crayons, as is their right (#21420)
FluidRock Nov 8, 2023
33f211b
Automatic changelog update
PJBot Nov 8, 2023
ac25dd8
Fix mob state error (#21431)
ElectroJr Nov 8, 2023
b5e8890
Adding damage visuals for directional windows (#21194)
Darkenson Nov 8, 2023
e249aba
Automatic changelog update
PJBot Nov 8, 2023
8f72e0a
Add Spawners (#20495)
Deeeeja Nov 8, 2023
b360391
Update Robust to v177.0.0 (#21528)
DrSmugleaf Nov 8, 2023
37cecec
Fix maps
Morb0 Nov 8, 2023
7a328a7
Merge remote-tracking branch 'upstream/master' into upstream-sync
Morb0 Nov 8, 2023
da7b583
Fix attributions license format
Morb0 Nov 8, 2023
0a488e0
Update locale
Morb0 Nov 8, 2023
52af546
Arachnid 2: Episode 2 (#19984)
PixelTheKermit Nov 8, 2023
e8a47cd
Automatic changelog update
PJBot Nov 8, 2023
6550f42
Common spelling mistake (#21535)
VasilisThePikachu Nov 8, 2023
55c6c35
Fix O id prototype (#21534)
Morb0 Nov 8, 2023
52508a6
Fixed typo "tranexmic -> tranexamic" (#21537)
Brandon-Huu Nov 8, 2023
a466a9e
Grill Resprite (#21524)
ps3moira Nov 8, 2023
4831f2a
Automatic changelog update
PJBot Nov 8, 2023
3f4d998
nitrile gloves (#21509)
KingFroozy Nov 8, 2023
174aa3b
Automatic changelog update
PJBot Nov 8, 2023
4220b09
Sling Resprites (#21538)
Boaz1111 Nov 8, 2023
7d7c9e5
Merge remote-tracking branch 'upstream/master' into upstream-sync
Morb0 Nov 8, 2023
172c234
Update locale
Morb0 Nov 8, 2023
c41fb89
Fix locale
Morb0 Nov 8, 2023
307262c
Fix locale
Morb0 Nov 8, 2023
28c263b
Merge pull request #1559 from space-syndicate/upstream-sync
Morb0 Nov 8, 2023
cf6eb20
Remove need to toggle vending machine button (#21543)
themias Nov 9, 2023
be8e5b7
Automatic changelog update
PJBot Nov 9, 2023
8be97a2
Roller Skates fixes (#21542)
brainfood1183 Nov 9, 2023
c1791eb
Fix space vault (#21541)
themias Nov 9, 2023
cb1e799
Automatic changelog update
PJBot Nov 9, 2023
2ef29fb
New crop: Cotton (#21536)
DoubleRiceEddiedd Nov 9, 2023
50e358a
Automatic changelog update
PJBot Nov 9, 2023
88a9dce
Tweak dwarf accent (#21522)
pewter-wiz Nov 9, 2023
df3ac34
Merge remote-tracking branch 'upstream/master' into upstream-sync
Rxup Nov 9, 2023
674e8ec
upd
Rxup Nov 9, 2023
823e51f
Merge remote-tracking branch 'wizard/master' into upstream-sync
Rxup Nov 9, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
15 changes: 11 additions & 4 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -44,10 +44,17 @@ jobs:
cd RobustToolbox
git fetch --depth=1

- name: Package all
run: |
Tools/package_server_build.py -p win-x64 linux-x64
Tools/package_client_build.py
- name: Install dependencies
run: dotnet restore

- name: Build Packaging
run: dotnet build Content.Packaging --configuration Release --no-restore /m

- name: Package server
run: dotnet run --project Content.Packaging server --platform win-x64 --platform linux-x64 --platform osx-x64 --platform linux-arm64

- name: Package client
run: dotnet run --project Content.Packaging client --no-wipe-release

- name: Update Build Info
run: Tools/gen_build_info.py
Expand Down
12 changes: 8 additions & 4 deletions .github/workflows/test-packaging.yml
Original file line number Diff line number Diff line change
Expand Up @@ -56,11 +56,15 @@ jobs:
- name: Install dependencies
run: dotnet restore

- name: Package client
run: |
Tools/package_server_build.py -p win-x64 linux-x64 osx-x64 linux-arm64
Tools/package_client_build.py
- name: Build Packaging
run: dotnet build Content.Packaging --configuration Release --no-restore /m

- name: Package server
run: dotnet run --project Content.Packaging server --platform win-x64 --platform linux-x64 --platform osx-x64 --platform linux-arm64

- name: Package client
run: dotnet run --project Content.Packaging client --no-wipe-release

- name: Update Build Info
run: Tools/gen_build_info.py

Expand Down
8 changes: 8 additions & 0 deletions Content.Client/Construction/UI/ConstructionMenuPresenter.cs
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
using System.Linq;
using Content.Client.UserInterface.Systems.MenuBar.Widgets;
using Content.Shared.Construction.Prototypes;
using Content.Shared.Tag;
using Robust.Client.GameObjects;
using Robust.Client.Graphics;
using Robust.Client.Placement;
using Robust.Client.Player;
using Robust.Client.UserInterface;
using Robust.Client.UserInterface.Controls;
using Robust.Client.Utility;
Expand All @@ -25,6 +27,7 @@ internal sealed class ConstructionMenuPresenter : IDisposable
[Dependency] private readonly IPrototypeManager _prototypeManager = default!;
[Dependency] private readonly IPlacementManager _placementManager = default!;
[Dependency] private readonly IUserInterfaceManager _uiManager = default!;
[Dependency] private readonly IPlayerManager _playerManager = default!;

private readonly IConstructionMenuView _constructionView;

Expand Down Expand Up @@ -152,6 +155,11 @@ private void OnViewPopulateRecipes(object? sender, (string search, string catago
if (recipe.Hide)
continue;

if (_playerManager.LocalSession == null
|| _playerManager.LocalEntity == null
|| (recipe.EntityWhitelist != null && !recipe.EntityWhitelist.IsValid(_playerManager.LocalEntity.Value)))
continue;

if (!string.IsNullOrEmpty(search))
{
if (!recipe.Name.ToLowerInvariant().Contains(search.Trim().ToLowerInvariant()))
Expand Down
43 changes: 43 additions & 0 deletions Content.Client/Overlays/ShowSyndicateIconsSystem.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
using Content.Shared.Overlays;
using Content.Shared.StatusIcon.Components;
using Content.Shared.NukeOps;
using Content.Shared.StatusIcon;
using Robust.Shared.Prototypes;

namespace Content.Client.Overlays;
public sealed class ShowSyndicateIconsSystem : EquipmentHudSystem<ShowSyndicateIconsComponent>
{
[Dependency] private readonly IPrototypeManager _prototype = default!;

public override void Initialize()
{
base.Initialize();

SubscribeLocalEvent<NukeOperativeComponent, GetStatusIconsEvent>(OnGetStatusIconsEvent);
}

private void OnGetStatusIconsEvent(EntityUid uid, NukeOperativeComponent nukeOperativeComponent, ref GetStatusIconsEvent args)
{
if (!IsActive || args.InContainer)
{
return;
}

var healthIcons = SyndicateIcon(uid, nukeOperativeComponent);

args.StatusIcons.AddRange(healthIcons);
}

private IReadOnlyList<StatusIconPrototype> SyndicateIcon(EntityUid uid, NukeOperativeComponent nukeOperativeComponent)
{
var result = new List<StatusIconPrototype>();

if (_prototype.TryIndex<StatusIconPrototype>(nukeOperativeComponent.SyndStatusIcon, out var syndicateicon))
{
result.Add(syndicateicon);
}

return result;
}
}

24 changes: 24 additions & 0 deletions Content.Client/PowerCell/PowerCellSystem.cs
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
using Content.Shared.PowerCell;
using Content.Shared.PowerCell.Components;
using JetBrains.Annotations;
using Robust.Client.GameObjects;

Expand All @@ -15,6 +16,29 @@ public override void Initialize()
SubscribeLocalEvent<PowerCellVisualsComponent, AppearanceChangeEvent>(OnPowerCellVisualsChange);
}

/// <inheritdoc/>
public override bool HasActivatableCharge(EntityUid uid, PowerCellDrawComponent? battery = null, PowerCellSlotComponent? cell = null,
EntityUid? user = null)
{
if (!Resolve(uid, ref battery, ref cell, false))
return true;

return battery.CanUse;
}

/// <inheritdoc/>
public override bool HasDrawCharge(
EntityUid uid,
PowerCellDrawComponent? battery = null,
PowerCellSlotComponent? cell = null,
EntityUid? user = null)
{
if (!Resolve(uid, ref battery, ref cell, false))
return true;

return battery.CanDraw;
}

private void OnPowerCellVisualsChange(EntityUid uid, PowerCellVisualsComponent component, ref AppearanceChangeEvent args)
{
if (args.Sprite == null)
Expand Down
6 changes: 4 additions & 2 deletions Content.Client/Roles/RoleSystem.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
namespace Content.Client.Roles;
using Content.Shared.Roles;

public sealed class RoleSystem : EntitySystem
namespace Content.Client.Roles;

public sealed class RoleSystem : SharedRoleSystem
{
}
11 changes: 7 additions & 4 deletions Content.Client/Storage/UI/StorageWindow.cs
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
using System.Numerics;
using Content.Client.Items.Systems;
using Content.Client.Message;
using Robust.Client.Graphics;
using Robust.Client.UserInterface.Controls;
Expand All @@ -23,6 +24,7 @@ public sealed class StorageWindow : FancyWindow
private readonly IEntityManager _entityManager;

private readonly SharedStorageSystem _storage;
private readonly ItemSystem _item;

private readonly RichTextLabel _information;
public readonly ContainerButton StorageContainerButton;
Expand All @@ -34,6 +36,7 @@ public StorageWindow(IEntityManager entityManager)
{
_entityManager = entityManager;
_storage = _entityManager.System<SharedStorageSystem>();
_item = _entityManager.System<ItemSystem>();
SetSize = new Vector2(240, 320);
Title = Loc.GetString("comp-storage-window-title");
RectClipContent = true;
Expand Down Expand Up @@ -69,7 +72,7 @@ public StorageWindow(IEntityManager entityManager)
_information.SetMessage(Loc.GetString("comp-storage-window-weight",
("weight", 0),
("maxWeight", 0),
("size", SharedItemSystem.GetItemSizeLocale(ItemSize.Normal))));
("size", _item.GetItemSizeLocale(SharedStorageSystem.DefaultStorageMaxItemSize))));

vBox.AddChild(_information);

Expand Down Expand Up @@ -117,14 +120,14 @@ private void SetStorageInformation(Entity<StorageComponent> uid)
_information.SetMarkup(Loc.GetString("comp-storage-window-weight",
("weight", _storage.GetCumulativeItemSizes(uid, uid.Comp)),
("maxWeight", uid.Comp.MaxTotalWeight),
("size", SharedItemSystem.GetItemSizeLocale(_storage.GetMaxItemSize((uid, uid.Comp))))));
("size", _item.GetItemSizeLocale(_storage.GetMaxItemSize((uid, uid.Comp))))));
}
else
{
_information.SetMarkup(Loc.GetString("comp-storage-window-slots",
("itemCount", uid.Comp.Container.ContainedEntities.Count),
("maxCount", uid.Comp.MaxSlots),
("size", SharedItemSystem.GetItemSizeLocale(_storage.GetMaxItemSize((uid, uid.Comp))))));
("size", _item.GetItemSizeLocale(_storage.GetMaxItemSize((uid, uid.Comp))))));
}
}

Expand Down Expand Up @@ -167,7 +170,7 @@ public void GenerateButton(ListData data, ListContainerButton button)
{
Align = Label.AlignMode.Right,
Text = item?.Size != null
? $"{SharedItemSystem.GetItemSizeWeight(item.Size)}"
? $"{_item.GetItemSizeWeight(item.Size)}"
: Loc.GetString("comp-storage-no-item-size")
}
}
Expand Down
5 changes: 3 additions & 2 deletions Content.Client/VendingMachines/UI/VendingMachineMenu.xaml
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
<DefaultWindow xmlns="https://spacestation14.io">
<DefaultWindow xmlns="https://spacestation14.io">
<BoxContainer Orientation="Vertical">
<LineEdit Name="SearchBar" PlaceHolder="{Loc 'vending-machine-component-search-filter'}" HorizontalExpand="True" Margin ="0 4" Access="Public"/>
<ItemList Name="VendingContents"
SizeFlagsStretchRatio="8"
VerticalExpand="True">
VerticalExpand="True"
SelectMode="Button">
</ItemList>
</BoxContainer>
</DefaultWindow>
58 changes: 44 additions & 14 deletions Content.IntegrationTests/Tests/StorageTest.cs
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,9 @@ public async Task StorageSizeArbitrageTest()
var server = pair.Server;

var protoManager = server.ResolveDependency<IPrototypeManager>();
var entMan = server.ResolveDependency<IEntityManager>();

var itemSys = entMan.System<SharedItemSystem>();

await server.WaitAssertion(() =>
{
Expand All @@ -37,7 +40,9 @@ await server.WaitAssertion(() =>
!proto.TryGetComponent<ItemComponent>("Item", out var item))
continue;

Assert.That(storage.MaxItemSize.Value, Is.LessThanOrEqualTo(item.Size), $"Found storage arbitrage on {proto.ID}");
Assert.That(itemSys.GetSizePrototype(storage.MaxItemSize.Value).Weight,
Is.LessThanOrEqualTo(itemSys.GetSizePrototype(item.Size).Weight),
$"Found storage arbitrage on {proto.ID}");
}
});
await pair.CleanReturnAsync();
Expand Down Expand Up @@ -77,10 +82,16 @@ public async Task TestSufficientSpaceForFill()
await using var pair = await PoolManager.GetServerClient();
var server = pair.Server;

var entMan = server.ResolveDependency<IEntityManager>();
var protoMan = server.ResolveDependency<IPrototypeManager>();
var compFact = server.ResolveDependency<IComponentFactory>();
var id = compFact.GetComponentName(typeof(StorageFillComponent));

var itemSys = entMan.System<SharedItemSystem>();

var allSizes = protoMan.EnumeratePrototypes<ItemSizePrototype>().ToList();
allSizes.Sort();

Assert.Multiple(() =>
{
foreach (var proto in PoolManager.GetPrototypesWithComponent<StorageFillComponent>(server))
Expand All @@ -97,14 +108,29 @@ public async Task TestSufficientSpaceForFill()
proto.TryGetComponent<ItemComponent>("Item", out var item);

var fill = (StorageFillComponent) proto.Components[id].Component;
var size = GetFillSize(fill, false, protoMan);
var maxSize = storage.MaxItemSize ??
(item?.Size == null
? SharedStorageSystem.DefaultStorageMaxItemSize
: (ItemSize) Math.Max(0, (int) item.Size - 1));
var size = GetFillSize(fill, false, protoMan, itemSys);

var maxSize = storage.MaxItemSize;
if (storage.MaxItemSize == null)
{
if (item?.Size == null)
{
maxSize = SharedStorageSystem.DefaultStorageMaxItemSize;
}
else
{
var curIndex = allSizes.IndexOf(protoMan.Index(item.Size));
var index = Math.Max(0, curIndex - 1);
maxSize = allSizes[index].ID;
}
}

if (maxSize == null)
continue;

if (storage.MaxSlots != null)
{
Assert.That(GetFillSize(fill, true, protoMan), Is.LessThanOrEqualTo(storage.MaxSlots),
Assert.That(GetFillSize(fill, true, protoMan, itemSys), Is.LessThanOrEqualTo(storage.MaxSlots),
$"{proto.ID} storage fill has too many items.");
}
else
Expand All @@ -123,14 +149,14 @@ public async Task TestSufficientSpaceForFill()
if (!fillItem.TryGetComponent<ItemComponent>("Item", out var entryItem))
continue;

Assert.That(entryItem.Size, Is.LessThanOrEqualTo(maxSize),
Assert.That(protoMan.Index(entryItem.Size).Weight,
Is.LessThanOrEqualTo(protoMan.Index(maxSize.Value).Weight),
$"Entity {proto.ID} has storage-fill item, {entry.PrototypeId}, that is too large");
}
}
});

await pair.CleanReturnAsync();

}

[Test]
Expand All @@ -139,10 +165,13 @@ public async Task TestSufficientSpaceForEntityStorageFill()
await using var pair = await PoolManager.GetServerClient();
var server = pair.Server;

var entMan = server.ResolveDependency<IEntityManager>();
var protoMan = server.ResolveDependency<IPrototypeManager>();
var compFact = server.ResolveDependency<IComponentFactory>();
var id = compFact.GetComponentName(typeof(StorageFillComponent));

var itemSys = entMan.System<SharedItemSystem>();

Assert.Multiple(() =>
{
foreach (var proto in PoolManager.GetPrototypesWithComponent<StorageFillComponent>(server))
Expand All @@ -157,15 +186,15 @@ public async Task TestSufficientSpaceForEntityStorageFill()
}

var fill = (StorageFillComponent) proto.Components[id].Component;
var size = GetFillSize(fill, true, protoMan);
var size = GetFillSize(fill, true, protoMan, itemSys);
Assert.That(size, Is.LessThanOrEqualTo(entStorage.Capacity),
$"{proto.ID} storage fill is too large.");
}
});
await pair.CleanReturnAsync();
}

private int GetEntrySize(EntitySpawnEntry entry, bool getCount, IPrototypeManager protoMan)
private int GetEntrySize(EntitySpawnEntry entry, bool getCount, IPrototypeManager protoMan, SharedItemSystem itemSystem)
{
if (entry.PrototypeId == null)
return 0;
Expand All @@ -179,20 +208,21 @@ private int GetEntrySize(EntitySpawnEntry entry, bool getCount, IPrototypeManage
if (getCount)
return entry.Amount;


if (proto.TryGetComponent<ItemComponent>("Item", out var item))
return SharedItemSystem.GetItemSizeWeight(item.Size) * entry.Amount;
return itemSystem.GetItemSizeWeight(item.Size) * entry.Amount;

Assert.Fail($"Prototype is missing item comp: {entry.PrototypeId}");
return 0;
}

private int GetFillSize(StorageFillComponent fill, bool getCount, IPrototypeManager protoMan)
private int GetFillSize(StorageFillComponent fill, bool getCount, IPrototypeManager protoMan, SharedItemSystem itemSystem)
{
var totalSize = 0;
var groups = new Dictionary<string, int>();
foreach (var entry in fill.Contents)
{
var size = GetEntrySize(entry, getCount, protoMan);
var size = GetEntrySize(entry, getCount, protoMan, itemSystem);

if (entry.GroupId == null)
totalSize += size;
Expand Down
Loading
Loading