forked from 0ad/0ad
Preprocessor: Avoid using "%.*hs" in log format string, since cppformat doesn't support it.
This was SVN commit r16189.
This commit is contained in:
parent
568c415d0a
commit
afa492f473
@ -231,8 +231,8 @@ static void DefaultError (void *iData, int iLine, const char *iError,
|
||||
{
|
||||
(void)iData;
|
||||
if (iToken)
|
||||
LOGERROR("Preprocessor error: line %d: %s: '%.*hs'\n",
|
||||
iLine, iError, int (iTokenLen), iToken);
|
||||
LOGERROR("Preprocessor error: line %d: %s: '%s'\n",
|
||||
iLine, iError, std::string (iToken, iTokenLen));
|
||||
else
|
||||
LOGERROR("Preprocessor error: line %d: %s\n", iLine, iError);
|
||||
}
|
||||
|
46
source/ps/tests/test_Preprocessor.h
Normal file
46
source/ps/tests/test_Preprocessor.h
Normal file
@ -0,0 +1,46 @@
|
||||
/* Copyright (C) 2015 Wildfire Games.
|
||||
* This file is part of 0 A.D.
|
||||
*
|
||||
* 0 A.D. 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, either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* 0 A.D. 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 0 A.D. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include "lib/self_test.h"
|
||||
|
||||
#include "ps/Preprocessor.h"
|
||||
|
||||
class TestPreprocessor : public CxxTest::TestSuite
|
||||
{
|
||||
public:
|
||||
void test_basic()
|
||||
{
|
||||
CPreprocessor preproc;
|
||||
const char* in = "#define TEST 2\n1+1=TEST\n";
|
||||
size_t len = 0;
|
||||
char* out = preproc.Parse(in, strlen(in), len);
|
||||
TS_ASSERT_EQUALS(std::string(out, len), "\n1+1=2\n");
|
||||
}
|
||||
|
||||
void test_error()
|
||||
{
|
||||
TestLogger logger;
|
||||
|
||||
CPreprocessor preproc;
|
||||
const char* in = "foo\n#if ()\nbar\n";
|
||||
size_t len = 0;
|
||||
char* out = preproc.Parse(in, strlen(in), len);
|
||||
TS_ASSERT_EQUALS(std::string(out, len), "");
|
||||
|
||||
TS_ASSERT_STR_CONTAINS(logger.GetOutput(), "ERROR: Preprocessor error: line 2: Unclosed parenthesis in #if expression\n");
|
||||
}
|
||||
};
|
Loading…
Reference in New Issue
Block a user