⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 typecode.h

📁 编译工具
💻 H
📖 第 1 页 / 共 3 页
字号:
// -*- Mode: C++; -*-//                            Package   : omniORB// typecode.h                 Created on: 03/09/98//                            Author1   : James Weatherall (jnw)//                            Author2   : David Riddoch (djr)////    Copyright (C) 1996-1999 AT&T Laboratories Cambridge////    This file is part of the omniORB library////    The omniORB library is free software; you can redistribute it and/or//    modify it under the terms of the GNU Library General Public//    License as published by the Free Software Foundation; either//    version 2 of the License, or (at your option) any later version.////    This library 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//    Library General Public License for more details.////    You should have received a copy of the GNU Library General Public//    License along with this library; if not, write to the Free//    Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA//    02111-1307, USA////// Description://   Internal typecode classes.///* * $Log: typecode.h,v $ * Revision 1.1.2.4  2002/12/18 15:58:52  dgrisby * Proper clean-up of recursive TypeCodes. * * Revision 1.1.2.3  2001/10/29 17:42:38  dpg1 * Support forward-declared structs/unions, ORB::create_recursive_tc(). * * Revision 1.1.2.2  2001/06/08 17:12:10  dpg1 * Merge all the bug fixes from omni3_develop. * * Revision 1.1.2.1  2001/04/18 17:18:13  sll * Big checkin with the brand new internal APIs. * These files were relocated and scoped with the omni namespace. * * Revision 1.10.2.6  2001/03/13 10:32:06  dpg1 * Fixed point support. * * Revision 1.10.2.5  2000/11/17 19:09:39  dpg1 * Support codeset conversion in any. * * Revision 1.10.2.4  2000/11/09 12:27:55  dpg1 * Huge merge from omni3_develop, plus full long long from omni3_1_develop. * * Revision 1.10.2.3  2000/10/06 16:40:55  sll * Changed to use cdrStream. * * Revision 1.10.2.2  2000/09/27 17:25:45  sll * Changed include/omniORB3 to include/omniORB4. * * Revision 1.10.2.1  2000/07/17 10:35:43  sll * Merged from omni3_develop the diff between omni3_0_0_pre3 and omni3_0_0. * * Revision 1.11  2000/07/13 15:26:02  dpg1 * Merge from omni3_develop for 3.0 release. * * Revision 1.8.6.5  2000/06/22 10:40:13  dpg1 * exception.h renamed to exceptiondefs.h to avoid name clash on some * platforms. * * Revision 1.8.6.4  2000/02/15 13:43:43  djr * Fixed bug in create_union_tc() -- problem if discriminator was an alias. * * Revision 1.8.6.3  1999/10/14 17:31:34  djr * Minor corrections. * * Revision 1.8.6.2  1999/10/14 16:22:04  djr * Implemented logging when system exceptions are thrown. * * Revision 1.8.6.1  1999/09/22 14:26:39  djr * Major rewrite of orbcore to support POA. * * Revision 1.7  1999/07/01 10:28:14  djr * Added two methods to TypeCode_pairlist. * Declare inline methods as inline. * * Revision 1.6  1999/06/18 21:00:31  sll * Updated to CORBA 2.3 mapping. * * Revision 1.5  1999/05/25 17:47:09  sll * Changed to use _CORBA_PseudoValue_Sequence. * * Revision 1.4  1999/03/11 16:25:59  djr * Updated copyright notice * * Revision 1.3  1999/02/18 15:49:30  djr * Simplified NP_namesEqualOrNull() * * Revision 1.2  1999/01/18 13:56:20  djr * Fixed bug in TypeCode_union. * * Revision 1.1  1999/01/07 17:12:37  djr * Initial revision * */#ifndef __TYPECODE_H__#define __TYPECODE_H__#include <exceptiondefs.h>OMNI_NAMESPACE_BEGIN(omni)///////////////////////////// Forward class defines /////////////////////////////// Buffer marshalling & unmarshallingclass TypeCode_offsetTable;class TypeCode_offsetEntry;// Helper class used by the NP_equal functionclass TypeCode_pairlist;// TypeCode internal marshalling class// This class takes care of marshalling & unmarshalling recursive typecodesclass TypeCode_marshaller;// TypeCode reference counting classclass TypeCode_collector;// TypeCode implementation classesclass TypeCode_base;class TypeCode_string;class TypeCode_wstring;class TypeCode_objref;class TypeCode_alias;class TypeCode_sequence;class TypeCode_array;class TypeCode_struct;class TypeCode_except;class TypeCode_enum;class TypeCode_union;// TypeCode parameter list types:enum TypeCode_paramListType {  plt_None,  plt_Simple,  plt_Complex};////////////// Macros //////////////// to cast a CORBA::TypeCode_ptr into a TypeCode_base*#define ToTcBase(a) ((TypeCode_base*)(CORBA::TypeCode_ptr)a)inline TypeCode_base*ToTcBase_Checked(CORBA::TypeCode_ptr a){  if( CORBA::is_nil(a) )    OMNIORB_THROW(BAD_TYPECODE,		  BAD_TYPECODE_TypeCodeIsNil,		  CORBA::COMPLETED_NO);  return (TypeCode_base*) a;}inline const TypeCode_base*ToConstTcBase_Checked(const CORBA::TypeCode* a){  if (CORBA::is_nil((CORBA::TypeCode_ptr)a))    OMNIORB_THROW(BAD_TYPECODE,		  BAD_TYPECODE_TypeCodeIsNil,		  CORBA::COMPLETED_NO);  return (const TypeCode_base*)a;}/////////////////////////////////////////////////////////////////////////////////////////////// TypeCode_alignTable //////////////////////////////////////////////////////////////////////////////////////////////class TypeCode_alignTable {public:  enum InfoType {    it_simple,             // know size and alignment    it_nasty               // data is variable length, or dodgy alignment  };  struct Alignment {    InfoType type;    struct SimpleAlignment {      omni::alignment_t alignment;      CORBA::ULong      size;    };    struct NastyAlignment {      TypeCode_base*    tc;    };    union {      SimpleAlignment simple;      NastyAlignment  nasty;    };  };  inline TypeCode_alignTable() : pd_entries(0), pd_table(0), pd_owns(0) {}  inline ~TypeCode_alignTable() {    if( pd_table ) {      for( unsigned i = 0; i < pd_entries; i++ )	if( i_own(i) )  delete pd_table[i];      delete[] pd_table;      delete[] pd_owns;    }  }  inline void setNumEntries(unsigned n) {    pd_table = (new Alignment*[n]);    unsigned owns_len = n & 31 ? (n>>5) + 1 : (n>>5);    pd_owns = new CORBA::ULong[owns_len];    for( unsigned i = 0; i < owns_len; i++ )  pd_owns[i] = 0;    for( unsigned j = 0; j < n; j++ )         pd_table[j] = 0;  }  inline void add(const TypeCode_alignTable& at, unsigned ati) {    pd_table[pd_entries++] = at.pd_table[ati];  }  inline void set(const TypeCode_alignTable& at) {    setNumEntries(at.entries());    for( unsigned i = 0; i < at.entries(); i++ )  add(at, i);  }  inline void addSimple(omni::alignment_t a, size_t s) {    unsigned i = new_entry();    pd_table[i]->type = it_simple;    pd_table[i]->simple.alignment = a;    pd_table[i]->simple.size = s;  }  inline void addNasty(TypeCode_base* tc) {    unsigned i = new_entry();    pd_table[i]->type = it_nasty;    pd_table[i]->nasty.tc = tc;  }  inline CORBA::Boolean is_simple() const {    return pd_entries == 1 && pd_table[0]->type == it_simple;  }  inline CORBA::Boolean has_only_simple() const {    for( unsigned i = 0; i < pd_entries; i++ )      if( pd_table[i]->type != it_simple )  return 0;    return 1;  }  inline unsigned entries() const { return pd_entries; }  inline const Alignment& operator [] (unsigned i) const {    return *(pd_table[i]);  }private:  inline int i_own(unsigned i) const {    return pd_owns[i >> 5] & (1 << (i & 31));  }  inline void set_i_own(unsigned i) { pd_owns[i >> 5] |= (1 << (i & 31)); }  inline unsigned new_entry() {    pd_table[pd_entries] = new Alignment;    set_i_own(pd_entries);    return pd_entries++;  }  unsigned      pd_entries;  Alignment**   pd_table;  CORBA::ULong* pd_owns;};////////////////////////////////////////////////////////////////////////////////////////////////// TypeCode_base /////////////////////////////////////////////////////////////////////////////////////////////////class TypeCode_base : public CORBA::TypeCode {public:  TypeCode_base(CORBA::TCKind tck);  virtual ~TypeCode_base();  // omniORB marshalling routines specific to simple typecodes  virtual void NP_marshalSimpleParams(cdrStream& nbuf,				      TypeCode_offsetTable*) const;  // omniORB marshalling routines specific to complex typecodes  virtual void NP_marshalComplexParams(cdrStream&,				       TypeCode_offsetTable*) const;  // omniORB recursive typecode & reference count handling  virtual CORBA::Boolean NP_complete_recursive_sequences(TypeCode_base* tc,							 CORBA::ULong offset) {    return 1;  }  virtual CORBA::Boolean NP_complete_recursive(TypeCode_base* tc,					       const char* repoId)  {    return 1;  }  // Complete recursive TypeCodes created using ORB::create_recursive_tc().  // omniORB equality check support functions  static const TypeCode_base* NP_expand(const TypeCode_base* tc);  inline static CORBA::Boolean NP_namesEqual(const char* name1,					     const char* name2) {    // returns 1 if both strings are nil or both strings are non-nil and    // with the same content.    if (name1 && name2) {      return (!strcmp(name1,name2));    }    else {      return (name1 == name2);    }  }  // omniORB internal versions of the OMG TypeCode interface  inline CORBA::TCKind NP_kind() const { return pd_tck; }  CORBA::Boolean NP_equal(const TypeCode_base* TCp,			  CORBA::Boolean equivalent,			  const TypeCode_pairlist* pl) const;  // If equivalent == 1, perform equivalent test as defined in the  //                     CORBA 2.3 TypeCode::equivalent() operation.  // else  //     perform equality test as defined in the CORBA 2.3 TypeCode::equal()  //     operation.  virtual CORBA::Boolean NP_extendedEqual(const TypeCode_base* TCp,					  CORBA::Boolean equivalent,					  const TypeCode_pairlist* pl) const;  // If equivalent == 1, perform equivalent test as defined in the  //                     CORBA 2.3 TypeCode::equivalent() operation.  // else  //     perform equality test as defined in the CORBA 2.3 TypeCode::equal()  //     operation.  virtual const char*    NP_id() const;  virtual const char*    NP_name() const;  virtual CORBA::ULong   NP_member_count() const;  virtual const char*    NP_member_name(CORBA::ULong index) const;  virtual TypeCode_base* NP_member_type(CORBA::ULong index) const;  virtual CORBA::Any*    NP_member_label(CORBA::ULong index) const;  virtual TypeCode_base* NP_discriminator_type() const;  virtual CORBA::Long    NP_default_index() const;  virtual CORBA::ULong   NP_length() const;  virtual TypeCode_base* NP_content_type() const;  virtual CORBA::UShort  NP_fixed_digits() const;  virtual CORBA::Short   NP_fixed_scale() const;  virtual CORBA::Long    NP_param_count() const;  virtual CORBA::Any*    NP_parameter(CORBA::Long) const;  virtual CORBA::Boolean NP_is_nil() const;  inline const TypeCode_alignTable& alignmentTable() const {    return pd_alignmentTable;  }  virtual CORBA::Boolean NP_containsAnAlias();  // Returns true if this TypeCode or any of its members  // is an alias.  Used in the implementation of  // aliasExpand() below.  virtual TypeCode_base* NP_aliasExpand(TypeCode_pairlist*);  // Return a TypeCode equivalent to this, but with aliases expanded  // to the actual type.  It is assumed that this will only be called  // if necassary - ie. the instance it is invoked on really does  // contain an alias.  This is necassary to reduce the number of  // calls to NP_containsAnAlias that are necassary.  //  **This is used to implement aliasExpand() below, and should not  // be called directly**  TypeCode_base* NP_compactTc();  // Return a TypeCode equivalent to this, but with the optional  // name and member_names removed.  virtual void removeOptionalNames();  // This internal function removes any optional names and member_names  // from the typecode  static TypeCode_base* aliasExpand(TypeCode_base* tc);  // Return a duplicate of <tc> with aliases expanded to  // the true type.  inline TypeCode_base* aliasExpandedTc() { return pd_aliasExpandedTc; }  // Returns the alias expanded TypeCode if it has been generated.  inline CORBA::Boolean complete() { return pd_complete; }protected:  TypeCode_alignTable pd_alignmentTable;  // Flag indicating whether this typecode & all it's child typecodes  // are 'complete' (i.e. they contain no unresolved recursive sequences)  CORBA::Boolean pd_complete;  // The garbage collection and marshalling classes require access to the  // internal details of typecodes  friend class TypeCode_collector;  friend class TypeCode_marshaller;  // Garbage-collection related fields.  CORBA::Boolean pd_mark;  CORBA::ULong   pd_ref_count;  CORBA::Boolean pd_loop_member;  CORBA::ULong   pd_internal_ref_count;  CORBA::ULong   pd_internal_depth;  // Placeholder for the cached on-the-wire form of the typecode's  // parameter list. This is only used for complex typecodes that aren't  // part of a loop.  cdrMemoryStream* pd_cached_paramlist;  // A pointer to the alias expanded version of this typecode  // if one has been generated, 0 otherwise. If the alias expanded  // version == this, then the reference is not duplicated.  TypeCode_base* pd_aliasExpandedTc;  // A pointer to the compact version of this typecode if one has  // been generated, 0 otherwise. If the compact version == this,  // then the reference is not duplicated.  // This compact version  has all the optional name and member_name   // field stripped.

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -