mirror of
https://git.proxmox.com/git/libgit2
synced 2025-08-06 04:49:46 +00:00
remote: Assert things that should be asserted
This commit is contained in:
parent
bec92f78bf
commit
4bef35656e
30
src/remote.c
30
src/remote.c
@ -60,8 +60,8 @@ int git_remote_new(git_remote **out, git_repository *repo, const char *url, cons
|
|||||||
{
|
{
|
||||||
git_remote *remote;
|
git_remote *remote;
|
||||||
|
|
||||||
if (url == NULL)
|
/* name is optional */
|
||||||
return git__throw(GIT_EINVALIDARGS, "No URL was given");
|
assert(out && repo && url);
|
||||||
|
|
||||||
remote = git__malloc(sizeof(git_remote));
|
remote = git__malloc(sizeof(git_remote));
|
||||||
if (remote == NULL)
|
if (remote == NULL)
|
||||||
@ -95,6 +95,8 @@ int git_remote_get(git_remote **out, git_config *cfg, const char *name)
|
|||||||
const char *val;
|
const char *val;
|
||||||
int ret, error, buf_len;
|
int ret, error, buf_len;
|
||||||
|
|
||||||
|
assert(out && cfg && name);
|
||||||
|
|
||||||
remote = git__malloc(sizeof(git_remote));
|
remote = git__malloc(sizeof(git_remote));
|
||||||
if (remote == NULL)
|
if (remote == NULL)
|
||||||
return GIT_ENOMEM;
|
return GIT_ENOMEM;
|
||||||
@ -169,23 +171,27 @@ cleanup:
|
|||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *git_remote_name(struct git_remote *remote)
|
const char *git_remote_name(git_remote *remote)
|
||||||
{
|
{
|
||||||
|
assert(remote);
|
||||||
return remote->name;
|
return remote->name;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *git_remote_url(struct git_remote *remote)
|
const char *git_remote_url(git_remote *remote)
|
||||||
{
|
{
|
||||||
|
assert(remote);
|
||||||
return remote->url;
|
return remote->url;
|
||||||
}
|
}
|
||||||
|
|
||||||
const git_refspec *git_remote_fetchspec(struct git_remote *remote)
|
const git_refspec *git_remote_fetchspec(git_remote *remote)
|
||||||
{
|
{
|
||||||
|
assert(remote);
|
||||||
return &remote->fetch;
|
return &remote->fetch;
|
||||||
}
|
}
|
||||||
|
|
||||||
const git_refspec *git_remote_pushspec(struct git_remote *remote)
|
const git_refspec *git_remote_pushspec(git_remote *remote)
|
||||||
{
|
{
|
||||||
|
assert(remote);
|
||||||
return &remote->push;
|
return &remote->push;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -194,6 +200,8 @@ int git_remote_connect(git_remote *remote, int direction)
|
|||||||
int error;
|
int error;
|
||||||
git_transport *t;
|
git_transport *t;
|
||||||
|
|
||||||
|
assert(remote);
|
||||||
|
|
||||||
error = git_transport_new(&t, remote->url);
|
error = git_transport_new(&t, remote->url);
|
||||||
if (error < GIT_SUCCESS)
|
if (error < GIT_SUCCESS)
|
||||||
return git__rethrow(error, "Failed to create transport");
|
return git__rethrow(error, "Failed to create transport");
|
||||||
@ -215,6 +223,7 @@ cleanup:
|
|||||||
|
|
||||||
int git_remote_ls(git_remote *remote, git_headarray *refs)
|
int git_remote_ls(git_remote *remote, git_headarray *refs)
|
||||||
{
|
{
|
||||||
|
assert(remote && refs);
|
||||||
return remote->transport->ls(remote->transport, refs);
|
return remote->transport->ls(remote->transport, refs);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -222,13 +231,15 @@ int git_remote_download(char **filename, git_remote *remote)
|
|||||||
{
|
{
|
||||||
int error;
|
int error;
|
||||||
|
|
||||||
|
assert(filename && remote);
|
||||||
|
|
||||||
if ((error = git_fetch_negotiate(remote)) < 0)
|
if ((error = git_fetch_negotiate(remote)) < 0)
|
||||||
return git__rethrow(error, "Error negotiating");
|
return git__rethrow(error, "Error negotiating");
|
||||||
|
|
||||||
return git_fetch_download_pack(filename, remote);
|
return git_fetch_download_pack(filename, remote);
|
||||||
}
|
}
|
||||||
|
|
||||||
int git_remote_update_tips(struct git_remote *remote)
|
int git_remote_update_tips(git_remote *remote)
|
||||||
{
|
{
|
||||||
int error = GIT_SUCCESS;
|
int error = GIT_SUCCESS;
|
||||||
unsigned int i = 0;
|
unsigned int i = 0;
|
||||||
@ -238,6 +249,8 @@ int git_remote_update_tips(struct git_remote *remote)
|
|||||||
git_reference *ref;
|
git_reference *ref;
|
||||||
struct git_refspec *spec = &remote->fetch;
|
struct git_refspec *spec = &remote->fetch;
|
||||||
|
|
||||||
|
assert(remote);
|
||||||
|
|
||||||
memset(refname, 0x0, sizeof(refname));
|
memset(refname, 0x0, sizeof(refname));
|
||||||
|
|
||||||
if (refs->len == 0)
|
if (refs->len == 0)
|
||||||
@ -269,11 +282,14 @@ int git_remote_update_tips(struct git_remote *remote)
|
|||||||
|
|
||||||
int git_remote_connected(git_remote *remote)
|
int git_remote_connected(git_remote *remote)
|
||||||
{
|
{
|
||||||
|
assert(remote);
|
||||||
return remote->transport == NULL ? 0 : remote->transport->connected;
|
return remote->transport == NULL ? 0 : remote->transport->connected;
|
||||||
}
|
}
|
||||||
|
|
||||||
void git_remote_disconnect(git_remote *remote)
|
void git_remote_disconnect(git_remote *remote)
|
||||||
{
|
{
|
||||||
|
assert(remote);
|
||||||
|
|
||||||
if (remote->transport != NULL) {
|
if (remote->transport != NULL) {
|
||||||
if (remote->transport->connected)
|
if (remote->transport->connected)
|
||||||
remote->transport->close(remote->transport);
|
remote->transport->close(remote->transport);
|
||||||
|
Loading…
Reference in New Issue
Block a user