A function to simplify building 'expected, but found' error messages.
This commit is contained in:
parent
cf014150ca
commit
60e0270ffa
|
@ -247,6 +247,13 @@ final class Scanner
|
||||||
return cast(string)msgBuffer_.printNoGC(args);
|
return cast(string)msgBuffer_.printNoGC(args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Most scanning error messages have the same format; so build them with this
|
||||||
|
/// function.
|
||||||
|
string expected(T)(string expected, T found) @safe pure nothrow @nogc
|
||||||
|
{
|
||||||
|
return buildMsg("expected ", expected, ", but found ", found);
|
||||||
|
}
|
||||||
|
|
||||||
/// If error_ is true, throws a ScannerException constructed from errorData_ and
|
/// If error_ is true, throws a ScannerException constructed from errorData_ and
|
||||||
/// sets error_ to false.
|
/// sets error_ to false.
|
||||||
void throwIfError() @safe pure
|
void throwIfError() @safe pure
|
||||||
|
@ -849,8 +856,7 @@ final class Scanner
|
||||||
if(length == 0)
|
if(length == 0)
|
||||||
{
|
{
|
||||||
enum contextMsg = "While scanning " ~ name;
|
enum contextMsg = "While scanning " ~ name;
|
||||||
error(contextMsg, startMark,
|
error(contextMsg, startMark, expected("alphanumeric, '-' or '_'", c),
|
||||||
buildMsg("expected alphanumeric, '-' or '_', but found ", c),
|
|
||||||
reader_.mark);
|
reader_.mark);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -961,8 +967,7 @@ final class Scanner
|
||||||
|
|
||||||
if(" \0\n\r\u0085\u2028\u2029"d.canFind(reader_.peek())) { return; }
|
if(" \0\n\r\u0085\u2028\u2029"d.canFind(reader_.peek())) { return; }
|
||||||
error("While scanning a directive", startMark,
|
error("While scanning a directive", startMark,
|
||||||
buildMsg("expected alphanumeric, '-' or '_', but found ", reader_.peek()),
|
expected("alphanumeric, '-' or '_'", reader_.peek()), reader_.mark);
|
||||||
reader_.mark);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
///Scan value of a YAML directive token. Returns major, minor version separated by '.'.
|
///Scan value of a YAML directive token. Returns major, minor version separated by '.'.
|
||||||
|
@ -1124,8 +1129,7 @@ final class Scanner
|
||||||
if(reader_.peek() != '>')
|
if(reader_.peek() != '>')
|
||||||
{
|
{
|
||||||
error("While scanning a tag", startMark,
|
error("While scanning a tag", startMark,
|
||||||
buildMsg("expected '>' but found ", reader_.peek()),
|
expected("'>'", reader_.peek()), reader_.mark);
|
||||||
reader_.mark);
|
|
||||||
return Token.init;
|
return Token.init;
|
||||||
}
|
}
|
||||||
reader_.forward();
|
reader_.forward();
|
||||||
|
@ -1175,8 +1179,8 @@ final class Scanner
|
||||||
return tagToken(startMark, reader_.mark, slice.utf32To8, handleEnd);
|
return tagToken(startMark, reader_.mark, slice.utf32To8, handleEnd);
|
||||||
}
|
}
|
||||||
|
|
||||||
error("While scanning a tag", startMark,
|
error("While scanning a tag", startMark, expected("' '", reader_.peek()),
|
||||||
buildMsg("expected ' ' but found ", reader_.peek()), reader_.mark);
|
reader_.mark);
|
||||||
return Token.init;
|
return Token.init;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1352,8 +1356,7 @@ final class Scanner
|
||||||
return tuple(chomping, increment);
|
return tuple(chomping, increment);
|
||||||
}
|
}
|
||||||
error("While scanning a block scalar", startMark,
|
error("While scanning a block scalar", startMark,
|
||||||
buildMsg("expected chomping or indentation indicator, but found ", c),
|
expected("chomping or indentation indicator", c), reader_.mark);
|
||||||
reader_.mark);
|
|
||||||
return tuple(Chomping.init, int.max);
|
return tuple(Chomping.init, int.max);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1401,7 +1404,7 @@ final class Scanner
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
error("While scanning a block scalar", startMark,
|
error("While scanning a block scalar", startMark,
|
||||||
"expected indentation indicator in range 1-9, but found 0", reader_.mark);
|
expected("indentation indicator in range 1-9", "0"), reader_.mark);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1419,8 +1422,7 @@ final class Scanner
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
error("While scanning a block scalar", startMark,
|
error("While scanning a block scalar", startMark,
|
||||||
buildMsg("expected comment or line break, but found ", reader_.peek()),
|
expected("comment or line break", reader_.peek()), reader_.mark);
|
||||||
reader_.mark);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Scan indentation in a block scalar, returning line breaks, max indent and end mark.
|
/// Scan indentation in a block scalar, returning line breaks, max indent and end mark.
|
||||||
|
@ -1559,8 +1561,8 @@ final class Scanner
|
||||||
foreach(i; 0 .. hexLength) if(!reader_.peek(i).isHexDigit())
|
foreach(i; 0 .. hexLength) if(!reader_.peek(i).isHexDigit())
|
||||||
{
|
{
|
||||||
error("While scanning a double quoted scalar", startMark,
|
error("While scanning a double quoted scalar", startMark,
|
||||||
"found an unexpected character; expected escape "
|
expected("escape sequence of hexadecimal numbers",
|
||||||
"sequence of hexadecimal numbers.", reader_.mark);
|
reader_.peek(i)), reader_.mark);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1585,7 +1587,7 @@ final class Scanner
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
error("While scanning a double quoted scalar", startMark,
|
error("While scanning a double quoted scalar", startMark,
|
||||||
buildMsg("found unsupported escape " "character", c),
|
buildMsg("found unsupported escape character", c),
|
||||||
reader_.mark);
|
reader_.mark);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1825,8 +1827,7 @@ final class Scanner
|
||||||
enum contextMsg = "While scanning a " ~ name;
|
enum contextMsg = "While scanning a " ~ name;
|
||||||
if(c != '!')
|
if(c != '!')
|
||||||
{
|
{
|
||||||
error(contextMsg, startMark,
|
error(contextMsg, startMark, expected("'!'", c), reader_.mark);
|
||||||
buildMsg("expected a '!', but found: ", c), reader_.mark);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1842,8 +1843,7 @@ final class Scanner
|
||||||
if(c != '!')
|
if(c != '!')
|
||||||
{
|
{
|
||||||
reader_.forward(length);
|
reader_.forward(length);
|
||||||
error(contextMsg, startMark,
|
error(contextMsg, startMark, expected("'!'", c), reader_.mark);
|
||||||
buildMsg("expected a '!', but found: ", c), reader_.mark);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
++length;
|
++length;
|
||||||
|
@ -1889,8 +1889,7 @@ final class Scanner
|
||||||
if(reader_.sliceBuilder.length > startLen) { return; }
|
if(reader_.sliceBuilder.length > startLen) { return; }
|
||||||
|
|
||||||
enum contextMsg = "While parsing a " ~ name;
|
enum contextMsg = "While parsing a " ~ name;
|
||||||
error(contextMsg, startMark, buildMsg("expected URI, but found: ", c),
|
error(contextMsg, startMark, expected("URI", c), reader_.mark);
|
||||||
reader_.mark);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Not @nogc yet because std.utf.decode is not @nogc
|
// Not @nogc yet because std.utf.decode is not @nogc
|
||||||
|
@ -1946,8 +1945,8 @@ final class Scanner
|
||||||
const dchar c = reader_.peek(k);
|
const dchar c = reader_.peek(k);
|
||||||
if(!c.isHexDigit)
|
if(!c.isHexDigit)
|
||||||
{
|
{
|
||||||
auto msg = buildMsg("expected URI escape sequence of 2 "
|
auto msg = expected("URI escape sequence of 2 hexadecimal "
|
||||||
"hexadecimal numbers, but found: ", c);
|
"numbers", c);
|
||||||
error(contextMsg, startMark, msg, reader_.mark);
|
error(contextMsg, startMark, msg, reader_.mark);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue