1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir #include <precomp.h>
29*cdf0e10cSrcweir #include <s2_luidl/pe_const.hxx>
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir // NOT FULLY DECLARED SERVICES
32*cdf0e10cSrcweir #include <ary/idl/i_gate.hxx>
33*cdf0e10cSrcweir #include <ary/idl/i_constant.hxx>
34*cdf0e10cSrcweir #include <ary/idl/i_constgroup.hxx>
35*cdf0e10cSrcweir #include <ary/idl/ip_ce.hxx>
36*cdf0e10cSrcweir #include <ary/doc/d_oldidldocu.hxx>
37*cdf0e10cSrcweir #include <s2_luidl/pe_type2.hxx>
38*cdf0e10cSrcweir #include <s2_luidl/pe_evalu.hxx>
39*cdf0e10cSrcweir #include <s2_luidl/tk_punct.hxx>
40*cdf0e10cSrcweir #include <s2_luidl/tk_ident.hxx>
41*cdf0e10cSrcweir #include <s2_luidl/tk_keyw.hxx>
42*cdf0e10cSrcweir 
43*cdf0e10cSrcweir 
44*cdf0e10cSrcweir namespace csi
45*cdf0e10cSrcweir {
46*cdf0e10cSrcweir namespace uidl
47*cdf0e10cSrcweir {
48*cdf0e10cSrcweir 
49*cdf0e10cSrcweir 
50*cdf0e10cSrcweir #ifdef DF
51*cdf0e10cSrcweir #undef DF
52*cdf0e10cSrcweir #endif
53*cdf0e10cSrcweir #define DF 	&PE_Constant::On_Default
54*cdf0e10cSrcweir 
55*cdf0e10cSrcweir PE_Constant::F_TOK
56*cdf0e10cSrcweir PE_Constant::aDispatcher[PE_Constant::e_STATES_MAX][PE_Constant::tt_MAX] =
57*cdf0e10cSrcweir 		{ 	{ DF, DF, DF },  // e_none
58*cdf0e10cSrcweir 			{ DF, &PE_Constant::On_expect_name_Identifier,
59*cdf0e10cSrcweir 					  DF },  // expect_name
60*cdf0e10cSrcweir 			{ DF, DF, &PE_Constant::On_expect_curl_bracket_open_Punctuation },  // expect_curl_bracket_open
61*cdf0e10cSrcweir 			{ &PE_Constant::On_expect_const_Stereotype,
62*cdf0e10cSrcweir 				  DF, &PE_Constant::On_expect_const_Punctuation },  // expect_const
63*cdf0e10cSrcweir 			{ DF, &PE_Constant::On_expect_value_Identifier,
64*cdf0e10cSrcweir 					  DF },  // expect_value
65*cdf0e10cSrcweir 			{ DF, DF, &PE_Constant::On_expect_finish_Punctuation }  // expect_finish
66*cdf0e10cSrcweir 		};
67*cdf0e10cSrcweir 
68*cdf0e10cSrcweir 
69*cdf0e10cSrcweir 
70*cdf0e10cSrcweir inline void
71*cdf0e10cSrcweir PE_Constant::CallHandler( const char *		i_sTokenText,
72*cdf0e10cSrcweir 						  E_TokenType		i_eTokenType )
73*cdf0e10cSrcweir 	{ (this->*aDispatcher[eState][i_eTokenType])(i_sTokenText); }
74*cdf0e10cSrcweir 
75*cdf0e10cSrcweir 
76*cdf0e10cSrcweir 
77*cdf0e10cSrcweir 
78*cdf0e10cSrcweir PE_Constant::PE_Constant()
79*cdf0e10cSrcweir 	:	eState(e_none),
80*cdf0e10cSrcweir 		sData_Name(),
81*cdf0e10cSrcweir         nDataId(0),
82*cdf0e10cSrcweir 		pPE_Type(0),
83*cdf0e10cSrcweir 		nType(0),
84*cdf0e10cSrcweir 		pPE_Value(0),
85*cdf0e10cSrcweir 		sName(),
86*cdf0e10cSrcweir 		sAssignment()
87*cdf0e10cSrcweir {
88*cdf0e10cSrcweir 	pPE_Type = new PE_Type(nType);
89*cdf0e10cSrcweir 	pPE_Value = new PE_Value(sName, sAssignment, true);
90*cdf0e10cSrcweir }
91*cdf0e10cSrcweir 
92*cdf0e10cSrcweir void
93*cdf0e10cSrcweir PE_Constant::EstablishContacts( UnoIDL_PE *					io_pParentPE,
94*cdf0e10cSrcweir 								ary::Repository &		io_rRepository,
95*cdf0e10cSrcweir 								TokenProcessing_Result & 	o_rResult )
96*cdf0e10cSrcweir {
97*cdf0e10cSrcweir 	UnoIDL_PE::EstablishContacts(io_pParentPE,io_rRepository,o_rResult);
98*cdf0e10cSrcweir 	pPE_Type->EstablishContacts(this,io_rRepository,o_rResult);
99*cdf0e10cSrcweir 	pPE_Value->EstablishContacts(this,io_rRepository,o_rResult);
100*cdf0e10cSrcweir }
101*cdf0e10cSrcweir 
102*cdf0e10cSrcweir PE_Constant::~PE_Constant()
103*cdf0e10cSrcweir {
104*cdf0e10cSrcweir }
105*cdf0e10cSrcweir 
106*cdf0e10cSrcweir void
107*cdf0e10cSrcweir PE_Constant::ProcessToken( const Token & i_rToken )
108*cdf0e10cSrcweir {
109*cdf0e10cSrcweir 	i_rToken.Trigger(*this);
110*cdf0e10cSrcweir }
111*cdf0e10cSrcweir 
112*cdf0e10cSrcweir void
113*cdf0e10cSrcweir PE_Constant::Process_Identifier( const TokIdentifier & i_rToken )
114*cdf0e10cSrcweir {
115*cdf0e10cSrcweir 	CallHandler(i_rToken.Text(), tt_identifier);
116*cdf0e10cSrcweir }
117*cdf0e10cSrcweir 
118*cdf0e10cSrcweir void
119*cdf0e10cSrcweir PE_Constant::Process_Punctuation( const TokPunctuation & i_rToken )
120*cdf0e10cSrcweir {
121*cdf0e10cSrcweir 	CallHandler(i_rToken.Text(), tt_punctuation);
122*cdf0e10cSrcweir }
123*cdf0e10cSrcweir 
124*cdf0e10cSrcweir void
125*cdf0e10cSrcweir PE_Constant::Process_Stereotype( const TokStereotype & i_rToken )
126*cdf0e10cSrcweir {
127*cdf0e10cSrcweir 	CallHandler(i_rToken.Text(), tt_stereotype);
128*cdf0e10cSrcweir }
129*cdf0e10cSrcweir 
130*cdf0e10cSrcweir void
131*cdf0e10cSrcweir PE_Constant::On_expect_name_Identifier(const char * i_sText)
132*cdf0e10cSrcweir {
133*cdf0e10cSrcweir 	sName = i_sText;
134*cdf0e10cSrcweir 
135*cdf0e10cSrcweir 	SetResult(done,stay);
136*cdf0e10cSrcweir 	eState = expect_curl_bracket_open;
137*cdf0e10cSrcweir }
138*cdf0e10cSrcweir 
139*cdf0e10cSrcweir void
140*cdf0e10cSrcweir PE_Constant::On_expect_curl_bracket_open_Punctuation(const char * i_sText)
141*cdf0e10cSrcweir {
142*cdf0e10cSrcweir 	if ( i_sText[0] == '{')
143*cdf0e10cSrcweir 	{
144*cdf0e10cSrcweir 		sData_Name = sName;
145*cdf0e10cSrcweir 
146*cdf0e10cSrcweir         ary::idl::ConstantsGroup &
147*cdf0e10cSrcweir         rCe = Gate().Ces().
148*cdf0e10cSrcweir                     Store_ConstantsGroup(CurNamespace().CeId(),sData_Name);
149*cdf0e10cSrcweir 		PassDocuAt(rCe);
150*cdf0e10cSrcweir         nDataId = rCe.CeId();
151*cdf0e10cSrcweir 
152*cdf0e10cSrcweir 		SetResult(done,stay);
153*cdf0e10cSrcweir 		eState = expect_const;
154*cdf0e10cSrcweir 	}
155*cdf0e10cSrcweir 	else
156*cdf0e10cSrcweir 	{
157*cdf0e10cSrcweir 		On_Default(i_sText);
158*cdf0e10cSrcweir 	}
159*cdf0e10cSrcweir }
160*cdf0e10cSrcweir 
161*cdf0e10cSrcweir void
162*cdf0e10cSrcweir PE_Constant::On_expect_const_Stereotype(const char *)
163*cdf0e10cSrcweir {
164*cdf0e10cSrcweir 	SetResult( done, push_sure, pPE_Type.Ptr() );
165*cdf0e10cSrcweir }
166*cdf0e10cSrcweir 
167*cdf0e10cSrcweir void
168*cdf0e10cSrcweir PE_Constant::On_expect_const_Punctuation(const char * i_sText)
169*cdf0e10cSrcweir {
170*cdf0e10cSrcweir 	if ( i_sText[0] == '}')
171*cdf0e10cSrcweir 	{
172*cdf0e10cSrcweir 		SetResult(done,stay);
173*cdf0e10cSrcweir 		eState = expect_finish;
174*cdf0e10cSrcweir 	}
175*cdf0e10cSrcweir 	else
176*cdf0e10cSrcweir 	{
177*cdf0e10cSrcweir 		On_Default(i_sText);
178*cdf0e10cSrcweir 	}
179*cdf0e10cSrcweir }
180*cdf0e10cSrcweir 
181*cdf0e10cSrcweir void
182*cdf0e10cSrcweir PE_Constant::On_expect_value_Identifier(const char *)
183*cdf0e10cSrcweir {
184*cdf0e10cSrcweir 	SetResult( not_done, push_sure, pPE_Value.Ptr() );
185*cdf0e10cSrcweir }
186*cdf0e10cSrcweir 
187*cdf0e10cSrcweir void
188*cdf0e10cSrcweir PE_Constant::On_expect_finish_Punctuation(const char * i_sText)
189*cdf0e10cSrcweir {
190*cdf0e10cSrcweir 	if ( i_sText[0] == ';')
191*cdf0e10cSrcweir 	{
192*cdf0e10cSrcweir 		SetResult(done,pop_success);
193*cdf0e10cSrcweir 		eState = e_none;
194*cdf0e10cSrcweir 	}
195*cdf0e10cSrcweir 	else
196*cdf0e10cSrcweir 	{
197*cdf0e10cSrcweir 		On_Default(i_sText);
198*cdf0e10cSrcweir 	}
199*cdf0e10cSrcweir }
200*cdf0e10cSrcweir 
201*cdf0e10cSrcweir void
202*cdf0e10cSrcweir PE_Constant::On_Default(const char * )
203*cdf0e10cSrcweir {
204*cdf0e10cSrcweir 	SetResult(not_done,pop_failure);
205*cdf0e10cSrcweir 	eState = e_none;
206*cdf0e10cSrcweir }
207*cdf0e10cSrcweir 
208*cdf0e10cSrcweir void
209*cdf0e10cSrcweir PE_Constant::EmptySingleConstData()
210*cdf0e10cSrcweir {
211*cdf0e10cSrcweir 	nType = 0;
212*cdf0e10cSrcweir 	sName = "";
213*cdf0e10cSrcweir 	sAssignment = "";
214*cdf0e10cSrcweir }
215*cdf0e10cSrcweir 
216*cdf0e10cSrcweir void
217*cdf0e10cSrcweir PE_Constant::CreateSingleConstant()
218*cdf0e10cSrcweir {
219*cdf0e10cSrcweir     ary::idl::Constant &
220*cdf0e10cSrcweir         rCe = Gate().Ces().Store_Constant( nDataId,
221*cdf0e10cSrcweir                                            sName,
222*cdf0e10cSrcweir                                            nType,
223*cdf0e10cSrcweir                                            sAssignment );
224*cdf0e10cSrcweir 	pPE_Type->PassDocuAt(rCe);
225*cdf0e10cSrcweir }
226*cdf0e10cSrcweir 
227*cdf0e10cSrcweir void
228*cdf0e10cSrcweir PE_Constant::InitData()
229*cdf0e10cSrcweir {
230*cdf0e10cSrcweir 	eState = expect_name;
231*cdf0e10cSrcweir 
232*cdf0e10cSrcweir 	sData_Name.clear();
233*cdf0e10cSrcweir 	nDataId = 0;
234*cdf0e10cSrcweir 
235*cdf0e10cSrcweir 	EmptySingleConstData();
236*cdf0e10cSrcweir }
237*cdf0e10cSrcweir 
238*cdf0e10cSrcweir void
239*cdf0e10cSrcweir PE_Constant::ReceiveData()
240*cdf0e10cSrcweir {
241*cdf0e10cSrcweir 	switch (eState)
242*cdf0e10cSrcweir 	{
243*cdf0e10cSrcweir 		case expect_const:
244*cdf0e10cSrcweir 					eState = expect_value;
245*cdf0e10cSrcweir 					break;
246*cdf0e10cSrcweir 		case expect_value:
247*cdf0e10cSrcweir 		{
248*cdf0e10cSrcweir 					if (sName.length() == 0 OR sAssignment.length() == 0 OR NOT nType.IsValid())
249*cdf0e10cSrcweir 					{
250*cdf0e10cSrcweir 						Cerr() << "Constant without value found." << Endl();
251*cdf0e10cSrcweir 						eState = expect_const;
252*cdf0e10cSrcweir 						break;
253*cdf0e10cSrcweir 					}
254*cdf0e10cSrcweir 
255*cdf0e10cSrcweir                     CreateSingleConstant();
256*cdf0e10cSrcweir 					EmptySingleConstData();
257*cdf0e10cSrcweir 					eState = expect_const;
258*cdf0e10cSrcweir 		}			break;
259*cdf0e10cSrcweir 		default:
260*cdf0e10cSrcweir 					SetResult(not_done, pop_failure);
261*cdf0e10cSrcweir 					eState = e_none;
262*cdf0e10cSrcweir 	}	// end switch
263*cdf0e10cSrcweir }
264*cdf0e10cSrcweir 
265*cdf0e10cSrcweir void
266*cdf0e10cSrcweir PE_Constant::TransferData()
267*cdf0e10cSrcweir {
268*cdf0e10cSrcweir 	csv_assert(nDataId.IsValid());
269*cdf0e10cSrcweir 	eState = e_none;
270*cdf0e10cSrcweir }
271*cdf0e10cSrcweir 
272*cdf0e10cSrcweir UnoIDL_PE &
273*cdf0e10cSrcweir PE_Constant::MyPE()
274*cdf0e10cSrcweir {
275*cdf0e10cSrcweir 	return *this;
276*cdf0e10cSrcweir }
277*cdf0e10cSrcweir 
278*cdf0e10cSrcweir }   // namespace uidl
279*cdf0e10cSrcweir }   // namespace csi
280*cdf0e10cSrcweir 
281