///////////////////////////////////////////////////////////////////////////////
/// \class RAT::GeoSolidFactory
///
/// \brief Factory for solids
///
/// \author Phil G Jones
/// \author Aksel Hallin -- contact person
///
/// REVISION HISTORY:\n
/// 21/06/2013 : P G Jones - New file. \n
///
/// \details Factory for solids, base class for multiple solid factories. This
/// factory will build a single solid and place it in the virtual detector.
///
///////////////////////////////////////////////////////////////////////////////
#ifndef __RAT_GeoSolidFactory_hh__
#define __RAT_GeoSolidFactory_hh__
#include
#include
class G4VSolid;
class G4LogicalVolume;
class G4Material;
namespace RAT
{
class GeoSolidFactory : public GeoFactory
{
public:
/// Construct a GeoSolidFactory, name the factory solid
GeoSolidFactory() : GeoFactory( "solid" ) { }
/// Constructor for derived classes
///
/// @param[in] name of the factory
GeoSolidFactory( const std::string& name ) : GeoFactory( name ) { }
/// Construct the physical volume
///
/// @param[in] table defines the volume
/// @param[in] checkOverlaps when placing
virtual void Construct( DBLinkPtr table,
const bool checkOverlaps );
protected:
/// Place the volume in the virtual detector
///
/// @param[in] name of the volume
/// @param[in] table that defines the volume
/// @param[in] logicalVolume to place in the virtual detector
/// @param[in] checkOverlaps when placing
virtual void PlaceVolume( const std::string& name,
DBLinkPtr table,
G4LogicalVolume* const logicalVolume,
const bool checkOverlaps ) const;
/// Build the logical volume from the solid using the db table
///
/// @param[in] name of the volume
/// @param[in] table that defines the volume
/// @param[in] solid the logical volume extends
/// @param[in] material of the volume
/// @return pointer to the logical volume
G4LogicalVolume* BuildVolume( const std::string& name,
DBLinkPtr table,
G4VSolid* const solid,
G4Material* const material ) const;
};
} //::RAT
#endif