1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122
/*
* Copyright (c) 2018 Stefan Sperling <stsp@openbsd.org>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
#include <sys/queue.h>
#include <errno.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sha1.h>
#include <zlib.h>
#include "got_error.h"
#include "got_object.h"
#include "got_lib_delta.h"
#include "got_lib_inflate.h"
#include "got_lib_object.h"
#include "got_lib_sha1.h"
#ifndef nitems
#define nitems(_a) (sizeof(_a) / sizeof((_a)[0]))
#endif
const struct got_error *
got_error(int code)
{
int i;
for (i = 0; i < nitems(got_errors); i++) {
if (code == got_errors[i].code)
return &got_errors[i];
}
abort();
}
const struct got_error *
got_error_msg(int code, const char *msg)
{
static struct got_error err;
int i;
for (i = 0; i < nitems(got_errors); i++) {
if (code == got_errors[i].code) {
err.code = code;
err.msg = msg;
return &err;
}
}
abort();
}
const struct got_error *
got_error_from_errno()
{
static struct got_error err;
err.code = GOT_ERR_ERRNO;
err.msg = strerror(errno);
return &err;
}
const struct got_error *
got_error_set_errno(int code)
{
errno = code;
return got_error_from_errno();
}
const struct got_error *
got_ferror(FILE *f, int code)
{
if (ferror(f))
return got_error_from_errno();
return got_error(code);
}
const struct got_error *
got_error_no_obj(struct got_object_id *id)
{
static char msg[sizeof("object not found") +
SHA1_DIGEST_STRING_LENGTH];
char id_str[SHA1_DIGEST_STRING_LENGTH];
int ret;
if (!got_sha1_digest_to_str(id->sha1, id_str, sizeof(id_str)))
return got_error(GOT_ERR_NO_OBJ);
ret = snprintf(msg, sizeof(msg), "object %s not found", id_str);
if (ret == -1 || ret >= sizeof(msg))
return got_error(GOT_ERR_NO_OBJ);
return got_error_msg(GOT_ERR_NO_OBJ, msg);
}
const struct got_error *
got_error_not_ref(const char *refname)
{
static char msg[sizeof("reference not found") + 1004];
int ret;
ret = snprintf(msg, sizeof(msg), "reference %s not found", refname);
if (ret == -1 || ret >= sizeof(msg))
return got_error(GOT_ERR_NOT_REF);
return got_error_msg(GOT_ERR_NOT_REF, msg);
}