diff options
Diffstat (limited to 'trunk/TAO/orbsvcs/IFR_Service/be_produce.cpp')
-rw-r--r-- | trunk/TAO/orbsvcs/IFR_Service/be_produce.cpp | 250 |
1 files changed, 250 insertions, 0 deletions
diff --git a/trunk/TAO/orbsvcs/IFR_Service/be_produce.cpp b/trunk/TAO/orbsvcs/IFR_Service/be_produce.cpp new file mode 100644 index 00000000000..043d02b66dc --- /dev/null +++ b/trunk/TAO/orbsvcs/IFR_Service/be_produce.cpp @@ -0,0 +1,250 @@ +// $Id$ + +/* + +COPYRIGHT + +Copyright 1992, 1993, 1994 Sun Microsystems, Inc. Printed in the United +States of America. All Rights Reserved. + +This product is protected by copyright and distributed under the following +license restricting its use. + +The Interface Definition Language Compiler Front End (CFE) is made +available for your use provided that you include this license and copyright +notice on all media and documentation and the software program in which +this product is incorporated in whole or part. You may copy and extend +functionality (but may not remove functionality) of the Interface +Definition Language CFE without charge, but you are not authorized to +license or distribute it to anyone else except as part of a product or +program developed by you or with the express written consent of Sun +Microsystems, Inc. ("Sun"). + +The names of Sun Microsystems, Inc. and any of its subsidiaries or +affiliates may not be used in advertising or publicity pertaining to +distribution of Interface Definition Language CFE as permitted herein. + +This license is effective until terminated by Sun for failure to comply +with this license. Upon termination, you shall destroy or return all code +and documentation for the Interface Definition Language CFE. + +INTERFACE DEFINITION LANGUAGE CFE IS PROVIDED AS IS WITH NO WARRANTIES OF +ANY KIND INCLUDING THE WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS +FOR A PARTICULAR PURPOSE, NONINFRINGEMENT, OR ARISING FROM A COURSE OF +DEALING, USAGE OR TRADE PRACTICE. + +INTERFACE DEFINITION LANGUAGE CFE IS PROVIDED WITH NO SUPPORT AND WITHOUT +ANY OBLIGATION ON THE PART OF Sun OR ANY OF ITS SUBSIDIARIES OR AFFILIATES +TO ASSIST IN ITS USE, CORRECTION, MODIFICATION OR ENHANCEMENT. + +SUN OR ANY OF ITS SUBSIDIARIES OR AFFILIATES SHALL HAVE NO LIABILITY WITH +RESPECT TO THE INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY +INTERFACE DEFINITION LANGUAGE CFE OR ANY PART THEREOF. + +IN NO EVENT WILL SUN OR ANY OF ITS SUBSIDIARIES OR AFFILIATES BE LIABLE FOR +ANY LOST REVENUE OR PROFITS OR OTHER SPECIAL, INDIRECT AND CONSEQUENTIAL +DAMAGES, EVEN IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. + +Use, duplication, or disclosure by the government is subject to +restrictions as set forth in subparagraph (c)(1)(ii) of the Rights in +Technical Data and Computer Software clause at DFARS 252.227-7013 and FAR +52.227-19. + +Sun, Sun Microsystems and the Sun logo are trademarks or registered +trademarks of Sun Microsystems, Inc. + +SunSoft, Inc. +2550 Garcia Avenue +Mountain View, California 94043 + +NOTE: + +SunOS, SunSoft, Sun, Solaris, Sun Microsystems or the Sun logo are +trademarks or registered trademarks of Sun Microsystems, Inc. + + */ + +// BE_produce.cc - Produce the work of the BE - does nothing in the +// dummy BE + +#include "global_extern.h" +#include "TAO_IFR_BE_Export.h" +#include "be_extern.h" +#include "fe_extern.h" +#include "ast_root.h" +#include "ifr_visitor_macro.h" +#include "ifr_removing_visitor.h" +#include "ifr_adding_visitor.h" + +ACE_RCSID (be, + be_produce, + "$Id$") + +// Clean up before exit, whether successful or not. +TAO_IFR_BE_Export void +BE_cleanup (void) +{ + idl_global->destroy (); +} + +// Abort this run of the BE. +TAO_IFR_BE_Export void +BE_abort (void) +{ + ACE_ERROR ((LM_ERROR, + ACE_TEXT ("Fatal Error - Aborting\n"))); + + // BE_cleanup will be called after the exception is caught. + throw FE_Bailout (); +} + +void +BE_create_holding_scope (ACE_ENV_SINGLE_ARG_DECL) +{ + CORBA::ModuleDef_ptr scope = CORBA::ModuleDef::_nil (); + + // If we are multi-threaded, it may already be created. + CORBA::Contained_var result = + be_global->repository ()->lookup_id (be_global->holding_scope_name () + ACE_ENV_ARG_PARAMETER); + ACE_CHECK; + + // Will live until the repository goes away for good. + if (CORBA::is_nil (result.in ())) + { + scope = + be_global->repository ()->create_module ( + be_global->holding_scope_name (), + be_global->holding_scope_name (), + "1.0" + ACE_ENV_ARG_PARAMETER + ); + ACE_CHECK; + } + else + { + scope = CORBA::ModuleDef::_narrow (result.in () + ACE_ENV_ARG_PARAMETER); + ACE_CHECK; + } + + be_global->holding_scope (scope); +} + +int +BE_ifr_repo_init (ACE_ENV_SINGLE_ARG_DECL) +{ + CORBA::Object_var object = + be_global->orb ()->resolve_initial_references ("InterfaceRepository" + ACE_ENV_ARG_PARAMETER); + ACE_CHECK_RETURN (-1); + + if (CORBA::is_nil (object.in ())) + { + ACE_ERROR_RETURN (( + LM_ERROR, + ACE_TEXT ("Null objref from resolve_initial_references\n") + ), + -1 + ); + } + + CORBA::Repository_var repo = + CORBA::Repository::_narrow (object.in () + ACE_ENV_ARG_PARAMETER); + ACE_CHECK_RETURN (-1); + + if (CORBA::is_nil (repo.in ())) + { + ACE_ERROR_RETURN (( + LM_ERROR, + ACE_TEXT ("CORBA::Repository::_narrow failed\n") + ), + -1 + ); + } + + be_global->repository (repo._retn ()); + + return 0; +} + +// Do the work of this BE. This is the starting point for code generation. +TAO_IFR_BE_Export void +BE_produce (void) +{ + ACE_DECLARE_NEW_CORBA_ENV; + ACE_TRY + { + int status = BE_ifr_repo_init (ACE_ENV_SINGLE_ARG_PARAMETER); + ACE_TRY_CHECK; + + if (status != 0) + { + return; + } + + BE_create_holding_scope (ACE_ENV_SINGLE_ARG_PARAMETER); + ACE_TRY_CHECK; + + // Get the root node. + AST_Decl *d = idl_global->root (); + AST_Root *root = AST_Root::narrow_from_decl (d); + + if (root == 0) + { + ACE_ERROR ((LM_ERROR, + ACE_TEXT ("(%N:%l) BE_produce - ") + ACE_TEXT ("No Root\n"))); + + BE_abort (); + } + + if (be_global->removing ()) + { + ifr_removing_visitor visitor; + + TAO_IFR_VISITOR_WRITE_GUARD; + + // If the visitor is dispatched this way, we need to override + // only visit_scope() for the removing visitor. + if (visitor.visit_scope (root) == -1) + { + ACE_ERROR (( + LM_ERROR, + ACE_TEXT ("(%N:%l) BE_produce -") + ACE_TEXT (" failed to accept removing visitor\n") + )); + + BE_abort (); + } + } + else + { + ifr_adding_visitor visitor (d); + + TAO_IFR_VISITOR_WRITE_GUARD; + + if (root->ast_accept (&visitor) == -1) + { + ACE_ERROR (( + LM_ERROR, + ACE_TEXT ("(%N:%l) BE_produce -") + ACE_TEXT (" failed to accept adding visitor\n") + )); + + BE_abort (); + } + } + } + ACE_CATCHANY + { + ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION, + ACE_TEXT ("BE_produce")); + + } + ACE_ENDTRY; + + // Clean up. + BE_cleanup (); +} |