Browse Source

Add IDependencyMap injection for public properties

tags/1.0-rc
james7132 8 years ago
parent
commit
a551064eaf
1 changed files with 20 additions and 1 deletions
  1. +20
    -1
      src/Discord.Net.Commands/Utilities/ReflectionUtils.cs

+ 20
- 1
src/Discord.Net.Commands/Utilities/ReflectionUtils.cs View File

@@ -19,6 +19,7 @@ namespace Discord.Commands


var constructor = constructors[0]; var constructor = constructors[0];
System.Reflection.ParameterInfo[] parameters = constructor.GetParameters(); System.Reflection.ParameterInfo[] parameters = constructor.GetParameters();
System.Reflection.PropertyInfo[] properties = typeInfo.DeclaredProperties.Where(p => p.CanWrite).ToArray();


return (map) => return (map) =>
{ {
@@ -40,15 +41,33 @@ namespace Discord.Commands
args[i] = arg; args[i] = arg;
} }


T obj;
try try
{ {
return (T)constructor.Invoke(args);
obj = (T)constructor.Invoke(args);
} }
catch (Exception ex) catch (Exception ex)
{ {
throw new Exception($"Failed to create \"{typeInfo.FullName}\"", ex); throw new Exception($"Failed to create \"{typeInfo.FullName}\"", ex);
} }

foreach(var property in properties)
{
object prop;
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(prop, null);
}
return obj;
}; };
} }

} }
} }

Loading…
Cancel
Save