Move std::string str_validate to separate header
This is to fix compilation of squirrel on MacOS/clang, as squirrel defines macros which clash with including <string>
This commit is contained in:
@@ -344,6 +344,7 @@ story_type.h
|
|||||||
strgen/strgen.h
|
strgen/strgen.h
|
||||||
string_base.h
|
string_base.h
|
||||||
string_func.h
|
string_func.h
|
||||||
|
string_func_extra.h
|
||||||
string_type.h
|
string_type.h
|
||||||
stringfilter_type.h
|
stringfilter_type.h
|
||||||
strings_func.h
|
strings_func.h
|
||||||
|
@@ -41,6 +41,7 @@
|
|||||||
#include "../fileio_func.h"
|
#include "../fileio_func.h"
|
||||||
#include "../gamelog.h"
|
#include "../gamelog.h"
|
||||||
#include "../string_func.h"
|
#include "../string_func.h"
|
||||||
|
#include "../string_func_extra.h"
|
||||||
#include "../fios.h"
|
#include "../fios.h"
|
||||||
#include "../error.h"
|
#include "../error.h"
|
||||||
|
|
||||||
|
@@ -27,7 +27,6 @@
|
|||||||
#define STRING_FUNC_H
|
#define STRING_FUNC_H
|
||||||
|
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <string>
|
|
||||||
|
|
||||||
#include "core/bitmath_func.hpp"
|
#include "core/bitmath_func.hpp"
|
||||||
#include "string_type.h"
|
#include "string_type.h"
|
||||||
@@ -56,13 +55,6 @@ static inline void str_validate(char *str, const char *last, StringValidationSet
|
|||||||
*str_validate_intl(str, last, settings) = '\0';
|
*str_validate_intl(str, last, settings) = '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void str_validate(std::string &str, StringValidationSettings settings = SVS_REPLACE_WITH_QUESTION_MARK)
|
|
||||||
{
|
|
||||||
if (str.empty()) return;
|
|
||||||
char *buf = const_cast<char *>(str.c_str());
|
|
||||||
str.resize(str_validate_intl(buf, buf + str.size(), settings) - buf);
|
|
||||||
}
|
|
||||||
|
|
||||||
void ValidateString(const char *str);
|
void ValidateString(const char *str);
|
||||||
|
|
||||||
void str_fix_scc_encoded(char *str, const char *last);
|
void str_fix_scc_encoded(char *str, const char *last);
|
||||||
|
23
src/string_func_extra.h
Normal file
23
src/string_func_extra.h
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* $Id$ */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef STRING_FUNC_EXTRA_H
|
||||||
|
#define STRING_FUNC_EXTRA_H
|
||||||
|
|
||||||
|
#include "string_func.h"
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
static inline void str_validate(std::string &str, StringValidationSettings settings = SVS_REPLACE_WITH_QUESTION_MARK)
|
||||||
|
{
|
||||||
|
if (str.empty()) return;
|
||||||
|
char *buf = const_cast<char *>(str.c_str());
|
||||||
|
str.resize(str_validate_intl(buf, buf + str.size(), settings) - buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* STRING_FUNC_EXTRA_H */
|
Reference in New Issue
Block a user