91 lines
2.2 KiB
C
91 lines
2.2 KiB
C
|
#ifndef PARSER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||
|
#define PARSER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||
|
|
||
|
#if defined(_MSC_VER) || \
|
||
|
(defined(__GNUC__) && (__GNUC__ == 3 && __GNUC_MINOR__ >= 4) || \
|
||
|
(__GNUC__ >= 4)) // GCC supports "pragma once" correctly since 3.4
|
||
|
#pragma once
|
||
|
#endif
|
||
|
|
||
|
#include <ios>
|
||
|
#include <memory>
|
||
|
|
||
|
#include "yaml-cpp/dll.h"
|
||
|
|
||
|
namespace YAML {
|
||
|
class EventHandler;
|
||
|
class Node;
|
||
|
class Scanner;
|
||
|
struct Directives;
|
||
|
struct Token;
|
||
|
|
||
|
/**
|
||
|
* A parser turns a stream of bytes into one stream of "events" per YAML
|
||
|
* document in the input stream.
|
||
|
*/
|
||
|
class YAML_CPP_API Parser {
|
||
|
public:
|
||
|
/** Constructs an empty parser (with no input. */
|
||
|
Parser();
|
||
|
|
||
|
Parser(const Parser&) = delete;
|
||
|
Parser(Parser&&) = delete;
|
||
|
Parser& operator=(const Parser&) = delete;
|
||
|
Parser& operator=(Parser&&) = delete;
|
||
|
|
||
|
/**
|
||
|
* Constructs a parser from the given input stream. The input stream must
|
||
|
* live as long as the parser.
|
||
|
*/
|
||
|
explicit Parser(std::istream& in);
|
||
|
|
||
|
~Parser();
|
||
|
|
||
|
/** Evaluates to true if the parser has some valid input to be read. */
|
||
|
explicit operator bool() const;
|
||
|
|
||
|
/**
|
||
|
* Resets the parser with the given input stream. Any existing state is
|
||
|
* erased.
|
||
|
*/
|
||
|
void Load(std::istream& in);
|
||
|
|
||
|
/**
|
||
|
* Handles the next document by calling events on the {@code eventHandler}.
|
||
|
*
|
||
|
* @throw a ParserException on error.
|
||
|
* @return false if there are no more documents
|
||
|
*/
|
||
|
bool HandleNextDocument(EventHandler& eventHandler);
|
||
|
|
||
|
void PrintTokens(std::ostream& out);
|
||
|
|
||
|
private:
|
||
|
/**
|
||
|
* Reads any directives that are next in the queue, setting the internal
|
||
|
* {@code m_pDirectives} state.
|
||
|
*/
|
||
|
void ParseDirectives();
|
||
|
|
||
|
void HandleDirective(const Token& token);
|
||
|
|
||
|
/**
|
||
|
* Handles a "YAML" directive, which should be of the form 'major.minor' (like
|
||
|
* a version number).
|
||
|
*/
|
||
|
void HandleYamlDirective(const Token& token);
|
||
|
|
||
|
/**
|
||
|
* Handles a "TAG" directive, which should be of the form 'handle prefix',
|
||
|
* where 'handle' is converted to 'prefix' in the file.
|
||
|
*/
|
||
|
void HandleTagDirective(const Token& token);
|
||
|
|
||
|
private:
|
||
|
std::unique_ptr<Scanner> m_pScanner;
|
||
|
std::unique_ptr<Directives> m_pDirectives;
|
||
|
};
|
||
|
} // namespace YAML
|
||
|
|
||
|
#endif // PARSER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|