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/astmodule.hxx>
21 #include <idlc/asttypedef.hxx>
22 #include <idlc/astservice.hxx>
23 #include <idlc/astconstant.hxx>
24 #include <idlc/astattribute.hxx>
25 #include <idlc/astinterfacemember.hxx>
26 #include <idlc/astservicemember.hxx>
27 #include <idlc/astobserves.hxx>
28 #include <idlc/astneeds.hxx>
29 #include <idlc/astsequence.hxx>
30 #include "idlc/astoperation.hxx"
32 #include "registry/version.h"
33 #include "registry/writer.hxx"
35 using namespace ::rtl
;
37 sal_Bool
AstModule::dump(RegistryKey
& rKey
)
41 if ( getNodeType() == NT_root
)
46 if (rKey
.createKey( OStringToOUString(getFullName(), RTL_TEXTENCODING_UTF8
), localKey
))
48 fprintf(stderr
, "%s: warning, could not create key '%s' in '%s'\n",
49 idlc()->getOptions()->getProgramName().getStr(),
50 getFullName().getStr(), OUStringToOString(rKey
.getRegistryName(), RTL_TEXTENCODING_UTF8
).getStr());
55 sal_uInt16 nConst
= getNodeCount(NT_const
);
59 RTTypeClass typeClass
= RT_TYPE_MODULE
;
60 if ( getNodeType() == NT_constants
)
61 typeClass
= RT_TYPE_CONSTANTS
;
63 typereg::Writer
aBlob(
64 m_bPublished
? TYPEREG_VERSION_1
: TYPEREG_VERSION_0
,
65 getDocumentation(), emptyStr
, typeClass
,
67 OStringToOUString(getRelativName(), RTL_TEXTENCODING_UTF8
), 0,
70 DeclList::const_iterator iter
= getIteratorBegin();
71 DeclList::const_iterator end
= getIteratorEnd();
72 AstDeclaration
* pDecl
= NULL
;
77 if ( pDecl
->getNodeType() == NT_const
&&
78 pDecl
->isInMainfile() )
80 ((AstConstant
*)pDecl
)->dumpBlob(
82 getNodeType() == NT_module
&& pDecl
->isPublished());
88 void const * pBlob
= aBlob
.getBlob(&aBlobSize
);
90 if (localKey
.setValue(emptyStr
, RG_VALUETYPE_BINARY
,
91 (RegValue
)pBlob
, aBlobSize
))
93 fprintf(stderr
, "%s: warning, could not set value of key \"%s\" in %s\n",
94 idlc()->getOptions()->getProgramName().getStr(),
95 getFullName().getStr(), OUStringToOString(localKey
.getRegistryName(), RTL_TEXTENCODING_UTF8
).getStr());
100 RTTypeClass typeClass
= RT_TYPE_MODULE
;
101 if ( getNodeType() == NT_constants
)
102 typeClass
= RT_TYPE_CONSTANTS
;
104 typereg::Writer
aBlob(
105 m_bPublished
? TYPEREG_VERSION_1
: TYPEREG_VERSION_0
,
106 getDocumentation(), emptyStr
, typeClass
, m_bPublished
,
107 OStringToOUString(getRelativName(), RTL_TEXTENCODING_UTF8
), 0, 0, 0,
110 sal_uInt32 aBlobSize
;
111 void const * pBlob
= aBlob
.getBlob(&aBlobSize
);
113 if ( getNodeType() != NT_root
)
115 if (localKey
.setValue(emptyStr
, RG_VALUETYPE_BINARY
,
116 (RegValue
)pBlob
, aBlobSize
))
118 fprintf(stderr
, "%s: warning, could not set value of key \"%s\" in %s\n",
119 idlc()->getOptions()->getProgramName().getStr(),
120 getFullName().getStr(), OUStringToOString(localKey
.getRegistryName(), RTL_TEXTENCODING_UTF8
).getStr());
125 if ( getNodeType() == NT_root
)
127 localKey
.releaseKey();
129 return AstDeclaration::dump(rKey
);
132 sal_Bool
AstTypeDef::dump(RegistryKey
& rKey
)
135 RegistryKey localKey
;
136 if (rKey
.createKey( OStringToOUString(getFullName(), RTL_TEXTENCODING_UTF8
), localKey
))
138 fprintf(stderr
, "%s: warning, could not create key '%s' in '%s'\n",
139 idlc()->getOptions()->getProgramName().getStr(),
140 getFullName().getStr(), OUStringToOString(rKey
.getRegistryName(), RTL_TEXTENCODING_UTF8
).getStr());
144 typereg::Writer
aBlob(
145 m_bPublished
? TYPEREG_VERSION_1
: TYPEREG_VERSION_0
,
146 getDocumentation(), emptyStr
, RT_TYPE_TYPEDEF
, m_bPublished
,
147 OStringToOUString(getRelativName(), RTL_TEXTENCODING_UTF8
), 1, 0, 0, 0);
148 aBlob
.setSuperTypeName(
151 getBaseType()->getRelativName(), RTL_TEXTENCODING_UTF8
));
153 sal_uInt32 aBlobSize
;
154 void const * pBlob
= aBlob
.getBlob(&aBlobSize
);
156 if (localKey
.setValue(emptyStr
, RG_VALUETYPE_BINARY
, (RegValue
)pBlob
, aBlobSize
))
158 fprintf(stderr
, "%s: warning, could not set value of key \"%s\" in %s\n",
159 idlc()->getOptions()->getProgramName().getStr(),
160 getFullName().getStr(), OUStringToOString(localKey
.getRegistryName(), RTL_TEXTENCODING_UTF8
).getStr());
167 sal_Bool
AstService::dump(RegistryKey
& rKey
)
170 typereg_Version version
= m_bPublished
171 ? TYPEREG_VERSION_1
: TYPEREG_VERSION_0
;
173 sal_uInt16 constructors
= 0;
174 sal_uInt16 properties
= 0;
175 sal_uInt16 references
= 0;
176 for (DeclList::const_iterator
i(getIteratorBegin()); i
!= getIteratorEnd();
179 switch ((*i
)->getNodeType()) {
182 version
= TYPEREG_VERSION_1
;
183 OSL_ASSERT(superName
.isEmpty());
184 superName
= (*i
)->getRelativName();
188 OSL_ASSERT(getNodeType() == NT_service
);
193 OSL_ASSERT(getNodeType() == NT_service
);
197 case NT_service_member
:
198 if (getNodeType() == NT_singleton
) {
199 OSL_ASSERT(superName
.isEmpty());
200 superName
= ((AstServiceMember
*)(*i
))->
201 getRealService()->getRelativName();
204 case NT_interface_member
:
207 OSL_ASSERT(getNodeType() == NT_service
);
216 OSL_ASSERT(constructors
== 0 || !m_defaultConstructor
);
217 if (m_defaultConstructor
) {
220 RegistryKey localKey
;
222 OStringToOUString(getFullName(), RTL_TEXTENCODING_UTF8
),
225 stderr
, "%s: warning, could not create key '%s' in '%s'\n",
226 idlc()->getOptions()->getProgramName().getStr(),
227 getFullName().getStr(),
229 rKey
.getRegistryName(), RTL_TEXTENCODING_UTF8
).getStr());
232 typereg::Writer
writer(
233 version
, getDocumentation(), emptyStr
,
234 getNodeType() == NT_singleton
? RT_TYPE_SINGLETON
: RT_TYPE_SERVICE
,
236 OStringToOUString(getRelativName(), RTL_TEXTENCODING_UTF8
),
237 superName
.isEmpty() ? 0 : 1, properties
, constructors
,
239 if (!superName
.isEmpty()) {
240 writer
.setSuperTypeName(
241 0, OStringToOUString(superName
, RTL_TEXTENCODING_UTF8
));
243 sal_uInt16 constructorIndex
= 0;
244 sal_uInt16 propertyIndex
= 0;
245 sal_uInt16 referenceIndex
= 0;
246 for (DeclList::const_iterator
i(getIteratorBegin()); i
!= getIteratorEnd(); ++i
)
248 switch ((*i
)->getNodeType()) {
250 ((AstOperation
*)(*i
))->dumpBlob(writer
, constructorIndex
++);
254 ((AstAttribute
*)(*i
))->dumpBlob(writer
, propertyIndex
++, 0);
257 case NT_interface_member
:
259 AstInterfaceMember
* decl
= (AstInterfaceMember
*)(*i
);
260 writer
.setReferenceData(
261 referenceIndex
++, decl
->getDocumentation(), RT_REF_SUPPORTS
,
262 (decl
->isOptional() ? RT_ACCESS_OPTIONAL
: RT_ACCESS_INVALID
),
263 OStringToOUString( decl
->getRealInterface()->getRelativName(),
264 RTL_TEXTENCODING_UTF8
));
268 case NT_service_member
:
269 if (getNodeType() == NT_service
)
271 AstServiceMember
* decl
= (AstServiceMember
*)(*i
);
272 writer
.setReferenceData(referenceIndex
++, decl
->getDocumentation(), RT_REF_EXPORTS
,
273 (decl
->isOptional() ? RT_ACCESS_OPTIONAL
: RT_ACCESS_INVALID
),
274 OStringToOUString(decl
->getRealService()->getRelativName(),
275 RTL_TEXTENCODING_UTF8
));
281 AstObserves
* decl
= (AstObserves
*)(*i
);
282 writer
.setReferenceData(referenceIndex
++, decl
->getDocumentation(), RT_REF_OBSERVES
,
284 OStringToOUString( decl
->getRealInterface()->getRelativName(),
285 RTL_TEXTENCODING_UTF8
));
291 AstNeeds
* decl
= (AstNeeds
*)(*i
);
292 writer
.setReferenceData( referenceIndex
++, decl
->getDocumentation(), RT_REF_NEEDS
,
294 OStringToOUString( decl
->getRealService()->getRelativName(),
295 RTL_TEXTENCODING_UTF8
));
300 OSL_ASSERT( (*i
)->getNodeType() == NT_interface
|| (*i
)->getNodeType() == NT_typedef
);
304 if (m_defaultConstructor
) {
305 writer
.setMethodData(
306 constructorIndex
++, emptyStr
, RT_MODE_TWOWAY
,
307 emptyStr
, OUString("void"),
311 void const * blob
= writer
.getBlob(&size
);
312 if (localKey
.setValue(
313 emptyStr
, RG_VALUETYPE_BINARY
, const_cast< void * >(blob
),
317 stderr
, "%s: warning, could not set value of key \"%s\" in %s\n",
318 idlc()->getOptions()->getProgramName().getStr(),
319 getFullName().getStr(),
321 localKey
.getRegistryName(), RTL_TEXTENCODING_UTF8
).getStr());
327 sal_Bool
AstAttribute::dumpBlob(
328 typereg::Writer
& rBlob
, sal_uInt16 index
, sal_uInt16
* methodIndex
)
330 RTFieldAccess accessMode
= RT_ACCESS_INVALID
;
334 accessMode
|= RT_ACCESS_READONLY
;
337 accessMode
|= RT_ACCESS_READWRITE
;
341 accessMode
|= RT_ACCESS_OPTIONAL
;
345 accessMode
|= RT_ACCESS_BOUND
;
349 accessMode
|= RT_ACCESS_MAYBEVOID
;
353 accessMode
|= RT_ACCESS_CONSTRAINED
;
357 accessMode
|= RT_ACCESS_TRANSIENT
;
359 if (isMayBeAmbiguous())
361 accessMode
|= RT_ACCESS_MAYBEAMBIGUOUS
;
363 if (isMayBeDefault())
365 accessMode
|= RT_ACCESS_MAYBEDEFAULT
;
369 accessMode
|= RT_ACCESS_REMOVEABLE
;
372 OUString
name(OStringToOUString(getLocalName(), RTL_TEXTENCODING_UTF8
));
374 index
, getDocumentation(), OUString(), accessMode
, name
,
375 OStringToOUString(getType()->getRelativName(), RTL_TEXTENCODING_UTF8
),
378 rBlob
, m_getDocumentation
, m_getExceptions
, RT_MODE_ATTRIBUTE_GET
,
381 rBlob
, m_setDocumentation
, m_setExceptions
, RT_MODE_ATTRIBUTE_SET
,
387 void AstAttribute::dumpExceptions(
388 typereg::Writer
& writer
, OUString
const & documentation
,
389 DeclList
const & exceptions
, RTMethodMode flags
, sal_uInt16
* methodIndex
)
391 if (!exceptions
.empty()) {
392 OSL_ASSERT(methodIndex
!= 0);
393 sal_uInt16 idx
= (*methodIndex
)++;
394 // exceptions.size() <= SAL_MAX_UINT16 already checked in
395 // AstInterface::dump:
396 writer
.setMethodData(
397 idx
, documentation
, flags
,
398 OStringToOUString(getLocalName(), RTL_TEXTENCODING_UTF8
),
400 static_cast< sal_uInt16
>(exceptions
.size()));
401 sal_uInt16 exceptionIndex
= 0;
402 for (DeclList::const_iterator
i(exceptions
.begin());
403 i
!= exceptions
.end(); ++i
)
405 writer
.setMethodExceptionTypeName(
406 idx
, exceptionIndex
++,
408 (*i
)->getRelativName(), RTL_TEXTENCODING_UTF8
));
413 const sal_Char
* AstSequence::getRelativName() const
415 if ( !m_pRelativName
)
417 m_pRelativName
= new OString("[]");
418 AstDeclaration
const * pType
= resolveTypedefs( m_pMemberType
);
419 *m_pRelativName
+= pType
->getRelativName();
422 return m_pRelativName
->getStr();
425 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */