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