From a910811873d23cefabb1e79fd403f5555dc37fe2 Mon Sep 17 00:00:00 2001 From: Patrick Plitzner Date: Wed, 9 Sep 2015 13:43:52 +0200 Subject: [PATCH] Optimize Code #5103 --- .../taxeditor/store/SearchManager.java | 41 +++++-------------- 1 file changed, 10 insertions(+), 31 deletions(-) diff --git a/eu.etaxonomy.taxeditor.store/src/main/java/eu/etaxonomy/taxeditor/store/SearchManager.java b/eu.etaxonomy.taxeditor.store/src/main/java/eu/etaxonomy/taxeditor/store/SearchManager.java index 4025e4197..e5861f668 100644 --- a/eu.etaxonomy.taxeditor.store/src/main/java/eu/etaxonomy/taxeditor/store/SearchManager.java +++ b/eu.etaxonomy.taxeditor.store/src/main/java/eu/etaxonomy/taxeditor/store/SearchManager.java @@ -65,10 +65,7 @@ public class SearchManager { public List findNames(IIdentifiableEntityServiceConfigurator configurator){ if(checkLargeResult(CdmStore.getService(INameService.class).countByTitle(configurator))){ List records = CdmStore.getService(INameService.class).findByTitle(configurator).getRecords(); - TaxonNameBase uuidSearchResult = addUuidSearchResults(configurator, INameService.class); - if(uuidSearchResult!=null){ - records.add(uuidSearchResult); - } + addUuidSearchResults(records, configurator, INameService.class); return records; } return NO_RESULTS; @@ -99,10 +96,7 @@ public class SearchManager { public List findReferences(IIdentifiableEntityServiceConfigurator configurator){ if(checkLargeResult(CdmStore.getService(IReferenceService.class).countByTitle(configurator))){ List records = CdmStore.getService(IReferenceService.class).findByTitle(configurator).getRecords(); - Reference uuidSearchResult = addUuidSearchResults(configurator, IReferenceService.class); - if(uuidSearchResult!=null){ - records.add(uuidSearchResult); - } + addUuidSearchResults(records, configurator, IReferenceService.class); return records; } return NO_RESULTS; @@ -111,10 +105,7 @@ public class SearchManager { public List findAgents(IIdentifiableEntityServiceConfigurator configurator){ if(checkLargeResult(CdmStore.getService(IAgentService.class).countByTitle(configurator))){ List records = CdmStore.getService(IAgentService.class).findByTitle(configurator).getRecords(); - AgentBase uuidSearchResult = addUuidSearchResults(configurator, IAgentService.class); - if(uuidSearchResult!=null){ - records.add(uuidSearchResult); - } + addUuidSearchResults(records, configurator, IAgentService.class); return records; } return NO_RESULTS; @@ -122,18 +113,18 @@ public class SearchManager { /** * Check search string if it is a {@link UUID} and, if true, search for the corresponding entity. + * @param records the list to which the search results are added * @param configurator the configurator holding the search string * @param service the service to use for searching */ - private T addUuidSearchResults(IIdentifiableEntityServiceConfigurator configurator, Class> service) { + private void addUuidSearchResults(List records, IIdentifiableEntityServiceConfigurator configurator, Class> service) { String titleSearchString = configurator.getTitleSearchString(); try { UUID uuid = UUID.fromString(titleSearchString); - return CdmStore.getService(service).find(uuid); + records.add(CdmStore.getService(service).find(uuid)); } catch (IllegalArgumentException e) { //search string was no UUID } - return null; } @SuppressWarnings("unchecked") @@ -194,10 +185,7 @@ public class SearchManager { else if(checkLargeResult(CdmStore.getService(IOccurrenceService.class).countOccurrences(configurator))){ records = CdmStore.getService(IOccurrenceService.class).findByTitle(configurator).getRecords(); } - SpecimenOrObservationBase uuidSearchResult = addUuidSearchResults(configurator, IOccurrenceService.class); - if(uuidSearchResult!=null){ - records.add(uuidSearchResult); - } + addUuidSearchResults(records, configurator, IOccurrenceService.class); return records; } @@ -205,10 +193,7 @@ public class SearchManager { String userNameSearchString = sqlizeTitleSearchString(configurator); // TODO why are users not identifiable entities? List records = CdmStore.getService(IUserService.class).listByUsername(userNameSearchString, null, null, null, null, null, null); - User uuidSearchResult = addUuidSearchResults(configurator, IUserService.class); - if(uuidSearchResult!=null){ - records.add(uuidSearchResult); - } + addUuidSearchResults(records, configurator, IUserService.class); return records; } @@ -217,10 +202,7 @@ public class SearchManager { String groupNameSearchString = sqlizeTitleSearchString(configurator); // TODO why are groups not identifiable entities? List records = CdmStore.getService(IGroupService.class).listByName(groupNameSearchString, null, null, null, null, null, null); - Group uuidSearchResult = addUuidSearchResults(configurator, IGroupService.class); - if(uuidSearchResult!=null){ - records.add(uuidSearchResult); - } + addUuidSearchResults(records, configurator, IGroupService.class); return records; } @@ -242,10 +224,7 @@ public class SearchManager { public List findTaxa(IIdentifiableEntityServiceConfigurator configurator) { if(checkLargeResult(CdmStore.getService(ITaxonService.class).countByTitle(configurator))){ List records = CdmStore.getService(ITaxonService.class).findByTitle(configurator).getRecords(); - TaxonBase uuidSearchResult = addUuidSearchResults(configurator, ITaxonService.class); - if(uuidSearchResult!=null){ - records.add(uuidSearchResult); - } + addUuidSearchResults(records, configurator, ITaxonService.class); return records; } return NO_RESULTS; -- 2.30.2