Blame lib/datum.c

Packit Service 4684c1
/*
Packit Service 4684c1
 * Copyright (C) 2001-2012 Free Software Foundation, Inc.
Packit Service 4684c1
 *
Packit Service 4684c1
 * Author: Nikos Mavrogiannopoulos
Packit Service 4684c1
 *
Packit Service 4684c1
 * This file is part of GnuTLS.
Packit Service 4684c1
 *
Packit Service 4684c1
 * The GnuTLS is free software; you can redistribute it and/or
Packit Service 4684c1
 * modify it under the terms of the GNU Lesser General Public License
Packit Service 4684c1
 * as published by the Free Software Foundation; either version 2.1 of
Packit Service 4684c1
 * the License, or (at your option) any later version.
Packit Service 4684c1
 *
Packit Service 4684c1
 * This library is distributed in the hope that it will be useful, but
Packit Service 4684c1
 * WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 4684c1
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 4684c1
 * Lesser General Public License for more details.
Packit Service 4684c1
 *
Packit Service 4684c1
 * You should have received a copy of the GNU Lesser General Public License
Packit Service 4684c1
 * along with this program.  If not, see <https://www.gnu.org/licenses/>
Packit Service 4684c1
 *
Packit Service 4684c1
 */
Packit Service 4684c1
Packit Service 4684c1
/* contains functions that make it easier to
Packit Service 4684c1
 * write vectors of <size|data>. The destination size
Packit Service 4684c1
 * should be preallocated (datum.size+(bits/8))
Packit Service 4684c1
 */
Packit Service 4684c1
Packit Service 4684c1
#include "gnutls_int.h"
Packit Service 4684c1
#include <num.h>
Packit Service 4684c1
#include <datum.h>
Packit Service 4684c1
#include "errors.h"
Packit Service 4684c1
Packit Service 4684c1
/* On error, @dat is not changed. */
Packit Service 4684c1
int
Packit Service 4684c1
_gnutls_set_datum(gnutls_datum_t * dat, const void *data, size_t data_size)
Packit Service 4684c1
{
Packit Service 4684c1
	if (data_size == 0 || data == NULL) {
Packit Service 4684c1
		dat->data = NULL;
Packit Service 4684c1
		dat->size = 0;
Packit Service 4684c1
		return 0;
Packit Service 4684c1
	}
Packit Service 4684c1
Packit Service 4684c1
	unsigned char *m = gnutls_malloc(data_size);
Packit Service 4684c1
	if (!m)
Packit Service 4684c1
		return GNUTLS_E_MEMORY_ERROR;
Packit Service 4684c1
Packit Service 4684c1
	dat->data = m;
Packit Service 4684c1
	dat->size = data_size;
Packit Service 4684c1
	memcpy(dat->data, data, data_size);
Packit Service 4684c1
Packit Service 4684c1
	return 0;
Packit Service 4684c1
}
Packit Service 4684c1
Packit Service 4684c1
/* ensures that the data set are null-terminated
Packit Service 4684c1
 * The function always returns an allocated string in @dat on success.
Packit Service 4684c1
 * On error, @dat is not changed.
Packit Service 4684c1
 */
Packit Service 4684c1
int
Packit Service 4684c1
_gnutls_set_strdatum(gnutls_datum_t * dat, const void *data, size_t data_size)
Packit Service 4684c1
{
Packit Service 4684c1
	if (data == NULL)
Packit Service 4684c1
		return gnutls_assert_val(GNUTLS_E_ILLEGAL_PARAMETER);
Packit Service 4684c1
Packit Service 4684c1
	unsigned char *m = gnutls_malloc(data_size + 1);
Packit Service 4684c1
	if (!m)
Packit Service 4684c1
		return GNUTLS_E_MEMORY_ERROR;
Packit Service 4684c1
Packit Service 4684c1
	dat->data = m;
Packit Service 4684c1
	dat->size = data_size;
Packit Service 4684c1
	if (data_size)
Packit Service 4684c1
		memcpy(dat->data, data, data_size);
Packit Service 4684c1
	dat->data[data_size] = 0;
Packit Service 4684c1
Packit Service 4684c1
	return 0;
Packit Service 4684c1
}
Packit Service 4684c1