url: return URL_SCHEME_UNKNOWN instead of dying

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>
main
Matheus Afonso Martins Moreira 2026-05-02 05:28:38 +00:00 committed by Junio C Hamano
parent d48e36a8a2
commit 46d6fb752e
3 changed files with 7 additions and 5 deletions

View File

@ -1071,6 +1071,8 @@ static enum url_scheme parse_connect_url(const char *url_orig, char **ret_host,
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;

3
url.c
View File

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "gettext.h"
#include "hex-ll.h"
#include "strbuf.h"
#include "url.h"
@ -154,5 +153,5 @@ enum url_scheme url_get_scheme(const char *name)
return URL_SCHEME_SSH;
if (!strcmp(name, "file"))
return URL_SCHEME_FILE;
die(_("protocol '%s' is not supported"), name);
return URL_SCHEME_UNKNOWN;
}

7
url.h
View File

@ -24,15 +24,16 @@ void str_end_url_with_slash(const char *url, char **dest);
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);