diff options
author | peter1138 <peter1138@openttd.org> | 2007-07-06 08:32:00 +0000 |
---|---|---|
committer | peter1138 <peter1138@openttd.org> | 2007-07-06 08:32:00 +0000 |
commit | a8b385d77d877c37be8e789d9ae8d72584dfdfa8 (patch) | |
tree | 98c9a3546ca31fa020597b5d978baabc6f752752 | |
parent | 1af0fc0a33e60ff8d72852aaadc7bff4bd321a38 (diff) | |
download | openttd-a8b385d77d877c37be8e789d9ae8d72584dfdfa8.tar.xz |
(svn r10453) -Codechange: Allow save/load of empty (unallocated) strings
-rw-r--r-- | src/saveload.cpp | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/src/saveload.cpp b/src/saveload.cpp index dd70f7a4a..86e515200 100644 --- a/src/saveload.cpp +++ b/src/saveload.cpp @@ -496,6 +496,7 @@ static void SlSaveLoadConv(void *ptr, VarType conv) * @return return the net length of the string */ static inline size_t SlCalcNetStringLen(const char *ptr, size_t length) { + if (ptr == NULL) return 0; return minu(strlen(ptr), length - 1); } @@ -573,9 +574,13 @@ static void SlString(void *ptr, size_t length, VarType conv) case SLE_VAR_STR: case SLE_VAR_STRQ: // Malloc'd string, free previous incarnation, and allocate free(*(char**)ptr); - *(char**)ptr = (char*)malloc(len + 1); // terminating '\0' - ptr = *(char**)ptr; - SlCopyBytes(ptr, len); + if (len == 0) { + *(char**)ptr = NULL; + } else { + *(char**)ptr = (char*)malloc(len + 1); // terminating '\0' + ptr = *(char**)ptr; + SlCopyBytes(ptr, len); + } break; } |