ECCE @ EIC Software
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
G4VCurvedTrajectoryFilter.cc
Go to the documentation of this file. Or view the newest version in sPHENIX GitHub for file G4VCurvedTrajectoryFilter.cc
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 // G4VCurvedTrajectoryFilter class implementation
27 //
28 // First version: Oct 30, 2002 - Jacek Generowicz
29 // --------------------------------------------------------------------
30 
32 
34 {
35 }
36 
38 {
39 }
40 
41 std::vector<G4ThreeVector>*
43 {
44  std::vector<G4ThreeVector>* tmp = fpFilteredPoints;
45  // ParticleChangeForTransport invokes this method (via
46  // PropagatorInField) at every Step, even if the step did not
47  // involve PropagatorInField. Must, therefore, ensure that points
48  // submitted by previous invocations of PIF are not
49  // copied. Therefore the points must be cleared. (Note that the
50  // responsibility for deleting the vector lies with the
51  // SmoothTrajctoryPoint, which is the vector's final destination.)
52  // (jacek 08/11/2002)
53  fpFilteredPoints = nullptr;
54  return tmp;
55 }
56 
57 void
59 {
60  if (fpFilteredPoints != nullptr)
61  {
62  // GimmePoints has not been called (it would have set the
63  // pointer to nullptr), therefore nobody has taken charge of the
64  // points and they will never be deleted!
65  G4cout << "!!!!!!!! Filter: auxiliary points are being memory leaked !!!!!"
66  << G4endl;
67  }
68  fpFilteredPoints = new std::vector<G4ThreeVector>;
69 }