Console Unify API Changes (#3059)
* Remove unused IChatCommand. * Lots of refactoring into a shared context. * Removed ICommonSession from server concmd Execute. * Added argStr parameter to concmd execute. * The execute function of client concmds now returns void, use the new shell.RemoteExecuteCommand function to forward commands. * Finally move shells and commands into shared. * Console commands can now be registered directly without a class in a shared context. * Engine API Changes. * Repair rebase damage. * Update Submodule.
This commit is contained in:
@@ -1,9 +1,9 @@
|
||||
using JetBrains.Annotations;
|
||||
using Robust.Client.Interfaces.Console;
|
||||
using Content.Client.GameObjects.EntitySystems;
|
||||
using Robust.Shared.GameObjects.Systems;
|
||||
using Content.Shared.Atmos;
|
||||
using System;
|
||||
using Robust.Shared.Console;
|
||||
|
||||
namespace Content.Client.Commands
|
||||
{
|
||||
@@ -13,32 +13,31 @@ namespace Content.Client.Commands
|
||||
public string Command => "atvrange";
|
||||
public string Description => "Sets the atmos debug range (as two floats, start [red] and end [blue])";
|
||||
public string Help => "atvrange <start> <end>";
|
||||
public bool Execute(IDebugConsole console, params string[] args)
|
||||
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
||||
{
|
||||
if (args.Length != 2)
|
||||
{
|
||||
console.AddLine(Help);
|
||||
return false;
|
||||
shell.WriteLine(Help);
|
||||
return;
|
||||
}
|
||||
if (!float.TryParse(args[0], out var xStart))
|
||||
{
|
||||
console.AddLine("Bad float START");
|
||||
return false;
|
||||
shell.WriteLine("Bad float START");
|
||||
return;
|
||||
}
|
||||
if (!float.TryParse(args[1], out var xEnd))
|
||||
{
|
||||
console.AddLine("Bad float END");
|
||||
return false;
|
||||
shell.WriteLine("Bad float END");
|
||||
return;
|
||||
}
|
||||
if (xStart == xEnd)
|
||||
{
|
||||
console.AddLine("Scale cannot be zero, as this would cause a division by zero in AtmosDebugOverlay.");
|
||||
return false;
|
||||
shell.WriteLine("Scale cannot be zero, as this would cause a division by zero in AtmosDebugOverlay.");
|
||||
return;
|
||||
}
|
||||
var sys = EntitySystem.Get<AtmosDebugOverlaySystem>();
|
||||
sys.CfgBase = xStart;
|
||||
sys.CfgScale = xEnd - xStart;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -48,17 +47,17 @@ namespace Content.Client.Commands
|
||||
public string Command => "atvmode";
|
||||
public string Description => "Sets the atmos debug mode. This will automatically reset the scale.";
|
||||
public string Help => "atvmode <TotalMoles/GasMoles/Temperature> [<gas ID (for GasMoles)>]";
|
||||
public bool Execute(IDebugConsole console, params string[] args)
|
||||
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
||||
{
|
||||
if (args.Length < 1)
|
||||
{
|
||||
console.AddLine(Help);
|
||||
return false;
|
||||
shell.WriteLine(Help);
|
||||
return;
|
||||
}
|
||||
if (!Enum.TryParse<AtmosDebugOverlayMode>(args[0], out var xMode))
|
||||
{
|
||||
console.AddLine("Invalid mode");
|
||||
return false;
|
||||
shell.WriteLine("Invalid mode");
|
||||
return;
|
||||
}
|
||||
int xSpecificGas = 0;
|
||||
float xBase = 0;
|
||||
@@ -67,21 +66,21 @@ namespace Content.Client.Commands
|
||||
{
|
||||
if (args.Length != 2)
|
||||
{
|
||||
console.AddLine("A target gas must be provided for this mode.");
|
||||
return false;
|
||||
shell.WriteLine("A target gas must be provided for this mode.");
|
||||
return;
|
||||
}
|
||||
if (!AtmosCommandUtils.TryParseGasID(args[1], out xSpecificGas))
|
||||
{
|
||||
console.AddLine("Gas ID not parsable or out of range.");
|
||||
return false;
|
||||
shell.WriteLine("Gas ID not parsable or out of range.");
|
||||
return;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if (args.Length != 1)
|
||||
{
|
||||
console.AddLine("No further information is required for this mode.");
|
||||
return false;
|
||||
shell.WriteLine("No further information is required for this mode.");
|
||||
return;
|
||||
}
|
||||
if (xMode == AtmosDebugOverlayMode.Temperature)
|
||||
{
|
||||
@@ -95,7 +94,6 @@ namespace Content.Client.Commands
|
||||
sys.CfgSpecificGas = xSpecificGas;
|
||||
sys.CfgBase = xBase;
|
||||
sys.CfgScale = xScale;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -105,21 +103,20 @@ namespace Content.Client.Commands
|
||||
public string Command => "atvcbm";
|
||||
public string Description => "Changes from red/green/blue to greyscale";
|
||||
public string Help => "atvcbm <true/false>";
|
||||
public bool Execute(IDebugConsole console, params string[] args)
|
||||
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
||||
{
|
||||
if (args.Length != 1)
|
||||
{
|
||||
console.AddLine(Help);
|
||||
return false;
|
||||
shell.WriteLine(Help);
|
||||
return;
|
||||
}
|
||||
if (!bool.TryParse(args[0], out var xFlag))
|
||||
{
|
||||
console.AddLine("Invalid flag");
|
||||
return false;
|
||||
shell.WriteLine("Invalid flag");
|
||||
return;
|
||||
}
|
||||
var sys = EntitySystem.Get<AtmosDebugOverlaySystem>();
|
||||
sys.CfgCBM = xFlag;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user