James Moger
2012-02-03 fe7c01a8bd76dff240e74bb770212911e227ba59
src/com/gitblit/GitBlit.java
@@ -69,7 +69,6 @@
import com.gitblit.models.FederationProposal;
import com.gitblit.models.FederationSet;
import com.gitblit.models.Metric;
import com.gitblit.models.RefModel;
import com.gitblit.models.RepositoryModel;
import com.gitblit.models.ServerSettings;
import com.gitblit.models.ServerStatus;
@@ -787,10 +786,8 @@
         model.mailingLists = new ArrayList<String>(Arrays.asList(config.getStringList(
               "gitblit", null, "mailingList")));
      }
      model.defaultHead = JGitUtils.getDefaultHead(r);
      model.availableHeads = new ArrayList<RefModel>();
      model.availableHeads.addAll(JGitUtils.getLocalBranches(r, true, -1));
      model.availableHeads.addAll(JGitUtils.getTags(r, true, -1));
      model.HEAD = JGitUtils.getHEADRef(r);
      model.availableRefs = JGitUtils.getAvailableHeadTargets(r);
      r.close();
      return model;
   }
@@ -986,9 +983,18 @@
      // update settings
      if (r != null) {
         updateConfiguration(r, repository);
         if (repository.defaultHead != null) {
            JGitUtils.setDefaultHead(r, repository.defaultHead.reference);
         // only update symbolic head if it changes
         String currentRef = JGitUtils.getHEADRef(r);
         if (!StringUtils.isEmpty(repository.HEAD) && !repository.HEAD.equals(currentRef)) {
            logger.info(MessageFormat.format("Relinking {0} HEAD from {1} to {2}",
                  repository.name, currentRef, repository.HEAD));
            if (JGitUtils.setHEADtoRef(r, repository.HEAD)) {
               // clear the cache
               clearRepositoryCache(repository.name);
            }
         }
         // close the repository object
         r.close();
      }
   }