//*CMZ : 2.23/07 25/10/99 18.54.13 by Fons Rademakers
//*CMZ : 1.03/09 07/12/97 12.15.59 by Fons Rademakers
//*-- Author : Rene Brun 04/02/95
//*KEEP,CopyRight,T=C.
/*************************************************************************
* Copyright(c) 1995-1999, The ROOT System, All rights reserved. *
* Authors: Rene Brun and Fons Rademakers. *
* *
* For the licensing terms see $ROOTSYS/AA_LICENSE. *
* For the list of contributors see $ROOTSYS/AA_CREDITS. *
*************************************************************************/
//*KEND.
//////////////////////////////////////////////////////////////////////////
// // //
// Basic data type descriptor (datatype information is obtained from //
// CINT). This class describes the attributes of type definitions //
// (typedef's). The TROOT class contains a list of all currently //
// defined types (accessible via TROOT::GetListOfTypes()). //
// //
//////////////////////////////////////////////////////////////////////////
//*KEEP,TDataType.
#include "TDataType.h"
//*KEEP,TInterpreter, T=C++.
#include "TInterpreter.h"
//*KEEP,Api.
#include "Api.h"
//*KEND.
ClassImp(TDataType)
//______________________________________________________________________________
TDataType::TDataType(G__TypedefInfo *info) : TDictionary()
{
// Default TDataType ctor. TDataTypes are constructed in TROOT via
// a call to TCint::UpdateListOfTypes().
fInfo = info;
fName = info->Name();
if (fInfo)
SetType(fInfo->TrueName());
}
//______________________________________________________________________________
TDataType::TDataType(const char *typenam)
{
// Constructor for basic data types, like "char", "unsigned char", etc.
fInfo = 0;
fName = typenam;
SetType(fName.Data());
}
//______________________________________________________________________________
TDataType::~TDataType()
{
// TDataType dtor deletes adopted G__TypedefInfo object.
delete fInfo;
}
//______________________________________________________________________________
const char *TDataType::GetTypeName() const
{
// Get basic type of typedef, e,g.: "class TDirectory*" -> "TDirectory".
// Result needs to be used or copied immediately.
if (fInfo)
return gInterpreter->TypeName(fInfo->TrueName());
else
return fName.Data();
}
//______________________________________________________________________________
const char *TDataType::GetFullTypeName() const
{
// Get full type description of typedef, e,g.: "class TDirectory*".
if (fInfo)
return fInfo->TrueName();
else
return fName.Data();
}
//______________________________________________________________________________
const char *TDataType::GetName() const
{
// Get name of typedef.
return fName.Data();
}
//______________________________________________________________________________
const char *TDataType::GetTitle() const
{
// Get typedef description string (comment).
if (fInfo)
return fInfo->Title();
else
return "Builtin basic type";
}
//______________________________________________________________________________
Int_t TDataType::Compare(TObject *obj)
{
// Compare to other object. Returns 0<, 0 or >0 depending on
// whether "this" is lexicographically less than, equal to, or
// greater than obj.
return strcmp(fName.Data(), obj->GetName());
}
//______________________________________________________________________________
ULong_t TDataType::Hash()
{
// Return hash value for TDataType based on its name.
return fName.Hash();
}
//______________________________________________________________________________
const char *TDataType::AsString(void *buf) const
{
// Return string containing value in buffer formatted according to
// the basic data type. The result needs to be used or copied immediately.
static char line[80];
const char *name;
if (fInfo)
name = fInfo->TrueName();
else
name = fName.Data();
line[0] = 0;
if (!strcmp("unsigned int", name))
sprintf(line, "%u", *(unsigned int *)buf);
else if (!strcmp("int", name))
sprintf(line, "%d", *(int *)buf);
else if (!strcmp("unsigned long", name))
sprintf(line, "%lu", *(unsigned long *)buf);
else if (!strcmp("long", name))
sprintf(line, "%ld", *(long *)buf);
else if (!strcmp("unsigned short", name))
sprintf(line, "%hu", *(unsigned short *)buf);
else if (!strcmp("short", name))
sprintf(line, "%hd", *(short *)buf);
else if (!strcmp("unsigned char", name))
sprintf(line, "%u", *(unsigned char *)buf);
else if (!strcmp("char", name))
sprintf(line, "%d", *(char *)buf);
else if (!strcmp("float", name))
sprintf(line, "%g", *(float *)buf);
else if (!strcmp("double", name))
sprintf(line, "%g", *(double *)buf);
return line;
}
//______________________________________________________________________________
Long_t TDataType::Property() const
{
// Get property description word. For meaning of bits see EProperty.
if (fInfo)
return fInfo->Property();
else
return (Long_t) kIsFundamental;
}
//______________________________________________________________________________
void TDataType::SetType(const char *name)
{
// Set type id depending on name.
fType = kOther_t;
fSize = 0;
if (!strcmp("unsigned int", name)) {
fType = kUInt_t;
fSize = sizeof(UInt_t);
} else if (!strcmp("int", name)) {
fType = kInt_t;
fSize = sizeof(Int_t);
} else if (!strcmp("unsigned long", name)) {
fType = kULong_t;
fSize = sizeof(ULong_t);
} else if (!strcmp("long", name)) {
fType = kLong_t;
fSize = sizeof(Long_t);
} else if (!strcmp("unsigned short", name)) {
fType = kUShort_t;
fSize = sizeof(UShort_t);
} else if (!strcmp("short", name)) {
fType = kShort_t;
fSize = sizeof(Short_t);
} else if (!strcmp("unsigned char", name)) {
fType = kUChar_t;
fSize = sizeof(UChar_t);
} else if (!strcmp("char", name)) {
fType = kChar_t;
fSize = sizeof(Char_t);
} else if (!strcmp("float", name)) {
fType = kFloat_t;
fSize = sizeof(Float_t);
} else if (!strcmp("double", name)) {
fType = kDouble_t;
fSize = sizeof(Double_t);
}
}
//______________________________________________________________________________
Int_t TDataType::Size() const
{
// Get size of basic typedef'ed type.
if (fInfo)
return fInfo->Size();
else
return fSize;
}
ROOT page - Class index - Top of the page
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.