xref: /aoo4110/main/idlc/source/astoperation.cxx (revision b1cdbd2c)
1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_idlc.hxx"
26*b1cdbd2cSJim Jagielski #include <idlc/astoperation.hxx>
27*b1cdbd2cSJim Jagielski #include <idlc/asttype.hxx>
28*b1cdbd2cSJim Jagielski #include <idlc/astbasetype.hxx>
29*b1cdbd2cSJim Jagielski #include <idlc/astparameter.hxx>
30*b1cdbd2cSJim Jagielski #include <idlc/errorhandler.hxx>
31*b1cdbd2cSJim Jagielski 
32*b1cdbd2cSJim Jagielski #include "registry/writer.hxx"
33*b1cdbd2cSJim Jagielski 
34*b1cdbd2cSJim Jagielski using namespace ::rtl;
35*b1cdbd2cSJim Jagielski 
setExceptions(DeclList const * pExceptions)36*b1cdbd2cSJim Jagielski void AstOperation::setExceptions(DeclList const * pExceptions)
37*b1cdbd2cSJim Jagielski {
38*b1cdbd2cSJim Jagielski     if (pExceptions != 0) {
39*b1cdbd2cSJim Jagielski         if (isOneway()) {
40*b1cdbd2cSJim Jagielski             idlc()->error()->error1(EIDL_ONEWAY_RAISE_CONFLICT, this);
41*b1cdbd2cSJim Jagielski         }
42*b1cdbd2cSJim Jagielski         m_exceptions = *pExceptions;
43*b1cdbd2cSJim Jagielski     }
44*b1cdbd2cSJim Jagielski }
45*b1cdbd2cSJim Jagielski 
isVariadic() const46*b1cdbd2cSJim Jagielski bool AstOperation::isVariadic() const {
47*b1cdbd2cSJim Jagielski     DeclList::const_iterator i(getIteratorEnd());
48*b1cdbd2cSJim Jagielski     return i != getIteratorBegin()
49*b1cdbd2cSJim Jagielski         && static_cast< AstParameter const * >(*(--i))->isRest();
50*b1cdbd2cSJim Jagielski }
51*b1cdbd2cSJim Jagielski 
dumpBlob(typereg::Writer & rBlob,sal_uInt16 index)52*b1cdbd2cSJim Jagielski sal_Bool AstOperation::dumpBlob(typereg::Writer & rBlob, sal_uInt16 index)
53*b1cdbd2cSJim Jagielski {
54*b1cdbd2cSJim Jagielski 	sal_uInt16		nParam = getNodeCount(NT_parameter);
55*b1cdbd2cSJim Jagielski 	sal_uInt16		nExcep = nExceptions();
56*b1cdbd2cSJim Jagielski 	RTMethodMode 	methodMode = RT_MODE_TWOWAY;
57*b1cdbd2cSJim Jagielski 
58*b1cdbd2cSJim Jagielski 	if ( isOneway() )
59*b1cdbd2cSJim Jagielski 		methodMode = RT_MODE_ONEWAY;
60*b1cdbd2cSJim Jagielski 
61*b1cdbd2cSJim Jagielski     rtl::OUString returnTypeName;
62*b1cdbd2cSJim Jagielski     if (m_pReturnType == 0) {
63*b1cdbd2cSJim Jagielski         returnTypeName = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("void"));
64*b1cdbd2cSJim Jagielski     } else {
65*b1cdbd2cSJim Jagielski         returnTypeName = rtl::OStringToOUString(
66*b1cdbd2cSJim Jagielski             m_pReturnType->getRelativName(), RTL_TEXTENCODING_UTF8);
67*b1cdbd2cSJim Jagielski     }
68*b1cdbd2cSJim Jagielski     rBlob.setMethodData(
69*b1cdbd2cSJim Jagielski         index, getDocumentation(), methodMode,
70*b1cdbd2cSJim Jagielski         OStringToOUString(getLocalName(), RTL_TEXTENCODING_UTF8),
71*b1cdbd2cSJim Jagielski         returnTypeName, nParam, nExcep);
72*b1cdbd2cSJim Jagielski 
73*b1cdbd2cSJim Jagielski 	if ( nParam )
74*b1cdbd2cSJim Jagielski 	{
75*b1cdbd2cSJim Jagielski 		DeclList::const_iterator iter = getIteratorBegin();
76*b1cdbd2cSJim Jagielski 		DeclList::const_iterator end = getIteratorEnd();
77*b1cdbd2cSJim Jagielski 		AstDeclaration* pDecl = NULL;
78*b1cdbd2cSJim Jagielski 		RTParamMode paramMode;
79*b1cdbd2cSJim Jagielski 		sal_uInt16 paramIndex = 0;
80*b1cdbd2cSJim Jagielski 		while ( iter != end )
81*b1cdbd2cSJim Jagielski 		{
82*b1cdbd2cSJim Jagielski 			pDecl = *iter;
83*b1cdbd2cSJim Jagielski 			if ( pDecl->getNodeType() == NT_parameter )
84*b1cdbd2cSJim Jagielski 			{
85*b1cdbd2cSJim Jagielski 				AstParameter* pParam = (AstParameter*)pDecl;
86*b1cdbd2cSJim Jagielski 				switch (pParam->getDirection())
87*b1cdbd2cSJim Jagielski 				{
88*b1cdbd2cSJim Jagielski 					case DIR_IN :
89*b1cdbd2cSJim Jagielski 						paramMode = RT_PARAM_IN;
90*b1cdbd2cSJim Jagielski 						break;
91*b1cdbd2cSJim Jagielski 					case DIR_OUT :
92*b1cdbd2cSJim Jagielski 						paramMode = RT_PARAM_OUT;
93*b1cdbd2cSJim Jagielski 						break;
94*b1cdbd2cSJim Jagielski 					case DIR_INOUT :
95*b1cdbd2cSJim Jagielski 						paramMode = RT_PARAM_INOUT;
96*b1cdbd2cSJim Jagielski 						break;
97*b1cdbd2cSJim Jagielski 					default:
98*b1cdbd2cSJim Jagielski 						paramMode = RT_PARAM_INVALID;
99*b1cdbd2cSJim Jagielski 						break;
100*b1cdbd2cSJim Jagielski 				}
101*b1cdbd2cSJim Jagielski                 if (pParam->isRest()) {
102*b1cdbd2cSJim Jagielski                     paramMode = static_cast< RTParamMode >(
103*b1cdbd2cSJim Jagielski                         paramMode | RT_PARAM_REST);
104*b1cdbd2cSJim Jagielski                 }
105*b1cdbd2cSJim Jagielski 
106*b1cdbd2cSJim Jagielski 				rBlob.setMethodParameterData(
107*b1cdbd2cSJim Jagielski                     index, paramIndex++, paramMode,
108*b1cdbd2cSJim Jagielski                     OStringToOUString(
109*b1cdbd2cSJim Jagielski                         pDecl->getLocalName(), RTL_TEXTENCODING_UTF8),
110*b1cdbd2cSJim Jagielski                     OStringToOUString(
111*b1cdbd2cSJim Jagielski                         pParam->getType()->getRelativName(),
112*b1cdbd2cSJim Jagielski                         RTL_TEXTENCODING_UTF8));
113*b1cdbd2cSJim Jagielski 			}
114*b1cdbd2cSJim Jagielski 			++iter;
115*b1cdbd2cSJim Jagielski 		}
116*b1cdbd2cSJim Jagielski 	}
117*b1cdbd2cSJim Jagielski 
118*b1cdbd2cSJim Jagielski 	if ( nExcep )
119*b1cdbd2cSJim Jagielski 	{
120*b1cdbd2cSJim Jagielski 		DeclList::iterator iter = m_exceptions.begin();
121*b1cdbd2cSJim Jagielski 		DeclList::iterator end = m_exceptions.end();
122*b1cdbd2cSJim Jagielski 		sal_uInt16 exceptIndex = 0;
123*b1cdbd2cSJim Jagielski 		while ( iter != end )
124*b1cdbd2cSJim Jagielski 		{
125*b1cdbd2cSJim Jagielski 			rBlob.setMethodExceptionTypeName(
126*b1cdbd2cSJim Jagielski                 index, exceptIndex++,
127*b1cdbd2cSJim Jagielski                 OStringToOUString(
128*b1cdbd2cSJim Jagielski                     (*iter)->getRelativName(), RTL_TEXTENCODING_UTF8));
129*b1cdbd2cSJim Jagielski 			++iter;
130*b1cdbd2cSJim Jagielski 		}
131*b1cdbd2cSJim Jagielski 	}
132*b1cdbd2cSJim Jagielski 
133*b1cdbd2cSJim Jagielski 	return sal_True;
134*b1cdbd2cSJim Jagielski }
135*b1cdbd2cSJim Jagielski 
addDeclaration(AstDeclaration * pDecl)136*b1cdbd2cSJim Jagielski AstDeclaration* AstOperation::addDeclaration(AstDeclaration* pDecl)
137*b1cdbd2cSJim Jagielski {
138*b1cdbd2cSJim Jagielski 	if ( pDecl->getNodeType() == NT_parameter )
139*b1cdbd2cSJim Jagielski 	{
140*b1cdbd2cSJim Jagielski 		AstParameter* pParam = (AstParameter*)pDecl;
141*b1cdbd2cSJim Jagielski 		if ( isOneway() &&
142*b1cdbd2cSJim Jagielski 			 (pParam->getDirection() == DIR_OUT || pParam->getDirection() == DIR_INOUT) )
143*b1cdbd2cSJim Jagielski 		{
144*b1cdbd2cSJim Jagielski 			idlc()->error()->error2(EIDL_ONEWAY_CONFLICT, pDecl, this);
145*b1cdbd2cSJim Jagielski 			return NULL;
146*b1cdbd2cSJim Jagielski 		}
147*b1cdbd2cSJim Jagielski 	}
148*b1cdbd2cSJim Jagielski 	return AstScope::addDeclaration(pDecl);
149*b1cdbd2cSJim Jagielski }
150