Source: ../../libxipc/xrl-parser.hh
|
|
|
|
// -*- c-basic-offset: 4; tab-width: 8; indent-tabs-mode: t -*-
// Copyright (c) 2001,2002 International Computer Science Institute
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software")
// to deal in the Software without restriction, subject to the conditions
// listed in the XORP LICENSE file. These conditions include: you must
// preserve this copyright notice, and you cannot mention the copyright
// holders in advertising related to the Software without their permission.
// The Software is provided WITHOUT ANY WARRANTY, EXPRESS OR IMPLIED. This
// notice is a summary of the XORP LICENSE file; the license in that file is
// legally binding.
// $XORP: xorp/libxipc/xrl-parser.hh,v 1.1.1.1 2002/12/11 23:56:04 hodson Exp $
#ifndef __LIBXIPC_XRL_PARSER_HH__
#define __LIBXIPC_XRL_PARSER_HH__
#include <stdarg.h>
#include <list>
#include "xrl.hh"
#include "xrl-parser-input.hh"
class XrlParseError {
public:
XrlParseError(const string& input, ssize_t offset, const string& reason)
: _input(input), _offset(offset), _reason(reason) {}
XrlParseError(const string& input, string::const_iterator pos,
const string& reason)
: _input(input), _offset(pos - input.begin()), _reason(reason) {}
XrlParseError() : _input(""), _offset(0xffffffff), _reason("") {}
virtual ~XrlParseError() {}
const string& input() const { return _input; }
const ssize_t offset() const { return _offset; }
const string& reason() const { return _reason; }
string pretty_print(size_t termwidth = 80u) const;
protected:
const string _input;
size_t _offset;
string _reason;
void get_coordinates(size_t& lineno, size_t& charno) const;
};
// XrlLocator - locates sub-strings that look like spaceless and
// presentation Xrl's. It does weak examination of syntax and leaves
// finer grained examination to the Xrl instantiation routines.
class XrlParser {
public:
XrlParser(XrlParserInput& xpi) : _xpi(xpi) {}
virtual ~XrlParser() {}
/** Starts new parsing cycle.
* @return true upon success, false if there is no more data
*/
bool start_next() throw (XrlParserInputException);
/** Check if input is exhausted.
* @return true if input is exhausted, false otherwise.
*/
bool finished() const { return _xpi.eof(); }
bool get(string& protocol,
string& target,
string& command,
XrlArgs& args)
throw (XrlParseError);
bool get(string& protocol,
string& target,
string& command,
XrlArgs& args,
list<XrlAtomSpell>& spells)
throw (XrlParseError);
bool get(string& xrl_c_str) throw (XrlParseError);
bool get_return_specs(list<XrlAtomSpell>& spells);
const string& input() const { return _input; }
/**
* Attempt to find a new XRL starting point after an error has
* occurred.
*
* @return true if text resembling an XRL start is found.
*/
bool resync();
const XrlParserInput& parser_input() const;
protected:
bool get(string& protocol,
string& target,
string& command,
XrlArgs* args,
list<XrlAtomSpell>* spells)
throw (XrlParseError);
bool parse_atoms_and_spells(XrlArgs* args,
list<XrlAtomSpell>* spells);
XrlParserInput& _xpi;
string _input;
string::const_iterator _pos;
};
#endif // __LIBXIPC_XRL_PARSER_HH__
Generated by: pavlin on possum.icir.org on Wed Dec 11 16:50:42 2002, using kdoc 2.0a54+XORP. |