Path: blob/main/crypto/heimdal/lib/roken/copyhostent.c
39507 views
/*1* Copyright (c) 1999 Kungliga Tekniska Högskolan2* (Royal Institute of Technology, Stockholm, Sweden).3* All rights reserved.4*5* Redistribution and use in source and binary forms, with or without6* modification, are permitted provided that the following conditions7* are met:8*9* 1. Redistributions of source code must retain the above copyright10* notice, this list of conditions and the following disclaimer.11*12* 2. Redistributions in binary form must reproduce the above copyright13* notice, this list of conditions and the following disclaimer in the14* documentation and/or other materials provided with the distribution.15*16* 3. Neither the name of the Institute nor the names of its contributors17* may be used to endorse or promote products derived from this software18* without specific prior written permission.19*20* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND21* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE22* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE23* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE24* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL25* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS26* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)27* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT28* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY29* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF30* SUCH DAMAGE.31*/3233#include <config.h>3435#include "roken.h"3637/*38* return a malloced copy of `h'39*/4041ROKEN_LIB_FUNCTION struct hostent * ROKEN_LIB_CALL42copyhostent (const struct hostent *h)43{44struct hostent *res;45char **p;46int i, n;4748res = malloc (sizeof (*res));49if (res == NULL)50return NULL;51res->h_name = NULL;52res->h_aliases = NULL;53res->h_addrtype = h->h_addrtype;54res->h_length = h->h_length;55res->h_addr_list = NULL;56res->h_name = strdup (h->h_name);57if (res->h_name == NULL) {58freehostent (res);59return NULL;60}61for (n = 0, p = h->h_aliases; *p != NULL; ++p)62++n;63res->h_aliases = malloc ((n + 1) * sizeof(*res->h_aliases));64if (res->h_aliases == NULL) {65freehostent (res);66return NULL;67}68for (i = 0; i < n + 1; ++i)69res->h_aliases[i] = NULL;70for (i = 0; i < n; ++i) {71res->h_aliases[i] = strdup (h->h_aliases[i]);72if (res->h_aliases[i] == NULL) {73freehostent (res);74return NULL;75}76}7778for (n = 0, p = h->h_addr_list; *p != NULL; ++p)79++n;80res->h_addr_list = malloc ((n + 1) * sizeof(*res->h_addr_list));81if (res->h_addr_list == NULL) {82freehostent (res);83return NULL;84}85for (i = 0; i < n + 1; ++i) {86res->h_addr_list[i] = NULL;87}88for (i = 0; i < n; ++i) {89res->h_addr_list[i] = malloc (h->h_length);90if (res->h_addr_list[i] == NULL) {91freehostent (res);92return NULL;93}94memcpy (res->h_addr_list[i], h->h_addr_list[i], h->h_length);95}96return res;97}9899100101