Kea 1.5.0
agent/parser_context.cc
Go to the documentation of this file.
1// Copyright (C) 2017-2018 Internet Systems Consortium, Inc. ("ISC")
2//
3// This Source Code Form is subject to the terms of the Mozilla Public
4// License, v. 2.0. If a copy of the MPL was not distributed with this
5// file, You can obtain one at http://mozilla.org/MPL/2.0/.
6
7#include <config.h>
8
10#include <agent/agent_parser.h>
13#include <cc/data.h>
14#include <fstream>
15#include <limits>
16
17namespace isc {
18namespace agent {
19
21 : sfile_(0), ctx_(NO_KEYWORDS), trace_scanning_(false), trace_parsing_(false)
22{
23}
24
26{
27}
28
30ParserContext::parseString(const std::string& str, ParserType parser_type)
31{
32 scanStringBegin(str, parser_type);
33 return (parseCommon());
34}
35
37ParserContext::parseFile(const std::string& filename, ParserType parser_type) {
38 FILE* f = fopen(filename.c_str(), "r");
39 if (!f) {
40 isc_throw(ParseError, "Unable to open file " << filename);
41 }
42 scanFileBegin(f, filename, parser_type);
43 return (parseCommon());
44}
45
47ParserContext::parseCommon() {
48 isc::agent::AgentParser parser(*this);
49 // Uncomment this to get detailed parser logs.
50 // trace_parsing_ = true;
51 parser.set_debug_level(trace_parsing_);
52 try {
53 int res = parser.parse();
54 if (res != 0) {
55 isc_throw(ParseError, "Parser abort");
56 }
57 scanEnd();
58 }
59 catch (...) {
60 scanEnd();
61 throw;
62 }
63 if (stack_.size() == 1) {
64 return (stack_[0]);
65 } else {
66 isc_throw(ParseError, "Expected exactly one terminal Element expected, found "
67 << stack_.size());
68 }
69}
70
71
72void
73ParserContext::error(const isc::agent::location& loc, const std::string& what)
74{
75 isc_throw(ParseError, loc << ": " << what);
76}
77
78void
79ParserContext::error(const std::string& what)
80{
81 isc_throw(ParseError, what);
82}
83
84void
85ParserContext::fatal(const std::string& what)
86{
87 isc_throw(ParseError, what);
88}
89
91ParserContext::loc2pos(isc::agent::location& loc)
92{
93 const std::string& file = *loc.begin.filename;
94 const uint32_t line = loc.begin.line;
95 const uint32_t pos = loc.begin.column;
96 return (isc::data::Element::Position(file, line, pos));
97}
98
99void
101{
102 cstack_.push_back(ctx_);
103 ctx_ = ctx;
104}
105
106void
108{
109 if (cstack_.empty()) {
110 fatal("unbalanced syntactic context");
111 }
112 ctx_ = cstack_.back();
113 cstack_.pop_back();
114}
115
116const std::string
118{
119 switch (ctx_) {
120 case NO_KEYWORDS:
121 return ("__no keywords__");
122 case CONFIG:
123 return ("toplevel");
124 case AGENT:
125 return ("Control-agent");
126 case LOGGING:
127 return ("Logging");
128 case CONTROL_SOCKETS:
129 return ("control-sockets");
130 case SERVER:
131 return ("xxx-server");
132 case SOCKET_TYPE:
133 return ("socket-type");
134 case HOOKS_LIBRARIES:
135 return ("hooks-libraries");
136 case LOGGERS:
137 return ("loggers");
138 case OUTPUT_OPTIONS:
139 return ("output-options");
140 default:
141 return ("__unknown__");
142 }
143}
144
145};
146};
Define the isc::agent::parser class.
Evaluation error exception raised when trying to parse.
void error(const isc::agent::location &loc, const std::string &what)
Error handler.
void scanStringBegin(const std::string &str, ParserType type)
Method called before scanning starts on a string.
ParserContext()
Default constructor.
void scanFileBegin(FILE *f, const std::string &filename, ParserType type)
Method called before scanning starts on a file.
std::vector< isc::data::ElementPtr > stack_
JSON elements being parsed.
static void fatal(const std::string &what)
Fatal error handler.
virtual ~ParserContext()
destructor
const std::string contextName()
Get the syntactic context name.
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.
LexerContext ctx_
Current syntactic context.
isc::data::ElementPtr parseString(const std::string &str, ParserType parser_type)
Run the parser on the string specified.
void leave()
Leave a syntactic context.
LexerContext
Defines syntactic contexts for lexical tie-ins.
@ CONFIG
Used while parsing content of Agent.
@ SERVER
Used while parsing Control-agent/control-socket/*-server/socket-type.
@ NO_KEYWORDS
This one is used in pure JSON mode.
@ HOOKS_LIBRARIES
Used while parsing Logging/loggers structures.
@ CONTROL_SOCKETS
Used while parsing Control-agent/control-socket/*-server.
@ SOCKET_TYPE
Used while parsing Control-agent/hooks-libraries.
@ AGENT
Used while parsing content of Logging.
@ LOGGING
Used while parsing Control-agent/control-sockets.
@ LOGGERS
Used while parsing Logging/loggers/output_options structures.
ParserType
Defines currently supported scopes.
void enter(const LexerContext &ctx)
Enter a new syntactic context.
void scanEnd()
Method called after the last tokens are scanned.
#define isc_throw(type, stream)
A shortcut macro to insert known values into exception arguments.
boost::shared_ptr< Element > ElementPtr
Definition: data.h:22
Defines the logger used by the top-level component of kea-dhcp-ddns.
Represents the position of the data element within a configuration string.
Definition: data.h:88