From bfa998a3d04e759be555dd8136aaa9450960a879 Mon Sep 17 00:00:00 2001
From: James Moger <james.moger@gitblit.com>
Date: Thu, 10 Apr 2014 19:00:04 -0400
Subject: [PATCH] Documentation

---
 src/main/java/com/gitblit/transport/ssh/gitblit/ListDispatcher.java |  148 ++----------------------------------------------
 1 files changed, 8 insertions(+), 140 deletions(-)

diff --git a/src/main/java/com/gitblit/transport/ssh/gitblit/ListDispatcher.java b/src/main/java/com/gitblit/transport/ssh/gitblit/ListDispatcher.java
index 0c372df..343e59a 100644
--- a/src/main/java/com/gitblit/transport/ssh/gitblit/ListDispatcher.java
+++ b/src/main/java/com/gitblit/transport/ssh/gitblit/ListDispatcher.java
@@ -15,20 +15,9 @@
  */
 package com.gitblit.transport.ssh.gitblit;
 
-import java.text.MessageFormat;
-import java.text.SimpleDateFormat;
-import java.util.List;
-
-import org.kohsuke.args4j.Option;
-import org.parboiled.common.StringUtils;
-
-import com.gitblit.manager.IGitblit;
-import com.gitblit.models.ProjectModel;
-import com.gitblit.models.RepositoryModel;
 import com.gitblit.models.UserModel;
 import com.gitblit.transport.ssh.commands.CommandMetaData;
 import com.gitblit.transport.ssh.commands.DispatchCommand;
-import com.gitblit.transport.ssh.commands.SshCommand;
 
 /**
  * The dispatcher and it's commands for Gitblit object listing.
@@ -40,11 +29,11 @@
 public class ListDispatcher extends DispatchCommand {
 
 	@Override
-	protected void registerCommands(UserModel user) {
-		registerCommand(user, ListRepositories.class);
-		registerCommand(user, ListProjects.class);
-		registerCommand(user, ListUsers.class);
-		registerCommand(user, ListKeys.class);
+	protected void setup(UserModel user) {
+		register(user, ListRepositories.class);
+		register(user, ListProjects.class);
+		register(user, ListUsers.class);
+		register(user, ListKeys.class);
 	}
 
 	/* List SSH public keys */
@@ -54,137 +43,16 @@
 
 	/* List repositories */
 	@CommandMetaData(name = "repositories", aliases = { "repos" }, description = "List repositories")
-	public static class ListRepositories extends SshCommand {
-
-		@Option(name = "--verbose", aliases = { "-v" }, usage = "verbose")
-		private boolean verbose;
-
-		@Override
-		public void run() {
-			IGitblit gitblit = getContext().getGitblit();
-			UserModel user = getContext().getClient().getUser();
-			SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");
-
-			List<RepositoryModel> repositories = gitblit.getRepositoryModels(user);
-			int nameLen = 0;
-			int descLen = 0;
-			for (RepositoryModel repo : repositories) {
-				int len = repo.name.length();
-				if (len > nameLen) {
-					nameLen = len;
-				}
-				if (!StringUtils.isEmpty(repo.description)) {
-					len = repo.description.length();
-					if (len > descLen) {
-						descLen = len;
-					}
-				}
-			}
-
-			String pattern;
-			if (verbose) {
-				pattern = MessageFormat.format("%-{0,number,0}s\t%-{1,number,0}s\t%s", nameLen, descLen);
-			} else {
-				pattern = "%s";
-			}
-
-			for (RepositoryModel repo : repositories) {
-				stdout.println(String.format(pattern,
-						repo.name,
-						repo.description == null ? "" : repo.description,
-						df.format(repo.lastChange)));
-			}
-		}
+	public static class ListRepositories extends RepositoriesDispatcher.ListRepositories {
 	}
 
 	/* List projects */
 	@CommandMetaData(name = "projects", description = "List projects")
-	public static class ListProjects extends SshCommand {
-
-		@Option(name = "--verbose", aliases = { "-v" }, usage = "verbose")
-		private boolean verbose;
-
-		@Override
-		public void run() {
-			IGitblit gitblit = getContext().getGitblit();
-			UserModel user = getContext().getClient().getUser();
-			SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");
-
-			List<ProjectModel> projects = gitblit.getProjectModels(user, false);
-			int nameLen = 0;
-			int descLen = 0;
-			for (ProjectModel project : projects) {
-				int len = project.name.length();
-				if (len > nameLen) {
-					nameLen = len;
-				}
-				if (!StringUtils.isEmpty(project.description)) {
-					len = project.description.length();
-					if (len > descLen) {
-						descLen = len;
-					}
-				}
-			}
-
-			String pattern;
-			if (verbose) {
-				pattern = MessageFormat.format("%-{0,number,0}s\t%-{1,number,0}s\t%s", nameLen, descLen);
-			} else {
-				pattern = "%s";
-			}
-
-			for (ProjectModel project : projects) {
-				stdout.println(String.format(pattern,
-						project.name,
-						project.description == null ? "" : project.description,
-						df.format(project.lastChange)));
-			}
-		}
+	public static class ListProjects extends ProjectsDispatcher.ListProjects {
 	}
 
 	/* List users */
 	@CommandMetaData(name = "users", description = "List users", admin = true)
-	public static class ListUsers extends SshCommand {
-
-		@Option(name = "--verbose", aliases = { "-v" }, usage = "verbose")
-		private boolean verbose;
-
-		@Override
-		public void run() {
-			IGitblit gitblit = getContext().getGitblit();
-			List<UserModel> users = gitblit.getAllUsers();
-			int displaynameLen = 0;
-			int usernameLen = 0;
-			for (UserModel user : users) {
-				int len = user.getDisplayName().length();
-				if (len > displaynameLen) {
-					displaynameLen = len;
-				}
-				if (!StringUtils.isEmpty(user.username)) {
-					len = user.username.length();
-					if (len > usernameLen) {
-						usernameLen = len;
-					}
-				}
-			}
-
-			String pattern;
-			if (verbose) {
-				pattern = MessageFormat.format("%-{0,number,0}s\t%-{1,number,0}s\t%-10s\t%s", displaynameLen, usernameLen);
-			} else {
-				pattern = MessageFormat.format("%-{0,number,0}s\t%-{1,number,0}s", displaynameLen, usernameLen);
-			}
-
-			for (UserModel user : users) {
-				if (user.disabled) {
-					continue;
-				}
-				stdout.println(String.format(pattern,
-						user.getDisplayName(),
-						(user.canAdmin() ? "*":" ") + user.username,
-						user.accountType,
-						user.emailAddress == null ? "" : user.emailAddress));
-			}
-		}
+	public static class ListUsers extends UsersDispatcher.ListUsers {
 	}
 }

--
Gitblit v1.9.1