From 046d1a2ef6ddea2a9521ac49ae339e05c1cc0acd Mon Sep 17 00:00:00 2001 From: Alex Blewitt Date: Fri, 4 Jun 2010 00:38:50 +0100 Subject: Provide a public entry method to determine whether a URI protocol is supported --- .../src/org/eclipse/jgit/transport/Transport.java | 32 ++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/transport/Transport.java b/org.eclipse.jgit/src/org/eclipse/jgit/transport/Transport.java index c0b2eedc00..2fe3cb9326 100644 --- a/org.eclipse.jgit/src/org/eclipse/jgit/transport/Transport.java +++ b/org.eclipse.jgit/src/org/eclipse/jgit/transport/Transport.java @@ -318,6 +318,38 @@ public abstract class Transport { return cfg.getURIs().isEmpty() && cfg.getPushURIs().isEmpty(); } + /** + * Determines whether the transport can handle the given URIish. + * + * @param remote + * location of the remote repository. + * @return true if the protocol is supported. + */ + public static boolean canHandleProtocol(final URIish remote) { + if (TransportGitSsh.canHandle(remote)) + return true; + + else if (TransportHttp.canHandle(remote)) + return true; + + else if (TransportSftp.canHandle(remote)) + return true; + + else if (TransportGitAnon.canHandle(remote)) + return true; + + else if (TransportAmazonS3.canHandle(remote)) + return true; + + else if (TransportBundleFile.canHandle(remote)) + return true; + + else if (TransportLocal.canHandle(remote)) + return true; + + return false; + } + /** * Open a new transport instance to connect two repositories. * -- cgit v1.2.3