00001 /* 00002 * $Id: ClearSilverNodeComparatorName.cc,v 1.3 2006/03/27 19:17:43 brook Exp $ 00003 */ 00004 00005 /* 00006 * ClearSilver++ Software License. 00007 * 00008 * Copyright (c) 2005,2006 Brook Milligan <brook@nmsu.edu> 00009 * All rights reserved. 00010 * 00011 * Redistribution and use in source and binary forms, with or without 00012 * modification, are permitted provided that the following conditions 00013 * are met: 00014 * 00015 * 1. Redistributions of source code must retain the above copyright 00016 * notice, this list of conditions and the following disclaimer. 00017 * 2. Redistributions in binary form must reproduce the above 00018 * copyright notice, this list of conditions and the following 00019 * disclaimer in the documentation and/or other materials provided 00020 * with the distribution. 00021 * 3. The name of the author may not be used to endorse or promote 00022 * products derived from this software without specific prior 00023 * written permission. 00024 * 00025 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS 00026 * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 00027 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00028 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY 00029 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 00030 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE 00031 * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00032 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 00033 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00034 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00035 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00036 */ 00037 00038 #include "ClearSilverNodeComparatorName.h" 00039 #include "ConstHDF.h" 00040 00041 namespace ClearSilver 00042 { 00043 // constructors 00044 ClearSilverNodeComparatorName::ClearSilverNodeComparatorName () 00045 : ClearSilverNodeComparator() {} 00046 00047 ClearSilverNodeComparatorName::ClearSilverNodeComparatorName 00048 (const ClearSilverNodeComparatorName&) 00049 : ClearSilverNodeComparator() {} 00050 00051 ClearSilverNodeComparatorName::~ClearSilverNodeComparatorName () throw() {} 00052 00053 // assignment 00054 ClearSilverNodeComparatorName& 00055 ClearSilverNodeComparatorName::operator = 00056 (const ClearSilverNodeComparatorName& c) 00057 { 00058 ClearSilverNodeComparatorName c_(c); 00059 swap(c_); 00060 return *this; 00061 } 00062 00063 void 00064 ClearSilverNodeComparatorName::swap (ClearSilverNodeComparatorName& c) throw() 00065 { 00066 ClearSilverNodeComparator::swap (c); 00067 } 00068 00069 // compare two nodes 00070 int 00071 ClearSilverNodeComparatorName::operator () (const ConstHDF& n1, 00072 const ConstHDF& n2) const 00073 { 00074 if (n1.node().name() < n2.node().name()) 00075 return -1; 00076 if (n1.node().name() > n2.node().name()) 00077 return +1; 00078 return 0; 00079 } 00080 00081 }; // namespace ClearSilver 00082
1.4.5