Kea 2.7.5
|
Parser context is a wrapper around flex/bison instances dedicated to Control-agent config file parser. More...
#include <parser_context.h>
Public Types | |
enum | LexerContext { NO_KEYWORDS , CONFIG , AGENT , AUTHENTICATION , AUTH_TYPE , CLIENTS , CONTROL_SOCKETS , SERVER , SOCKET_TYPE , HOOKS_LIBRARIES , LOGGERS , OUTPUT_OPTIONS } |
Defines syntactic contexts for lexical tie-ins. More... | |
enum | ParserType { PARSER_JSON , PARSER_AGENT , PARSER_SUB_AGENT } |
Defines currently supported scopes. More... | |
Public Member Functions | |
ParserContext () | |
Default constructor. | |
virtual | ~ParserContext () |
destructor | |
const std::string | contextName () |
Get the syntactic context name. | |
void | enter (const LexerContext &ctx) |
Enter a new syntactic context. | |
void | error (const isc::agent::location &loc, const std::string &what, size_t pos=0) |
Error handler. | |
void | error (const std::string &what) |
Error handler. | |
void | includeFile (const std::string &filename) |
Divert input to an include file. | |
void | leave () |
Leave a syntactic context. | |
isc::data::Element::Position | loc2pos (isc::agent::location &loc) |
Converts bison's position to one understandable by isc::data::Element. | |
isc::data::ElementPtr | parseFile (const std::string &filename, ParserType parser_type) |
Run the parser on the file specified. | |
isc::data::ElementPtr | parseString (const std::string &str, ParserType parser_type) |
Run the parser on the string specified. | |
void | require (const std::string &name, isc::data::Element::Position open_loc, isc::data::Element::Position close_loc) |
Check if a required parameter is present. | |
void | scanEnd () |
Method called after the last tokens are scanned. | |
void | scanFileBegin (FILE *f, const std::string &filename, ParserType type) |
Method called before scanning starts on a file. | |
void | scanStringBegin (const std::string &str, ParserType type) |
Method called before scanning starts on a string. | |
void | unique (const std::string &name, isc::data::Element::Position loc) |
Check if a parameter is already present. | |
void | warnAboutExtraCommas (const isc::agent::location &loc) |
Warning for extra commas. | |
void | warning (const isc::agent::location &loc, const std::string &what) |
Warning handler. | |
Static Public Member Functions | |
static void | fatal (const std::string &what) |
Fatal error handler. | |
Public Attributes | |
LexerContext | ctx_ |
Current syntactic context. | |
std::string | file_ |
File name. | |
std::vector< std::string > | files_ |
File name stack. | |
isc::agent::location | loc_ |
Location of the current token. | |
std::vector< isc::agent::location > | locs_ |
Location stack. | |
FILE * | sfile_ |
sFile (aka FILE) | |
std::vector< FILE * > | sfiles_ |
sFile (aka FILE) stack | |
std::vector< isc::data::ElementPtr > | stack_ |
JSON elements being parsed. | |
std::vector< struct yy_buffer_state * > | states_ |
Lexer state stack. | |
Parser context is a wrapper around flex/bison instances dedicated to Control-agent config file parser.
It follows the same principle as other components. The primary interface are parseString and parseFile methods. All other methods are public for testing purposes only. This interface allows parsing the whole configuration with syntactic checking (which is by far the most frequent use), but it also allows parsing input as generic JSON or parse only content of the Control-agent object, which is a subset of full grammar (this will be very useful for unit-tests to not duplicate unnecessary parts of the config file).
Definition at line 36 of file agent/parser_context.h.
Defines syntactic contexts for lexical tie-ins.
Definition at line 196 of file agent/parser_context.h.
Defines currently supported scopes.
AgentParser is able to parse several types of scope. Usually, when it parses a config file, it expects the data to have a map with Control-agent in it and all the parameters within that map. However, sometimes the parser is expected to parse only a subset of that information.
Definition at line 47 of file agent/parser_context.h.
isc::agent::ParserContext::ParserContext | ( | ) |
Default constructor.
Definition at line 22 of file agent/parser_context.cc.
|
virtual |
destructor
Definition at line 27 of file agent/parser_context.cc.
const std::string isc::agent::ParserContext::contextName | ( | ) |
Get the syntactic context name.
Definition at line 156 of file agent/parser_context.cc.
References AGENT, AUTH_TYPE, AUTHENTICATION, CLIENTS, CONFIG, CONTROL_SOCKETS, ctx_, HOOKS_LIBRARIES, LOGGERS, NO_KEYWORDS, OUTPUT_OPTIONS, SERVER, and SOCKET_TYPE.
Referenced by isc::agent::AgentParser::parse(), require(), and unique().
void isc::agent::ParserContext::enter | ( | const LexerContext & | ctx | ) |
Enter a new syntactic context.
Entering a new syntactic context is useful in several ways. First, it allows the parser to avoid conflicts. Second, it allows the lexer to return different tokens depending on context (e.g. if "renew-timer" string is detected, the lexer will return STRING token if in JSON mode or RENEW_TIMER if in DHCP6 mode. Finally, the syntactic context allows the error message to be more descriptive if the input string does not parse properly. Control Agent parser uses simplified contexts: either it recognizes keywords (value set to KEYWORDS) or not (value set to NO_KEYWORDS).
Make sure to call leave() once the parsing of your context is complete.
ctx | the syntactic context to enter into |
Definition at line 139 of file agent/parser_context.cc.
References ctx_.
Referenced by isc::agent::AgentParser::parse().
void isc::agent::ParserContext::error | ( | const isc::agent::location & | loc, |
const std::string & | what, | ||
size_t | pos = 0 ) |
Error handler.
loc | location within the parsed file where the problem was experienced. |
what | string explaining the nature of the error. |
pos | optional position for in string errors. |
ParseError |
Definition at line 73 of file agent/parser_context.cc.
References isc_throw.
void isc::agent::ParserContext::error | ( | const std::string & | what | ) |
Error handler.
This is a simplified error reporting tool for possible future cases when the AgentParser is not able to handle the packet.
what | string explaining the nature of the error. |
ParseError |
Definition at line 85 of file agent/parser_context.cc.
References isc_throw.
|
static |
Fatal error handler.
This is for should not happen but fatal errors. Used by YY_FATAL_ERROR macro so required to be static.
what | string explaining the nature of the error. |
ParseError |
Definition at line 91 of file agent/parser_context.cc.
References isc_throw.
Referenced by leave().
void ParserContext::includeFile | ( | const std::string & | filename | ) |
Divert input to an include file.
filename | file to be included |
Definition at line 4112 of file agent_lexer.cc.
References BEGIN, isc::db::fatal, file_, files_, INITIAL, loc_, locs_, sfile_, sfiles_, states_, and YY_CURRENT_BUFFER.
void isc::agent::ParserContext::leave | ( | ) |
Leave a syntactic context.
enter() must be called before (when entering a new scope or context). Once you complete the parsing, this method should be called.
isc::Unexpected | if unbalanced (more leave() than enter() calls) |
Definition at line 146 of file agent/parser_context.cc.
Referenced by isc::agent::AgentParser::parse().
isc::data::Element::Position isc::agent::ParserContext::loc2pos | ( | isc::agent::location & | loc | ) |
Converts bison's position to one understandable by isc::data::Element.
Convert a bison location into an element position (take the begin, the end is lost)
loc | location in bison format |
Definition at line 97 of file agent/parser_context.cc.
Referenced by isc::agent::AgentParser::parse().
isc::data::ElementPtr isc::agent::ParserContext::parseFile | ( | const std::string & | filename, |
ParserType | parser_type ) |
Run the parser on the file specified.
This method parses specified file. Depending on the value of parser_type, parser may either check only that the input is valid JSON, or may do more specific syntax checking. See ParserType for supported syntax checkers.
filename | file to be parsed |
parser_type | specifies expected content (usually PARSER_AGENT or PARSER_JSON) |
Definition at line 39 of file agent/parser_context.cc.
References isc_throw, and scanFileBegin().
Referenced by isc::agent::CtrlAgentController::parseFile().
isc::data::ElementPtr isc::agent::ParserContext::parseString | ( | const std::string & | str, |
ParserType | parser_type ) |
Run the parser on the string specified.
This method parses specified string. Depending on the value of parser_type, parser may either check only that the input is valid JSON, or may do more specific syntax checking. See ParserType for supported syntax checkers.
str | string to be parsed |
parser_type | specifies expected content (usually AGENT or generic JSON) |
Definition at line 32 of file agent/parser_context.cc.
References scanStringBegin().
void isc::agent::ParserContext::require | ( | const std::string & | name, |
isc::data::Element::Position | open_loc, | ||
isc::data::Element::Position | close_loc ) |
Check if a required parameter is present.
Check if a required parameter is present in the map at the top of the stack and raise an error when it is not.
name | name of the parameter to check |
open_loc | location of the opening curly bracket |
close_loc | location of the closing curly bracket |
ParseError |
Definition at line 106 of file agent/parser_context.cc.
References contextName(), isc_throw, and stack_.
Referenced by isc::agent::AgentParser::parse().
void ParserContext::scanEnd | ( | ) |
Method called after the last tokens are scanned.
Definition at line 4091 of file agent_lexer.cc.
void ParserContext::scanFileBegin | ( | FILE * | f, |
const std::string & | filename, | ||
ParserType | type ) |
Method called before scanning starts on a file.
f | stdio FILE pointer |
filename | file to be parsed |
type | specifies expected content |
Definition at line 4069 of file agent_lexer.cc.
References isc::db::fatal, file_, loc_, sfile_, and yy_flex_debug.
Referenced by parseFile().
void ParserContext::scanStringBegin | ( | const std::string & | str, |
ParserType | type ) |
Method called before scanning starts on a string.
str | string to be parsed |
type | specifies expected content |
Definition at line 4051 of file agent_lexer.cc.
References isc::db::fatal, file_, loc_, sfile_, and yy_flex_debug.
Referenced by parseString().
void isc::agent::ParserContext::unique | ( | const std::string & | name, |
isc::data::Element::Position | loc ) |
Check if a parameter is already present.
Check if a parameter is already present in the map at the top of the stack and raise an error when it is.
name | name of the parameter to check |
loc | location of the current parameter |
ParseError |
Definition at line 121 of file agent/parser_context.cc.
References contextName(), ctx_, isc_throw, NO_KEYWORDS, and stack_.
Referenced by isc::agent::AgentParser::parse().
void isc::agent::ParserContext::warnAboutExtraCommas | ( | const isc::agent::location & | loc | ) |
Warning for extra commas.
loc | location within the parsed file of the extra comma |
ParseError |
Definition at line 198 of file agent/parser_context.cc.
References warning().
Referenced by isc::agent::AgentParser::parse().
void isc::agent::ParserContext::warning | ( | const isc::agent::location & | loc, |
const std::string & | what ) |
Warning handler.
loc | location within the parsed file where the problem was experienced |
what | string explaining the nature of the error |
ParseError |
Definition at line 189 of file agent/parser_context.cc.
References isc::agent::agent_logger, isc::agent::CTRL_AGENT_CONFIG_SYNTAX_WARNING, and LOG_WARN.
Referenced by warnAboutExtraCommas().
LexerContext isc::agent::ParserContext::ctx_ |
Current syntactic context.
Definition at line 263 of file agent/parser_context.h.
Referenced by contextName(), enter(), leave(), isc::agent::AgentParser::parse(), and unique().
std::string isc::agent::ParserContext::file_ |
File name.
Definition at line 235 of file agent/parser_context.h.
Referenced by includeFile(), scanFileBegin(), and scanStringBegin().
std::vector<std::string> isc::agent::ParserContext::files_ |
File name stack.
Definition at line 238 of file agent/parser_context.h.
Referenced by includeFile().
isc::agent::location isc::agent::ParserContext::loc_ |
Location of the current token.
The lexer will keep updating it. This variable will be useful for logging errors.
Definition at line 244 of file agent/parser_context.h.
Referenced by includeFile(), scanFileBegin(), and scanStringBegin().
std::vector<isc::agent::location> isc::agent::ParserContext::locs_ |
FILE* isc::agent::ParserContext::sfile_ |
sFile (aka FILE)
Definition at line 253 of file agent/parser_context.h.
Referenced by includeFile(), scanEnd(), scanFileBegin(), and scanStringBegin().
std::vector<FILE*> isc::agent::ParserContext::sfiles_ |
sFile (aka FILE) stack
This is a stack of files. Typically there's only one file (the one being currently parsed), but there may be more if one file includes another.
Definition at line 260 of file agent/parser_context.h.
Referenced by includeFile(), and scanEnd().
std::vector<isc::data::ElementPtr> isc::agent::ParserContext::stack_ |
JSON elements being parsed.
Definition at line 66 of file agent/parser_context.h.
Referenced by isc::agent::AgentParser::parse(), require(), and unique().
std::vector<struct yy_buffer_state*> isc::agent::ParserContext::states_ |
Lexer state stack.
Definition at line 250 of file agent/parser_context.h.
Referenced by includeFile(), and scanEnd().