James Moger
2013-01-05 9e186eedf1a09ca7ac4fbdea32b00e7e5331f7eb
src/com/gitblit/wicket/pages/RepositoriesPage.java
@@ -20,12 +20,14 @@
import java.io.InputStream;
import java.io.InputStreamReader;
import java.text.MessageFormat;
import java.util.ArrayList;
import java.util.List;
import org.apache.wicket.Component;
import org.apache.wicket.PageParameters;
import org.apache.wicket.markup.html.basic.Label;
import org.apache.wicket.resource.ContextRelativeResource;
import org.apache.wicket.util.resource.ResourceStreamNotFoundException;
import org.eclipse.jgit.lib.Constants;
import com.gitblit.GitBlit;
@@ -80,7 +82,7 @@
      List<RepositoryModel> repositories = getRepositories(params);
      RepositoriesPanel repositoriesPanel = new RepositoriesPanel("repositoriesPanel", showAdmin,
            repositories, true, getAccessRestrictions());
            true, repositories, true, getAccessRestrictions());
      // push the panel down if we are hiding the admin controls and the
      // welcome message
      if (!showAdmin && !repositoriesMessage.isVisible()) {
@@ -126,11 +128,11 @@
                  message = MarkdownUtils.transformMarkdown(reader);
                  reader.close();
               } catch (Throwable t) {
                  message = "Failed to read " + file;
                  message = getString("gb.failedToRead") + " " + file;
                  warn(message, t);
               }
            } else {
               message = messageSource + " is not a valid file.";
               message = messageSource + " " + getString("gb.isNotValidFile");
            }
         }
      }
@@ -138,17 +140,47 @@
   }
   private String readDefaultMarkdown(String file) {
      String message;
      try {
         ContextRelativeResource res = WicketUtils.getResource(file);
         InputStream is = res.getResourceStream().getInputStream();
         InputStreamReader reader = new InputStreamReader(is, Constants.CHARACTER_ENCODING);
         message = MarkdownUtils.transformMarkdown(reader);
         reader.close();
      } catch (Throwable t) {
         message = MessageFormat.format("Failed to read default message from {0}!", file);
         error(message, t, false);
      String base = file.substring(0, file.lastIndexOf('.'));
      String ext = file.substring(file.lastIndexOf('.'));
      String lc = getLanguageCode();
      String cc = getCountryCode();
      // try to read file_en-us.ext, file_en.ext, file.ext
      List<String> files = new ArrayList<String>();
      if (!StringUtils.isEmpty(lc)) {
         if (!StringUtils.isEmpty(cc)) {
            files.add(base + "_" + lc + "-" + cc + ext);
            files.add(base + "_" + lc + "_" + cc + ext);
         }
         files.add(base + "_" + lc + ext);
      }
      return message;
      files.add(file);
      for (String name : files) {
         String message;
         InputStreamReader reader = null;
         try {
            ContextRelativeResource res = WicketUtils.getResource(name);
            InputStream is = res.getResourceStream().getInputStream();
            reader = new InputStreamReader(is, Constants.CHARACTER_ENCODING);
            message = MarkdownUtils.transformMarkdown(reader);
            reader.close();
            return message;
         } catch (ResourceStreamNotFoundException t) {
            continue;
         } catch (Throwable t) {
            message = MessageFormat.format(getString("gb.failedToReadMessage"), file);
            error(message, t, false);
            return message;
         } finally {
            if (reader != null) {
               try {
                  reader.close();
               } catch (Exception e) {
               }
            }
         }
      }
      return MessageFormat.format(getString("gb.failedToReadMessage"), file);
   }
}