36 std::string dummy_script = fmt::format(
37 "class Dummy{0} extends {0}Info {{\n"
38 "function GetAuthor() {{ return \"OpenTTD Developers Team\"; }}\n"
39 "function GetName() {{ return \"Dummy{0}\"; }}\n"
40 "function GetShortName() {{ return \"DUMM\"; }}\n"
41 "function GetDescription() {{ return \"A Dummy {0} that is loaded when your {1}/ dir is empty\"; }}\n"
42 "function GetVersion() {{ return 1; }}\n"
43 "function GetDate() {{ return \"2008-07-26\"; }}\n"
44 "function CreateInstance() {{ return \"Dummy{0}\"; }}\n"
45 "}} RegisterDummy{0}(Dummy{0}());\n", type, dir);
50 if (SQ_SUCCEEDED(sq_compilebuffer(vm, dummy_script,
"dummy", SQTrue))) {
52 if (SQ_SUCCEEDED(sq_call(vm, 1, SQFalse, SQTrue))) {
68 std::vector<std::string> messages;
70 std::string safe_message;
71 for (
auto c : message) {
73 messages.emplace_back(std::move(safe_message));
78 if (c ==
'"' || c ==
'\\') safe_message.push_back(
'\\');
79 safe_message.push_back(c);
81 messages.emplace_back(std::move(safe_message));
98 std::string error_message =
GetString(
string);
102 std::string dummy_script;
104 dummy_script.reserve(error_message.size() + 128 + 64 * messages.size());
106 format_append(dummy_script,
"class Dummy{0} extends {0}Controller {{\n function Start()\n {{\n", type);
107 for (std::string &message : messages) {
108 format_append(dummy_script,
" {}Log.Error(\"{}\");\n", type, message);
110 dummy_script +=
" }\n}\n";
113 sq_pushroottable(vm);
114 if (SQ_SUCCEEDED(sq_compilebuffer(vm, dummy_script,
"dummy", SQTrue))) {
116 if (SQ_SUCCEEDED(sq_call(vm, 1, SQFalse, SQTrue))) {
A number of safeguards to prevent using unsafe methods.
static std::vector< std::string > EscapeQuotesAndSlashesAndSplitOnNewLines(const std::string &message)
Split the given message on newlines (' ') and escape quotes and (back)slashes, so they can be properl...
void Script_CreateDummy(HSQUIRRELVM vm, StringID string, std::string_view type)
Run the dummy AI and let it generate an error message.
void Script_CreateDummyInfo(HSQUIRRELVM vm, std::string_view type, std::string_view dir)
Run the dummy info.nut.
Definition of base types and functions in a cross-platform compatible way.
Functions related to low-level strings.
std::string GetString(StringID string)
Resolve the given StringID into a std::string with formatting but no parameters.
Functions related to OTTD's strings.
uint32_t StringID
Numeric value that represents a string, independent of the selected language.