| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- using Content.Shared.Chemistry.EntitySystems;
- using Content.Shared.Administration;
- using Content.Shared.Chemistry.Components.SolutionManager;
- using Robust.Shared.Console;
- using System.Linq;
- namespace Content.Server.Administration.Commands
- {
- [AdminCommand(AdminFlags.Fun)]
- public sealed class SetSolutionTemperature : IConsoleCommand
- {
- [Dependency] private readonly IEntityManager _entManager = default!;
- public string Command => "setsolutiontemperature";
- public string Description => "Set the temperature of some solution.";
- public string Help => $"Usage: {Command} <target> <solution> <new temperature>";
- public void Execute(IConsoleShell shell, string argStr, string[] args)
- {
- if (args.Length < 3)
- {
- shell.WriteLine($"Not enough arguments.\n{Help}");
- return;
- }
- if (!NetEntity.TryParse(args[0], out var uidNet) || !_entManager.TryGetEntity(uidNet, out var uid))
- {
- shell.WriteLine($"Invalid entity id.");
- return;
- }
- if (!_entManager.TryGetComponent(uid, out SolutionContainerManagerComponent? man))
- {
- shell.WriteLine($"Entity does not have any solutions.");
- return;
- }
- var solutionContainerSystem = _entManager.System<SharedSolutionContainerSystem>();
- if (!solutionContainerSystem.TryGetSolution((uid.Value, man), args[1], out var solution))
- {
- var validSolutions = string.Join(", ", solutionContainerSystem.EnumerateSolutions((uid.Value, man)).Select(s => s.Name));
- shell.WriteLine($"Entity does not have a \"{args[1]}\" solution. Valid solutions are:\n{validSolutions}");
- return;
- }
- if (!float.TryParse(args[2], out var quantity))
- {
- shell.WriteLine($"Failed to parse new temperature.");
- return;
- }
- if (quantity <= 0.0f)
- {
- shell.WriteLine($"Cannot set the temperature of a solution to a non-positive number.");
- return;
- }
- solutionContainerSystem.SetTemperature(solution.Value, quantity);
- }
- }
- }
|