Tengo el siguiente código y me gustaría escribirlo de manera que tenga un mínimo de líneas de código y el trabajo se hace de la misma manera. ¿Cómo puedo hacer eso?¿Cómo puedo evitar la duplicación de código?
List<Category> categoryList = new List<Category>();
categoryList = Category.LoadForProject(project.ID).ToList();
List<string> categories = new List<string>(Categories);
IList<Category> currentCategories = Category.LoadForProject(project.ID).ToList();
if (currentCategories != null)
{
foreach (var existingCategories in currentCategories)
{
if (categories.Contains(existingCategories.Name))
categories.Remove(existingCategories.Name);
else
existingCategories.Delete(Services.UserServices.User);
}
foreach (string item in categories)
{
Category category = new Category(project, item.ToString());
category.Project = project;
category.Save();
}
}
List<string> priorities = new List<string>(Priorities);
IList<Priority> currentPriorities = Priority.LoadForProject(project.ID).ToList();
if (currentPriorities != null)
{
foreach (var existingPriorities in currentPriorities)
{
if (priorities.Contains(existingPriorities.Name))
priorities.Remove(existingPriorities.Name);
else
existingPriorities.Delete(Services.UserServices.User);
}
foreach (string item in priorities)
{
Priority priority = new Priority(project, item.ToString());
priority.Project = project;
priority.Save();
}
}
genéricos es una buena solución ... su llamada necesitaría agregar el tipo ¿no es así, es decir 'var currentCategories = DoYourThing (Categories.ToList(), Category.LoadForProject (project.ID) .ToList()) ; '? –
Lazarus
@Lasarus: No. Cuando los parámetros pueden inferir el tipo (como en este caso), la declaración de tipo en el método es redundante. :) –
@Brian Genisio su derecho que es imposiblemente difícil de conseguir si no entiende el Activador.Crea parte. Esto es simple Genius. – msarchet