Geant4  10.03.p03
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
DMXDetectorMessenger Class Reference

#include <DMXDetectorMessenger.hh>

Inheritance diagram for DMXDetectorMessenger:
Collaboration diagram for DMXDetectorMessenger:

Public Member Functions

 DMXDetectorMessenger (DMXDetectorConstruction *)
 
 ~DMXDetectorMessenger ()
 
void SetNewValue (G4UIcommand *, G4String)
 
- Public Member Functions inherited from G4UImessenger
 G4UImessenger ()
 
 G4UImessenger (const G4String &path, const G4String &dsc, G4bool commandsToBeBroadcasted=true)
 
virtual ~G4UImessenger ()
 
virtual G4String GetCurrentValue (G4UIcommand *command)
 
G4bool operator== (const G4UImessenger &messenger) const
 
G4bool CommandsShouldBeInMaster () const
 

Additional Inherited Members

- Protected Member Functions inherited from G4UImessenger
G4String ItoS (G4int i)
 
G4String DtoS (G4double a)
 
G4String BtoS (G4bool b)
 
G4int StoI (G4String s)
 
G4double StoD (G4String s)
 
G4bool StoB (G4String s)
 
void AddUIcommand (G4UIcommand *newCommand)
 
void CreateDirectory (const G4String &path, const G4String &dsc, G4bool commandsToBeBroadcasted=true)
 
template<typename T >
T * CreateCommand (const G4String &cname, const G4String &dsc)
 
- Protected Attributes inherited from G4UImessenger
G4UIdirectorybaseDir
 
G4String baseDirName
 
G4bool commandsShouldBeInMaster
 

Detailed Description

Definition at line 55 of file DMXDetectorMessenger.hh.

Constructor & Destructor Documentation

DMXDetectorMessenger::DMXDetectorMessenger ( DMXDetectorConstruction DC)

Definition at line 55 of file DMXDetectorMessenger.cc.

55  :detectorConstruction(DC) {
56 
57  RoomEKineCutCmd = new G4UIcmdWithADoubleAndUnit("/dmx/RoomMinEnergyCut",this);
58  RoomEKineCutCmd->SetGuidance("Minimum Charged particle cut in ROOM");
59  RoomEKineCutCmd->SetParameterName("ECut",false,false);
60  RoomEKineCutCmd->SetRange("ECut>=250.0*eV");
61  RoomEKineCutCmd->SetDefaultUnit("eV");
62  RoomEKineCutCmd->SetUnitCategory("Energy");
64 
65  EKineCutCmd = new G4UIcmdWithADoubleAndUnit("/dmx/MinEnergyCut",this);
66  EKineCutCmd->SetGuidance("Minimum Charged particle cut inside detector");
67  EKineCutCmd->SetParameterName("ECut",false,false);
68  EKineCutCmd->SetRange("ECut>=250.0*eV");
69  EKineCutCmd->SetDefaultUnit("eV");
70  EKineCutCmd->SetUnitCategory("Energy");
72 
73  RoomTimeCutCmd = new G4UIcmdWithADoubleAndUnit("/dmx/RoomTimeCut",this);
74  RoomTimeCutCmd->SetGuidance("Set Time Cut (for neutrons) inside ROOM");
75  RoomTimeCutCmd->SetParameterName("RTCut",false,false);
76  RoomTimeCutCmd->SetRange("RTCut>0.");
77  RoomTimeCutCmd->SetDefaultUnit("ns");
78  RoomTimeCutCmd->SetUnitCategory("Time");
80 
81  TimeCutCmd = new G4UIcmdWithADoubleAndUnit("/dmx/TimeCut",this);
82  TimeCutCmd->SetGuidance("Set Time Cut (for neutrons) inside detector");
83  TimeCutCmd->SetParameterName("TCut",false,false);
84  TimeCutCmd->SetRange("TCut>0.");
85  TimeCutCmd->SetDefaultUnit("ns");
86  TimeCutCmd->SetUnitCategory("Time");
88 
89 }
void SetUnitCategory(const char *unitCategory)
void SetRange(const char *rs)
Definition: G4UIcommand.hh:125
void SetGuidance(const char *aGuidance)
Definition: G4UIcommand.hh:161
void AvailableForStates(G4ApplicationState s1)
Definition: G4UIcommand.cc:240
void SetDefaultUnit(const char *defUnit)
void SetParameterName(const char *theName, G4bool omittable, G4bool currentAsDefault=false)
DMXDetectorMessenger::~DMXDetectorMessenger ( )

Definition at line 93 of file DMXDetectorMessenger.cc.

94 {
95  delete EKineCutCmd;
96  delete RoomEKineCutCmd;
97  delete RoomTimeCutCmd;
98  delete TimeCutCmd;
99  }

Member Function Documentation

void DMXDetectorMessenger::SetNewValue ( G4UIcommand command,
G4String  newValue 
)
virtual

Reimplemented from G4UImessenger.

Definition at line 103 of file DMXDetectorMessenger.cc.

105 {
106 
107  if(command == EKineCutCmd)
108  detectorConstruction->
109  SetEnergyCut(EKineCutCmd->GetNewDoubleValue(newValue));
110 
111  if(command == RoomEKineCutCmd)
112  detectorConstruction->
113  SetEnergyCut(RoomEKineCutCmd->GetNewDoubleValue(newValue));
114 
115  if(command == TimeCutCmd)
116  detectorConstruction->
117  SetTimeCut(TimeCutCmd->GetNewDoubleValue(newValue));
118 
119  if(command == RoomTimeCutCmd)
120  detectorConstruction->
121  SetRoomTimeCut(RoomTimeCutCmd->GetNewDoubleValue(newValue));
122 
123  //trigger a re-optimization of the geometry
126 
127 
128 }
void GeometryHasBeenModified(G4bool prop=true)
static G4double GetNewDoubleValue(const char *paramString)
void PhysicsHasBeenModified()
static G4RunManager * GetRunManager()
Definition: G4RunManager.cc:79

Here is the call graph for this function:


The documentation for this class was generated from the following files: