Geant4 Cross Reference |
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 // G4coutDestination class implementation 27 // 28 // Authors: H.Yoshida, M.Nagamatu, 1997 29 // -------------------------------------------------------------------- 30 31 #include "G4coutDestination.hh" 32 33 #include <algorithm> 34 35 G4coutDestination* G4coutDestination::masterG4coutDestination = nullptr; 36 37 // -------------------------------------------------------------------- 38 void G4coutDestination::ResetTransformers() 39 { 40 transformersDebug.clear(); 41 transformersCout.clear(); 42 transformersCerr.clear(); 43 } 44 45 // -------------------------------------------------------------------- 46 G4int G4coutDestination::ReceiveG4debug(const G4String& msg) 47 { 48 std::cout << msg << std::flush; 49 return 0; 50 } 51 52 // -------------------------------------------------------------------- 53 G4int G4coutDestination::ReceiveG4cout(const G4String& msg) 54 { 55 std::cout << msg << std::flush; 56 return 0; 57 } 58 59 // -------------------------------------------------------------------- 60 G4int G4coutDestination::ReceiveG4cerr(const G4String& msg) 61 { 62 std::cerr << msg << std::flush; 63 return 0; 64 } 65 66 // -------------------------------------------------------------------- 67 G4int G4coutDestination::ReceiveG4debug_(const G4String& msg) 68 { 69 // Avoid copy of string if not necessary 70 if(!transformersDebug.empty()) 71 { 72 G4String m = msg; 73 G4bool result = true; 74 for(const auto& el : transformersDebug) 75 { 76 result &= el(m); 77 if(!result) 78 { 79 break; 80 } 81 } 82 return (result ? ReceiveG4debug(m) : 0); 83 } 84 85 return ReceiveG4debug(msg); 86 } 87 88 // -------------------------------------------------------------------- 89 G4int G4coutDestination::ReceiveG4cout_(const G4String& msg) 90 { 91 // Avoid copy of string if not necessary 92 if(!transformersCout.empty()) 93 { 94 G4String m = msg; 95 G4bool result = true; 96 for(const auto& el : transformersCout) 97 { 98 result &= el(m); 99 if(!result) 100 { 101 break; 102 } 103 } 104 return (result ? ReceiveG4cout(m) : 0); 105 } 106 107 return ReceiveG4cout(msg); 108 } 109 110 // -------------------------------------------------------------------- 111 G4int G4coutDestination::ReceiveG4cerr_(const G4String& msg) 112 { 113 if(!transformersCout.empty()) 114 { 115 G4String m = msg; 116 std::for_each(transformersCerr.begin(), transformersCerr.end(), 117 [&m](const Transformer& t) { t(m); } 118 // Call transforming function on message 119 ); 120 return ReceiveG4cerr(m); 121 } 122 123 return ReceiveG4cerr(msg); 124 } 125