Use strdup() instead of strncpy().

This commit is contained in:
Jason S. Ninneman 2017-06-12 09:21:24 -07:00 committed by Eric S. Raymond
parent a044f10411
commit ca0e042952
2 changed files with 13 additions and 2 deletions

View file

@ -87,6 +87,7 @@ extern lcg_state lcgstate;
#define READ_MODE "rb"
#define WRITE_MODE "wb"
extern void* xmalloc(size_t);
extern char* xstrdup(const char*);
extern void packed_to_token(long, char token[6]);
extern void newspeak(char*);
extern void PSPEAK(vocab_t,int);

14
misc.c
View file

@ -21,6 +21,17 @@ void* xmalloc(size_t size)
return(ptr);
}
char* xstrdup(const char* s)
{
char* ptr = strdup(s);
if (ptr == NULL)
{
fprintf(stderr, "Out of memory!\n");
exit(EXIT_FAILURE);
}
return(ptr);
}
void packed_to_token(long packed, char token[6])
{
// Unpack and map back to ASCII.
@ -60,8 +71,7 @@ void newspeak(char* msg)
printf("\n");
// Create a copy of our string, so we can edit it.
char* copy = (char*) xmalloc(strlen(msg) + 1);
strncpy(copy, msg, strlen(msg) + 1);
char* copy = xstrdup(msg);
// Staging area for stringified parameters.
char parameters[5][100]; // FIXME: to be replaced with dynamic allocation