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