Main Page   Namespace List   Class Hierarchy   Compound List   File List   Namespace Members   Compound Members  

sort_algorithm.hh

00001 /*
00002 *  Name:      sort_algorithm.hh
00003 *  Author:    Rafael Jesus Alcantara Perez
00004 *  Summary:   Base sort algorithm
00005 *  Date:      $Date: 2003/04/14 00:18:35 $
00006 *  Revision:  $Revision: 1.1 $
00007 *
00008 *  Copyright (C) 1994-2002  Rafael Jesus Alcantara Perez <rafa@dedalo-ing.com>
00009 *
00010 *  This program is free software; you can redistribute it and/or modify
00011 *  it under the terms of the GNU General Public License as published by
00012 *  the Free Software Foundation; either version 2 of the License, or
00013 *  (at your option) any later version.
00014 *
00015 *  This program is distributed in the hope that it will be useful,
00016 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
00017 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00018 *  GNU General Public License for more details.
00019 *
00020 *  You should have received a copy of the GNU General Public License
00021 *  along with this program; if not, write to the Free Software
00022 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston,
00023 *  MA 02111-1307, USA.
00024 */
00025 
00026 #ifndef _MPCL_UTIL_STRATEGY_SORT_ALGORITHM__
00027 #define _MPCL_UTIL_STRATEGY_SORT_ALGORITHM__
00028 
00029 
00031 namespace mpcl
00032 {
00033 
00035   namespace util
00036   {
00037 
00039     namespace strategy
00040     {
00041 
00056       template <typename TSequence>
00057       class ISortAlgorithm
00058       {
00059 
00060         public:
00061 
00063           typedef
00064             typename TSequence::const_iterator
00065             const_iterator;
00066 
00068           typedef
00069             typename TSequence::iterator
00070             iterator;
00071 
00073           typedef
00074             typename TSequence::value_type
00075             value_type;
00076 
00077 
00078         public:
00079 
00080           //
00081           //  C O N S T R U C T O R S
00082           //
00083 
00089           virtual void execute (TSequence& rtSOURCE_SEQUENCE) = 0;
00090 
00091 
00092         protected:
00093 
00094           //
00095           //  S E L E C T O R S
00096           //
00097 
00103           void swap (value_type& rtFIRST_ITEM, value_type& rtSECOND_ITEM)
00104           {
00105             value_type   tTempItem (rtFIRST_ITEM);
00106 
00107             rtFIRST_ITEM  = rtSECOND_ITEM;
00108             rtSECOND_ITEM = tTempItem;
00109           }
00110 
00111       };  // class ISortAlgorithm
00112 
00113     }  // namespace strategy
00114 
00115   }  // namespace util
00116 
00117 }  // namespace mpcl
00118 
00119 
00120 #endif  // not _MPCL_UTIL_STRATEGY_SORT_ALGORITHM__

Generated on Mon Oct 13 02:35:24 2003 for MPCL by doxygen1.2.18