Browse Source

Merge pull request #377 from RogueException/issue/368

Add CommandServiceConfig, DefaultRunMode
tags/1.0-rc
RogueException GitHub 8 years ago
parent
commit
aefbf1716d
5 changed files with 16 additions and 4 deletions
  1. +1
    -1
      src/Discord.Net.Commands/Attributes/CommandAttribute.cs
  2. +1
    -1
      src/Discord.Net.Commands/Builders/CommandBuilder.cs
  3. +5
    -1
      src/Discord.Net.Commands/CommandService.cs
  4. +8
    -0
      src/Discord.Net.Commands/CommandServiceConfig.cs
  5. +1
    -1
      src/Discord.Net.Commands/Info/CommandInfo.cs

+ 1
- 1
src/Discord.Net.Commands/Attributes/CommandAttribute.cs View File

@@ -6,7 +6,7 @@ namespace Discord.Commands
public class CommandAttribute : Attribute
{
public string Text { get; }
public RunMode RunMode { get; set; } = RunMode.Sync;
public RunMode RunMode { get; set; }

public CommandAttribute()
{


+ 1
- 1
src/Discord.Net.Commands/Builders/CommandBuilder.cs View File

@@ -17,7 +17,7 @@ namespace Discord.Commands.Builders
public string Name { get; set; }
public string Summary { get; set; }
public string Remarks { get; set; }
public RunMode RunMode { get; set; }
public RunMode? RunMode { get; set; }
public int Priority { get; set; }

public IReadOnlyList<PreconditionAttribute> Preconditions => _preconditions;


+ 5
- 1
src/Discord.Net.Commands/CommandService.cs View File

@@ -19,10 +19,13 @@ namespace Discord.Commands
private readonly ConcurrentBag<ModuleInfo> _moduleDefs;
private readonly CommandMap _map;

internal readonly RunMode _defaultRunMode;

public IEnumerable<ModuleInfo> Modules => _typedModuleDefs.Select(x => x.Value);
public IEnumerable<CommandInfo> Commands => _typedModuleDefs.SelectMany(x => x.Value.Commands);

public CommandService()
public CommandService() : this(new CommandServiceConfig()) { }
public CommandService(CommandServiceConfig config)
{
_moduleLock = new SemaphoreSlim(1, 1);
_typedModuleDefs = new ConcurrentDictionary<Type, ModuleInfo>();
@@ -64,6 +67,7 @@ namespace Discord.Commands
[typeof(IGroupUser)] = new UserTypeReader<IGroupUser>(),
[typeof(IGuildUser)] = new UserTypeReader<IGuildUser>(),
};
_defaultRunMode = config.DefaultRunMode;
}

//Modules


+ 8
- 0
src/Discord.Net.Commands/CommandServiceConfig.cs View File

@@ -0,0 +1,8 @@
namespace Discord.Commands
{
public class CommandServiceConfig
{
/// <summary> The default RunMode commands should have, if one is not specified on the Command attribute or builder. </summary>
public RunMode DefaultRunMode { get; set; } = RunMode.Mixed;
}
}

+ 1
- 1
src/Discord.Net.Commands/Info/CommandInfo.cs View File

@@ -37,7 +37,7 @@ namespace Discord.Commands
Summary = builder.Summary;
Remarks = builder.Remarks;

RunMode = builder.RunMode;
RunMode = builder.RunMode ?? service._defaultRunMode;
Priority = builder.Priority;
if (module.Aliases.Count != 0)


Loading…
Cancel
Save