Geant4.10
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Public Member Functions
HadrontherapyPhysicsListMessenger Class Reference

#include <HadrontherapyPhysicsListMessenger.hh>

Inheritance diagram for HadrontherapyPhysicsListMessenger:
G4UImessenger

Public Member Functions

 HadrontherapyPhysicsListMessenger (HadrontherapyPhysicsList *)
 
 ~HadrontherapyPhysicsListMessenger ()
 
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
 

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
 

Detailed Description

Definition at line 48 of file HadrontherapyPhysicsListMessenger.hh.

Constructor & Destructor Documentation

HadrontherapyPhysicsListMessenger::HadrontherapyPhysicsListMessenger ( HadrontherapyPhysicsList pPhys)

Definition at line 43 of file HadrontherapyPhysicsListMessenger.cc.

References G4UIcommand::AvailableForStates(), G4State_Idle, G4State_PreInit, G4UIcommand::SetGuidance(), G4UIcmdWithAString::SetParameterName(), G4UIcmdWithADoubleAndUnit::SetParameterName(), G4UIcommand::SetRange(), and G4UIcmdWithADoubleAndUnit::SetUnitCategory().

44 :pPhysicsList(pPhys)
45 {
46  physDir = new G4UIdirectory("/Physics/");
47  physDir->SetGuidance("Commands to activate physics models and set cuts");
48 
49  gammaCutCmd = new G4UIcmdWithADoubleAndUnit("/Physics/setGCut",this);
50  gammaCutCmd->SetGuidance("Set gamma cut.");
51  gammaCutCmd->SetParameterName("Gcut",false);
52  gammaCutCmd->SetUnitCategory("Length");
53  gammaCutCmd->SetRange("Gcut>0.0");
55 
56  electCutCmd = new G4UIcmdWithADoubleAndUnit("/Physics/setECut",this);
57  electCutCmd->SetGuidance("Set electron cut.");
58  electCutCmd->SetParameterName("Ecut",false);
59  electCutCmd->SetUnitCategory("Length");
60  electCutCmd->SetRange("Ecut>0.0");
62 
63  protoCutCmd = new G4UIcmdWithADoubleAndUnit("/Physics/setPCut",this);
64  protoCutCmd->SetGuidance("Set positron cut.");
65  protoCutCmd->SetParameterName("Pcut",false);
66  protoCutCmd->SetUnitCategory("Length");
67  protoCutCmd->SetRange("Pcut>0.0");
69 
70  allCutCmd = new G4UIcmdWithADoubleAndUnit("/Physics/setCuts",this);
71  allCutCmd->SetGuidance("Set cut for all.");
72  allCutCmd->SetParameterName("cut",false);
73  allCutCmd->SetUnitCategory("Length");
74  allCutCmd->SetRange("cut>0.0");
76 
77  allDetectorCmd = new G4UIcmdWithADoubleAndUnit("/Physics/setDetectorCuts",this);
78  allDetectorCmd->SetGuidance("Set cut for all. into Detector");
79  allDetectorCmd->SetParameterName("cut",false);
80  allDetectorCmd->SetUnitCategory("Length");
81  allDetectorCmd->SetRange("cut>0.0");
83 
84  pListCmd = new G4UIcmdWithAString("/Physics/addPhysics",this);
85  pListCmd->SetGuidance("Add physics list.");
86  pListCmd->SetParameterName("PList",false);
88 }
void SetParameterName(const char *theName, G4bool omittable, G4bool currentAsDefault=false)
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:225
void SetParameterName(const char *theName, G4bool omittable, G4bool currentAsDefault=false)
HadrontherapyPhysicsListMessenger::~HadrontherapyPhysicsListMessenger ( )

Definition at line 91 of file HadrontherapyPhysicsListMessenger.cc.

92 {
93  delete gammaCutCmd;
94  delete electCutCmd;
95  delete protoCutCmd;
96  delete allCutCmd;
97  delete allDetectorCmd;
98  delete pListCmd;
99  delete physDir;
100 }

Member Function Documentation

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

Reimplemented from G4UImessenger.

Definition at line 103 of file HadrontherapyPhysicsListMessenger.cc.

References HadrontherapyPhysicsList::AddPhysicsList(), G4UIcmdWithADoubleAndUnit::GetNewDoubleValue(), HadrontherapyPhysicsList::SetCutForElectron(), HadrontherapyPhysicsList::SetCutForGamma(), and HadrontherapyPhysicsList::SetCutForPositron().

105 {
106  if( command == gammaCutCmd )
107  { pPhysicsList->SetCutForGamma(gammaCutCmd->GetNewDoubleValue(newValue));}
108 
109  else if( command == electCutCmd )
110  { pPhysicsList->SetCutForElectron(electCutCmd->GetNewDoubleValue(newValue));}
111 
112  else if( command == protoCutCmd )
113  { pPhysicsList->SetCutForPositron(protoCutCmd->GetNewDoubleValue(newValue));}
114 
115  else if( command == allCutCmd )
116  {
117  G4double cut = allCutCmd->GetNewDoubleValue(newValue);
118  pPhysicsList->SetCutForGamma(cut);
119  pPhysicsList->SetCutForElectron(cut);
120  pPhysicsList->SetCutForPositron(cut);
121  }
122  else if( command == allDetectorCmd)
123  {
124  G4double cut = allDetectorCmd -> GetNewDoubleValue(newValue);
125  pPhysicsList -> SetDetectorCut(cut);
126  }
127  else if( command == pListCmd )
128  { pPhysicsList->AddPhysicsList(newValue);}
129 }
static G4double GetNewDoubleValue(const char *paramString)
void AddPhysicsList(const G4String &name)
double G4double
Definition: G4Types.hh:76

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