2011-12-10 13:54:10 +00:00
|
|
|
/*
|
|
|
|
* This file is part of OpenTTD.
|
|
|
|
* 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.
|
|
|
|
* 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.
|
|
|
|
* 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/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** @file error.h Functions related to errors. */
|
|
|
|
|
|
|
|
#ifndef ERROR_H
|
|
|
|
#define ERROR_H
|
|
|
|
|
|
|
|
#include "strings_type.h"
|
2012-05-14 20:58:59 +00:00
|
|
|
#include "company_type.h"
|
|
|
|
#include "core/geometry_type.hpp"
|
2021-01-06 23:53:10 +00:00
|
|
|
#include "guitimer_func.h"
|
2023-11-09 15:49:54 +00:00
|
|
|
#include <list>
|
|
|
|
#include <vector>
|
2011-12-10 13:54:10 +00:00
|
|
|
|
2014-01-12 18:00:39 +00:00
|
|
|
struct GRFFile;
|
|
|
|
|
2011-12-10 13:54:10 +00:00
|
|
|
/** Message severity/type */
|
|
|
|
enum WarningLevel {
|
2013-01-08 22:46:42 +00:00
|
|
|
WL_INFO, ///< Used for DoCommand-like (and some non-fatal AI GUI) errors/information
|
2011-12-10 13:54:10 +00:00
|
|
|
WL_WARNING, ///< Other information
|
|
|
|
WL_ERROR, ///< Errors (eg. saving/loading failed)
|
|
|
|
WL_CRITICAL, ///< Critical errors, the MessageBox is shown in all cases
|
|
|
|
};
|
|
|
|
|
2012-05-14 20:58:59 +00:00
|
|
|
/** The data of the error message. */
|
|
|
|
class ErrorMessageData {
|
|
|
|
protected:
|
2021-01-06 23:53:10 +00:00
|
|
|
GUITimer display_timer; ///< Timer before closing the message.
|
2023-06-21 05:03:20 +00:00
|
|
|
std::vector<StringParameterBackup> params; ///< Backup of parameters of the message strings.
|
2014-01-12 18:00:39 +00:00
|
|
|
const GRFFile *textref_stack_grffile; ///< NewGRF that filled the #TextRefStack for the error message.
|
2024-01-07 16:41:53 +00:00
|
|
|
uint textref_stack_size; ///< Number of uint32_t values to put on the #TextRefStack for the error message.
|
|
|
|
uint32_t textref_stack[16]; ///< Values to put on the #TextRefStack for the error message.
|
2012-05-14 20:58:59 +00:00
|
|
|
StringID summary_msg; ///< General error message showed in first line. Must be valid.
|
|
|
|
StringID detailed_msg; ///< Detailed error message showed in second line. Can be #INVALID_STRING_ID.
|
2018-11-19 18:59:25 +00:00
|
|
|
StringID extra_msg; ///< Extra error message shown in third line. Can be #INVALID_STRING_ID.
|
2012-05-14 20:58:59 +00:00
|
|
|
Point position; ///< Position of the error message window.
|
|
|
|
CompanyID face; ///< Company belonging to the face being shown. #INVALID_COMPANY if no face present.
|
|
|
|
|
|
|
|
public:
|
|
|
|
ErrorMessageData(const ErrorMessageData &data);
|
2024-01-07 16:41:53 +00:00
|
|
|
ErrorMessageData(StringID summary_msg, StringID detailed_msg, uint duration = 0, int x = 0, int y = 0, const GRFFile *textref_stack_grffile = nullptr, uint textref_stack_size = 0, const uint32_t *textref_stack = nullptr, StringID extra_msg = INVALID_STRING_ID);
|
2012-05-14 21:01:54 +00:00
|
|
|
|
2021-05-26 19:48:28 +00:00
|
|
|
/* Remove the copy assignment, as the default implementation will not do the right thing. */
|
|
|
|
ErrorMessageData &operator=(ErrorMessageData &rhs) = delete;
|
|
|
|
|
2013-05-26 19:23:42 +00:00
|
|
|
/** Check whether error window shall display a company manager face */
|
|
|
|
bool HasFace() const { return face != INVALID_COMPANY; }
|
|
|
|
|
2024-01-07 16:41:53 +00:00
|
|
|
void SetDParam(uint n, uint64_t v);
|
2012-05-14 21:04:49 +00:00
|
|
|
void SetDParamStr(uint n, const char *str);
|
2021-05-30 09:40:54 +00:00
|
|
|
void SetDParamStr(uint n, const std::string &str);
|
2012-05-14 21:04:49 +00:00
|
|
|
|
2012-05-14 21:01:54 +00:00
|
|
|
void CopyOutDParams();
|
2012-05-14 20:58:59 +00:00
|
|
|
};
|
|
|
|
|
2023-01-29 08:28:24 +00:00
|
|
|
/** Define a queue with errors. */
|
|
|
|
typedef std::list<ErrorMessageData> ErrorList;
|
|
|
|
|
|
|
|
void ScheduleErrorMessage(ErrorList &datas);
|
2012-07-08 18:41:50 +00:00
|
|
|
void ScheduleErrorMessage(const ErrorMessageData &data);
|
|
|
|
|
2024-01-07 16:41:53 +00:00
|
|
|
void ShowErrorMessage(StringID summary_msg, StringID detailed_msg, WarningLevel wl, int x = 0, int y = 0, const GRFFile *textref_stack_grffile = nullptr, uint textref_stack_size = 0, const uint32_t *textref_stack = nullptr, StringID extra_msg = INVALID_STRING_ID);
|
2020-07-05 18:18:35 +00:00
|
|
|
bool HideActiveErrorMessage();
|
2011-12-10 15:14:11 +00:00
|
|
|
void ClearErrorMessages();
|
2011-12-10 15:16:58 +00:00
|
|
|
void ShowFirstError();
|
|
|
|
void UnshowCriticalError();
|
2011-12-10 13:54:10 +00:00
|
|
|
|
|
|
|
#endif /* ERROR_H */
|