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