Kea  1.9.9-git
isc::netconf::ParserContext Class Reference

Parser context is a wrapper around flex/bison instances dedicated to Netconf-agent config file parser. More...

#include <parser_context.h>

Public Types

enum  LexerContext {
  NO_KEYWORDS, CONFIG, NETCONF, MANAGED_SERVERS,
  SERVER, CONTROL_SOCKET, SOCKET_TYPE, HOOKS_LIBRARIES,
  LOGGERS, OUTPUT_OPTIONS
}
 Defines syntactic contexts for lexical tie-ins. More...
 
enum  ParserType { PARSER_JSON, PARSER_NETCONF, PARSER_SUB_NETCONF }
 Defines currently supported scopes. More...
 

Public Member Functions

 ParserContext ()
 Default constructor. More...
 
virtual ~ParserContext ()
 destructor More...
 
const std::string contextName ()
 Get the syntactic context name. More...
 
void enter (const LexerContext &ctx)
 Enter a new syntactic context. More...
 
void error (const isc::netconf::location &loc, const std::string &what, size_t pos=0)
 Error handler. More...
 
void error (const std::string &what)
 Error handler. More...
 
void includeFile (const std::string &filename)
 Divert input to an include file. More...
 
void leave ()
 Leave a syntactic context. More...
 
isc::data::Element::Position loc2pos (isc::netconf::location &loc)
 Converts bison's position to one understandable by isc::data::Element. More...
 
isc::data::ElementPtr parseFile (const std::string &filename, ParserType parser_type)
 Run the parser on the file specified. More...
 
isc::data::ElementPtr parseString (const std::string &str, ParserType parser_type)
 Run the parser on the string specified. More...
 
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. More...
 
void scanEnd ()
 Method called after the last tokens are scanned. More...
 
void scanFileBegin (FILE *f, const std::string &filename, ParserType type)
 Method called before scanning starts on a file. More...
 
void scanStringBegin (const std::string &str, ParserType type)
 Method called before scanning starts on a string. More...
 
void unique (const std::string &name, isc::data::Element::Position loc)
 Check if a parameter is already present. More...
 

Static Public Member Functions

static void fatal (const std::string &what)
 Fatal error handler. More...
 

Public Attributes

LexerContext ctx_
 Current syntactic context. More...
 
std::string file_
 File name. More...
 
std::vector< std::string > files_
 File name stack. More...
 
isc::netconf::location loc_
 Location of the current token. More...
 
std::vector< isc::netconf::location > locs_
 Location stack. More...
 
FILE * sfile_
 sFile (aka FILE) More...
 
std::vector< FILE * > sfiles_
 sFile (aka FILE) stack More...
 
std::vector< isc::data::ElementPtrstack_
 JSON elements being parsed. More...
 
std::vector< struct yy_buffer_state * > states_
 Lexer state stack. More...
 

Detailed Description

Parser context is a wrapper around flex/bison instances dedicated to Netconf-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 Netconf-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 37 of file netconf/parser_context.h.

Member Enumeration Documentation

Defines syntactic contexts for lexical tie-ins.

Enumerator
NO_KEYWORDS 

This one is used in pure JSON mode.

Used while parsing top level (that contains Netconf)

CONFIG 

Used while parsing content of Netconf.

NETCONF 
MANAGED_SERVERS 

Used while parsing Netconf/managed-servers.

Used while parsing Netconf/managed-servers/*.

SERVER 

Used while parsing Netconf/manages-servers/*/control-socket.

CONTROL_SOCKET 

