Main Page | Class Hierarchy | Class List | Directories | File List | Class Members

start_range_and_end_range.h

00001 /***************************************************************************
00002  *   Copyright (C) 2006 by Radko Mihal                                     *
00003  *   rmihal@pobox.sk                                                       *
00004  *                                                                         *
00005  *   This program is free software; you can redistribute it and/or modify  *
00006  *   it under the terms of the GNU General Public License as published by  *
00007  *   the Free Software Foundation; either version 2 of the License, or     *
00008  *   (at your option) any later version.                                   *
00009  *                                                                         *
00010  *   This program is distributed in the hope that it will be useful,       *
00011  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
00012  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
00013  *   GNU General Public License for more details.                          *
00014  *                                                                         *
00015  *   You should have received a copy of the GNU General Public License     *
00016  *   along with this program; if not, write to the                         *
00017  *   Free Software Foundation, Inc.,                                       *
00018  *   51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.              *
00019  ***************************************************************************/
00020 #ifndef BRACKET_EXPRESSIONSTART_RANGE_AND_END_RANGE_H
00021 #define BRACKET_EXPRESSIONSTART_RANGE_AND_END_RANGE_H
00022 
00023 namespace bracket_expression {
00024 
00025 template<typename E>
00026 class start_range_and_end_range
00027 {
00028         grammar_to_parser::basic_non_terminal<E,start_range<E> >        m_start_range;
00029         grammar_to_parser::basic_choice<E,collating_choice<E> >         m_end_range;
00030         
00031 public:
00032         unsigned long recognize( const E* buf, const unsigned long buf_length )
00033         {
00034                 if( m_start_range->is_lower_or_equals(buf,buf_length) &&
00035                         m_end_range->is_greater_or_equals(buf,buf_length) &&
00036                         m_start_range->recognized_size() == m_end_range->recognized_size() )
00037                 {
00038                         return m_start_range->recognized_size();
00039                 }
00040                 else
00041                 {
00042                         return 0;
00043                 }
00044         }
00045     start_range_and_end_range();
00046 
00047     ~start_range_and_end_range();
00048 
00049 };
00050 
00051 };
00052 
00053 #endif

Generated on Sun Jul 2 18:39:43 2006 for grammar2parser.kdevelop by  doxygen 1.4.1