-
Notifications
You must be signed in to change notification settings - Fork 154
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #995 from Rxup/upstream-sync
[Tweak] Upstream sync
- Loading branch information
Showing
157 changed files
with
382,354 additions
and
220,238 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,48 +1,8 @@ | ||
using Content.Shared.PDA; | ||
using Content.Shared.Light; | ||
using Robust.Client.GameObjects; | ||
|
||
namespace Content.Client.PDA; | ||
|
||
public sealed class PdaSystem : SharedPdaSystem | ||
{ | ||
public override void Initialize() | ||
{ | ||
base.Initialize(); | ||
|
||
SubscribeLocalEvent<PdaComponent, AppearanceChangeEvent>(OnAppearanceChange); | ||
} | ||
|
||
private void OnAppearanceChange(EntityUid uid, PdaComponent component, ref AppearanceChangeEvent args) | ||
{ | ||
if (args.Sprite == null) | ||
return; | ||
|
||
if (Appearance.TryGetData<bool>(uid, UnpoweredFlashlightVisuals.LightOn, out var isFlashlightOn, args.Component)) | ||
args.Sprite.LayerSetVisible(PdaVisualLayers.Flashlight, isFlashlightOn); | ||
|
||
if (Appearance.TryGetData<bool>(uid, PdaVisuals.IdCardInserted, out var isCardInserted, args.Component)) | ||
args.Sprite.LayerSetVisible(PdaVisualLayers.IdLight, isCardInserted); | ||
} | ||
|
||
protected override void OnComponentInit(EntityUid uid, PdaComponent component, ComponentInit args) | ||
{ | ||
base.OnComponentInit(uid, component, args); | ||
|
||
if (!TryComp<SpriteComponent>(uid, out var sprite)) | ||
return; | ||
|
||
if (component.State != null) | ||
sprite.LayerSetState(PdaVisualLayers.Base, component.State); | ||
|
||
sprite.LayerSetVisible(PdaVisualLayers.Flashlight, component.FlashlightOn); | ||
sprite.LayerSetVisible(PdaVisualLayers.IdLight, component.IdSlot.StartingItem != null); | ||
} | ||
|
||
public enum PdaVisualLayers : byte | ||
{ | ||
Base, | ||
Flashlight, | ||
IdLight | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
using Content.Shared.Light; | ||
using Content.Shared.PDA; | ||
using Robust.Client.GameObjects; | ||
|
||
namespace Content.Client.PDA; | ||
|
||
public sealed class PdaVisualizerSystem : VisualizerSystem<PdaVisualsComponent> | ||
{ | ||
protected override void OnAppearanceChange(EntityUid uid, PdaVisualsComponent comp, ref AppearanceChangeEvent args) | ||
{ | ||
if (args.Sprite == null) | ||
return; | ||
|
||
if (AppearanceSystem.TryGetData<string>(uid, PdaVisuals.PdaType, out var pdaType, args.Component)) | ||
args.Sprite.LayerSetState(PdaVisualLayers.Base, pdaType); | ||
|
||
if (AppearanceSystem.TryGetData<bool>(uid, UnpoweredFlashlightVisuals.LightOn, out var isFlashlightOn, args.Component)) | ||
args.Sprite.LayerSetVisible(PdaVisualLayers.Flashlight, isFlashlightOn); | ||
|
||
if (AppearanceSystem.TryGetData<bool>(uid, PdaVisuals.IdCardInserted, out var isCardInserted, args.Component)) | ||
args.Sprite.LayerSetVisible(PdaVisualLayers.IdLight, isCardInserted); | ||
} | ||
|
||
public enum PdaVisualLayers : byte | ||
{ | ||
Base, | ||
Flashlight, | ||
IdLight | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
namespace Content.Client.PDA; | ||
|
||
/// <summary> | ||
/// Used for visualizing PDA visuals. | ||
/// </summary> | ||
[RegisterComponent] | ||
public sealed partial class PdaVisualsComponent : Component | ||
{ | ||
public string? BorderColor; | ||
|
||
public string? AccentHColor; | ||
|
||
public string? AccentVColor; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
using System.Linq; | ||
using Content.Server.Body.Systems; | ||
using Content.Server.Hands.Systems; | ||
using Content.Shared.Body.Part; | ||
using Content.Shared.Humanoid.Prototypes; | ||
using Robust.Shared.GameObjects; | ||
using Robust.Shared.Prototypes; | ||
|
||
namespace Content.IntegrationTests.Tests.Backmen.Body; | ||
|
||
[TestFixture] | ||
public sealed class HandsTest | ||
{ | ||
[Test] | ||
public async Task AllSpeciesHaveLegs() | ||
{ | ||
await using var pair = await PoolManager.GetServerClient(new PoolSettings | ||
{ | ||
Dirty = true, | ||
Connected = true, | ||
InLobby = false, | ||
}); | ||
|
||
var server = pair.Server; | ||
var bodySys = server.EntMan.System<BodySystem>(); | ||
|
||
foreach (var speciesPrototype in server.ProtoMan.EnumeratePrototypes<SpeciesPrototype>()) | ||
{ | ||
var dummy = EntityUid.Invalid; | ||
await server.WaitAssertion(() => | ||
{ | ||
dummy = server.EntMan.Spawn(speciesPrototype.Prototype); | ||
}); | ||
await server.WaitIdleAsync(); | ||
await server.WaitRunTicks(2); | ||
await server.WaitAssertion(() => | ||
{ | ||
Assert.That(dummy, Is.Not.EqualTo(EntityUid.Invalid)); | ||
var handCount = bodySys.GetBodyPartCount(dummy, BodyPartType.Leg); | ||
Assert.That(handCount, Is.GreaterThanOrEqualTo(2), $"legs {speciesPrototype.ID}({speciesPrototype.Prototype})"); | ||
}); | ||
|
||
} | ||
|
||
await pair.CleanReturnAsync(); | ||
} | ||
[Test] | ||
public async Task AllSpeciesHaveHands() | ||
{ | ||
await using var pair = await PoolManager.GetServerClient(new PoolSettings | ||
{ | ||
Dirty = true, | ||
Connected = true, | ||
InLobby = false, | ||
}); | ||
|
||
var server = pair.Server; | ||
var handsSys = server.EntMan.System<HandsSystem>(); | ||
|
||
foreach (var speciesPrototype in server.ProtoMan.EnumeratePrototypes<SpeciesPrototype>()) | ||
{ | ||
var dummy = EntityUid.Invalid; | ||
await server.WaitAssertion(() => | ||
{ | ||
dummy = server.EntMan.Spawn(speciesPrototype.Prototype); | ||
}); | ||
await server.WaitIdleAsync(); | ||
await server.WaitRunTicks(2); | ||
await server.WaitAssertion(() => | ||
{ | ||
Assert.That(dummy, Is.Not.EqualTo(EntityUid.Invalid)); | ||
var handCount = handsSys.EnumerateHands(dummy).Count(); | ||
Assert.That(handCount, Is.GreaterThanOrEqualTo(2), $"hands {speciesPrototype.ID}({speciesPrototype.Prototype})"); | ||
}); | ||
|
||
} | ||
|
||
await pair.CleanReturnAsync(); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.