Sto provando a giocare con (quello che penso sia) una factory che crea un repository a seconda dell'enum che viene passato al metodo. Si presenta così:Activator.CreateInstance con un repository generico
RepositoryFactory
public class RepositoryFactory
{
public IRepository<IEntity> GetRepository(FormTypes formType)
{
// Represents the IRepository that should be created, based on the form type passed
var typeToCreate = formType.GetAttribute<EnumTypeAttribute>().Type;
// return an instance of the form type repository
IRepository<IEntity> type = Activator.CreateInstance(typeToCreate) as IRepository<IEntity>;
if (type != null)
return type;
throw new ArgumentException(string.Format("No repository found for {0}", nameof(formType)));
}
}
IRepository
public interface IRepository <T>
where T : class, IEntity
{
bool Create(IEnumerable<T> entities);
IEnumerable<T> Read();
bool Update(IEnumerable<T> entities);
bool Delete(IEnumerable<T> entities);
}
FormTypes
public enum FormTypes
{
[EnumType(typeof(Form64_9C2Repository))]
Form64_9C2,
[EnumType(typeof(Form64_9BaseRepository))]
Form64_9Base
}
EnumExtensions
public static class EnumExtensions
{
/// <summary>
/// Get the Enum attribute
/// </summary>
/// <typeparam name="T">The attribute</typeparam>
/// <param name="enumValue">The enum</param>
/// <returns>The type to create</returns>
public static T GetAttribute<T>(this System.Enum enumValue)
where T : Attribute
{
FieldInfo field = enumValue.GetType().GetField(enumValue.ToString());
object[] attribs = field.GetCustomAttributes(typeof(T), false);
T result = default(T);
if (attribs.Length > 0)
{
result = attribs[0] as T;
}
return result;
}
}
Form64_9C2Repository
public class Form64_9C2Repository : IRepository<Form64_9C2>
{
public bool Create(IEnumerable<Form64_9C2> entities)
{
throw new NotImplementedException();
}
public bool Delete(IEnumerable<Form64_9C2> entities)
{
throw new NotImplementedException();
}
public IEnumerable<Form64_9C2> Read()
{
throw new NotImplementedException();
}
public bool Update(IEnumerable<Form64_9C2> entities)
{
throw new NotImplementedException();
}
}
IEntity
public interface IEntity { }
Form64_9C2 (stub)
public class Form64_9C2 : IEntity { }
Calling tutto come:
class Program
{
static void Main(string[] args)
{
Console.WriteLine("Repository Factory Example \n\n");
Business.Factory.RepositoryFactory factory = new Business.Factory.RepositoryFactory();
// Get a 64 9C2 repository
var repo9c2 = factory.GetRepository(FormTypes.Form64_9C2);
Console.WriteLine(repo9c2);
}
}
Il mio problema è il mio type
è sempre la risoluzione a null
. Mi aspetto di ottenere un NotImplementedException
, ma sto invece ottenendo il ArgumentException
per non avere un formType valido.
Prima di implementare il mio IRepository<T>
type
/repository
è stata con successo essere creato (codice funzionante here), tutte le idee? Sto solo iniziando a giocare con fabbriche, generici e simili - quindi se sto facendo qualcosa di sbagliato, ti prego di avvisare!
wow, solo facendo 'fuori T' cambia molto - anche se non capisco veramente perché :(Purtroppo ho voluto essere in grado di risolvere un repository per tutti CRUD , non solo R. Vedo che hai fornito un modo per farlo, ma aggiungendo un additio parametro nale. Speravo davvero di mantenere il mio repository e la sua entità associata "insieme" in modo da evitare di chiamare un determinato repository con un'entità in conflitto. Grazie +1, accetterò presto, supponendo di non trovare qualcosa di più simile a quello che speravo davvero di ottenere. – Kritner