/usr/include/ThePEG/Utilities/Current.h is in libthepeg-dev 1.8.0-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 | // -*- C++ -*-
//
// Current.h is a part of ThePEG - Toolkit for HEP Event Generation
// Copyright (C) 1999-2011 Leif Lonnblad
//
// ThePEG is licenced under version 2 of the GPL, see COPYING for details.
// Please respect the MCnet academic guidelines, see GUIDELINES for details.
//
#ifndef ThePEG_Current_H
#define ThePEG_Current_H
// This is the declaration of the Current class.
namespace ThePEG {
/**
* The Current class keeps a static stack of objects of the templated
* class, which can be used anywhere by any class. When an object is
* active it adds itself to the stack which can be used by any other
* object through the static functions of the Current class. If
* someone needs to use an alternative object a new Current object can
* be constructed with a pointer to the desired object
* as argument and that object will the be used by the static Current
* functions until the Current object is destructed.
*
* Default-contructed objects of the Current class can be used as a
* pointer to the currently chosen object on the stack.
*
* The typical use case for this class is a handler class which uses a
* number of objects which do not have a reference back to the
* handler, but still need to acces some member functions. In a member
* function the handler class will construct a Current object:
* <code>Current<Handler> current(this);</code> in any following
* function called in this member function, any object can then access
* the handlers methods as
* <code>Current<Handler>()->memfun();</code>.
*
*/
template <typename T>
class Current {
public:
/**
* Default constructor does nothing.
*/
Current() : pushed(false) {}
/**
* Copy-constructor does nothing.
*/
Current(const Current<T> &)
: pushed(false) {}
/**
* Construct a new object specifying a new object, \a o, to be used
* during this objects lifetime. The object must not be deleted
* until the Current object us destroyed.
*/
Current(T * t) : pushed(false) {
if ( t ) {
theStack.push_back(t);
pushed = true;
}
}
/**
* The destructor removing the object specified in the constructor
* from the stack.
*/
~Current() {
if ( pushed ) theStack.pop_back();
}
public:
/**
* Returns true if there is no currently chosen object.
*/
static bool isVoid() {
return theStack.empty() || !(theStack.back());
}
/**
* Return a reference to the currently chosen object.
*/
static T & current() {
return *theStack.back();
}
/**
* Return a reference to the currently chosen object.
*/
T & operator*() const {
return *theStack.back();
}
/**
* Return a pointer to the currently chosen object.
*/
T * operator->() const {
return theStack.back();
}
/**
* Pointer to the stack
*/
static T * ptr() {
return theStack.back();
}
/**
* Test for existance
*/
operator bool() const {
return ptr();
}
/**
* Test for existance
*/
bool operator!() const {
return !ptr();
}
private:
/**
* The stack of objects requested.
*/
static vector<T *> theStack;
/**
* True if this object is responsible for pushing an object
* onto the stack.
*/
bool pushed;
private:
/**
* Private and non-existent assignment operator.
*/
Current<T> & operator=(const Current<T> &);
};
template <typename T>
std::vector<T *> ThePEG::Current<T>::theStack;
}
#endif /* ThePEG_Current_H */
|