/*
 *  MICO --- a free CORBA implementation
 *  Copyright (C) 1997-98 Kay Roemer & Arno Puder
 *
 *  This file was automatically generated. DO NOT EDIT!
 */

#include "module1.h"

//--------------------------------------------------------
//  Implementation of stubs
//--------------------------------------------------------


// Stub interface I
M::I::~I()
{
}

M::I_ptr M::I::_duplicate( I_ptr _obj )
{
  if( !CORBA::is_nil( _obj ) )
    _obj->_ref();
  return _obj;
}

void *M::I::_narrow_helper( const char *_repoid )
{
  if( strcmp( _repoid, "IDL:M/I:1.0" ) == 0 )
    return (void *)this;
  return NULL;
}

bool M::I::_narrow_helper2( CORBA::Object_ptr _obj )
{
  if( strcmp( _obj->_repoid(), "IDL:M/I:1.0" ) == 0) {
    return true;
  }
  for( vector<CORBA::Narrow_proto>::size_type _i = 0;
       _narrow_helpers && _i < _narrow_helpers->size(); _i++ ) {
    bool _res = (*(*_narrow_helpers)[ _i ])( _obj );
    if( _res )
      return true;
  }
  return false;
}

M::I_ptr M::I::_narrow( CORBA::Object_ptr _obj )
{
  M::I_ptr _o;
  if( !CORBA::is_nil( _obj ) ) {
    void *_p;
    if( (_p = _obj->_narrow_helper( "IDL:M/I:1.0" )))
      return _duplicate( (M::I_ptr) _p );
    if( _narrow_helper2( _obj ) ) {
      _o = new M::I_stub;
      _o->MICO_SCOPE(CORBA,Object::operator=)( *_obj );
      return _o;
    }
  }
  return _nil();
}

M::I_ptr M::I::_nil()
{
  return NULL;
}

M::I_stub::~I_stub()
{
}

#ifdef HAVE_NAMESPACE
namespace M { vector<CORBA::Narrow_proto> * I::_narrow_helpers; };
#else
vector<CORBA::Narrow_proto> * M::I::_narrow_helpers;
#endif

class _Marshaller_M_I : public CORBA::StaticTypeInfo {
    typedef M::I_ptr _T;
  public:
    StaticValueType create () const;
    void assign (StaticValueType dst, const StaticValueType src) const;
    void free (StaticValueType) const;
    CORBA::Boolean demarshal (CORBA::DataDecoder&, StaticValueType) const;
    void marshal (CORBA::DataEncoder &, StaticValueType) const;
};


CORBA::StaticValueType _Marshaller_M_I::create() const
{
  return (StaticValueType) new _T( 0 );
}

void _Marshaller_M_I::assign( StaticValueType d, const StaticValueType s ) const
{
  *(_T*) d = ::M::I::_duplicate( *(_T*) s );
}

void _Marshaller_M_I::free( StaticValueType v ) const
{
  CORBA::release( *(_T *) v );
  delete (_T*) v;
}

CORBA::Boolean _Marshaller_M_I::demarshal( CORBA::DataDecoder &dc, StaticValueType v ) const
{
  CORBA::Object_ptr obj;
  if( !CORBA::_stc_Object->demarshal( dc, &obj ) )
    return FALSE;
  *(_T *) v = ::M::I::_narrow( obj );
  CORBA::release( obj );
  return TRUE;
}

void _Marshaller_M_I::marshal( CORBA::DataEncoder &ec, StaticValueType v ) const
{
  CORBA::Object_ptr obj = *(_T *) v;
  CORBA::_stc_Object->marshal( ec, &obj );
}

CORBA::StaticTypeInfo *_marshaller_M_I;

struct __tc_init_MODULE1 {
  __tc_init_MODULE1()
  {
    _marshaller_M_I = new _Marshaller_M_I;

  }
};

static __tc_init_MODULE1 __init_MODULE1;

//--------------------------------------------------------
//  Implementation of skeletons
//--------------------------------------------------------

M::I_skel::I_skel( const CORBA::BOA::ReferenceData &_id )
{
  CORBA::ImplementationDef_var _impl =
    _find_impl( "IDL:M/I:1.0", "I" );
  assert( !CORBA::is_nil( _impl ) );
  _create_ref( _id,
    CORBA::InterfaceDef::_nil(),
    _impl,
    "IDL:M/I:1.0" );
  register_dispatcher( new StaticInterfaceDispatcherWrapper<I_skel>( this ) );
}

M::I_skel::I_skel( CORBA::Object_ptr _obj )
{
  CORBA::ImplementationDef_var _impl =
    _find_impl( "IDL:M/I:1.0", "I" );
  assert( !CORBA::is_nil( _impl ) );
  _restore_ref( _obj,
    CORBA::BOA::ReferenceData(),
    CORBA::InterfaceDef::_nil(),
    _impl );
  register_dispatcher( new StaticInterfaceDispatcherWrapper<I_skel>( this ) );
}

M::I_skel::~I_skel()
{
}

bool M::I_skel::dispatch( CORBA::StaticServerRequest_ptr /*_req*/, CORBA::Environment & /*_env*/ )
{
  return false;
}

M::I_ptr M::I_skel::_this()
{
  return M::I::_duplicate( this );
}

