1 /* $Id: strings_sl.cpp 22957 2011-09-23 19:27:15Z rubidium $ */
4 * This file is part of OpenTTD.
5 * OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
6 * OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
7 * See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
10 /** @file strings_sl.cpp Code handling saving and loading of strings */
12 #include "../stdafx.h"
13 #include "../string_func.h"
14 #include "../strings_func.h"
15 #include "saveload_internal.h"
17 #include "table/strings.h"
19 #include "../safeguards.h"
21 static const int NUM_OLD_STRINGS
= 512; ///< The number of custom strings stored in old savegames.
22 static const int LEN_OLD_STRINGS
= 32; ///< The number of characters per string.
23 static const int LEN_OLD_STRINGS_TTO
= 24; ///< The number of characters per string in TTO savegames.
26 * Remap a string ID from the old format to the new format
27 * @param s StringID that requires remapping
28 * @return translated ID
30 StringID
RemapOldStringID(StringID s
)
33 case 0x0006: return STR_SV_EMPTY
;
34 case 0x7000: return STR_SV_UNNAMED
;
35 case 0x70E4: return SPECSTR_COMPANY_NAME_START
;
36 case 0x70E9: return SPECSTR_COMPANY_NAME_START
;
37 case 0x8864: return STR_SV_TRAIN_NAME
;
38 case 0x902B: return STR_SV_ROAD_VEHICLE_NAME
;
39 case 0x9830: return STR_SV_SHIP_NAME
;
40 case 0xA02F: return STR_SV_AIRCRAFT_NAME
;
43 if (IsInsideMM(s
, 0x300F, 0x3030)) {
44 return s
- 0x300F + STR_SV_STNAME
;
51 /** Location to load the old names to. */
52 char *_old_name_array
= NULL
;
55 * Copy and convert old custom names to UTF-8.
56 * They were all stored in a 512 by 32 (200 by 24 for TTO) long string array
57 * and are now stored with stations, waypoints and other places with names.
58 * @param id the StringID of the custom name to clone.
59 * @return the clones custom name.
61 char *CopyFromOldName(StringID id
)
63 /* Is this name an (old) custom name? */
64 if (GetStringTab(id
) != TEXT_TAB_OLD_CUSTOM
) return NULL
;
66 if (IsSavegameVersionBefore(37)) {
67 /* Allow for expansion when converted to UTF-8. */
68 char tmp
[LEN_OLD_STRINGS
* MAX_CHAR_LENGTH
];
69 uint offs
= _savegame_type
== SGT_TTO
? LEN_OLD_STRINGS_TTO
* GB(id
, 0, 8) : LEN_OLD_STRINGS
* GB(id
, 0, 9);
70 const char *strfrom
= &_old_name_array
[offs
];
73 for (; *strfrom
!= '\0'; strfrom
++) {
74 WChar c
= (byte
)*strfrom
;
76 /* Map from non-ISO8859-15 characters to UTF-8. */
78 case 0xA4: c
= 0x20AC; break; // Euro
79 case 0xA6: c
= 0x0160; break; // S with caron
80 case 0xA8: c
= 0x0161; break; // s with caron
81 case 0xB4: c
= 0x017D; break; // Z with caron
82 case 0xB8: c
= 0x017E; break; // z with caron
83 case 0xBC: c
= 0x0152; break; // OE ligature
84 case 0xBD: c
= 0x0153; break; // oe ligature
85 case 0xBE: c
= 0x0178; break; // Y with diaresis
89 /* Check character will fit into our buffer. */
90 if (strto
+ Utf8CharLen(c
) > lastof(tmp
)) break;
92 strto
+= Utf8Encode(strto
, c
);
95 /* Terminate the new string and copy it back to the name array */
100 /* Name will already be in UTF-8. */
101 return stredup(&_old_name_array
[LEN_OLD_STRINGS
* GB(id
, 0, 9)]);
106 * Free the memory of the old names array.
107 * Should be called once the old names have all been converted.
111 free(_old_name_array
);
112 _old_name_array
= NULL
;
116 * Initialize the old names table memory.
118 void InitializeOldNames()
120 free(_old_name_array
);
121 _old_name_array
= CallocT
<char>(NUM_OLD_STRINGS
* LEN_OLD_STRINGS
); // 200 * 24 would be enough for TTO savegames
125 * Load the NAME chunk.
127 static void Load_NAME()
131 while ((index
= SlIterateArray()) != -1) {
132 if (index
>= NUM_OLD_STRINGS
) SlErrorCorrupt("Invalid old name index");
133 if (SlGetFieldLength() > (uint
)LEN_OLD_STRINGS
) SlErrorCorrupt("Invalid old name length");
135 SlArray(&_old_name_array
[LEN_OLD_STRINGS
* index
], SlGetFieldLength(), SLE_UINT8
);
136 /* Make sure the old name is null terminated */
137 _old_name_array
[LEN_OLD_STRINGS
* index
+ LEN_OLD_STRINGS
- 1] = '\0';
141 /** Chunk handlers related to strings. */
142 extern const ChunkHandler _name_chunk_handlers
[] = {
143 { 'NAME', NULL
, Load_NAME
, NULL
, NULL
, CH_ARRAY
| CH_LAST
},