Enumerate a URL_SCHEME_UNKNOWN result with value 0.
Have url_get_scheme() return it for unrecognized
schemes instead of calling die() itself.
Move the die() call to parse_connect_url()
where url_get_scheme() is used.
This lets url_get_scheme() be used from contexts
that need to identify a URL's scheme without aborting
the program. For example, a future plumbing command
that validates URLs.
No external behavior change. parse_connect_url() still dies
with the same translated message for unrecognized schemes.
Signed-off-by: Matheus Afonso Martins Moreira <matheus@matheusmoreira.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
if (host) {
*host = '\0';
scheme = url_get_scheme(url);
+ if (scheme == URL_SCHEME_UNKNOWN)
+ die(_("protocol '%s' is not supported"), url);
host += 3;
} else {
host = url;
#include "git-compat-util.h"
-#include "gettext.h"
#include "hex-ll.h"
#include "strbuf.h"
#include "url.h"
return URL_SCHEME_SSH;
if (!strcmp(name, "file"))
return URL_SCHEME_FILE;
- die(_("protocol '%s' is not supported"), name);
+ return URL_SCHEME_UNKNOWN;
}
int url_is_local_not_ssh(const char *url);
enum url_scheme {
- URL_SCHEME_LOCAL = 1,
+ URL_SCHEME_UNKNOWN = 0,
+ URL_SCHEME_LOCAL,
URL_SCHEME_FILE,
URL_SCHEME_SSH,
URL_SCHEME_GIT,
};
/*
- * Identify the URL scheme by name. Dies if the name does not match
- * any scheme that Git knows about.
+ * Identify the URL scheme by name. Returns URL_SCHEME_UNKNOWN
+ * if the name does not match any scheme that Git knows about.
*/
enum url_scheme url_get_scheme(const char *name);