50{
52 if (! is_adjoint_tracking_mode)
53 {
54 if (! did_one_adj_part_reach_ext_source_during_event) {
56 return;
57 }
58 if (theUserFwdSteppingAction != nullptr) {
59 theUserFwdSteppingAction->UserSteppingAction(aStep);
60 }
61 return;
62 }
63
64
65
66
67 did_adj_part_reach_ext_source = false;
68 if (theUserAdjointSteppingAction != nullptr) {
69 theUserAdjointSteppingAction->UserSteppingAction(aStep);
70 }
71
74
77 }
78
79
80
81
84 did_adj_part_reach_ext_source = false;
85 return;
86 }
87
88
89
90
91 G4String surface_name;
95 if (theG4AdjointCrossSurfChecker->CrossingOneOfTheRegisteredSurface(
96 aStep, surface_name, crossing_pos, cos_to_surface, GoingIn))
97 {
98 if (surface_name == "ExternalSource") {
99
100 did_adj_part_reach_ext_source = true;
101 did_one_adj_part_reach_ext_source_during_event = true;
103
104
109 last_pos = crossing_pos;
110 return;
111 }
112 if (surface_name == "AdjointSource" && GoingIn) {
113 did_adj_part_reach_ext_source = false;
115 return;
116 }
117 }
118
119
120
122 did_adj_part_reach_ext_source = true;
123 did_one_adj_part_reach_ext_source_during_event = true;
128 last_pos = crossing_pos;
129 return;
130 }
131}
CLHEP::Hep3Vector G4ThreeVector
const G4String & GetParticleType() const
G4int GetBaryonNumber() const
G4StepStatus GetStepStatus() const
G4Track * GetTrack() const
G4StepPoint * GetPostStepPoint() const
void SetTrackStatus(const G4TrackStatus aTrackStatus)
G4double GetWeight() const
G4ThreeVector GetMomentum() const
G4ParticleDefinition * GetDefinition() const
G4double GetKineticEnergy() const