From 2ff3ee7e06c124ff831ce9517d48191a2f581ca1 Mon Sep 17 00:00:00 2001 From: Joachim Fritzsch Date: Thu, 1 May 2014 13:19:42 +0200 Subject: [PATCH] android: single login wizard, bugfix race condition. --- .../boinc/attach/ProjectAttachService.java | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/android/BOINC/src/edu/berkeley/boinc/attach/ProjectAttachService.java b/android/BOINC/src/edu/berkeley/boinc/attach/ProjectAttachService.java index 3332f7197b..15818044a3 100644 --- a/android/BOINC/src/edu/berkeley/boinc/attach/ProjectAttachService.java +++ b/android/BOINC/src/edu/berkeley/boinc/attach/ProjectAttachService.java @@ -108,7 +108,7 @@ public class ProjectAttachService extends Service { private ArrayList selectedProjects = new ArrayList(); - public boolean projectConfigRetrievalFinished = false; + public boolean projectConfigRetrievalFinished = true; // shows whether project retrieval is ongoing //credentials private String email = ""; @@ -152,16 +152,20 @@ public class ProjectAttachService extends Service { * @return success */ public boolean setSelectedProjects (ArrayList selected) { + if(!projectConfigRetrievalFinished) { + if(Logging.ERROR) Log.e(Logging.TAG,"ProjectAttachService.setSelectedProjects: stop, async task already running."); + return false; + } + selectedProjects.clear(); for(ProjectInfo tmp: selected) { selectedProjects.add(new ProjectAttachWrapper(tmp)); } - // get projectConfigs if(mIsBound) { new GetProjectConfigsAsync().execute(); } else { - if(Logging.ERROR) Log.e(Logging.TAG,"ProjectAttachService.setSelectedProjects: could not load configuration files, monitor not bound!"); + if(Logging.ERROR) Log.e(Logging.TAG,"ProjectAttachService.setSelectedProjects: could not load configuration files, monitor not bound."); return false; } @@ -177,6 +181,11 @@ public class ProjectAttachService extends Service { * @return success */ public boolean setManuallySelectedProject(String url) { + if(!projectConfigRetrievalFinished) { + if(Logging.ERROR) Log.e(Logging.TAG,"ProjectAttachService.setManuallySelectedProject: stop, async task already running."); + return false; + } + selectedProjects.clear(); selectedProjects.add(new ProjectAttachWrapper(url)); @@ -184,7 +193,7 @@ public class ProjectAttachService extends Service { if(mIsBound) { new GetProjectConfigsAsync().execute(); } else { - if(Logging.ERROR) Log.e(Logging.TAG,"ProjectAttachService.setManuallySelectedProject: could not load configuration file, monitor not bound!"); + if(Logging.ERROR) Log.e(Logging.TAG,"ProjectAttachService.setManuallySelectedProject: could not load configuration file, monitor not bound."); return false; }