1 /************************************************************************* 2 * 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * Copyright 2000, 2010 Oracle and/or its affiliates. 6 * 7 * OpenOffice.org - a multi-platform office productivity suite 8 * 9 * This file is part of OpenOffice.org. 10 * 11 * OpenOffice.org is free software: you can redistribute it and/or modify 12 * it under the terms of the GNU Lesser General Public License version 3 13 * only, as published by the Free Software Foundation. 14 * 15 * OpenOffice.org is distributed in the hope that it will be useful, 16 * but WITHOUT ANY WARRANTY; without even the implied warranty of 17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18 * GNU Lesser General Public License version 3 for more details 19 * (a copy is included in the LICENSE file that accompanied this code). 20 * 21 * You should have received a copy of the GNU Lesser General Public License 22 * version 3 along with OpenOffice.org. If not, see 23 * <http://www.openoffice.org/license.html> 24 * for a copy of the LGPLv3 License. 25 * 26 ************************************************************************/ 27 28 #include <precomp.h> 29 #include <ary/cpp/c_osigna.hxx> 30 31 32 // NOT FULLY DEFINED SERVICES 33 34 35 namespace ary 36 { 37 namespace cpp 38 { 39 40 41 OperationSignature::OperationSignature( std::vector<Type_id> i_parameterTypes, 42 E_ConVol i_conVol ) 43 : aParameterTypes(i_parameterTypes), 44 eConVol(i_conVol) 45 { 46 } 47 48 int 49 OperationSignature::Compare( const OperationSignature & i_rSig ) const 50 { 51 if ( aParameterTypes.size() < i_rSig.aParameterTypes.size() ) 52 return -1; 53 else if ( i_rSig.aParameterTypes.size() < aParameterTypes.size() ) 54 return 1; 55 56 ParameterTypeList::const_iterator iMe = aParameterTypes.begin(); 57 ParameterTypeList::const_iterator iOther = i_rSig.aParameterTypes.begin(); 58 for ( ; iMe != aParameterTypes.end(); ++iMe, ++iOther ) 59 { 60 if ( *iMe < *iOther ) 61 return -1; 62 else if ( *iOther < *iMe ) 63 return 1; 64 } 65 66 if ( eConVol < i_rSig.eConVol ) 67 return -1; 68 else if ( eConVol != i_rSig.eConVol ) 69 return 1; 70 71 return 0; 72 } 73 74 75 } // namespace cpp 76 } // namespace ary 77