Logo Search packages:      
Sourcecode: cableswig version File versions  Download package

cxxTypeSystem.cxx

/*=========================================================================

  Program:   CABLE - CABLE Automates Bindings for Language Extension
  Module:    $RCSfile: cxxTypeSystem.cxx,v $
  Language:  C++
  Date:      $Date: 2002/10/23 21:35:02 $
  Version:   $Revision: 1.15 $

  Copyright (c) 2002 Kitware, Inc., Insight Consortium.  All rights reserved.
  See Copyright.txt for details.

     This software is distributed WITHOUT ANY WARRANTY; without even 
     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 
     PURPOSE.  See the above copyright notices for more information.

=========================================================================*/
#include "cxxTypeSystem.h"

#include <map>

namespace _cxx_
{

// A macro to define the class definitions for the classes that wrap
// around stl map instantiations to hide them inside this file.
#define _cxx_DEFINE_MAP_CLASS(type)                                     \
struct TypeSystem::type##Map: public std::map<type##Key, type*>         \
{                                                                       \
  typedef std::map<type##Key, type*>::iterator iterator;                \
  typedef std::map<type##Key, type*>::const_iterator const_iterator;    \
  typedef std::map<type##Key, type*>::value_type value_type;            \
}

// Define the key types for the maps.
typedef std::pair<CvQualifiedType, unsigned long>  ArrayTypeKey;
typedef String ClassTypeKey;
typedef String EnumerationTypeKey;
typedef std::pair<CvQualifiedType, CvQualifiedTypes>  FunctionTypeKey;
typedef FundamentalType::Id FundamentalTypeKey;
typedef CvQualifiedType PointerTypeKey;
typedef std::pair<CvQualifiedType, const ClassType*>  PointerToMemberTypeKey;
typedef CvQualifiedType ReferenceTypeKey;

// The map definitions.
_cxx_DEFINE_MAP_CLASS(ArrayType);
_cxx_DEFINE_MAP_CLASS(ClassType);
_cxx_DEFINE_MAP_CLASS(EnumerationType);
_cxx_DEFINE_MAP_CLASS(FunctionType);
_cxx_DEFINE_MAP_CLASS(FundamentalType);
_cxx_DEFINE_MAP_CLASS(PointerType);
_cxx_DEFINE_MAP_CLASS(PointerToMemberType);
_cxx_DEFINE_MAP_CLASS(ReferenceType);

/**
 * Get the type representation for an ArrayType with the given element type
 * and length.  If one does not exist, it will be created.
 */
const ArrayType*
TypeSystem
00060 ::GetArrayType(const CvQualifiedType& in_elementType,
               unsigned long in_length)
{
  // Create a key to identify this type in the map.
  ArrayTypeKey key(in_elementType, in_length);
  
  // Look for an existing copy of this type.
  ArrayTypeMap::const_iterator i = m_ArrayTypeMap->find(key);
  
  if(i != m_ArrayTypeMap->end())
    {
    // An existing copy was found, return it.
    return i->second;
    }
  else
    {
    // This is a new type.  Generate an entry and return it.
    ArrayType* newArrayType = new ArrayType(in_elementType, in_length);
    m_ArrayTypeMap->insert(ArrayTypeMap::value_type(key,newArrayType));
    return newArrayType;
    }
}


/**
 * Get the type representation for a ClassType with the given name
 * and superclasses.
 * If one does not exist, it will be created.
 * We allow the pointer to a non-const ClassType so that
 * conversion constructor/operator information can be added.
 */
ClassType*
TypeSystem
00093 ::GetClassType(const String& name, bool isCopyable, const ClassTypes& parents)
{
  // Look for an existing copy of this type.
  ClassTypeMap::const_iterator i = m_ClassTypeMap->find(name);
  
  if(i != m_ClassTypeMap->end())
    {
    // An existing copy was found.  Merge in the new information we have
    // and return it.
    i->second->MergeClassInformation(isCopyable, parents);
    return i->second;
    }
  else
    {
    // This is a new type.  Generate an entry and return it.
    ClassType* newClassType = new ClassType(name, isCopyable, parents);
    m_ClassTypeMap->insert(ClassTypeMap::value_type(name, newClassType));
    return newClassType;
    }
}


/**
 * Get the type representation for a EnumerationType with the given name.
 * If one does not exist, it will be created.
 */
const EnumerationType*
TypeSystem
00121 ::GetEnumerationType(const String& name)
{
  // Look for an existing copy of this type.
  EnumerationTypeMap::const_iterator i = m_EnumerationTypeMap->find(name);
  
  if(i != m_EnumerationTypeMap->end())
    {
    // An existing copy was found, return it.
    return i->second;
    }
  else
    {
    // This is a new type.  Generate an entry and return it.
    EnumerationType* newEnumerationType = new EnumerationType(name);
    m_EnumerationTypeMap->insert(EnumerationTypeMap::value_type(name, newEnumerationType));
    return newEnumerationType;
    }
}


/**
 * Get the type representation for a FunctionType with the given return
 * type and argument types.
 */
const FunctionType*
TypeSystem
00147 ::GetFunctionType(const CvQualifiedType& returnType,
                  const CvQualifiedTypes& arguments)
{
  // Create a key to identify this type in the map.
  FunctionTypeKey key(returnType, arguments);
  
  // Look for an existing copy of this type.
  FunctionTypeMap::const_iterator i = m_FunctionTypeMap->find(key);
  
  if(i != m_FunctionTypeMap->end())
    {
    // An existing copy was found, return it.
    return i->second;
    }
  else
    {
    // This is a new type.  Generate an entry and return it.
    FunctionType* newFunctionType =
      new FunctionType(returnType, arguments);
    m_FunctionTypeMap->insert(FunctionTypeMap::value_type(key, newFunctionType));
    return newFunctionType;
    }  
}


/**
 * Get the type representation for a FundamentalType with the given id.
 * If one does not exist, it will be created.
 */
const FundamentalType*
TypeSystem
00178 ::GetFundamentalType(FundamentalType::Id in_id)
{
  // Look for an existing copy of this type.
  FundamentalTypeMap::const_iterator i = m_FundamentalTypeMap->find(in_id);
  
  if(i != m_FundamentalTypeMap->end())
    {
    // An existing copy was found, return it.
    return i->second;
    }
  else
    {
    // This is a new type.  Generate an entry and return it.
    FundamentalType* newFundamentalType = new FundamentalType(in_id);
    m_FundamentalTypeMap->insert(FundamentalTypeMap::value_type(in_id, newFundamentalType));
    return newFundamentalType;
    }
}


/**
 * Get the type representation for a PointerType with the given destination
 * type.  If one does not exist, it will be created.
 */
const PointerType*
TypeSystem
00204 ::GetPointerType(const CvQualifiedType& in_type)
{
  // Look for an existing copy of this type.
  PointerTypeMap::const_iterator i = m_PointerTypeMap->find(in_type);
  
  if(i != m_PointerTypeMap->end())
    {
    // An existing copy was found, return it.
    return i->second;
    }
  else
    {
    // This is a new type.  Generate an entry and return it.
    PointerType* newPointerType = new PointerType(in_type);
    m_PointerTypeMap->insert(PointerTypeMap::value_type(in_type, newPointerType));
    return newPointerType;
    }
}


/**
 * Get the type representation for a PointerToMemberType with the given
 * destination type and ClassType.  If one does not exist, it will be created.
 */
const PointerToMemberType*
TypeSystem
00230 ::GetPointerToMemberType(const CvQualifiedType& in_type,
                            const ClassType* in_class)
{
  // Create a key to identify this type in the map.
  PointerToMemberTypeKey key(in_type, in_class);
  
  // Look for an existing copy of this type.
  PointerToMemberTypeMap::const_iterator i =
    m_PointerToMemberTypeMap->find(key);
  
  if(i != m_PointerToMemberTypeMap->end())
    {
    // An existing copy was found, return it.
    return i->second;
    }
  else
    {
    // This is a new type.  Generate an entry and return it.
    PointerToMemberType* newPointerToMemberType =
      new PointerToMemberType(in_type, in_class);
    m_PointerToMemberTypeMap->insert(PointerToMemberTypeMap::value_type(key, newPointerToMemberType));
    return newPointerToMemberType;
    }
}


/**
 * Get the type representation for a ReferenceType with the given
 * destination type.  If one does not exist, it will be created.
 */
const ReferenceType*
TypeSystem
00262 ::GetReferenceType(const CvQualifiedType& in_type)
{
  // Look for an existing copy of this type.
  ReferenceTypeMap::const_iterator i = m_ReferenceTypeMap->find(in_type);
  
  if(i != m_ReferenceTypeMap->end())
    {
    // An existing copy was found, return it.
    return i->second;
    }
  else
    {
    // This is a new type.  Generate an entry and return it.
    ReferenceType* newReferenceType = new ReferenceType(in_type);
    m_ReferenceTypeMap->insert(ReferenceTypeMap::value_type(in_type, newReferenceType));
    return newReferenceType;
    }
}


/**
 * Constructor creates the internal representation maps.
 */
TypeSystem
00286 ::TypeSystem():
  m_ArrayTypeMap(new ArrayTypeMap),
  m_ClassTypeMap(new ClassTypeMap),
  m_EnumerationTypeMap(new EnumerationTypeMap),
  m_FunctionTypeMap(new FunctionTypeMap),
  m_FundamentalTypeMap(new FundamentalTypeMap),
  m_PointerTypeMap(new PointerTypeMap),
  m_PointerToMemberTypeMap(new PointerToMemberTypeMap),
  m_ReferenceTypeMap(new ReferenceTypeMap)
{
}


/**
 * Destructor frees all existing type representations allocated by
 * this TypeSystem.  It then destroys the internal representation
 * maps.
 */
TypeSystem
00305 ::~TypeSystem()
{
  // First free all type representations in the maps.
  for(ArrayTypeMap::const_iterator i = m_ArrayTypeMap->begin();
      i != m_ArrayTypeMap->end(); ++i)
    {
    delete i->second;
    }
  for(ClassTypeMap::const_iterator i = m_ClassTypeMap->begin();
      i != m_ClassTypeMap->end(); ++i)
    {
    delete i->second;
    }
  for(FunctionTypeMap::const_iterator i = m_FunctionTypeMap->begin();
      i != m_FunctionTypeMap->end(); ++i)
    {
    delete i->second;
    }
  for(FundamentalTypeMap::const_iterator i = m_FundamentalTypeMap->begin();
      i != m_FundamentalTypeMap->end(); ++i)
    {
    delete i->second;
    }
  for(PointerTypeMap::const_iterator i = m_PointerTypeMap->begin();
      i != m_PointerTypeMap->end(); ++i)
    {
    delete i->second;
    }
  for(PointerToMemberTypeMap::const_iterator i = m_PointerToMemberTypeMap->begin();
      i != m_PointerToMemberTypeMap->end(); ++i)
    {
    delete i->second;
    }
  for(ReferenceTypeMap::const_iterator i = m_ReferenceTypeMap->begin();
      i != m_ReferenceTypeMap->end(); ++i)
    {
    delete i->second;
    }
  
  // Now delete the maps themselves.
  delete m_ArrayTypeMap;
  delete m_ClassTypeMap;
  delete m_EnumerationTypeMap;
  delete m_FunctionTypeMap;
  delete m_FundamentalTypeMap;
  delete m_PointerTypeMap;
  delete m_PointerToMemberTypeMap;
  delete m_ReferenceTypeMap;
}


} // namespace _cxx_

Generated by  Doxygen 1.6.0   Back to index