Cleanup property injection
This commit is contained in:
@@ -30,17 +30,7 @@ namespace Discord.Commands
|
|||||||
for (int i = 0; i < parameters.Length; i++)
|
for (int i = 0; i < parameters.Length; i++)
|
||||||
{
|
{
|
||||||
var parameter = parameters[i];
|
var parameter = parameters[i];
|
||||||
object arg;
|
args[i] = GetMember(parameter.ParameterType, map, service, typeInfo);
|
||||||
if (map == null || !map.TryGet(parameter.ParameterType, out arg))
|
|
||||||
{
|
|
||||||
if (parameter.ParameterType == typeof(CommandService))
|
|
||||||
arg = service;
|
|
||||||
else if (parameter.ParameterType == typeof(IDependencyMap))
|
|
||||||
arg = map;
|
|
||||||
else
|
|
||||||
throw new InvalidOperationException($"Failed to create \"{typeInfo.FullName}\", dependency \"{parameter.ParameterType.Name}\" was not found.");
|
|
||||||
}
|
|
||||||
args[i] = arg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
T obj;
|
T obj;
|
||||||
@@ -55,21 +45,25 @@ namespace Discord.Commands
|
|||||||
|
|
||||||
foreach(var property in properties)
|
foreach(var property in properties)
|
||||||
{
|
{
|
||||||
object prop;
|
property.SetValue(obj, GetMember(property.PropertyType, map, service, typeInfo));
|
||||||
if (map == null || !map.TryGet(property.PropertyType, out prop))
|
|
||||||
{
|
|
||||||
if (property.PropertyType == typeof(CommandService))
|
|
||||||
prop = service;
|
|
||||||
else if (property.PropertyType == typeof(IDependencyMap))
|
|
||||||
prop = map;
|
|
||||||
else
|
|
||||||
throw new InvalidOperationException($"Failed to create \"{typeInfo.FullName}\", dependency \"{property.PropertyType.Name}\" was not found.");
|
|
||||||
}
|
|
||||||
property.SetValue(obj, prop);
|
|
||||||
}
|
}
|
||||||
return obj;
|
return obj;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal static object GetMember(Type targetType, IDependencyMap map, CommandService service, TypeInfo baseType)
|
||||||
|
{
|
||||||
|
object arg;
|
||||||
|
if (map == null || !map.TryGet(targetType, out arg))
|
||||||
|
{
|
||||||
|
if (targetType == typeof(CommandService))
|
||||||
|
arg = service;
|
||||||
|
else if (targetType == typeof(IDependencyMap))
|
||||||
|
arg = map;
|
||||||
|
else
|
||||||
|
throw new InvalidOperationException($"Failed to create \"{baseType.FullName}\", dependency \"{targetType.Name}\" was not found.");
|
||||||
|
}
|
||||||
|
return arg;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user