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

#include "enums.h"

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

class _Marshaller_enums_x : public CORBA::StaticTypeInfo {
    typedef enums::x _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_enums_x::create() const
{
  return (StaticValueType) new _T;
}

void _Marshaller_enums_x::assign( StaticValueType d, const StaticValueType s ) const
{
  *(_T*) d = *(_T*) s;
}

void _Marshaller_enums_x::free( StaticValueType v ) const
{
  delete (_T*) v;
}

CORBA::Boolean _Marshaller_enums_x::demarshal( CORBA::DataDecoder &dc, StaticValueType v ) const
{
  CORBA::ULong ul;
  if( !dc.enumeration( ul ) )
    return FALSE;
  *(_T*) v = (_T) ul;
  return TRUE;
}

void _Marshaller_enums_x::marshal( CORBA::DataEncoder &ec, StaticValueType v ) const
{
  ec.enumeration( (CORBA::ULong) *(_T *) v );
}

CORBA::StaticTypeInfo *_marshaller_enums_x;


// Stub interface enums
enums::~enums()
{
}

enums_ptr enums::_duplicate( enums_ptr _obj )
{
  if( !CORBA::is_nil( _obj ) )
    _obj->_ref();
  return _obj;
}

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

bool enums::_narrow_helper2( CORBA::Object_ptr _obj )
{
  if( strcmp( _obj->_repoid(), "IDL:enums: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;
}

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

enums_ptr enums::_nil()
{
  return NULL;
}

enums_stub::~enums_stub()
{
}

vector<CORBA::Narrow_proto> * enums::_narrow_helpers;

class _Marshaller_enums : public CORBA::StaticTypeInfo {
    typedef enums_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_enums::create() const
{
  return (StaticValueType) new _T( 0 );
}

void _Marshaller_enums::assign( StaticValueType d, const StaticValueType s ) const
{
  *(_T*) d = ::enums::_duplicate( *(_T*) s );
}

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

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

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

CORBA::StaticTypeInfo *_marshaller_enums;

struct __tc_init_ENUMS {
  __tc_init_ENUMS()
  {
    _marshaller_enums_x = new _Marshaller_enums_x;

    _marshaller_enums = new _Marshaller_enums;

  }
};

static __tc_init_ENUMS __init_ENUMS;

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

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

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

enums_skel::~enums_skel()
{
}

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

enums_ptr enums_skel::_this()
{
  return enums::_duplicate( this );
}

