1 |
frodo |
2 |
/* strdup.c -- return a newly allocated copy of a string |
2 |
|
|
Copyright (C) 1990 Free Software Foundation, Inc. |
3 |
|
|
|
4 |
|
|
This program is free software; you can redistribute it and/or modify |
5 |
|
|
it under the terms of the GNU General Public License as published by |
6 |
|
|
the Free Software Foundation; either version 2, or (at your option) |
7 |
|
|
any later version. |
8 |
|
|
|
9 |
|
|
This program is distributed in the hope that it will be useful, |
10 |
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of |
11 |
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
12 |
|
|
GNU General Public License for more details. |
13 |
|
|
|
14 |
|
|
You should have received a copy of the GNU General Public License |
15 |
|
|
along with this program; if not, write to the Free Software |
16 |
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ |
17 |
|
|
|
18 |
|
|
#ifdef HAVE_CONFIG_H |
19 |
|
|
#include <config.h> |
20 |
|
|
#endif |
21 |
|
|
|
22 |
|
|
#ifdef STDC_HEADERS |
23 |
|
|
#include <string.h> |
24 |
|
|
#include <stdlib.h> |
25 |
|
|
#else |
26 |
|
|
char *malloc (); |
27 |
|
|
char *strcpy (); |
28 |
|
|
#endif |
29 |
|
|
|
30 |
|
|
/* Return a newly allocated copy of STR, |
31 |
|
|
or 0 if out of memory. */ |
32 |
|
|
|
33 |
|
|
char * |
34 |
|
|
strdup (str) |
35 |
|
|
const char *str; |
36 |
|
|
{ |
37 |
|
|
char *newstr; |
38 |
|
|
|
39 |
|
|
newstr = (char *) malloc (strlen (str) + 1); |
40 |
|
|
if (newstr) |
41 |
|
|
strcpy (newstr, str); |
42 |
|
|
return newstr; |
43 |
|
|
} |