Gaudi Framework, version v22r2

Home   Generated: Tue May 10 2011
Public Member Functions | Protected Member Functions | Private Attributes

GaudiHandleBase Class Reference

Base class to handles to be used in lieu of naked pointers to various Gaudi components. More...

#include <GaudiKernel/GaudiHandle.h>

Inheritance diagram for GaudiHandleBase:
Inheritance graph
[legend]
Collaboration diagram for GaudiHandleBase:
Collaboration graph
[legend]

List of all members.

Public Member Functions

std::string typeAndName () const
 The full type and name: "type/name".
std::string type () const
 The concrete component class name: the part before the '/'.
std::string name () const
 The instance name: the part after the '/'.
bool empty () const
 Check if the handle has been set to empty string (i.e.
void setTypeAndName (const std::string &myTypeAndName)
 The component "type/name" string.
void setName (const std::string &myName)
 Set the instance name (part after the '/') without changing the class type.
const std::string pythonPropertyClassName () const
 Name of the componentType with "Handle" appended.
const std::string messageName () const
 name used for printing messages
virtual const std::string pythonRepr () const
 Python representation of handle, i.e.

Protected Member Functions

 GaudiHandleBase (const std::string &myTypeAndName, const std::string &myComponentType, const std::string &myParentName)
 Create a handle ('smart pointer') to a gaudi component.

Private Attributes

std::string m_typeAndName

Detailed Description

Base class to handles to be used in lieu of naked pointers to various Gaudi components.

This allows better control through the framework of component loading, configuration and usage. This base class implements common features.

Author:
Martin.Woudstra@cern.ch

Definition at line 80 of file GaudiHandle.h.


Constructor & Destructor Documentation

GaudiHandleBase::GaudiHandleBase ( const std::string myTypeAndName,
const std::string myComponentType,
const std::string myParentName 
) [inline, protected]

Create a handle ('smart pointer') to a gaudi component.

Parameters:
myTypeAndName,:"MyType/MyName" ("MyType" is short for "MyType/MyType") 'MyType' is the name of the concrete class of the component 'MyName' is to distinguish several instances of the same concrete class
myComponentType,:string indicating what type of component the handle is pointing to. For example: "PublicTool", "PrivateTool", "Service". This is used for printout and on the python side for type checking. On the python side there are classes with these names with "Handle" appended: PublicToolHandle,PrivateToolHandle,ServiceHandle
myParentName,:Name of the parent that has this handle as a member. Used in printout.

Definition at line 96 of file GaudiHandle.h.

    : GaudiHandleInfo(myComponentType,myParentName)
  {
    setTypeAndName(myTypeAndName);
  }

Member Function Documentation

bool GaudiHandleBase::empty ( void   ) const [inline]

Check if the handle has been set to empty string (i.e.

typeAndName string is empty).

Definition at line 118 of file GaudiHandle.h.

                     {
    return m_typeAndName.empty();
  }
const std::string GaudiHandleBase::messageName (  ) const

name used for printing messages

Definition at line 48 of file GaudiHandle.cpp.

                                                   {
  std::string propName = propertyName();
  if ( propName.empty() ) {
    propName = pythonPropertyClassName() + "('" + m_typeAndName + "')";
  }
  return parentName() + "." + propName;
}
std::string GaudiHandleBase::name (  ) const

The instance name: the part after the '/'.

Definition at line 24 of file GaudiHandle.cpp.

                                      {
  std::string::size_type slash = m_typeAndName.find('/');
  if ( slash == std::string::npos ) {
    // only type is given, or string is empty.
    // return default name (=type or empty, in this case full string)
    return m_typeAndName;
  } else if ( slash != m_typeAndName.length() -1 ) {
    // an explicit name is given, so return it
    return m_typeAndName.substr(slash+1);
  } else {
    // ends with /, i.e. explicit empty name.
    // Should probably never happen.
    return "";
  }
}
const std::string GaudiHandleBase::pythonPropertyClassName (  ) const [virtual]

Name of the componentType with "Handle" appended.

Used as the python class name for the property in the genconf-generated configurables. The python class is defined in GaudiPython/python/GaudiHandles.py.

Implements GaudiHandleInfo.

Definition at line 44 of file GaudiHandle.cpp.

                                                               {
  return componentType() + "Handle";
}
const std::string GaudiHandleBase::pythonRepr (  ) const [virtual]

Python representation of handle, i.e.

python class name and argument. Can be used in the genconf-generated configurables. The corresponding python classes are defined in GaudiPython/GaudiHandles.py

Implements GaudiHandleInfo.

Definition at line 56 of file GaudiHandle.cpp.

                                                  {
  return pythonPropertyClassName() + "('" + m_typeAndName + "')";
}
void GaudiHandleBase::setName ( const std::string myName )

Set the instance name (part after the '/') without changing the class type.

Definition at line 40 of file GaudiHandle.cpp.

                                                       {
  m_typeAndName = type() + '/' + myName;
}
void GaudiHandleBase::setTypeAndName ( const std::string myTypeAndName )

The component "type/name" string.

Definition at line 9 of file GaudiHandle.cpp.

                                                                     {
  m_typeAndName = myTypeAndName;
}
std::string GaudiHandleBase::type (  ) const

The concrete component class name: the part before the '/'.

Definition at line 13 of file GaudiHandle.cpp.

                                      {
  std::string::size_type slash = m_typeAndName.find('/');
  if ( slash != std::string::npos ) {
    // return only part before /
    return m_typeAndName.substr(0,slash);
  } else {
    // return full string
    return m_typeAndName;
  }
}
std::string GaudiHandleBase::typeAndName (  ) const [inline]

The full type and name: "type/name".

Definition at line 107 of file GaudiHandle.h.

                                {
     return m_typeAndName;
  }

Member Data Documentation

Definition at line 145 of file GaudiHandle.h.


The documentation for this class was generated from the following files:
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Defines

Generated at Tue May 10 2011 18:54:45 for Gaudi Framework, version v22r2 by Doxygen version 1.7.2 written by Dimitri van Heesch, © 1997-2004