| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 |
- using Content.Shared.Administration;
- using Robust.Shared.Console;
- using Robust.Shared.Prototypes;
- namespace Content.Server.Administration.Commands
- {
- [AdminCommand(AdminFlags.Mapping)]
- public sealed class RemoveExtraComponents : IConsoleCommand
- {
- public string Command => "removeextracomponents";
- public string Description => "Removes all components from all entities of the specified id if that component is not in its prototype.\nIf no id is specified, it matches all entities.";
- public string Help => $"{Command} <entityId> / {Command}";
- public void Execute(IConsoleShell shell, string argStr, string[] args)
- {
- var id = args.Length == 0 ? null : string.Join(" ", args);
- var entityManager = IoCManager.Resolve<IEntityManager>();
- var prototypeManager = IoCManager.Resolve<IPrototypeManager>();
- var fac = IoCManager.Resolve<IComponentFactory>();
- EntityPrototype? prototype = null;
- var checkPrototype = !string.IsNullOrEmpty(id);
- if (checkPrototype && !prototypeManager.TryIndex(id!, out prototype))
- {
- shell.WriteError($"Can't find entity prototype with id \"{id}\"!");
- return;
- }
- var entities = 0;
- var components = 0;
- foreach (var entity in entityManager.GetEntities())
- {
- var metaData = entityManager.GetComponent<MetaDataComponent>(entity);
- if (checkPrototype && metaData.EntityPrototype != prototype || metaData.EntityPrototype == null)
- {
- continue;
- }
- var modified = false;
- foreach (var component in entityManager.GetComponents(entity))
- {
- if (metaData.EntityPrototype.Components.ContainsKey(fac.GetComponentName(component.GetType())))
- continue;
- entityManager.RemoveComponent(entity, component);
- components++;
- modified = true;
- }
- if (modified)
- entities++;
- }
- shell.WriteLine($"Removed {components} components from {entities} entities{(id == null ? "." : $" with id {id}")}");
- }
- }
- }
|