xref: /aoo41x/main/idlc/source/astservice.cxx (revision cdf0e10c)
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 // MARKER(update_precomp.py): autogen include statement, do not remove
29 #include "precompiled_idlc.hxx"
30 
31 #include "sal/config.h"
32 
33 #include "idlc/astmember.hxx"
34 #include "idlc/astoperation.hxx"
35 #include "idlc/astservice.hxx"
36 #include "idlc/asttype.hxx"
37 
38 bool AstService::checkLastConstructor() const {
39     AstOperation const * last = static_cast< AstOperation const * >(getLast());
40     for (DeclList::const_iterator i(getIteratorBegin()); i != getIteratorEnd();
41          ++i)
42     {
43         if (*i != last && (*i)->getNodeType() == NT_operation) {
44             AstOperation const * ctor = static_cast< AstOperation * >(*i);
45             if (ctor->isVariadic() && last->isVariadic()) {
46                 return true;
47             }
48             sal_uInt32 n = ctor->nMembers();
49             if (n == last->nMembers()) {
50                 for (DeclList::const_iterator i1(ctor->getIteratorBegin()),
51                          i2(last->getIteratorBegin());
52                      i1 != ctor->getIteratorEnd(); ++i1, ++i2)
53                 {
54                     sal_Int32 r1;
55                     AstDeclaration const * t1 = deconstructAndResolveTypedefs(
56                         static_cast< AstMember * >(*i1)->getType(), &r1);
57                     sal_Int32 r2;
58                     AstDeclaration const * t2 = deconstructAndResolveTypedefs(
59                         static_cast< AstMember * >(*i2)->getType(), &r2);
60                     if (r1 != r2 || t1->getScopedName() != t2->getScopedName())
61                     {
62                         return false;
63                     }
64                 }
65                 return true;
66             }
67         }
68     }
69     return false;
70 }
71