xref: /AOO41X/main/idlc/source/astdeclaration.cxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
29*cdf0e10cSrcweir #include "precompiled_idlc.hxx"
30*cdf0e10cSrcweir #include <idlc/astdeclaration.hxx>
31*cdf0e10cSrcweir #include <idlc/astscope.hxx>
32*cdf0e10cSrcweir #include <rtl/strbuf.hxx>
33*cdf0e10cSrcweir 
34*cdf0e10cSrcweir using namespace ::rtl;
35*cdf0e10cSrcweir 
36*cdf0e10cSrcweir static OString sGlobal("::");
37*cdf0e10cSrcweir 
38*cdf0e10cSrcweir static OString convertName(const OString& name)
39*cdf0e10cSrcweir {
40*cdf0e10cSrcweir 	OStringBuffer nameBuffer(name.getLength()+1);
41*cdf0e10cSrcweir     sal_Int32 nIndex = 0;
42*cdf0e10cSrcweir     do
43*cdf0e10cSrcweir     {
44*cdf0e10cSrcweir         OString token( name.getToken( 0, ':', nIndex ) );
45*cdf0e10cSrcweir         if( token.getLength() )
46*cdf0e10cSrcweir         {
47*cdf0e10cSrcweir 			nameBuffer.append('/');
48*cdf0e10cSrcweir             nameBuffer.append( token );
49*cdf0e10cSrcweir         }
50*cdf0e10cSrcweir     } while( nIndex != -1 );
51*cdf0e10cSrcweir 	return nameBuffer.makeStringAndClear();
52*cdf0e10cSrcweir }
53*cdf0e10cSrcweir 
54*cdf0e10cSrcweir AstDeclaration::AstDeclaration(NodeType type, const OString& name, AstScope* pScope)
55*cdf0e10cSrcweir 	: m_localName(name)
56*cdf0e10cSrcweir 	, m_pScope(pScope)
57*cdf0e10cSrcweir 	, m_nodeType(type)
58*cdf0e10cSrcweir 	, m_bImported(sal_False)
59*cdf0e10cSrcweir 	, m_bIsAdded(sal_False)
60*cdf0e10cSrcweir 	, m_bInMainFile(sal_False)
61*cdf0e10cSrcweir     , m_bPredefined(false)
62*cdf0e10cSrcweir {
63*cdf0e10cSrcweir 	if ( m_pScope )
64*cdf0e10cSrcweir 	{
65*cdf0e10cSrcweir 		AstDeclaration* pDecl = scopeAsDecl(m_pScope);
66*cdf0e10cSrcweir 		if (pDecl)
67*cdf0e10cSrcweir 		{
68*cdf0e10cSrcweir 			m_scopedName = pDecl->getScopedName();
69*cdf0e10cSrcweir 			if (m_scopedName.getLength() > 0)
70*cdf0e10cSrcweir 				m_scopedName += sGlobal;
71*cdf0e10cSrcweir 			m_scopedName +=	m_localName;
72*cdf0e10cSrcweir 		}
73*cdf0e10cSrcweir 	} else
74*cdf0e10cSrcweir 	{
75*cdf0e10cSrcweir 		m_scopedName = m_localName;
76*cdf0e10cSrcweir 	}
77*cdf0e10cSrcweir 	m_fullName = convertName(m_scopedName);
78*cdf0e10cSrcweir 
79*cdf0e10cSrcweir 	if ( idlc()->getFileName() == idlc()->getRealFileName() )
80*cdf0e10cSrcweir 	{
81*cdf0e10cSrcweir 		m_fileName = idlc()->getMainFileName();
82*cdf0e10cSrcweir 		m_bInMainFile = sal_True;
83*cdf0e10cSrcweir 	} else
84*cdf0e10cSrcweir 	{
85*cdf0e10cSrcweir 		m_fileName = idlc()->getFileName();
86*cdf0e10cSrcweir 		m_bImported = sal_True;
87*cdf0e10cSrcweir 	}
88*cdf0e10cSrcweir 
89*cdf0e10cSrcweir 	if ( idlc()->isDocValid() )
90*cdf0e10cSrcweir 		m_documentation = OStringToOUString(idlc()->getDocumentation(), RTL_TEXTENCODING_UTF8);
91*cdf0e10cSrcweir 
92*cdf0e10cSrcweir     m_bPublished = idlc()->isPublished();
93*cdf0e10cSrcweir }
94*cdf0e10cSrcweir 
95*cdf0e10cSrcweir 
96*cdf0e10cSrcweir AstDeclaration::~AstDeclaration()
97*cdf0e10cSrcweir {
98*cdf0e10cSrcweir 
99*cdf0e10cSrcweir }
100*cdf0e10cSrcweir 
101*cdf0e10cSrcweir void AstDeclaration::setPredefined(bool bPredefined)
102*cdf0e10cSrcweir {
103*cdf0e10cSrcweir     m_bPredefined = bPredefined;
104*cdf0e10cSrcweir     if ( m_bPredefined )
105*cdf0e10cSrcweir     {
106*cdf0e10cSrcweir         m_fileName = OString();
107*cdf0e10cSrcweir         m_bInMainFile = sal_False;
108*cdf0e10cSrcweir     }
109*cdf0e10cSrcweir }
110*cdf0e10cSrcweir 
111*cdf0e10cSrcweir void AstDeclaration::setName(const ::rtl::OString& name)
112*cdf0e10cSrcweir {
113*cdf0e10cSrcweir     m_scopedName = name;
114*cdf0e10cSrcweir     sal_Int32 nIndex = name.lastIndexOf( ':' );
115*cdf0e10cSrcweir     m_localName = name.copy( nIndex+1 );
116*cdf0e10cSrcweir 
117*cdf0e10cSrcweir // Huh ? There is always at least one token
118*cdf0e10cSrcweir 
119*cdf0e10cSrcweir // 	sal_Int32 count = name.getTokenCount(':');
120*cdf0e10cSrcweir 
121*cdf0e10cSrcweir // 	if ( count > 0 )
122*cdf0e10cSrcweir // 	{
123*cdf0e10cSrcweir // 		m_localName = name.getToken(count-1, ':');
124*cdf0e10cSrcweir // 		m_scopedName = name;
125*cdf0e10cSrcweir // 	} else if ( m_pScope )
126*cdf0e10cSrcweir // 	{
127*cdf0e10cSrcweir // 		m_localName = name;
128*cdf0e10cSrcweir // 		AstDeclaration* pDecl = scopeAsDecl(m_pScope);
129*cdf0e10cSrcweir // 		if (pDecl)
130*cdf0e10cSrcweir // 		{
131*cdf0e10cSrcweir // 			m_scopedName = pDecl->getScopedName();
132*cdf0e10cSrcweir // 			if (m_scopedName.getLength() > 0)
133*cdf0e10cSrcweir // 				m_scopedName += sGlobal;
134*cdf0e10cSrcweir // 			m_scopedName +=	m_localName;
135*cdf0e10cSrcweir // 		}
136*cdf0e10cSrcweir // 	} else
137*cdf0e10cSrcweir // 	{
138*cdf0e10cSrcweir // 		m_localName = name;
139*cdf0e10cSrcweir // 		m_scopedName = name;
140*cdf0e10cSrcweir // 	}
141*cdf0e10cSrcweir 	m_fullName = convertName(m_scopedName);
142*cdf0e10cSrcweir }
143*cdf0e10cSrcweir 
144*cdf0e10cSrcweir bool AstDeclaration::isType() const {
145*cdf0e10cSrcweir     switch (m_nodeType) {
146*cdf0e10cSrcweir     case NT_interface:
147*cdf0e10cSrcweir     case NT_instantiated_struct:
148*cdf0e10cSrcweir     case NT_union:
149*cdf0e10cSrcweir     case NT_enum:
150*cdf0e10cSrcweir     case NT_sequence:
151*cdf0e10cSrcweir     case NT_array:
152*cdf0e10cSrcweir     case NT_typedef:
153*cdf0e10cSrcweir     case NT_predefined:
154*cdf0e10cSrcweir     case NT_type_parameter:
155*cdf0e10cSrcweir         return true;
156*cdf0e10cSrcweir 
157*cdf0e10cSrcweir     default:
158*cdf0e10cSrcweir         OSL_ASSERT(m_nodeType != NT_struct); // see AstStruct::isType
159*cdf0e10cSrcweir         return false;
160*cdf0e10cSrcweir     }
161*cdf0e10cSrcweir }
162*cdf0e10cSrcweir 
163*cdf0e10cSrcweir sal_Bool AstDeclaration::hasAncestor(AstDeclaration* pDecl)
164*cdf0e10cSrcweir {
165*cdf0e10cSrcweir 	if (this == pDecl)
166*cdf0e10cSrcweir 		return sal_True;
167*cdf0e10cSrcweir 	if ( !m_pScope )
168*cdf0e10cSrcweir 		return sal_False;
169*cdf0e10cSrcweir 	return scopeAsDecl(m_pScope)->hasAncestor(pDecl);
170*cdf0e10cSrcweir }
171*cdf0e10cSrcweir 
172*cdf0e10cSrcweir sal_Bool AstDeclaration::dump(RegistryKey& rKey)
173*cdf0e10cSrcweir {
174*cdf0e10cSrcweir 	AstScope* pScope = declAsScope(this);
175*cdf0e10cSrcweir 	sal_Bool bRet = sal_True;
176*cdf0e10cSrcweir 
177*cdf0e10cSrcweir 	if ( pScope )
178*cdf0e10cSrcweir 	{
179*cdf0e10cSrcweir         DeclList::const_iterator iter = pScope->getIteratorBegin();
180*cdf0e10cSrcweir 		DeclList::const_iterator end = pScope->getIteratorEnd();
181*cdf0e10cSrcweir 		AstDeclaration* pDecl = NULL;
182*cdf0e10cSrcweir 		while ( iter != end && bRet)
183*cdf0e10cSrcweir 		{
184*cdf0e10cSrcweir 			pDecl = *iter;
185*cdf0e10cSrcweir 			if ( pDecl->isInMainfile() )
186*cdf0e10cSrcweir 			{
187*cdf0e10cSrcweir 				switch ( pDecl->getNodeType() )
188*cdf0e10cSrcweir 				{
189*cdf0e10cSrcweir 					case NT_module:
190*cdf0e10cSrcweir 					case NT_constants:
191*cdf0e10cSrcweir 					case NT_interface:
192*cdf0e10cSrcweir 					case NT_struct:
193*cdf0e10cSrcweir 					case NT_exception:
194*cdf0e10cSrcweir 					case NT_enum:
195*cdf0e10cSrcweir 					case NT_union:
196*cdf0e10cSrcweir 					case NT_typedef:
197*cdf0e10cSrcweir 					case NT_service:
198*cdf0e10cSrcweir 					case NT_singleton:
199*cdf0e10cSrcweir 						bRet = pDecl->dump(rKey);
200*cdf0e10cSrcweir                         break;
201*cdf0e10cSrcweir                     default:
202*cdf0e10cSrcweir                         break;
203*cdf0e10cSrcweir 				}
204*cdf0e10cSrcweir 			}
205*cdf0e10cSrcweir 
206*cdf0e10cSrcweir 			++iter;
207*cdf0e10cSrcweir 		}
208*cdf0e10cSrcweir 	}
209*cdf0e10cSrcweir 	return bRet;
210*cdf0e10cSrcweir }
211*cdf0e10cSrcweir 
212