From f81ed74578eb1d0fed26c56ddcfbb39f08a4e47c Mon Sep 17 00:00:00 2001
From: James Moger <james.moger@gitblit.com>
Date: Thu, 10 Apr 2014 18:58:10 -0400
Subject: [PATCH] Support querying in tickets ls and accept Object[][] for table data

---
 src/main/java/com/gitblit/transport/ssh/commands/RootDispatcher.java |   27 ++++++++++++++++-----------
 1 files changed, 16 insertions(+), 11 deletions(-)

diff --git a/src/main/java/com/gitblit/transport/ssh/commands/RootDispatcher.java b/src/main/java/com/gitblit/transport/ssh/commands/RootDispatcher.java
index 749d10e..8a871eb 100644
--- a/src/main/java/com/gitblit/transport/ssh/commands/RootDispatcher.java
+++ b/src/main/java/com/gitblit/transport/ssh/commands/RootDispatcher.java
@@ -17,6 +17,9 @@
 
 import java.util.List;
 
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
 import com.gitblit.manager.IGitblit;
 import com.gitblit.models.UserModel;
 import com.gitblit.transport.ssh.SshDaemonClient;
@@ -28,28 +31,30 @@
  * other commands.
  *
  */
-public class RootDispatcher extends DispatchCommand {
+@CommandMetaData(name = "")
+class RootDispatcher extends DispatchCommand {
+
+	private Logger log = LoggerFactory.getLogger(getClass());
 
 	public RootDispatcher(IGitblit gitblit, SshDaemonClient client, String cmdLine) {
 		super();
 		setContext(new SshCommandContext(gitblit, client, cmdLine));
 
-		final UserModel user = client.getUser();
-		registerDispatcher(user, GitblitDispatcher.class);
-		registerDispatcher(user, GitDispatcher.class);
+		UserModel user = client.getUser();
+		register(user, GitblitDispatcher.class);
+		register(user, GitDispatcher.class);
 
 		List<DispatchCommand> exts = gitblit.getExtensions(DispatchCommand.class);
 		for (DispatchCommand ext : exts) {
-			registerDispatcher(user, ext);
+			Class<? extends DispatchCommand> extClass = ext.getClass();
+			String plugin = gitblit.whichPlugin(extClass).getDescriptor().getPluginId();
+			CommandMetaData meta = extClass.getAnnotation(CommandMetaData.class);
+			log.info("Dispatcher {} is loaded from plugin {}", meta.name(), plugin);
+			register(user, ext);
 		}
 	}
 
 	@Override
-	protected final void registerCommands(UserModel user) {
-	}
-
-	@Override
-	protected final void registerCommand(UserModel user, Class<? extends BaseCommand> cmd) {
-		throw new RuntimeException("The root dispatcher does not accept commands, only dispatchers!");
+	protected final void setup(UserModel user) {
 	}
 }
\ No newline at end of file

--
Gitblit v1.9.1