OpenTTD Source 20260311-master-g511d3794ce
newgrf_act13.cpp
Go to the documentation of this file.
1/*
2 * This file is part of OpenTTD.
3 * 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.
4 * 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.
5 * 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 <https://www.gnu.org/licenses/old-licenses/gpl-2.0>.
6 */
7
9
10#include "../stdafx.h"
11#include "../debug.h"
12#include "../newgrf_text.h"
13#include "../strings_func.h"
14#include "newgrf_bytereader.h"
15#include "newgrf_internal.h"
16
17#include "table/strings.h"
18
19#include "../safeguards.h"
20
26{
27 /* <13> <grfid> <num-ent> <offset> <text...>
28 *
29 * 4*B grfid The GRFID of the file whose texts are to be translated
30 * B num-ent Number of strings
31 * W offset First text ID
32 * S text... Zero-terminated strings */
33
34 uint32_t grfid = buf.ReadDWord();
35 const GRFConfig *c = GetGRFConfig(grfid);
36 if (c == nullptr || (c->status != GCS_INITIALISED && c->status != GCS_ACTIVATED)) {
37 GrfMsg(7, "TranslateGRFStrings: GRFID 0x{:08X} unknown, skipping action 13", std::byteswap(grfid));
38 return;
39 }
40
41 if (c->status == GCS_INITIALISED) {
42 /* If the file is not active but will be activated later, give an error
43 * and disable this file. */
44 GRFError *error = DisableGrf(STR_NEWGRF_ERROR_LOAD_AFTER);
45
46 error->data = GetString(STR_NEWGRF_ERROR_AFTER_TRANSLATED_FILE);
47
48 return;
49 }
50
51 /* Since no language id is supplied for with version 7 and lower NewGRFs, this string has
52 * to be added as a generic string, thus the language id of 0x7F. For this to work
53 * new_scheme has to be true as well, which will also be implicitly the case for version 8
54 * and higher. A language id of 0x7F will be overridden by a non-generic id, so this will
55 * not change anything if a string has been provided specifically for this language. */
56 uint8_t language = _cur_gps.grffile->grf_version >= 8 ? buf.ReadByte() : 0x7F;
57 uint8_t num_strings = buf.ReadByte();
58 uint16_t first_id = buf.ReadWord();
59
60 if (!((first_id >= 0xD000 && first_id + num_strings <= 0xD400) || (first_id >= 0xD800 && first_id + num_strings <= 0xE000))) {
61 GrfMsg(7, "TranslateGRFStrings: Attempting to set out-of-range string IDs in action 13 (first: 0x{:04X}, number: 0x{:02X})", first_id, num_strings);
62 return;
63 }
64
65 for (uint i = 0; i < num_strings && buf.HasData(); i++) {
66 std::string_view string = buf.ReadString();
67
68 if (string.empty()) {
69 GrfMsg(7, "TranslateGRFString: Ignoring empty string.");
70 continue;
71 }
72
73 AddGRFString(grfid, GRFStringID(first_id + i), language, true, true, string, STR_UNDEFINED);
74 }
75}
76
constexpr enable_if_t< is_integral_v< T >, T > byteswap(T x) noexcept
Custom implementation of std::byteswap; remove once we build with C++23.
Class to read from a NewGRF file.
uint32_t ReadDWord()
Read a single DWord (32 bits).
uint16_t ReadWord()
Read a single Word (16 bits).
std::string_view ReadString()
Read a NUL-terminated string.
uint8_t ReadByte()
Read a single byte (8 bits).
Functions related to debugging.
GRFError * DisableGrf(StringID message, GRFConfig *config)
Disable a GRF.
Definition newgrf.cpp:139
static void TranslateGRFStrings(ByteReader &buf)
Action 0x13 - Load translation.
NewGRF buffer reader definition.
GRFConfig * GetGRFConfig(uint32_t grfid, uint32_t mask)
Retrieve a NewGRF from the current config by its grfid.
@ GCS_INITIALISED
GRF file has been initialised.
@ GCS_ACTIVATED
GRF file has been activated.
NewGRF internal processing state.
StringID AddGRFString(uint32_t grfid, GRFStringID stringid, uint8_t langid_to_add, bool new_scheme, bool allow_newlines, std::string_view text_to_add, StringID def_string)
Add the new read string into our structure.
Header of Action 04 "universal holder" structure and functions.
StrongType::Typedef< uint32_t, struct GRFStringIDTag, StrongType::Compare, StrongType::Integer > GRFStringID
Type for GRF-internal string IDs.
A number of safeguards to prevent using unsafe methods.
Definition of base types and functions in a cross-platform compatible way.
std::string GetString(StringID string)
Resolve the given StringID into a std::string with formatting but no parameters.
Definition strings.cpp:424
Functions related to OTTD's strings.
Information about GRF, used in the game and (part of it) in savegames.
GRFStatus status
NOSAVE: GRFStatus, enum.
Information about why GRF had problems during initialisation.
std::string data
Additional data for message and custom_message.
static void FileScan(ByteReader &buf)
Implementation of the GrfLoadingStage::FileScan stage of this action.
static void SafetyScan(ByteReader &buf)
Implementation of the GrfLoadingStage::SafetyScan stage of this action.
static void Reserve(ByteReader &buf)
Implementation of the GrfLoadingStage::Reserve stage of this action.
static void Activation(ByteReader &buf)
Implementation of the GrfLoadingStage::Activation stage of this action.
static void Init(ByteReader &buf)
Implementation of the GrfLoadingStage::Init stage of this action.
static void LabelScan(ByteReader &buf)
Implementation of the GrfLoadingStage::LabelScan stage of this action.