When the parser returned an error, it set the data type of the token to Double to indicate a number error or None for an unknown token. This was necessary since a number error could be returned when the parser was in operator state. This no longer occurs after the last change as the unknown token error is returned if the parser finds a character of a number when numbers are not allowed, so the error status alone can be used to determine the error type. Setting of the token data type for errors was removed. This reduces the amount of data to send back with an exception.
When the parser returned an error, the get token function of the translator returned the special Parser status enumerator. The translator routines used this enumerator along with the token data type to determine if the error was an unknown token or a number error. The parser error type can now determined directly with the error status from the parser, so the get token function was changed to return this status instead of the Parser enumerator.
The checks in the rest of the translator routines for the Parser enumerator and None data type were changed to just check for unknown token. The check in the get operand routine to set the token length to 1 for non-references when there was a parser error was removed since this is the only possible error. When getting the token after an argument in the process internal function routine, the check for a unary operator (an error) was moved to before the check for an error, which was changed to return all errors except unknown token. When this token was not a comma or closing parentheses the appropriate error is determined for the error or bad token.
The special Parser status enumerator was no longer used, so it was removed. The concludes all the prep work for changing parser errors into exceptions.
[branch parser commit ae9e97696e]
Saturday, October 25, 2014
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment
All comments and feedback welcomed, whether positive or negative.
(Anonymous comments are allowed, but comments with URL links or unrelated comments will be removed.)