/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ #include #include "pe_tydef.hxx" // NOT FULLY DECLARED SERVICES #include #include #include #include #include "pe_type.hxx" namespace cpp { PE_Typedef::PE_Typedef(Cpp_PE * i_pParent ) : Cpp_PE(i_pParent), pStati( new PeStatusArray ), // pSpType, // pSpuType, // sName nType(0) { Setup_StatusFunctions(); pSpType = new SP_Type(*this); pSpuType = new SPU_Type(*pSpType, 0, &PE_Typedef::SpReturn_Type); } PE_Typedef::~PE_Typedef() { } void PE_Typedef::Call_Handler( const cpp::Token & i_rTok ) { pStati->Cur().Call_Handler(i_rTok.TypeId(), i_rTok.Text()); } void PE_Typedef::Setup_StatusFunctions() { typedef CallFunction::F_Tok F_Tok; static F_Tok stateF_start[] = { &PE_Typedef::On_start_typedef }; static INT16 stateT_start[] = { Tid_typedef }; static F_Tok stateF_expectName[] = { &PE_Typedef::On_expectName_Identifier }; static INT16 stateT_expectName[] = { Tid_Identifier }; static F_Tok stateF_afterName[] = { &PE_Typedef::On_afterName_Semicolon }; static INT16 stateT_afterName[] = { Tid_Semicolon }; SEMPARSE_CREATE_STATUS(PE_Typedef, start, Hdl_SyntaxError); SEMPARSE_CREATE_STATUS(PE_Typedef, expectName, Hdl_SyntaxError); SEMPARSE_CREATE_STATUS(PE_Typedef, afterName, Hdl_SyntaxError); } void PE_Typedef::InitData() { pStati->SetCur(start); sName.clear(); nType = 0; } void PE_Typedef::TransferData() { pStati->SetCur(size_of_states); ary::cpp::Typedef & rTypedef = Env().AryGate().Ces().Store_Typedef( Env().Context(), sName, nType ); Env().Event_Store_Typedef(rTypedef); } void PE_Typedef::Hdl_SyntaxError( const char * i_sText) { StdHandlingOfSyntaxError(i_sText); } void PE_Typedef::SpReturn_Type() { pStati->SetCur(expectName); nType = pSpuType->Child().Result_Type().Id(); } void PE_Typedef::On_start_typedef( const char * ) { pSpuType->Push(done); } void PE_Typedef::On_expectName_Identifier( const char * i_sText ) { SetTokenResult(done, stay); pStati->SetCur(afterName); sName = i_sText; } void PE_Typedef::On_afterName_Semicolon( const char * ) { SetTokenResult(done, pop_success); } } // namespace cpp