Fix detection of IDependencyMap impltags/1.0-rc
@@ -38,6 +38,10 @@ namespace Discord.Commands | |||||
public void AddFactory<T>(Func<T> factory) where T : class | public void AddFactory<T>(Func<T> factory) where T : class | ||||
{ | { | ||||
var t = typeof(T); | var t = typeof(T); | ||||
if (typeof(T) == typeof(IDependencyMap)) | |||||
throw new InvalidOperationException("IDependencyMap is used internally and cannot be added as a dependency"); | |||||
if (typeof(T) == typeof(CommandService)) | |||||
throw new InvalidOperationException("CommandService is used internally and cannot be added as a dependency"); | |||||
if (map.ContainsKey(t)) | if (map.ContainsKey(t)) | ||||
throw new InvalidOperationException($"The dependency map already contains \"{t.FullName}\""); | throw new InvalidOperationException($"The dependency map already contains \"{t.FullName}\""); | ||||
map.Add(t, factory); | map.Add(t, factory); | ||||
@@ -48,6 +52,10 @@ namespace Discord.Commands | |||||
var t = typeof(T); | var t = typeof(T); | ||||
if (map.ContainsKey(t)) | if (map.ContainsKey(t)) | ||||
return false; | return false; | ||||
if (typeof(T) == typeof(IDependencyMap)) | |||||
throw new InvalidOperationException("IDependencyMap is used internally and cannot be added as a dependency"); | |||||
if (typeof(T) == typeof(CommandService)) | |||||
throw new InvalidOperationException("CommandService is used internally and cannot be added as a dependency"); | |||||
map.Add(t, factory); | map.Add(t, factory); | ||||
return true; | return true; | ||||
} | } | ||||
@@ -51,6 +51,8 @@ namespace Discord.Commands | |||||
}; | }; | ||||
} | } | ||||
private static readonly TypeInfo _dependencyTypeInfo = typeof(IDependencyMap).GetTypeInfo(); | |||||
internal static object GetMember(Type targetType, IDependencyMap map, CommandService service, TypeInfo baseType) | internal static object GetMember(Type targetType, IDependencyMap map, CommandService service, TypeInfo baseType) | ||||
{ | { | ||||
object arg; | object arg; | ||||
@@ -58,7 +60,7 @@ namespace Discord.Commands | |||||
{ | { | ||||
if (targetType == typeof(CommandService)) | if (targetType == typeof(CommandService)) | ||||
arg = service; | arg = service; | ||||
else if (targetType == typeof(IDependencyMap)) | |||||
else if (targetType == typeof(IDependencyMap) || targetType == map.GetType()) | |||||
arg = map; | arg = map; | ||||
else | else | ||||
throw new InvalidOperationException($"Failed to create \"{baseType.FullName}\", dependency \"{targetType.Name}\" was not found."); | throw new InvalidOperationException($"Failed to create \"{baseType.FullName}\", dependency \"{targetType.Name}\" was not found."); | ||||