1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include <idlc/astdeclaration.hxx>
21 #include <idlc/astscope.hxx>
22 #include <rtl/strbuf.hxx>
24 using namespace ::rtl
;
26 static OString
sGlobal("::");
28 static OString
convertName(const OString
& name
)
30 OStringBuffer
nameBuffer(name
.getLength()+1);
34 OString
token( name
.getToken( 0, ':', nIndex
) );
35 if( !token
.isEmpty() )
37 nameBuffer
.append('/');
38 nameBuffer
.append( token
);
40 } while( nIndex
!= -1 );
41 return nameBuffer
.makeStringAndClear();
44 AstDeclaration::AstDeclaration(NodeType type
, const OString
& name
, AstScope
* pScope
)
48 , m_bImported(sal_False
)
49 , m_bIsAdded(sal_False
)
50 , m_bInMainFile(sal_False
)
51 , m_bPredefined(false)
55 AstDeclaration
* pDecl
= scopeAsDecl(m_pScope
);
58 m_scopedName
= pDecl
->getScopedName();
59 if (!m_scopedName
.isEmpty())
60 m_scopedName
+= sGlobal
;
61 m_scopedName
+= m_localName
;
65 m_scopedName
= m_localName
;
67 m_fullName
= convertName(m_scopedName
);
69 if ( idlc()->getFileName() == idlc()->getRealFileName() )
71 m_fileName
= idlc()->getMainFileName();
72 m_bInMainFile
= sal_True
;
75 m_fileName
= idlc()->getFileName();
76 m_bImported
= sal_True
;
79 m_documentation
= idlc()->processDocumentation();
81 m_bPublished
= idlc()->isPublished();
85 AstDeclaration::~AstDeclaration()
90 void AstDeclaration::setPredefined(bool bPredefined
)
92 m_bPredefined
= bPredefined
;
95 m_fileName
= OString();
96 m_bInMainFile
= sal_False
;
100 void AstDeclaration::setName(const ::rtl::OString
& name
)
103 sal_Int32 nIndex
= name
.lastIndexOf( ':' );
104 m_localName
= name
.copy( nIndex
+1 );
106 // Huh ? There is always at least one token
108 // sal_Int32 count = name.getTokenCount(':');
112 // m_localName = name.getToken(count-1, ':');
113 // m_scopedName = name;
114 // } else if ( m_pScope )
116 // m_localName = name;
117 // AstDeclaration* pDecl = scopeAsDecl(m_pScope);
120 // m_scopedName = pDecl->getScopedName();
121 // if (m_scopedName.getLength() > 0)
122 // m_scopedName += sGlobal;
123 // m_scopedName += m_localName;
127 // m_localName = name;
128 // m_scopedName = name;
130 m_fullName
= convertName(m_scopedName
);
133 bool AstDeclaration::isType() const {
134 switch (m_nodeType
) {
136 case NT_instantiated_struct
:
143 case NT_type_parameter
:
147 OSL_ASSERT(m_nodeType
!= NT_struct
); // see AstStruct::isType
152 sal_Bool
AstDeclaration::hasAncestor(AstDeclaration
* pDecl
)
158 return scopeAsDecl(m_pScope
)->hasAncestor(pDecl
);
161 sal_Bool
AstDeclaration::dump(RegistryKey
& rKey
)
163 AstScope
* pScope
= declAsScope(this);
164 sal_Bool bRet
= sal_True
;
168 DeclList::const_iterator iter
= pScope
->getIteratorBegin();
169 DeclList::const_iterator end
= pScope
->getIteratorEnd();
170 AstDeclaration
* pDecl
= NULL
;
171 while ( iter
!= end
&& bRet
)
174 if ( pDecl
->isInMainfile() )
176 switch ( pDecl
->getNodeType() )
188 bRet
= pDecl
->dump(rKey
);
201 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */