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 #include <precomp.h>
23*b1cdbd2cSJim Jagielski #include "pe_enum.hxx"
24*b1cdbd2cSJim Jagielski 
25*b1cdbd2cSJim Jagielski 
26*b1cdbd2cSJim Jagielski // NOT FULLY DECLARED SERVICES
27*b1cdbd2cSJim Jagielski #include <ary/cpp/c_gate.hxx>
28*b1cdbd2cSJim Jagielski #include <ary/cpp/c_enum.hxx>
29*b1cdbd2cSJim Jagielski #include <ary/cpp/cp_ce.hxx>
30*b1cdbd2cSJim Jagielski #include <all_toks.hxx>
31*b1cdbd2cSJim Jagielski #include "pe_enval.hxx"
32*b1cdbd2cSJim Jagielski 
33*b1cdbd2cSJim Jagielski 
34*b1cdbd2cSJim Jagielski namespace cpp {
35*b1cdbd2cSJim Jagielski 
36*b1cdbd2cSJim Jagielski 
PE_Enum(Cpp_PE * i_pParent)37*b1cdbd2cSJim Jagielski PE_Enum::PE_Enum(Cpp_PE * i_pParent )
38*b1cdbd2cSJim Jagielski 	:   Cpp_PE(i_pParent),
39*b1cdbd2cSJim Jagielski 		pStati( new PeStatusArray<PE_Enum> ),
40*b1cdbd2cSJim Jagielski 		// pSpValue,
41*b1cdbd2cSJim Jagielski 		// pSpuValue,
42*b1cdbd2cSJim Jagielski         // sLocalName,
43*b1cdbd2cSJim Jagielski 		pCurObject(0),
44*b1cdbd2cSJim Jagielski         eResult_KindOf(is_declaration)
45*b1cdbd2cSJim Jagielski {
46*b1cdbd2cSJim Jagielski 	Setup_StatusFunctions();
47*b1cdbd2cSJim Jagielski 
48*b1cdbd2cSJim Jagielski 	pSpValue    = new SP_EnumValue(*this);
49*b1cdbd2cSJim Jagielski 	pSpuValue	= new SPU_EnumValue(*pSpValue, 0, 0);
50*b1cdbd2cSJim Jagielski }
51*b1cdbd2cSJim Jagielski 
52*b1cdbd2cSJim Jagielski 
~PE_Enum()53*b1cdbd2cSJim Jagielski PE_Enum::~PE_Enum()
54*b1cdbd2cSJim Jagielski {
55*b1cdbd2cSJim Jagielski }
56*b1cdbd2cSJim Jagielski 
57*b1cdbd2cSJim Jagielski void
Call_Handler(const cpp::Token & i_rTok)58*b1cdbd2cSJim Jagielski PE_Enum::Call_Handler( const cpp::Token & i_rTok )
59*b1cdbd2cSJim Jagielski {
60*b1cdbd2cSJim Jagielski 	pStati->Cur().Call_Handler(i_rTok.TypeId(), i_rTok.Text());
61*b1cdbd2cSJim Jagielski }
62*b1cdbd2cSJim Jagielski 
63*b1cdbd2cSJim Jagielski void
Setup_StatusFunctions()64*b1cdbd2cSJim Jagielski PE_Enum::Setup_StatusFunctions()
65*b1cdbd2cSJim Jagielski {
66*b1cdbd2cSJim Jagielski 	typedef CallFunction<PE_Enum>::F_Tok	F_Tok;
67*b1cdbd2cSJim Jagielski 	static F_Tok stateF_expectName[] = 		{ &PE_Enum::On_expectName_Identifier,
68*b1cdbd2cSJim Jagielski                                               &PE_Enum::On_expectName_SwBracket_Left
69*b1cdbd2cSJim Jagielski                                             };
70*b1cdbd2cSJim Jagielski 	static INT16 stateT_expectName[] = 		{ Tid_Identifier,
71*b1cdbd2cSJim Jagielski                                               Tid_SwBracket_Left
72*b1cdbd2cSJim Jagielski                                             };
73*b1cdbd2cSJim Jagielski 
74*b1cdbd2cSJim Jagielski 	static F_Tok stateF_gotName[] =			{ &PE_Enum::On_gotName_SwBracket_Left };
75*b1cdbd2cSJim Jagielski 	static INT16 stateT_gotName[] =       	{ Tid_SwBracket_Left };
76*b1cdbd2cSJim Jagielski 
77*b1cdbd2cSJim Jagielski 	static F_Tok stateF_bodyStd[] =			{ &PE_Enum::On_bodyStd_Identifier,
78*b1cdbd2cSJim Jagielski                                               &PE_Enum::On_bodyStd_SwBracket_Right };
79*b1cdbd2cSJim Jagielski 	static INT16 stateT_bodyStd[] =       	{ Tid_Identifier,
80*b1cdbd2cSJim Jagielski                                               Tid_SwBracket_Right };
81*b1cdbd2cSJim Jagielski 
82*b1cdbd2cSJim Jagielski 	static F_Tok stateF_afterBlock[] = 	    { &PE_Enum::On_afterBlock_Semicolon };
83*b1cdbd2cSJim Jagielski 	static INT16 stateT_afterBlock[] =   	{ Tid_Semicolon };
84*b1cdbd2cSJim Jagielski 
85*b1cdbd2cSJim Jagielski 	SEMPARSE_CREATE_STATUS(PE_Enum, expectName, Hdl_SyntaxError);
86*b1cdbd2cSJim Jagielski 	SEMPARSE_CREATE_STATUS(PE_Enum, gotName, On_gotName_Return2Type);
87*b1cdbd2cSJim Jagielski 	SEMPARSE_CREATE_STATUS(PE_Enum, bodyStd, Hdl_SyntaxError);
88*b1cdbd2cSJim Jagielski 	SEMPARSE_CREATE_STATUS(PE_Enum, afterBlock, On_afterBlock_Return2Type);
89*b1cdbd2cSJim Jagielski }
90*b1cdbd2cSJim Jagielski 
91*b1cdbd2cSJim Jagielski void
InitData()92*b1cdbd2cSJim Jagielski PE_Enum::InitData()
93*b1cdbd2cSJim Jagielski {
94*b1cdbd2cSJim Jagielski 	pStati->SetCur(expectName);
95*b1cdbd2cSJim Jagielski 	pCurObject = 0;
96*b1cdbd2cSJim Jagielski     sLocalName.clear();
97*b1cdbd2cSJim Jagielski     eResult_KindOf = is_declaration;
98*b1cdbd2cSJim Jagielski }
99*b1cdbd2cSJim Jagielski 
100*b1cdbd2cSJim Jagielski void
TransferData()101*b1cdbd2cSJim Jagielski PE_Enum::TransferData()
102*b1cdbd2cSJim Jagielski {
103*b1cdbd2cSJim Jagielski 	pStati->SetCur(size_of_states);
104*b1cdbd2cSJim Jagielski }
105*b1cdbd2cSJim Jagielski 
106*b1cdbd2cSJim Jagielski void
Hdl_SyntaxError(const char * i_sText)107*b1cdbd2cSJim Jagielski PE_Enum::Hdl_SyntaxError( const char * i_sText)
108*b1cdbd2cSJim Jagielski {
109*b1cdbd2cSJim Jagielski 	StdHandlingOfSyntaxError(i_sText);
110*b1cdbd2cSJim Jagielski }
111*b1cdbd2cSJim Jagielski 
112*b1cdbd2cSJim Jagielski void
On_expectName_Identifier(const char * i_sText)113*b1cdbd2cSJim Jagielski PE_Enum::On_expectName_Identifier( const char * i_sText )
114*b1cdbd2cSJim Jagielski {
115*b1cdbd2cSJim Jagielski 	SetTokenResult(done, stay);
116*b1cdbd2cSJim Jagielski 	pStati->SetCur(gotName);
117*b1cdbd2cSJim Jagielski 
118*b1cdbd2cSJim Jagielski 	sLocalName = i_sText;
119*b1cdbd2cSJim Jagielski 	pCurObject = & Env().AryGate().Ces().Store_Enum( Env().Context(), sLocalName );
120*b1cdbd2cSJim Jagielski }
121*b1cdbd2cSJim Jagielski 
122*b1cdbd2cSJim Jagielski void
On_expectName_SwBracket_Left(const char *)123*b1cdbd2cSJim Jagielski PE_Enum::On_expectName_SwBracket_Left( const char * )
124*b1cdbd2cSJim Jagielski {
125*b1cdbd2cSJim Jagielski 	SetTokenResult(done, stay);
126*b1cdbd2cSJim Jagielski 	pStati->SetCur(bodyStd);
127*b1cdbd2cSJim Jagielski 
128*b1cdbd2cSJim Jagielski     sLocalName = "";
129*b1cdbd2cSJim Jagielski 	pCurObject = & Env().AryGate().Ces().Store_Enum( Env().Context(), sLocalName );
130*b1cdbd2cSJim Jagielski     sLocalName = pCurObject->LocalName();
131*b1cdbd2cSJim Jagielski 
132*b1cdbd2cSJim Jagielski 	Env().OpenEnum(*pCurObject);
133*b1cdbd2cSJim Jagielski }
134*b1cdbd2cSJim Jagielski 
135*b1cdbd2cSJim Jagielski void
On_gotName_SwBracket_Left(const char *)136*b1cdbd2cSJim Jagielski PE_Enum::On_gotName_SwBracket_Left( const char * )
137*b1cdbd2cSJim Jagielski {
138*b1cdbd2cSJim Jagielski 	SetTokenResult(done, stay);
139*b1cdbd2cSJim Jagielski 	pStati->SetCur(bodyStd);
140*b1cdbd2cSJim Jagielski 	Env().OpenEnum(*pCurObject);
141*b1cdbd2cSJim Jagielski }
142*b1cdbd2cSJim Jagielski 
143*b1cdbd2cSJim Jagielski void
On_gotName_Return2Type(const char *)144*b1cdbd2cSJim Jagielski PE_Enum::On_gotName_Return2Type( const char * )
145*b1cdbd2cSJim Jagielski {
146*b1cdbd2cSJim Jagielski 	SetTokenResult(not_done, pop_success);
147*b1cdbd2cSJim Jagielski 
148*b1cdbd2cSJim Jagielski 	eResult_KindOf = is_qualified_typename;
149*b1cdbd2cSJim Jagielski }
150*b1cdbd2cSJim Jagielski 
151*b1cdbd2cSJim Jagielski void
On_bodyStd_Identifier(const char *)152*b1cdbd2cSJim Jagielski PE_Enum::On_bodyStd_Identifier( const char * )
153*b1cdbd2cSJim Jagielski {
154*b1cdbd2cSJim Jagielski     pSpuValue->Push(not_done);
155*b1cdbd2cSJim Jagielski }
156*b1cdbd2cSJim Jagielski 
157*b1cdbd2cSJim Jagielski void
On_bodyStd_SwBracket_Right(const char *)158*b1cdbd2cSJim Jagielski PE_Enum::On_bodyStd_SwBracket_Right( const char * )
159*b1cdbd2cSJim Jagielski {
160*b1cdbd2cSJim Jagielski     SetTokenResult(done, stay);
161*b1cdbd2cSJim Jagielski 	pStati->SetCur(afterBlock);
162*b1cdbd2cSJim Jagielski 
163*b1cdbd2cSJim Jagielski 	Env().CloseEnum();
164*b1cdbd2cSJim Jagielski }
165*b1cdbd2cSJim Jagielski 
166*b1cdbd2cSJim Jagielski void
On_afterBlock_Semicolon(const char *)167*b1cdbd2cSJim Jagielski PE_Enum::On_afterBlock_Semicolon( const char * )
168*b1cdbd2cSJim Jagielski {
169*b1cdbd2cSJim Jagielski 	SetTokenResult(not_done, pop_success);
170*b1cdbd2cSJim Jagielski 	eResult_KindOf = is_declaration;
171*b1cdbd2cSJim Jagielski }
172*b1cdbd2cSJim Jagielski 
173*b1cdbd2cSJim Jagielski void
On_afterBlock_Return2Type(const char *)174*b1cdbd2cSJim Jagielski PE_Enum::On_afterBlock_Return2Type( const char * )
175*b1cdbd2cSJim Jagielski {
176*b1cdbd2cSJim Jagielski 	SetTokenResult(not_done, pop_success);
177*b1cdbd2cSJim Jagielski 	eResult_KindOf = is_implicit_declaration;
178*b1cdbd2cSJim Jagielski }
179*b1cdbd2cSJim Jagielski 
180*b1cdbd2cSJim Jagielski }   // namespace cpp
181*b1cdbd2cSJim Jagielski 
182*b1cdbd2cSJim Jagielski 
183*b1cdbd2cSJim Jagielski 
184