63 lines
2.0 KiB
C#
Raw Normal View History

2021-08-15 07:54:25 +02:00
using System;
2021-08-14 21:49:23 +02:00
2022-06-04 18:09:42 +08:00
namespace RageCoop.Server.Scripting
2021-08-14 21:49:23 +02:00
{
/// <summary>
/// Inherit from this class, constructor will be called automatically, but other scripts might have yet been loaded, you should use <see cref="OnStart"/>. to initiate your script.
/// </summary>
public abstract class ServerScript :Core.Scripting.IScriptable
{
/// <summary>
/// This method would be called from main thread after all scripts have been loaded.
/// </summary>
public abstract void OnStart();
2021-08-18 11:47:59 +02:00
2022-04-12 06:04:02 +02:00
/// <summary>
/// This method would be called from main thread when the server is shutting down, you MUST terminate all background jobs/threads in this method.
2022-04-12 06:04:02 +02:00
/// </summary>
public abstract void OnStop();
2022-04-12 06:04:02 +02:00
/// <summary>
/// Get the resource directory this script belongs to.
2022-04-12 06:04:02 +02:00
/// </summary>
public string CurrentDirectory { get; internal set; }
2022-04-12 06:04:02 +02:00
}
[AttributeUsage(AttributeTargets.Method, Inherited = false)]
public class Command : Attribute
2021-08-18 11:47:59 +02:00
{
/// <summary>
/// Sets name of the command
/// </summary>
public string Name { get; set; }
2021-12-16 14:52:48 +01:00
/// <summary>
/// Set the Usage (Example: "Please use "/help"". ArgsLength required!)
/// </summary>
public string Usage { get; set; }
2021-12-16 14:52:48 +01:00
/// <summary>
/// Set the length of arguments (Example: 2 for "/message USERNAME MESSAGE". Usage required!)
/// </summary>
public short ArgsLength { get; set; }
public Command(string name)
2021-08-15 07:54:25 +02:00
{
2021-08-18 11:47:59 +02:00
Name = name;
2021-08-15 07:54:25 +02:00
}
2021-08-14 21:49:23 +02:00
}
2021-08-18 11:47:59 +02:00
public class CommandContext
{
/// <summary>
/// Gets the client which executed the command
/// </summary>
2021-08-26 17:01:32 +02:00
public Client Client { get; internal set; }
2021-08-18 11:47:59 +02:00
/// <summary>
2021-12-16 14:52:48 +01:00
/// Gets the arguments (Example: "/message USERNAME MESSAGE", Args[0] for USERNAME)
2021-08-18 11:47:59 +02:00
/// </summary>
public string[] Args { get; internal set; }
}
2021-08-14 21:49:23 +02:00
}