From f5654729757eedefc1c656ac4be764b6a19ada2e Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Fri, 29 Mar 2013 10:59:26 -0400 Subject: [PATCH] Add more error checking to blob page --- src/main/java/com/gitblit/wicket/pages/BlobPage.java | 23 +++++++++++++++++++++-- 1 files changed, 21 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/gitblit/wicket/pages/BlobPage.java b/src/main/java/com/gitblit/wicket/pages/BlobPage.java index e2b8546..ab0f0f1 100644 --- a/src/main/java/com/gitblit/wicket/pages/BlobPage.java +++ b/src/main/java/com/gitblit/wicket/pages/BlobPage.java @@ -124,20 +124,39 @@ default: // plain text String source = JGitUtils.getStringContent(r, commit.getTree(), blobPath, encodings); - String table = generateSourceView(source, type == 1); + String table; + if (source == null) { + table = missingBlob(blobPath, commit); + } else { + table = generateSourceView(source, type == 1); + } add(new Label("blobText", table).setEscapeModelStrings(false)); add(new Image("blobImage").setVisible(false)); } } else { // plain text String source = JGitUtils.getStringContent(r, commit.getTree(), blobPath, encodings); - String table = generateSourceView(source, false); + String table; + if (source == null) { + table = missingBlob(blobPath, commit); + } else { + table = generateSourceView(source, false); + } add(new Label("blobText", table).setEscapeModelStrings(false)); add(new Image("blobImage").setVisible(false)); } } } + protected String missingBlob(String blobPath, RevCommit commit) { + StringBuilder sb = new StringBuilder(); + sb.append("<div class=\"alert alert-error\">"); + String pattern = getString("gb.doesNotExistInTree").replace("{0}", "<b>{0}</b>").replace("{1}", "<b>{1}</b>"); + sb.append(MessageFormat.format(pattern, blobPath, commit.getTree().getId().getName())); + sb.append("</div>"); + return sb.toString(); + } + protected String generateSourceView(String source, boolean prettyPrint) { String [] lines = source.split("\n"); -- Gitblit v1.9.1