source: trunk/source/processes/hadronic/models/management/src/G4HadronicInteractionRegistry.cc @ 1340

Last change on this file since 1340 was 1340, checked in by garnier, 14 years ago

update ti head

File size: 3.6 KB
RevLine 
[819]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//
[1315]26// $Id: G4HadronicInteractionRegistry.cc,v 1.10 2010/03/25 15:31:42 vnivanch Exp $
[1340]27// GEANT4 tag $Name: geant4-09-03-ref-09 $
[1055]28//
29// 23-Jan-2009 V.Ivanchenko make the class to be a singleton
30
[819]31#include "G4HadronicInteractionRegistry.hh"
32#include "G4HadronicInteraction.hh"
33
[1055]34G4HadronicInteractionRegistry* G4HadronicInteractionRegistry::theInstance = 0;
35
36G4HadronicInteractionRegistry* G4HadronicInteractionRegistry::Instance()
[819]37{
[1055]38  if(0 == theInstance) {
39    static G4HadronicInteractionRegistry manager;
40    theInstance = &manager;
41  }
42  return theInstance;
[819]43}
44
[1055]45G4HadronicInteractionRegistry::G4HadronicInteractionRegistry()
[1196]46{}
[819]47
[1055]48G4HadronicInteractionRegistry::~G4HadronicInteractionRegistry()
[819]49{
[1055]50  Clean();
[819]51}
52
[1055]53void G4HadronicInteractionRegistry::Clean()
[819]54{
[1228]55  size_t nModels = allModels.size();
[1055]56  //G4cout << "G4HadronicInteractionRegistry::Clean() start " << nModels << G4endl;
57  if(0 < nModels) {
[1196]58    for (size_t i=0; i<nModels; ++i) {
[1055]59      if( allModels[i] ) {
60        //G4cout << "delete " << i << G4endl;
61        //G4cout << allModels[i]->GetModelName() << G4endl;
[1228]62        G4HadronicInteraction * model = allModels[i];
[1055]63        allModels[i] = 0;
[1228]64        delete model;
[1055]65      }
66    }
[1228]67    allModels.clear();
[819]68  }
[1055]69  //G4cout << "G4HadronicInteractionRegistry::Clean() is done " << G4endl;
[819]70}
71
72void G4HadronicInteractionRegistry::
[1055]73RegisterMe(G4HadronicInteraction * aModel)
[819]74{
[1228]75  if(!aModel) { return; }
[1196]76  size_t nModels = allModels.size();
[1055]77  if(nModels > 0) {
[1196]78    for (size_t i=0; i<nModels; ++i) {
[1228]79      if( aModel == allModels[i] ) { return; }
[819]80    }
81  }
[1055]82  //G4cout << "Register model <" << aModel->GetModelName()
[1196]83  //<< ">  " << nModels+1 << G4endl;
[1055]84  allModels.push_back(aModel);
85}
86
87void G4HadronicInteractionRegistry::
88RemoveMe(G4HadronicInteraction * aModel)
89{
[1228]90  if(!aModel) { return; }
[1196]91  size_t nModels = allModels.size();
[1228]92  if(0 == nModels) { return; }
[1196]93  for (size_t i=0; i<nModels; ++i) {
94    if( aModel == allModels[i] ) {
95      //G4cout << "DeRegister model <" << aModel->GetModelName()
96      //<< ">  " << i << G4endl;
97      allModels[i] = 0;
98      return;
[1055]99    }
[819]100  }
101}
Note: See TracBrowser for help on using the repository browser.