Commit e02e6a5c by Edward Thomson

url: introduce git_net_str_is_url

We occasionally need to determine whether a given string is a URL or
something else.  (The "something else" may be a git path in a different
format, like scp formatting, which needs to be handled differently.)
parent 69134223
...@@ -20,6 +20,24 @@ ...@@ -20,6 +20,24 @@
#define DEFAULT_PORT_GIT "9418" #define DEFAULT_PORT_GIT "9418"
#define DEFAULT_PORT_SSH "22" #define DEFAULT_PORT_SSH "22"
bool git_net_str_is_url(const char *str)
{
const char *c;
for (c = str; *c; c++) {
if (*c == ':' && *(c+1) == '/' && *(c+2) == '/')
return true;
if ((*c < 'a' || *c > 'z') &&
(*c < 'A' || *c > 'Z') &&
(*c < '0' || *c > '9') &&
(*c != '+' && *c != '-' && *c != '.'))
break;
}
return false;
}
static const char *default_port_for_scheme(const char *scheme) static const char *default_port_for_scheme(const char *scheme)
{ {
if (strcmp(scheme, "http") == 0) if (strcmp(scheme, "http") == 0)
...@@ -28,7 +46,9 @@ static const char *default_port_for_scheme(const char *scheme) ...@@ -28,7 +46,9 @@ static const char *default_port_for_scheme(const char *scheme)
return DEFAULT_PORT_HTTPS; return DEFAULT_PORT_HTTPS;
else if (strcmp(scheme, "git") == 0) else if (strcmp(scheme, "git") == 0)
return DEFAULT_PORT_GIT; return DEFAULT_PORT_GIT;
else if (strcmp(scheme, "ssh") == 0) else if (strcmp(scheme, "ssh") == 0 ||
strcmp(scheme, "ssh+git") == 0 ||
strcmp(scheme, "git+ssh") == 0)
return DEFAULT_PORT_SSH; return DEFAULT_PORT_SSH;
return NULL; return NULL;
......
...@@ -21,6 +21,9 @@ typedef struct git_net_url { ...@@ -21,6 +21,9 @@ typedef struct git_net_url {
#define GIT_NET_URL_INIT { NULL } #define GIT_NET_URL_INIT { NULL }
/** Is a given string a url? */
extern bool git_net_str_is_url(const char *str);
/** Duplicate a URL */ /** Duplicate a URL */
extern int git_net_url_dup(git_net_url *out, git_net_url *in); extern int git_net_url_dup(git_net_url *out, git_net_url *in);
......
#include "clar_libgit2.h"
#include "net.h"
void test_network_url_valid__test(void)
{
cl_assert(git_net_str_is_url("http://example.com/"));
cl_assert(git_net_str_is_url("file://localhost/tmp/foo/"));
cl_assert(git_net_str_is_url("ssh://user@host:42/tmp"));
cl_assert(git_net_str_is_url("git+ssh://user@host:42/tmp"));
cl_assert(git_net_str_is_url("ssh+git://user@host:42/tmp"));
cl_assert(git_net_str_is_url("https://user:pass@example.com/foo/bar"));
cl_assert(!git_net_str_is_url("host:foo.git"));
cl_assert(!git_net_str_is_url("host:/foo.git"));
cl_assert(!git_net_str_is_url("[host:42]:/foo.git"));
cl_assert(!git_net_str_is_url("[user@host:42]:/foo.git"));
}
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