funny container commands (#5113)
This commit is contained in:
60
Content.Server/Administration/Commands/AddBodyPartCommand.cs
Normal file
60
Content.Server/Administration/Commands/AddBodyPartCommand.cs
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
using Content.Server.Body;
|
||||||
|
using Content.Server.Body.Mechanism;
|
||||||
|
using Content.Server.Body.Part;
|
||||||
|
using Content.Server.Storage.Components;
|
||||||
|
using Content.Shared.Administration;
|
||||||
|
using Robust.Shared.Console;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
using Robust.Shared.IoC;
|
||||||
|
using Robust.Shared.Localization;
|
||||||
|
|
||||||
|
namespace Content.Server.Administration.Commands
|
||||||
|
{
|
||||||
|
[AdminCommand(AdminFlags.Fun)]
|
||||||
|
public class AddBodyPartCommand : IConsoleCommand
|
||||||
|
{
|
||||||
|
public string Command => "addbodypart";
|
||||||
|
public string Description => "Adds a given entity to a containing body.";
|
||||||
|
public string Help => "Usage: addbodypart <entity uid> <body uid> <part slot>";
|
||||||
|
|
||||||
|
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
||||||
|
{
|
||||||
|
if (args.Length != 3)
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-wrong-arguments-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!EntityUid.TryParse(args[0], out var entityUid))
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-entity-uid-must-be-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!EntityUid.TryParse(args[1], out var storageUid))
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-entity-uid-must-be-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var entityManager = IoCManager.Resolve<IEntityManager>();
|
||||||
|
|
||||||
|
if (entityManager.TryGetComponent<BodyComponent>(storageUid, out var storage)
|
||||||
|
&& entityManager.TryGetComponent<BodyPartComponent>(entityUid, out var bodyPart))
|
||||||
|
{
|
||||||
|
if (storage.TryAddPart(args[3], bodyPart))
|
||||||
|
{
|
||||||
|
shell.WriteLine($@"Added {entityUid} to {storageUid}.");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
shell.WriteError($@"Could not add {entityUid} to {storageUid}.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
shell.WriteError("Could not insert.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,51 @@
|
|||||||
|
using Content.Server.Body.Mechanism;
|
||||||
|
using Content.Server.Body.Part;
|
||||||
|
using Content.Server.Storage.Components;
|
||||||
|
using Content.Shared.Administration;
|
||||||
|
using Robust.Shared.Console;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
using Robust.Shared.IoC;
|
||||||
|
using Robust.Shared.Localization;
|
||||||
|
|
||||||
|
namespace Content.Server.Administration.Commands
|
||||||
|
{
|
||||||
|
[AdminCommand(AdminFlags.Fun)]
|
||||||
|
public class AddEntityStorageCommand : IConsoleCommand
|
||||||
|
{
|
||||||
|
public string Command => "addstorage";
|
||||||
|
public string Description => "Adds a given entity to a containing storage.";
|
||||||
|
public string Help => "Usage: addstorage <entity uid> <storage uid>";
|
||||||
|
|
||||||
|
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
||||||
|
{
|
||||||
|
if (args.Length != 2)
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-wrong-arguments-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!EntityUid.TryParse(args[0], out var entityUid))
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-entity-uid-must-be-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!EntityUid.TryParse(args[1], out var storageUid))
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-entity-uid-must-be-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var entityManager = IoCManager.Resolve<IEntityManager>();
|
||||||
|
|
||||||
|
if (entityManager.TryGetComponent<EntityStorageComponent>(storageUid, out var storage))
|
||||||
|
{
|
||||||
|
storage.Insert(entityManager.GetEntity(entityUid));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
shell.WriteError("Could not insert into non-storage.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,60 @@
|
|||||||
|
using Content.Server.Body;
|
||||||
|
using Content.Server.Body.Mechanism;
|
||||||
|
using Content.Server.Body.Part;
|
||||||
|
using Content.Server.Storage.Components;
|
||||||
|
using Content.Shared.Administration;
|
||||||
|
using Robust.Shared.Console;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
using Robust.Shared.IoC;
|
||||||
|
using Robust.Shared.Localization;
|
||||||
|
|
||||||
|
namespace Content.Server.Administration.Commands
|
||||||
|
{
|
||||||
|
[AdminCommand(AdminFlags.Fun)]
|
||||||
|
public class AddMechanismCommand : IConsoleCommand
|
||||||
|
{
|
||||||
|
public string Command => "addmechanism";
|
||||||
|
public string Description => "Adds a given entity to a containing body.";
|
||||||
|
public string Help => "Usage: addmechanism <entity uid> <bodypart uid>";
|
||||||
|
|
||||||
|
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
||||||
|
{
|
||||||
|
if (args.Length != 2)
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-wrong-arguments-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!EntityUid.TryParse(args[0], out var entityUid))
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-entity-uid-must-be-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!EntityUid.TryParse(args[1], out var storageUid))
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-entity-uid-must-be-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var entityManager = IoCManager.Resolve<IEntityManager>();
|
||||||
|
|
||||||
|
if (entityManager.TryGetComponent<BodyPartComponent>(storageUid, out var storage)
|
||||||
|
&& entityManager.TryGetComponent<MechanismComponent>(entityUid, out var bodyPart))
|
||||||
|
{
|
||||||
|
if (storage.TryAddMechanism(bodyPart))
|
||||||
|
{
|
||||||
|
shell.WriteLine($@"Added {entityUid} to {storageUid}.");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
shell.WriteError($@"Could not add {entityUid} to {storageUid}.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
shell.WriteError("Could not insert.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,50 @@
|
|||||||
|
using Content.Server.Body;
|
||||||
|
using Content.Server.Body.Part;
|
||||||
|
using Content.Shared.Administration;
|
||||||
|
using Robust.Shared.Console;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
using Robust.Shared.IoC;
|
||||||
|
using Robust.Shared.Localization;
|
||||||
|
|
||||||
|
namespace Content.Server.Administration.Commands
|
||||||
|
{
|
||||||
|
[AdminCommand(AdminFlags.Fun)]
|
||||||
|
public class RemoveBodyPartCommand : IConsoleCommand
|
||||||
|
{
|
||||||
|
public string Command => "rmbodypart";
|
||||||
|
public string Description => "Removes a given entity from it's containing body, if any.";
|
||||||
|
public string Help => "Usage: rmbodypart <uid>";
|
||||||
|
|
||||||
|
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
||||||
|
{
|
||||||
|
if (args.Length != 1)
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-wrong-arguments-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!EntityUid.TryParse(args[0], out var entityUid))
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-entity-uid-must-be-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var entityManager = IoCManager.Resolve<IEntityManager>();
|
||||||
|
|
||||||
|
if (!entityManager.TryGetComponent<ITransformComponent>(entityUid, out var transform)) return;
|
||||||
|
|
||||||
|
var parent = transform.ParentUid;
|
||||||
|
|
||||||
|
if (entityManager.TryGetComponent<BodyComponent>(parent, out var body) &&
|
||||||
|
entityManager.TryGetComponent<BodyPartComponent>(entityUid, out var part))
|
||||||
|
{
|
||||||
|
body.RemovePart(part);
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
shell.WriteError("Was not a body part, or did not have a parent.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,49 @@
|
|||||||
|
using Content.Server.Body.Mechanism;
|
||||||
|
using Content.Server.Body.Part;
|
||||||
|
using Content.Server.Storage.Components;
|
||||||
|
using Content.Shared.Administration;
|
||||||
|
using Robust.Shared.Console;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
using Robust.Shared.IoC;
|
||||||
|
using Robust.Shared.Localization;
|
||||||
|
|
||||||
|
namespace Content.Server.Administration.Commands
|
||||||
|
{
|
||||||
|
[AdminCommand(AdminFlags.Fun)]
|
||||||
|
public class RemoveEntityStorageCommand : IConsoleCommand
|
||||||
|
{
|
||||||
|
public string Command => "rmstorage";
|
||||||
|
public string Description => "Removes a given entity from it's containing storage, if any.";
|
||||||
|
public string Help => "Usage: rmstorage <uid>";
|
||||||
|
|
||||||
|
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
||||||
|
{
|
||||||
|
if (args.Length != 1)
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-wrong-arguments-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!EntityUid.TryParse(args[0], out var entityUid))
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-entity-uid-must-be-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var entityManager = IoCManager.Resolve<IEntityManager>();
|
||||||
|
|
||||||
|
if (!entityManager.TryGetComponent<ITransformComponent>(entityUid, out var transform)) return;
|
||||||
|
|
||||||
|
var parent = transform.ParentUid;
|
||||||
|
|
||||||
|
if (entityManager.TryGetComponent<EntityStorageComponent>(parent, out var storage))
|
||||||
|
{
|
||||||
|
storage.Remove(entityManager.GetEntity(entityUid));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
shell.WriteError("Could not remove from storage.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,50 @@
|
|||||||
|
using Content.Server.Body;
|
||||||
|
using Content.Server.Body.Mechanism;
|
||||||
|
using Content.Server.Body.Part;
|
||||||
|
using Content.Shared.Administration;
|
||||||
|
using Robust.Shared.Console;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
using Robust.Shared.IoC;
|
||||||
|
using Robust.Shared.Localization;
|
||||||
|
|
||||||
|
namespace Content.Server.Administration.Commands
|
||||||
|
{
|
||||||
|
[AdminCommand(AdminFlags.Fun)]
|
||||||
|
public class RemoveMechanismCommand : IConsoleCommand
|
||||||
|
{
|
||||||
|
public string Command => "rmmechanism";
|
||||||
|
public string Description => "Removes a given entity from it's containing bodypart, if any.";
|
||||||
|
public string Help => "Usage: rmmechanism <uid>";
|
||||||
|
|
||||||
|
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
||||||
|
{
|
||||||
|
if (args.Length != 1)
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-wrong-arguments-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!EntityUid.TryParse(args[0], out var entityUid))
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-entity-uid-must-be-number"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var entityManager = IoCManager.Resolve<IEntityManager>();
|
||||||
|
|
||||||
|
if (!entityManager.TryGetComponent<ITransformComponent>(entityUid, out var transform)) return;
|
||||||
|
|
||||||
|
var parent = transform.ParentUid;
|
||||||
|
|
||||||
|
if (entityManager.TryGetComponent<BodyPartComponent>(parent, out var body) &&
|
||||||
|
entityManager.TryGetComponent<MechanismComponent>(entityUid, out var part))
|
||||||
|
{
|
||||||
|
body.RemoveMechanism(part);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
shell.WriteError("Was not a mechanism, or did not have a parent.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user