xref: /aoo42x/main/idlc/source/aststruct.cxx (revision 2fe1ca3d)
1*2fe1ca3dSAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*2fe1ca3dSAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*2fe1ca3dSAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*2fe1ca3dSAndrew Rist  * distributed with this work for additional information
6*2fe1ca3dSAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*2fe1ca3dSAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*2fe1ca3dSAndrew Rist  * "License"); you may not use this file except in compliance
9*2fe1ca3dSAndrew Rist  * with the License.  You may obtain a copy of the License at
10*2fe1ca3dSAndrew Rist  *
11*2fe1ca3dSAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12*2fe1ca3dSAndrew Rist  *
13*2fe1ca3dSAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*2fe1ca3dSAndrew Rist  * software distributed under the License is distributed on an
15*2fe1ca3dSAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*2fe1ca3dSAndrew Rist  * KIND, either express or implied.  See the License for the
17*2fe1ca3dSAndrew Rist  * specific language governing permissions and limitations
18*2fe1ca3dSAndrew Rist  * under the License.
19*2fe1ca3dSAndrew Rist  *
20*2fe1ca3dSAndrew Rist  *************************************************************/
21*2fe1ca3dSAndrew Rist 
22*2fe1ca3dSAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_idlc.hxx"
26cdf0e10cSrcweir #include <idlc/aststruct.hxx>
27cdf0e10cSrcweir #ifndef _IDLC_ASTMember_HXX_
28cdf0e10cSrcweir #include <idlc/astmember.hxx>
29cdf0e10cSrcweir #endif
30cdf0e10cSrcweir 
31cdf0e10cSrcweir #include "registry/version.h"
32cdf0e10cSrcweir #include "registry/writer.hxx"
33cdf0e10cSrcweir 
34cdf0e10cSrcweir using namespace ::rtl;
35cdf0e10cSrcweir 
AstStruct(const OString & name,std::vector<rtl::OString> const & typeParameters,AstStruct * pBaseType,AstScope * pScope)36cdf0e10cSrcweir AstStruct::AstStruct(
37cdf0e10cSrcweir     const OString& name, std::vector< rtl::OString > const & typeParameters,
38cdf0e10cSrcweir     AstStruct* pBaseType, AstScope* pScope)
39cdf0e10cSrcweir 	: AstType(NT_struct, name, pScope)
40cdf0e10cSrcweir 	, AstScope(NT_struct)
41cdf0e10cSrcweir 	, m_pBaseType(pBaseType)
42cdf0e10cSrcweir {
43cdf0e10cSrcweir     for (std::vector< rtl::OString >::const_iterator i(typeParameters.begin());
44cdf0e10cSrcweir          i != typeParameters.end(); ++i)
45cdf0e10cSrcweir     {
46cdf0e10cSrcweir         m_typeParameters.push_back(
47cdf0e10cSrcweir             new AstDeclaration(NT_type_parameter, *i, 0));
48cdf0e10cSrcweir     }
49cdf0e10cSrcweir }
50cdf0e10cSrcweir 
AstStruct(const NodeType type,const OString & name,AstStruct * pBaseType,AstScope * pScope)51cdf0e10cSrcweir AstStruct::AstStruct(const NodeType type,
52cdf0e10cSrcweir 		 		  	 const OString& name,
53cdf0e10cSrcweir 			  		 AstStruct* pBaseType,
54cdf0e10cSrcweir 					 AstScope* pScope)
55cdf0e10cSrcweir 	: AstType(type, name, pScope)
56cdf0e10cSrcweir 	, AstScope(type)
57cdf0e10cSrcweir 	, m_pBaseType(pBaseType)
58cdf0e10cSrcweir {
59cdf0e10cSrcweir }
60cdf0e10cSrcweir 
~AstStruct()61cdf0e10cSrcweir AstStruct::~AstStruct()
62cdf0e10cSrcweir {
63cdf0e10cSrcweir     for (DeclList::iterator i(m_typeParameters.begin());
64cdf0e10cSrcweir          i != m_typeParameters.end(); ++i)
65cdf0e10cSrcweir     {
66cdf0e10cSrcweir         delete *i;
67cdf0e10cSrcweir     }
68cdf0e10cSrcweir }
69cdf0e10cSrcweir 
findTypeParameter(rtl::OString const & name) const70cdf0e10cSrcweir AstDeclaration const * AstStruct::findTypeParameter(rtl::OString const & name)
71cdf0e10cSrcweir     const
72cdf0e10cSrcweir {
73cdf0e10cSrcweir     for (DeclList::const_iterator i(m_typeParameters.begin());
74cdf0e10cSrcweir          i != m_typeParameters.end(); ++i)
75cdf0e10cSrcweir     {
76cdf0e10cSrcweir         if ((*i)->getLocalName() == name) {
77cdf0e10cSrcweir             return *i;
78cdf0e10cSrcweir         }
79cdf0e10cSrcweir     }
80cdf0e10cSrcweir     return 0;
81cdf0e10cSrcweir }
82cdf0e10cSrcweir 
isType() const83cdf0e10cSrcweir bool AstStruct::isType() const {
84cdf0e10cSrcweir     return getNodeType() == NT_struct
85cdf0e10cSrcweir         ? getTypeParameterCount() == 0 : AstDeclaration::isType();
86cdf0e10cSrcweir }
87cdf0e10cSrcweir 
dump(RegistryKey & rKey)88cdf0e10cSrcweir sal_Bool AstStruct::dump(RegistryKey& rKey)
89cdf0e10cSrcweir {
90cdf0e10cSrcweir 	RegistryKey localKey;
91cdf0e10cSrcweir 	if (rKey.createKey( OStringToOUString(getFullName(), RTL_TEXTENCODING_UTF8 ), localKey))
92cdf0e10cSrcweir 	{
93cdf0e10cSrcweir 		fprintf(stderr, "%s: warning, could	not create key '%s' in '%s'\n",
94cdf0e10cSrcweir 			    idlc()->getOptions()->getProgramName().getStr(),
95cdf0e10cSrcweir 			    getFullName().getStr(), OUStringToOString(rKey.getRegistryName(), RTL_TEXTENCODING_UTF8).getStr());
96cdf0e10cSrcweir 		return sal_False;
97cdf0e10cSrcweir 	}
98cdf0e10cSrcweir 
99cdf0e10cSrcweir     if (m_typeParameters.size() > SAL_MAX_UINT16) {
100cdf0e10cSrcweir         fprintf(
101cdf0e10cSrcweir             stderr,
102cdf0e10cSrcweir             ("%s: polymorphic struct type template %s has too many type"
103cdf0e10cSrcweir              " parameters\n"),
104cdf0e10cSrcweir             idlc()->getOptions()->getProgramName().getStr(),
105cdf0e10cSrcweir             getScopedName().getStr());
106cdf0e10cSrcweir         return false;
107cdf0e10cSrcweir     }
108cdf0e10cSrcweir 
109cdf0e10cSrcweir 	sal_uInt16 nMember = getNodeCount(NT_member);
110cdf0e10cSrcweir 
111cdf0e10cSrcweir 	RTTypeClass typeClass = RT_TYPE_STRUCT;
112cdf0e10cSrcweir 	if ( getNodeType() == NT_exception )
113cdf0e10cSrcweir 		typeClass = RT_TYPE_EXCEPTION;
114cdf0e10cSrcweir 
115cdf0e10cSrcweir     OUString emptyStr;
116cdf0e10cSrcweir 	typereg::Writer aBlob(
117cdf0e10cSrcweir         (m_typeParameters.empty() && !m_bPublished
118cdf0e10cSrcweir          ? TYPEREG_VERSION_0 : TYPEREG_VERSION_1),
119cdf0e10cSrcweir         getDocumentation(), emptyStr, typeClass, m_bPublished,
120cdf0e10cSrcweir         OStringToOUString(getRelativName(), RTL_TEXTENCODING_UTF8),
121cdf0e10cSrcweir         m_pBaseType == 0 ? 0 : 1, nMember, 0,
122cdf0e10cSrcweir         static_cast< sal_uInt16 >(m_typeParameters.size()));
123cdf0e10cSrcweir     if (m_pBaseType != 0) {
124cdf0e10cSrcweir         aBlob.setSuperTypeName(
125cdf0e10cSrcweir             0,
126cdf0e10cSrcweir             OStringToOUString(
127cdf0e10cSrcweir                 m_pBaseType->getRelativName(), RTL_TEXTENCODING_UTF8));
128cdf0e10cSrcweir     }
129cdf0e10cSrcweir 
130cdf0e10cSrcweir 	if ( nMember > 0 )
131cdf0e10cSrcweir 	{
132cdf0e10cSrcweir 		DeclList::const_iterator iter = getIteratorBegin();
133cdf0e10cSrcweir 		DeclList::const_iterator end = getIteratorEnd();
134cdf0e10cSrcweir 		AstDeclaration* pDecl = NULL;
135cdf0e10cSrcweir 		AstMember* 	pMember = NULL;
136cdf0e10cSrcweir 		OUString 	docu;
137cdf0e10cSrcweir 		sal_uInt16 	index = 0;
138cdf0e10cSrcweir 		while ( iter != end )
139cdf0e10cSrcweir 		{
140cdf0e10cSrcweir 			pDecl = *iter;
141cdf0e10cSrcweir 			if ( pDecl->getNodeType() == NT_member )
142cdf0e10cSrcweir 			{
143cdf0e10cSrcweir 				pMember = (AstMember*)pDecl;
144cdf0e10cSrcweir                 RTFieldAccess flags = RT_ACCESS_READWRITE;
145cdf0e10cSrcweir                 rtl::OString typeName;
146cdf0e10cSrcweir                 if (pMember->getType()->getNodeType() == NT_type_parameter) {
147cdf0e10cSrcweir                     flags |= RT_ACCESS_PARAMETERIZED_TYPE;
148cdf0e10cSrcweir                     typeName = pMember->getType()->getLocalName();
149cdf0e10cSrcweir                 } else {
150cdf0e10cSrcweir                     typeName = pMember->getType()->getRelativName();
151cdf0e10cSrcweir                 }
152cdf0e10cSrcweir 				aBlob.setFieldData(
153cdf0e10cSrcweir                     index++, pMember->getDocumentation(), emptyStr, flags,
154cdf0e10cSrcweir 					OStringToOUString(
155cdf0e10cSrcweir                         pMember->getLocalName(), RTL_TEXTENCODING_UTF8),
156cdf0e10cSrcweir 					OStringToOUString(typeName, RTL_TEXTENCODING_UTF8),
157cdf0e10cSrcweir                     RTConstValue());
158cdf0e10cSrcweir 			}
159cdf0e10cSrcweir 			++iter;
160cdf0e10cSrcweir 		}
161cdf0e10cSrcweir 	}
162cdf0e10cSrcweir 
163cdf0e10cSrcweir     sal_uInt16 index = 0;
164cdf0e10cSrcweir     for (DeclList::iterator i(m_typeParameters.begin());
165cdf0e10cSrcweir          i != m_typeParameters.end(); ++i)
166cdf0e10cSrcweir     {
167cdf0e10cSrcweir         aBlob.setReferenceData(
168cdf0e10cSrcweir             index++, emptyStr, RT_REF_TYPE_PARAMETER, RT_ACCESS_INVALID,
169cdf0e10cSrcweir             OStringToOUString(
170cdf0e10cSrcweir                 (*i)->getLocalName(), RTL_TEXTENCODING_UTF8));
171cdf0e10cSrcweir     }
172cdf0e10cSrcweir 
173cdf0e10cSrcweir     sal_uInt32 aBlobSize;
174cdf0e10cSrcweir     void const * pBlob = aBlob.getBlob(&aBlobSize);
175cdf0e10cSrcweir 
176cdf0e10cSrcweir 	if (localKey.setValue(emptyStr, RG_VALUETYPE_BINARY,
177cdf0e10cSrcweir 					  	  (RegValue)pBlob, aBlobSize))
178cdf0e10cSrcweir 	{
179cdf0e10cSrcweir 		fprintf(stderr, "%s: warning, could	not set value of key \"%s\" in %s\n",
180cdf0e10cSrcweir 			    idlc()->getOptions()->getProgramName().getStr(),
181cdf0e10cSrcweir 				getFullName().getStr(), OUStringToOString(localKey.getRegistryName(), RTL_TEXTENCODING_UTF8).getStr());
182cdf0e10cSrcweir 		return sal_False;
183cdf0e10cSrcweir 	}
184cdf0e10cSrcweir 
185cdf0e10cSrcweir 	return sal_True;
186cdf0e10cSrcweir }
187cdf0e10cSrcweir 
188