Ho il seguente codice e vorrei scriverlo in modo che abbia linee di codice minime e il lavoro sia fatto allo stesso modo. Come lo posso fare?Come evitare la duplicazione del codice
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();
}
}
Generics è una bella soluzione ... la tua chiamata dovrebbe aggiungere il tipo, no, vale a dire var currentCategories = DoYourThing (Categories.ToList(), Category.LoadForProject (project.ID) .ToList()) ; '? –
Lazarus
@Lasarus: No. Quando il tipo può essere dedotto dai parametri (come in questo caso), la dichiarazione del tipo sul metodo è ridondante. :) –
@Brian Genisio il tuo diritto che è impossibile da trovare se non capisci la parte Activator.Create. Questo è semplice Genius. – msarchet