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 extends IService> service) {
+ private void addUuidSearchResults(List records, IIdentifiableEntityServiceConfigurator configurator, Class extends IService> 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