Commit 253d6df5 by Ryan Wilcox

fix up previous SSH path parsing commit based on @carlosmn feedback

parent 58448910
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
#include "git2/remote.h" #include "git2/remote.h"
#include "git2/net.h" #include "git2/net.h"
#include "transport.h" #include "transport.h"
#include "path.h"
#include <regex.h> #include <regex.h>
static struct { static struct {
...@@ -30,9 +30,6 @@ static struct { ...@@ -30,9 +30,6 @@ static struct {
static git_transport_cb transport_find_fn(const char *url) static git_transport_cb transport_find_fn(const char *url)
{ {
size_t i = 0; size_t i = 0;
regex_t preg;
int error;
git_transport_cb output = NULL;
// First, check to see if it's an obvious URL, which a URL scheme // First, check to see if it's an obvious URL, which a URL scheme
for (i = 0; i < GIT_TRANSPORT_COUNT; ++i) { for (i = 0; i < GIT_TRANSPORT_COUNT; ++i) {
...@@ -40,25 +37,15 @@ static git_transport_cb transport_find_fn(const char *url) ...@@ -40,25 +37,15 @@ static git_transport_cb transport_find_fn(const char *url)
return transports[i].fn; return transports[i].fn;
} }
/* still here? Check to see if the path points to a file on the local file system */
if ((git_path_exists(url) == GIT_SUCCESS) && git_path_isdir(url))
return &git_transport_local;
// next, see if it matches un-schemed SSH paths used by Git /* It could be a SSH remote path. Check to see if there's a : */
// if it does not match, it must be a local transport method if (strrchr(url, ':'))
// use the slightly old fashioned :alnum: instead of \w or :word:, because return &git_transport_dummy; /* SSH is an unsupported transport mechanism in this version of libgit2 */
// both are Perl extensions to the Regular Expression language (and not available here)
error = regcomp(&preg, "^[[:alnum:]_]+@[[:alnum:]_]+\\.[[:alnum:]_]+:.+\\.git$", REG_EXTENDED);
if (error < 0)
goto cleanup;
int rc = regexec(&preg, url, 0, NULL, 0);
if ( rc == REG_NOMATCH )
output = NULL; // a match was not found - it's probably a file system path
else
output = &git_transport_git; // a match was found!
cleanup: return NULL;
regfree(&preg);
return output;
} }
/************** /**************
...@@ -79,12 +66,8 @@ int git_transport_new(git_transport **out, const char *url) ...@@ -79,12 +66,8 @@ int git_transport_new(git_transport **out, const char *url)
fn = transport_find_fn(url); fn = transport_find_fn(url);
/*
* If we haven't found the transport, we assume we mean a
* local file.
*/
if (fn == NULL) if (fn == NULL)
fn = &git_transport_local; return git__throw(GIT_EINVALIDARGS, "No supported transport mechanism found for URL or path. Either libgit2 has not implemented this transport protocol, or it can not find the specified path.");
error = fn(&transport); error = fn(&transport);
if (error < GIT_SUCCESS) if (error < GIT_SUCCESS)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment