2014-07-15 17:27:27 -07:00
|
|
|
/* parsers.hh
|
|
|
|
* vim: set tw=80:
|
|
|
|
* Eryn Wells <eryn@erynwells.me>
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* Some top-level YAML parser objects.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __YAML_PARSERS_HH__
|
|
|
|
#define __YAML_PARSERS_HH__
|
|
|
|
|
|
|
|
#include <functional>
|
|
|
|
#include <stack>
|
|
|
|
|
|
|
|
#include "yaml.h"
|
|
|
|
|
|
|
|
#include "scene.h"
|
|
|
|
|
|
|
|
|
|
|
|
namespace yaml {
|
|
|
|
|
|
|
|
struct Parser;
|
|
|
|
typedef std::stack<Parser*> ParserStack;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A Parser handles parsing a chunk of YAML, updating its mScene member as
|
|
|
|
* necessary.
|
|
|
|
*/
|
|
|
|
struct Parser
|
|
|
|
{
|
|
|
|
/** Constructor */
|
|
|
|
Parser(Scene& scene, ParserStack& parsers);
|
|
|
|
|
|
|
|
/** Destructor */
|
|
|
|
virtual ~Parser();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Called by the parser event loop to handle a libyaml parser event.
|
|
|
|
*
|
|
|
|
* @param [in] event A libyaml parser event object
|
|
|
|
*/
|
|
|
|
virtual void HandleEvent(yaml_event_t& event);
|
|
|
|
|
|
|
|
|
|
|
|
/** Set the done flag. */
|
|
|
|
void SetDone(bool done);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns true if the parser is done parsing.
|
|
|
|
*
|
|
|
|
* @returns `true` if done, `false` if not
|
|
|
|
*/
|
|
|
|
bool GetDone() const;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
Scene& GetScene() const;
|
|
|
|
ParserStack& GetParsers() const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
/** The Scene being described by the YAML this parser is parsing. */
|
|
|
|
Scene& mScene;
|
|
|
|
|
|
|
|
/** The stack of parsers. */
|
|
|
|
ParserStack& mParsers;
|
|
|
|
|
|
|
|
/** `true` if the parser is done parsing */
|
|
|
|
bool mDone;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2014-07-15 23:27:24 -07:00
|
|
|
* UtilityParsers handle small reusable bits of YAML. Their constructors take a
|
|
|
|
* C++11 lambda, which will be called back with the result of the parsed data.
|
2014-07-15 17:27:27 -07:00
|
|
|
*/
|
2014-07-15 23:27:24 -07:00
|
|
|
template<typename T>
|
2014-07-15 17:27:27 -07:00
|
|
|
struct UtilityParser
|
|
|
|
: public Parser
|
|
|
|
{
|
2014-07-15 23:27:24 -07:00
|
|
|
typedef std::function<void (T)> CallbackFunction;
|
2014-07-15 17:27:27 -07:00
|
|
|
|
|
|
|
UtilityParser(Scene& scene,
|
|
|
|
ParserStack& parsers,
|
|
|
|
CallbackFunction callback)
|
|
|
|
: Parser(scene, parsers),
|
|
|
|
mCallback(callback)
|
|
|
|
{ }
|
|
|
|
|
|
|
|
virtual
|
|
|
|
~UtilityParser()
|
|
|
|
{ }
|
|
|
|
|
2014-07-15 23:27:24 -07:00
|
|
|
void
|
|
|
|
Notify(T value)
|
|
|
|
{
|
|
|
|
mCallback(value);
|
|
|
|
}
|
|
|
|
|
2014-07-15 17:27:27 -07:00
|
|
|
private:
|
|
|
|
CallbackFunction mCallback;
|
|
|
|
};
|
|
|
|
|
2014-07-15 23:28:59 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines traits for the ParseScalar function. In particular, defines the
|
|
|
|
* format strings for supported scalar types.
|
|
|
|
*/
|
|
|
|
template<typename T>
|
|
|
|
struct ScalarParserTraits
|
|
|
|
{
|
|
|
|
static const char* fmt;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parse a YAML scalar value into a native datatype.
|
|
|
|
*
|
2014-07-17 20:17:17 -07:00
|
|
|
* @param [in] scalarValue The YAML scalar value
|
|
|
|
* @param [out] value The parsed value of the scalar value
|
|
|
|
* @return `true` if the conversion succeeded
|
2014-07-15 23:28:59 -07:00
|
|
|
*/
|
|
|
|
template<typename T>
|
|
|
|
bool
|
|
|
|
ParseScalar(const std::string& scalarValue,
|
|
|
|
T& value)
|
|
|
|
{
|
|
|
|
return sscanf(scalarValue.c_str(), ScalarParserTraits<T>::fmt, &value) == EOF;
|
|
|
|
}
|
|
|
|
|
2014-07-15 17:27:27 -07:00
|
|
|
} /* namespace yaml */
|
|
|
|
|
|
|
|
#endif /* __YAML_PARSERS_HH__ */
|