Algorithms Library Toolkit
A toolkit for algorithms, especially for algorithms on formal languages
RankedTree.h
Go to the documentation of this file.
1
6#pragma once
7
9#include <core/stringApi.hpp>
10
12
15
16namespace core {
17
18template<class SymbolType >
19struct stringApi < tree::RankedTree < SymbolType > > {
20 static tree::RankedTree < SymbolType > parse ( ext::istream & input );
21 static bool first ( ext::istream & input );
22 static void compose ( ext::ostream & output, const tree::RankedTree < SymbolType > & tree );
23};
24
25template<class SymbolType >
27 tree::TreeFromStringLexer::Token token = tree::TreeFromStringLexer::next ( input );
29 throw exception::CommonException ( "Unrecognised RANKED_TREE token." );
30
33 bool isPattern = false;
34
35 ext::tree < common::ranked_symbol < SymbolType > > content = tree::TreeFromStringParserCommon::parseRankedContent < SymbolType > ( input, isPattern, nonlinearVariables, nodeWildcards );
36
37 if ( isPattern )
38 throw exception::CommonException ( "Unexpected subtree wildcard recognised" );
39 if ( ! nonlinearVariables.empty ( ) )
40 throw exception::CommonException ( "Unexpected variables recognised" );
41 if ( ! nodeWildcards.empty ( ) )
42 throw exception::CommonException ( "Unexpected node wildcards recognised" );
43
44 return tree::RankedTree < SymbolType > ( content );
45}
46
47template<class SymbolType >
49 tree::TreeFromStringLexer::Token token = tree::TreeFromStringLexer::next ( input );
52 return res;
53}
54
55template<class SymbolType >
57 output << "RANKED_TREE ";
58 tree::TreeToStringComposerCommon::compose ( output, tree.getContent ( ) );
59}
60
61} /* namespace core */
62
Basic exception from which all other exceptions are derived.
Definition: CommonException.h:21
static void putback(ext::istream &input, const Token &token)
Definition: lexer.hpp:61
Definition: istream.h:32
Definition: ostream.h:14
Definition: set.hpp:44
Class introducing a tree with interface trying to be close to the interface of standard library conta...
Definition: tree.hpp:52
Tree structure represented in its natural representation. The representation is so called ranked,...
Definition: RankedTree.h:72
static Token next(ext::istream &input)
Definition: TreeFromStringLexer.cpp:10
static void compose(ext::ostream &, const ext::tree< common::ranked_symbol< SymbolType > > &node)
Definition: TreeToStringComposerCommon.h:28
return res
Definition: MinimizeByPartitioning.h:145
Definition: normalize.hpp:10
Definition: BackwardOccurrenceTest.h:17
Definition: stringApi.hpp:26