X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Flibgame%2Fsetup.c;h=561c51ed73b7e2afa45142bd5ce9a24a8c742b86;hb=3683bbbe90156d2a9ab32de08099e094a446e5f8;hp=5cd8c700fc1925bf4d5b5a4051c908a35db4e79a;hpb=05ca3ceb489c27197cf846441c1464536479a5cb;p=rocksndiamonds.git diff --git a/src/libgame/setup.c b/src/libgame/setup.c index 5cd8c700..561c51ed 100644 --- a/src/libgame/setup.c +++ b/src/libgame/setup.c @@ -1031,7 +1031,7 @@ char *getFormattedSetupEntry(char *token, char *value) void freeSetupFileList(struct SetupFileList *setup_file_list) { - if (!setup_file_list) + if (setup_file_list == NULL) return; if (setup_file_list->token) @@ -1043,15 +1043,12 @@ void freeSetupFileList(struct SetupFileList *setup_file_list) free(setup_file_list); } -static struct SetupFileList *newSetupFileList(char *token, char *value) +struct SetupFileList *newSetupFileList(char *token, char *value) { struct SetupFileList *new = checked_malloc(sizeof(struct SetupFileList)); - new->token = checked_malloc(strlen(token) + 1); - strcpy(new->token, token); - - new->value = checked_malloc(strlen(value) + 1); - strcpy(new->value, value); + new->token = getStringCopy(token); + new->value = getStringCopy(value); new->next = NULL; @@ -1060,7 +1057,7 @@ static struct SetupFileList *newSetupFileList(char *token, char *value) char *getTokenValue(struct SetupFileList *setup_file_list, char *token) { - if (!setup_file_list) + if (setup_file_list == NULL) return NULL; if (strcmp(setup_file_list->token, token) == 0) @@ -1069,17 +1066,18 @@ char *getTokenValue(struct SetupFileList *setup_file_list, char *token) return getTokenValue(setup_file_list->next, token); } -static void setTokenValue(struct SetupFileList *setup_file_list, - char *token, char *value) +void setTokenValue(struct SetupFileList *setup_file_list, + char *token, char *value) { - if (!setup_file_list) + if (setup_file_list == NULL) return; if (strcmp(setup_file_list->token, token) == 0) { - free(setup_file_list->value); - setup_file_list->value = checked_malloc(strlen(value) + 1); - strcpy(setup_file_list->value, value); + if (setup_file_list->value) + free(setup_file_list->value); + + setup_file_list->value = getStringCopy(value); } else if (setup_file_list->next == NULL) setup_file_list->next = newSetupFileList(token, value);