source: trunk/source/event/src/G4StackingMessenger.cc @ 1202

Last change on this file since 1202 was 1196, checked in by garnier, 15 years ago

update CVS release candidate geant4.9.3.01

File size: 4.5 KB
Line 
1//
2// ********************************************************************
3// * License and Disclaimer                                           *
4// *                                                                  *
5// * The  Geant4 software  is  copyright of the Copyright Holders  of *
6// * the Geant4 Collaboration.  It is provided  under  the terms  and *
7// * conditions of the Geant4 Software License,  included in the file *
8// * LICENSE and available at  http://cern.ch/geant4/license .  These *
9// * include a list of copyright holders.                             *
10// *                                                                  *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work  make  any representation or  warranty, express or implied, *
14// * regarding  this  software system or assume any liability for its *
15// * use.  Please see the license in the file  LICENSE  and URL above *
16// * for the full disclaimer and the limitation of liability.         *
17// *                                                                  *
18// * This  code  implementation is the result of  the  scientific and *
19// * technical work of the GEANT4 collaboration.                      *
20// * By using,  copying,  modifying or  distributing the software (or *
21// * any work based  on the software)  you  agree  to acknowledge its *
22// * use  in  resulting  scientific  publications,  and indicate your *
23// * acceptance of all terms of the Geant4 Software license.          *
24// ********************************************************************
25//
26//
27// $Id: G4StackingMessenger.cc,v 1.6 2009/09/16 23:10:46 asaim Exp $
28// GEANT4 tag $Name: geant4-09-03-cand-01 $
29//
30// --------------------------------------------------------------------
31
32#include "G4StackingMessenger.hh"
33#include "G4StackManager.hh"
34#include "G4UIdirectory.hh"
35#include "G4UIcmdWithoutParameter.hh"
36#include "G4UIcmdWithAnInteger.hh"
37#include "G4ios.hh"
38
39G4StackingMessenger::G4StackingMessenger(G4StackManager * fCont)
40:fContainer(fCont)
41{
42  stackDir = new G4UIdirectory("/event/stack/");
43  stackDir->SetGuidance("Stack control commands.");
44
45  statusCmd = new G4UIcmdWithoutParameter("/event/stack/status",this);
46  statusCmd->SetGuidance("List current status of the stack.");
47
48  clearCmd = new G4UIcmdWithAnInteger("/event/stack/clear",this);
49  clearCmd->SetGuidance("Clear stacked tracks.");
50  clearCmd->SetGuidance(" 2 : clear all tracks in all stacks");
51  clearCmd->SetGuidance(" 1 : clear tracks in the urgent and waiting stacks");
52  clearCmd->SetGuidance(" 0 : clear tracks in the waiting stack (default)");
53  clearCmd->SetGuidance("-1 : clear tracks in the urgent stack");
54  clearCmd->SetGuidance("-2 : clear tracks in the postponed stack");
55  clearCmd->SetParameterName("level",true);
56  clearCmd->SetDefaultValue(0);
57  clearCmd->SetRange("level>=-2&&level<=2");
58  clearCmd->AvailableForStates(G4State_GeomClosed,G4State_EventProc);
59
60  verboseCmd = new G4UIcmdWithAnInteger("/event/stack/verbose",this);
61  verboseCmd->SetGuidance("Set verbose level for G4StackManager");
62  verboseCmd->SetGuidance(" 0 : Silence (default)");
63  verboseCmd->SetGuidance(" 1 : Minimum statistics");
64  verboseCmd->SetGuidance(" 2 : Detailed reports");
65  verboseCmd->SetGuidance("Note - this value is overwritten by /event/verbose command.");
66
67}
68
69G4StackingMessenger::~G4StackingMessenger()
70{
71  delete statusCmd;
72  delete clearCmd;
73  delete stackDir;
74}
75
76void G4StackingMessenger::SetNewValue(G4UIcommand * command,G4String newValues)
77{
78  if( command==statusCmd )
79  {
80    G4cout << "========================== Current status of the stack =====" << G4endl;
81    G4cout << " Number of tracks in the stack" << G4endl;
82    G4cout << "    Urgent stack    : " << fContainer->GetNUrgentTrack() << G4endl;
83    G4cout << "    Waiting stack   : " << fContainer->GetNWaitingTrack() << G4endl;
84    G4cout << "    Postponed stack : " << fContainer->GetNPostponedTrack() << G4endl;
85  }
86  else if( command==clearCmd )
87  {
88    G4int vc = clearCmd->GetNewIntValue(newValues);
89    switch (vc)
90    { 
91      case 2:
92        fContainer->ClearPostponeStack();
93      case 1:
94        fContainer->ClearUrgentStack();
95      case 0:
96        fContainer->ClearWaitingStack();
97        break;
98      case -1:
99        fContainer->ClearUrgentStack();
100        break;
101      case -2:
102        fContainer->ClearPostponeStack();
103        break;
104    }
105  }
106  else if( command==verboseCmd )
107  {
108    fContainer->SetVerboseLevel(verboseCmd->GetNewIntValue(newValues));
109  }
110}
111
Note: See TracBrowser for help on using the repository browser.