00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef BRACKET_EXPRESSIONCHARACTER_CLASS_H
00021 #define BRACKET_EXPRESSIONCHARACTER_CLASS_H
00022
00023 namespace bracket_expression {
00024
00025 template<typename E>
00026 class character_class
00027 {
00028 typedef typename grammar_to_parser::basic_parser<E>::parser_list parser_list;
00029 grammar_to_parser::basic_terminal<E,'['> m_open;
00030 grammar_to_parser::basic_terminal<E,':'> m_open_colon;
00031 grammar_to_parser::basic_choice<E,class_name<E> > m_class_name;
00032 grammar_to_parser::basic_terminal<E,':'> m_close_colon;
00033 grammar_to_parser::basic_terminal<E,']'> m_close;
00034
00035 public:
00036 void push_parsers( parser_list &l )
00037 {
00038 l.push_back(&m_open);
00039 l.push_back(&m_open_colon);
00040 l.push_back(&m_class_name);
00041 l.push_back(&m_close_colon);
00042 l.push_back(&m_close);
00043 }
00044 int compare( const E* buf, const unsigned long buf_length )
00045 {
00046 return m_class_name->compare(buf,buf_length);
00047 }
00048
00049 unsigned long matched_size() { return m_class_name->matched_size(); }
00050
00051 };
00052
00053 };
00054
00055 #endif