Used while parsing Netconf/managed-servers/*/control-socket/socket-type.

SOCKET_TYPE 

Used while parsing Netconf/hooks-libraries.

HOOKS_LIBRARIES 

Used while parsing Netconf/loggers structures.

LOGGERS 

Used while parsing Netconf/loggers/output_options structures.

OUTPUT_OPTIONS 

Definition at line 182 of file netconf/parser_context.h.

Defines currently supported scopes.

NetconfParser is able to parse several types of scope. Usually, when it parses a config file, it expects the data to have a map with Netconf-agent in it and all the parameters within that map. However, sometimes the parser is expected to parse only a subset of that information.

Enumerator
PARSER_JSON 

This parser will parse the content as generic JSON.

PARSER_NETCONF 

This parser will expect the content as Netconf config wrapped in a map (that's the regular config file)

PARSER_SUB_NETCONF 

This parser will expect only the content of Netconf.

Definition at line 48 of file netconf/parser_context.h.

Constructor & Destructor Documentation

isc::netconf::ParserContext::ParserContext ( )

Default constructor.

Definition at line 20 of file netconf/parser_context.cc.

isc::netconf::ParserContext::~ParserContext ( )
virtual

destructor

Definition at line 25 of file netconf/parser_context.cc.

Member Function Documentation

const std::string isc::netconf::ParserContext::contextName ( )

Get the syntactic context name.

Returns
printable name of the context.

Definition at line 155 of file netconf/parser_context.cc.

References CONFIG, CONTROL_SOCKET, ctx_, HOOKS_LIBRARIES, LOGGERS, MANAGED_SERVERS, NETCONF, NO_KEYWORDS, OUTPUT_OPTIONS, SERVER, and SOCKET_TYPE.

Referenced by isc::netconf::NetconfParser::parse(), require(), and unique().

void isc::netconf::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. Netconf 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.

Parameters
ctxthe syntactic context to enter into

Definition at line 138 of file netconf/parser_context.cc.

References ctx_.

Referenced by isc::netconf::NetconfParser::parse().

void isc::netconf::ParserContext::error ( const isc::netconf::location &  loc,
const std::string &  what,
size_t  pos = 0 
)

Error handler.

Note
The optional position for an error in a string begins by 1 so the caller should add 1 to the position of the C++ string.
Parameters
loclocation within the parsed file when experienced a problem.
whatstring explaining the nature of the error.
posoptional position for in string errors.
Exceptions
ParseError

Definition at line 72 of file netconf/parser_context.cc.

References isc_throw.

void isc::netconf::ParserContext::error ( const std::string &  what)

Error handler.

This is a simplified error reporting tool for possible future cases when the NetconfParser is not able to handle the packet.

Parameters
whatstring explaining the nature of the error.
Exceptions
ParseError

Definition at line 84 of file netconf/parser_context.cc.

References isc_throw.

void isc::netconf::ParserContext::fatal ( const std::string &  what)
static

Fatal error handler.

This is for should not happen but fatal errors. Used by YY_FATAL_ERROR macro so required to be static.

Parameters
whatstring explaining the nature of the error.
Exceptions
ParseError

Definition at line 90 of file netconf/parser_context.cc.

References isc_throw.

Referenced by leave().

void ParserContext::includeFile ( const std::string &  filename)

Divert input to an include file.

Parameters
filenamefile to be included

Definition at line 3913 of file netconf_lexer.cc.

References BEGIN, isc::db::fatal, INITIAL, and YY_CURRENT_BUFFER.

void isc::netconf::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.

Exceptions
isc::Unexpectedif unbalanced (more leave() than enter() calls)

Definition at line 145 of file netconf/parser_context.cc.

References ctx_, and fatal().

Referenced by isc::netconf::NetconfParser::parse().

+ Here is the call graph for this function:

isc::data::Element::Position isc::netconf::ParserContext::loc2pos ( isc::netconf::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)

Parameters
loclocation in bison format
Returns
Position in format accepted by Element

Definition at line 96 of file netconf/parser_context.cc.

Referenced by isc::netconf::NetconfParser::parse().

isc::data::ElementPtr isc::netconf::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.

Parameters
filenamefile to be parsed
parser_typespecifies expected content (usually PARSER_NETCONF or PARSER_JSON)
Returns
Element structure representing parsed text.

Definition at line 37 of file netconf/parser_context.cc.

References isc_throw, and scanFileBegin().

Referenced by isc::netconf::NetconfController::parseFile().

+ Here is the call graph for this function:

isc::data::ElementPtr isc::netconf::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.

Parameters
strstring to be parsed
parser_typespecifies expected content (usually NETCONF or generic JSON)
Returns
Element structure representing parsed text.

Definition at line 30 of file netconf/parser_context.cc.

References scanStringBegin().

+ Here is the call graph for this function:

void isc::netconf::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.

Parameters
namename of the parameter to check
open_loclocation of the opening curly bracket
close_loclocation of the closing curly bracket
Exceptions
ParseError

Definition at line 105 of file netconf/parser_context.cc.

References contextName(), isc_throw, and stack_.

+ Here is the call graph for this function:

void ParserContext::scanEnd ( )

Method called after the last tokens are scanned.

Definition at line 3892 of file netconf_lexer.cc.

void ParserContext::scanFileBegin ( FILE *  f,
const std::string &  filename,
ParserType  type 
)

Method called before scanning starts on a file.

Parameters
fstdio FILE pointer
filenamefile to be parsed
typespecifies expected content

Definition at line 3870 of file netconf_lexer.cc.

References isc::db::fatal, and yy_flex_debug.

Referenced by parseFile().

void ParserContext::scanStringBegin ( const std::string &  str,
ParserType  type 
)

Method called before scanning starts on a string.

Parameters
strstring to be parsed
typespecifies expected content

Definition at line 3852 of file netconf_lexer.cc.

References isc::db::fatal, and yy_flex_debug.

Referenced by parseString().

void isc::netconf::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.

Parameters
namename of the parameter to check
loclocation of the current parameter
Exceptions
ParseError

Definition at line 120 of file netconf/parser_context.cc.

References contextName(), ctx_, isc_throw, NO_KEYWORDS, and stack_.

Referenced by isc::netconf::NetconfParser::parse().

+ Here is the call graph for this function:

Member Data Documentation

LexerContext isc::netconf::ParserContext::ctx_

Current syntactic context.

Definition at line 244 of file netconf/parser_context.h.

Referenced by contextName(), enter(), leave(), isc::netconf::NetconfParser::parse(), and unique().

std::string isc::netconf::ParserContext::file_

File name.

Definition at line 216 of file netconf/parser_context.h.

std::vector<std::string> isc::netconf::ParserContext::files_

File name stack.

Definition at line 219 of file netconf/parser_context.h.

isc::netconf::location isc::netconf::ParserContext::loc_

Location of the current token.

The lexer will keep updating it. This variable will be useful for logging errors.

Definition at line 225 of file netconf/parser_context.h.

std::vector<isc::netconf::location> isc::netconf::ParserContext::locs_

Location stack.

Definition at line 228 of file netconf/parser_context.h.

FILE* isc::netconf::ParserContext::sfile_

sFile (aka FILE)

Definition at line 234 of file netconf/parser_context.h.

std::vector<FILE*> isc::netconf::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 241 of file netconf/parser_context.h.

std::vector<isc::data::ElementPtr> isc::netconf::ParserContext::stack_

JSON elements being parsed.

Definition at line 67 of file netconf/parser_context.h.

Referenced by isc::netconf::NetconfParser::parse(), require(), and unique().

std::vector<struct yy_buffer_state*> isc::netconf::ParserContext::states_

Lexer state stack.

Definition at line 231 of file netconf/parser_context.h.


The documentation for this class was generated from the following files: