/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /************************************************************************* * * 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 // NOT FULLY DEFINED SERVICES #include #include #include #include #include #include #include #include #include #include #include #include #include #include namespace csi { namespace uidl { UnoIDL_PE::~UnoIDL_PE() { } void UnoIDL_PE::EstablishContacts( UnoIDL_PE * io_pParentPE, ary::Repository & io_rRepository, TokenProcessing_Result & o_rResult ) { pRepository = &io_rRepository; aMyNode.EstablishContacts(io_pParentPE, io_rRepository.Gate_Idl(), o_rResult); } //void //UnoIDL_PE::EstablishContacts( UnoIDL_PE * io_pParentPE, // ary::idl::Gate & io_rGate, // TokenProcessing_Result & o_rResult ) //{ // aMyNode.EstablishContacts(io_pParentPE, io_rGate, o_rResult); //} void UnoIDL_PE::Enter( E_EnvStackAction i_eWayOfEntering ) { switch (i_eWayOfEntering) { case push_sure: InitData(); break; case push_try: csv_assert(false); break; case pop_success: ReceiveData(); break; case pop_failure: throw X_AutodocParser(X_AutodocParser::x_Any); // no break because of throw default: csv_assert(false); } // end switch } void UnoIDL_PE::Leave( E_EnvStackAction i_eWayOfLeaving ) { switch (i_eWayOfLeaving) { case push_sure: break; case push_try: csv_assert(false); break; case pop_success: TransferData(); break; case pop_failure: throw X_AutodocParser(X_AutodocParser::x_Any); // no break because of throw default: csv_assert(false); } // end switch } void UnoIDL_PE::SetDocu( DYN ary::doc::OldIdlDocu * let_dpDocu ) { pDocu = let_dpDocu; } void UnoIDL_PE::SetPublished() { if (NOT pDocu) { pDocu = new ary::doc::OldIdlDocu; } pDocu->SetPublished(); } void UnoIDL_PE::SetOptional() { if (NOT pDocu) { pDocu = new ary::doc::OldIdlDocu; } pDocu->SetOptional(); } void UnoIDL_PE::PassDocuAt( ary::idl::CodeEntity & io_rCe ) { if (pDocu) { io_rCe.Set_Docu(*pDocu.Release()); } else if // KORR_FUTURE // Re-enable doc-warning for Enum Values, as soon as there is a // @option -no-doc-for-enumvalues. ( NOT ary::is_type(io_rCe) AND NOT ary::is_type(io_rCe) ) { TheMessages().Out_MissingDoc( io_rCe.LocalName(), ParseInfo().CurFile(), ParseInfo().CurLine() ); } } void UnoIDL_PE::InitData() { // Needs not anything to do. } void UnoIDL_PE::ReceiveData() { // Needs not anything to do. } const ary::idl::Module & UnoIDL_PE::CurNamespace() const { if ( Parent() != 0 ) return Parent()->CurNamespace(); else { csv_assert(false); return *(const ary::idl::Module*)0; } } const ParserInfo & UnoIDL_PE::ParseInfo() const { if ( Parent() != 0 ) return Parent()->ParseInfo(); else { csv_assert(false); return *(const ParserInfo*)0; } } UnoIDL_PE::UnoIDL_PE() : aMyNode(), pDocu(), pRepository(0) { } } // namespace uidl } // namespace csi /* vim:set shiftwidth=4 softtabstop=4 expandtab: */