mirror of
https://github.com/space-syndicate/space-station-14.git
synced 2026-06-09 15:06:34 +02:00
ef3a0ecc2a
* Everything except the YAML slop... * She solution on my manager till I sajfslkahfsjakfhaskjfshajksafhfsakhfasjfas * another 1000 lines * fix chem dispenser size * go my shnelf * Implicit ass * rider is being mean for some reason * dasdas * borger * better formatting go! * clothes/bloodstream * Cartons * cups and bottles * mmm soder * bar drinks * Spray bottles and some size tweaks with hindsight * 99 bottles of beer on the wall I hate YAML * push that shit * mmm burger * Sneed * sheets * condiments * mmm yummy * fridge yummyfood * meat... * sub 300 * burger... * bready * let them eat cake * does she know how to make a grilled cheese? * pizza pie! * misc shit * soup or salad * Food and drinks, vanquished * the cubes!!! * Almost free from YAML... * fix test fails and some yaml issues * fix prediction, almost done * fix all test fails * remove master merge artifacts and undo autonetworking * review and compatibility * graaah * unfuck master merge I hate github * merg conflicts * sfsa * ehoop * sadas * afsafsaasf * merge conflicts * fucked up the merge conflicts * merge conflict is fucked I might need to completely redo this branch * test fail * no calcium???? --------- Co-authored-by: Princess Cheeseballs <66055347+Pronana@users.noreply.github.com>
74 lines
2.2 KiB
C#
74 lines
2.2 KiB
C#
using Content.Shared.Administration;
|
|
using Content.Shared.Chemistry.Components;
|
|
using Content.Shared.Chemistry.Reagent;
|
|
using Content.Shared.FixedPoint;
|
|
using Content.Shared.Chemistry.EntitySystems;
|
|
using Robust.Shared.Toolshed;
|
|
using System.Linq;
|
|
using Robust.Shared.Prototypes;
|
|
|
|
namespace Content.Server.Administration.Toolshed;
|
|
|
|
[ToolshedCommand, AdminCommand(AdminFlags.Debug)]
|
|
public sealed class SolutionCommand : ToolshedCommand
|
|
{
|
|
private SharedSolutionContainerSystem? _solutionContainer;
|
|
|
|
[CommandImplementation("get")]
|
|
public SolutionRef? Get([PipedArgument] EntityUid input, string name)
|
|
{
|
|
_solutionContainer ??= GetSys<SharedSolutionContainerSystem>();
|
|
|
|
if (_solutionContainer.TryGetSolution(input, name, out var solution))
|
|
return new SolutionRef(solution.Value);
|
|
|
|
return null;
|
|
}
|
|
|
|
[CommandImplementation("get")]
|
|
public IEnumerable<SolutionRef> Get([PipedArgument] IEnumerable<EntityUid> input, string name)
|
|
{
|
|
return input.Select(x => Get(x, name)).Where(x => x is not null).Cast<SolutionRef>();
|
|
}
|
|
|
|
[CommandImplementation("adjreagent")]
|
|
public SolutionRef AdjReagent(
|
|
[PipedArgument] SolutionRef input,
|
|
ProtoId<ReagentPrototype> proto,
|
|
float amount
|
|
)
|
|
{
|
|
_solutionContainer ??= GetSys<SharedSolutionContainerSystem>();
|
|
|
|
// Convert float to FixedPoint2
|
|
var amountFixed = FixedPoint2.New(amount);
|
|
|
|
if (amountFixed > 0)
|
|
{
|
|
_solutionContainer.TryAddReagent(input.Solution, proto, amountFixed, out _);
|
|
}
|
|
else if (amountFixed < 0)
|
|
{
|
|
_solutionContainer.RemoveReagent(input.Solution, proto, -amountFixed);
|
|
}
|
|
|
|
return input;
|
|
}
|
|
|
|
[CommandImplementation("adjreagent")]
|
|
public IEnumerable<SolutionRef> AdjReagent(
|
|
[PipedArgument] IEnumerable<SolutionRef> input,
|
|
ProtoId<ReagentPrototype> name,
|
|
float amount
|
|
)
|
|
=> input.Select(x => AdjReagent(x, name, amount));
|
|
}
|
|
|
|
public readonly record struct SolutionRef(Entity<SolutionComponent> Solution)
|
|
{
|
|
public override string ToString()
|
|
{
|
|
return $"{Solution.Owner} {Solution.Comp.Solution}";
|
|
}
|
|
}
|