mirror of
https://github.com/space-wizards/RobustToolbox.git
synced 2026-02-15 03:30:53 +01:00
* Renamed shared ICommand to IConsoleCommand. * 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. # Conflicts: # Robust.Client/Console/Commands/Debug.cs * Finally move shells and commands into shared. * Console commands can now be registered directly without a class in a shared context. * Pulled up ConsoleHost and Console shell into a shared context. * Pulled up half the functions of ConsoleHost into a shared context. * Repair rebase damage. * Make LoadConsoleCommands function not remove any previously registered commands.
75 lines
2.7 KiB
C#
75 lines
2.7 KiB
C#
using Robust.Shared.Log;
|
|
using Robust.Shared.Maths;
|
|
using System;
|
|
using Robust.Shared.Console;
|
|
|
|
namespace Robust.Client.Console.Commands
|
|
{
|
|
class LogSetLevelCommand : IConsoleCommand
|
|
{
|
|
public string Command => "loglevel";
|
|
public string Description => "Changes the log level for a provided sawmill.";
|
|
public string Help => "Usage: loglevel <sawmill> <level>"
|
|
+ "\n sawmill: A label prefixing log messages. This is the one you're setting the level for."
|
|
+ "\n level: The log level. Must match one of the values of the LogLevel enum.";
|
|
|
|
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
|
{
|
|
if (args.Length != 2)
|
|
{
|
|
shell.WriteLine("Invalid argument amount. Expected 2 arguments.", Color.Red);
|
|
return;
|
|
}
|
|
|
|
var name = args[0];
|
|
var levelname = args[1];
|
|
LogLevel? level;
|
|
if (levelname == "null")
|
|
{
|
|
level = null;
|
|
}
|
|
else
|
|
{
|
|
if (!Enum.TryParse<LogLevel>(levelname, out var result))
|
|
{
|
|
shell.WriteLine("Failed to parse 2nd argument. Must be one of the values of the LogLevel enum.");
|
|
return;
|
|
}
|
|
level = result;
|
|
}
|
|
Logger.GetSawmill(name).Level = level;
|
|
}
|
|
}
|
|
|
|
class TestLog : IConsoleCommand
|
|
{
|
|
public string Command => "testlog";
|
|
public string Description => "Writes a test log to a sawmill.";
|
|
public string Help => "Usage: testlog <sawmill> <level> <message>"
|
|
+ "\n sawmill: A label prefixing the logged message."
|
|
+ "\n level: The log level. Must match one of the values of the LogLevel enum."
|
|
+ "\n message: The message to be logged. Wrap this in double quotes if you want to use spaces.";
|
|
|
|
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
|
{
|
|
if (args.Length != 3)
|
|
{
|
|
shell.WriteLine("Invalid argument amount. Expected 3 arguments.", Color.Red);
|
|
return;
|
|
}
|
|
|
|
var name = args[0];
|
|
var levelname = args[1];
|
|
var message = args[2]; // yes this doesn't support spaces idgaf.
|
|
if (!Enum.TryParse<LogLevel>(levelname, out var result))
|
|
{
|
|
shell.WriteLine("Failed to parse 2nd argument. Must be one of the values of the LogLevel enum.");
|
|
return;
|
|
}
|
|
var level = result;
|
|
|
|
Logger.LogS(level, name, message);
|
|
}
|
|
}
|
|
}
|