{
struct GNUNET_SECRETSHARING_Share *share;
const struct GNUNET_SECRETSHARING_ShareHeaderNBO *sh = data;
- char *p;
+ const char *p;
size_t n;
uint16_t payload_size;
if (NULL != readlen)
*readlen = payload_size + sizeof *sh;
- share = GNUNET_malloc (sizeof *share);
+ share = GNUNET_new (struct GNUNET_SECRETSHARING_Share);
share->threshold = ntohs (sh->threshold);
share->num_peers = ntohs (sh->num_peers);
share->my_share = sh->my_share;
share->public_key = sh->public_key;
- p = (void *) &sh[1];
+ p = (const char *) &sh[1];
n = share->num_peers * sizeof (struct GNUNET_PeerIdentity);
- share->peers = GNUNET_malloc (n);
- memcpy (share->peers, p, n);
+ share->peers = GNUNET_new_array (share->num_peers,
+ struct GNUNET_PeerIdentity);
+ GNUNET_memcpy (share->peers, p, n);
p += n;
n = share->num_peers * sizeof (struct GNUNET_SECRETSHARING_FieldElement);
- share->sigmas = GNUNET_malloc (n);
- memcpy (share->sigmas, p, n);
+ share->sigmas = GNUNET_new_array (share->num_peers,
+ struct GNUNET_SECRETSHARING_FieldElement);
+ GNUNET_memcpy (share->sigmas, p, n);
p += n;
n = share->num_peers * sizeof (uint16_t);
- share->original_indices = GNUNET_malloc (n);
- memcpy (share->original_indices, p, n);
+ share->original_indices = GNUNET_new_array (share->num_peers,
+ uint16_t);
+ GNUNET_memcpy (share->original_indices, p, n);
return share;
}
p = (void *) &sh[1];
n = share->num_peers * sizeof (struct GNUNET_PeerIdentity);
- memcpy (p, share->peers, n);
+ GNUNET_memcpy (p, share->peers, n);
p += n;
n = share->num_peers * sizeof (struct GNUNET_SECRETSHARING_FieldElement);
- memcpy (p, share->sigmas, n);
+ GNUNET_memcpy (p, share->sigmas, n);
p += n;
n = share->num_peers * sizeof (uint16_t);
- memcpy (p, share->original_indices, n);
+ GNUNET_memcpy (p, share->original_indices, n);
return GNUNET_OK;
}
share->peers = NULL;
GNUNET_free (share);
}
-
-