00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef BRACKET_EXPRESSIONFOLLOW_LIST_H
00021 #define BRACKET_EXPRESSIONFOLLOW_LIST_H
00022
00023 namespace bracket_expression {
00024
00025 template<typename E>
00026 class follow_list
00027 {
00028 typedef typename grammar_to_parser::basic_parser<E>::parser_list
00029 parser_list;
00030 public:
00031 class follow_list_and_expression_term
00032 {
00033 grammar_to_parser::basic_choice<E,follow_list<E> > m_follow_list;
00034 grammar_to_parser::basic_choice<E,expression_term<E> > m_expression_term;
00035
00036 public:
00037 unsigned long recognize( const E* buf, const unsigned long buf_length )
00038 {
00039 unsigned long size = m_follow_list->recognize(buf,buf_length);
00040 if( size == 0 )
00041 {
00042 size = m_expression_term->recognize(buf,buf_length);
00043 }
00044 return size;
00045 }
00046
00047 follow_list_and_expression_term() {};
00048 ~follow_list_and_expression_term() {};
00049 void push_parsers( parser_list &l )
00050 {
00051 l.push_back( &m_expression_term );
00052 l.push_back( &m_follow_list );
00053 }
00054
00055 };
00056
00057 grammar_to_parser::basic_choice<E,expression_term<E> >
00058 m_expression_term;
00059 grammar_to_parser::basic_non_terminal<E,follow_list_and_expression_term >
00060 m_follow_and_expression;
00061
00062 public:
00063 unsigned long recognize( const E* buf, const unsigned long buf_length )
00064 {
00065 if( m_expression_term.is_parsed() )
00066 {
00067 return m_expression_term->recognize(buf,buf_length);
00068 }
00069 else
00070 {
00071 return m_follow_and_expression->recognize(buf,buf_length);
00072 }
00073 }
00074
00075 public:
00076 follow_list() : m_follow_and_expression() {};
00077
00078 ~follow_list() {};
00079
00080 void push_parsers( parser_list &l )
00081 {
00082 l.push_back( &m_follow_and_expression );
00083 l.push_back( &m_expression_term );
00084 }
00085 };
00086
00087 };
00088
00089 #endif