16#ifndef ROO_TEMPLATE_PROXY 
   17#define ROO_TEMPLATE_PROXY 
  163  template<typename Bool = bool, typename = std::enable_if_t<std::is_same<Bool,bool>::value>>
 
  165      Bool valueServer=
true, 
bool shapeServer=
false, 
bool proxyOwnsArg=
false)
 
  166  : 
RooArgProxy(theName, desc, 
owner, valueServer, shapeServer, proxyOwnsArg) {
 
  188      bool valueServer=
true, 
bool shapeServer=
false, 
bool proxyOwnsArg=
false) :
 
  189        RooArgProxy(theName, desc, 
owner, const_cast<typename std::remove_const<T>::
type&>(ref), valueServer, shapeServer, proxyOwnsArg) { }
 
  205    if (
_arg && !
dynamic_cast<const T*
>(
_arg)) {
 
  206      if (allowWrongTypes) {
 
  207        coutE(InputArguments) << 
"Error trying to copy an argument from a proxy with an incompatible payload." << std::endl;
 
  209        throw std::invalid_argument(
"Tried to construct a RooTemplateProxy with incompatible payload.");
 
  219    return static_cast<T&
>(*_arg);
 
  224    return static_cast<T*
>(
_arg);
 
  230  operator typename T::value_type()
 const {
 
  239      if (std::string(
arg().
GetName()) != newRef.GetName()) {
 
  240        newRef.setAttribute((
"ORIGNAME:" + std::string(
arg().
GetName())).c_str()) ;
 
  252  template<
class U, 
class... ConstructorArgs>
 
  256      throw std::runtime_error(
"Error in RooTemplateProxy: emplaceOwnedArg<>() called on a proxy already owning an arg.");
 
  258    auto ownedArg = 
new U{std::forward<ConstructorArgs>(constructorArgs)...};
 
  272      throw std::runtime_error(
"Error in RooTemplateProxy: putOwnedArg<>() called on a proxy already owning an arg.");
 
  274    auto argPtr = ownedArg.get();
 
  275    setArg(*ownedArg.release());
 
  291    return arg().getCurrentLabel();
 
  296    return arg().hasRange(rangeName);
 
  300  const T& 
arg()
 const { 
return static_cast<const T&
>(*_arg); }
 
  305    lvptr(
static_cast<T*
>(
nullptr))->operator=(
value);
 
  310    static_assert(std::is_base_of<RooAbsCategory, T>::value, 
"Strings can only be assigned to category proxies.");
 
  316  double min(
const char* rname=
nullptr)
 const  { 
return lvptr(
static_cast<const T*
>(
nullptr))->getMin(rname) ; }
 
  318  double max(
const char* rname=
nullptr)
 const  { 
return lvptr(
static_cast<const T*
>(
nullptr))->getMax(rname) ; }
 
  320  bool hasMin(
const char* rname=
nullptr)
 const { 
return lvptr(
static_cast<const T*
>(
nullptr))->hasMin(rname) ; }
 
  322  bool hasMax(
const char* rname=
nullptr)
 const { 
return lvptr(
static_cast<const T*
>(
nullptr))->hasMax(rname) ; }
 
  329  using LValue_t = 
typename std::conditional<std::is_base_of<RooAbsReal, T>::value,
 
  350  R__SUGGEST_ALTERNATIVE(
"The template argument of RooTemplateProxy needs to derive from RooAbsRealLValue or RooAbsCategoryLValue to safely call this function.") {
 
  361  R__SUGGEST_ALTERNATIVE(
"The template argument of RooTemplateProxy needs to derive from RooAbsRealLValue or RooAbsCategoryLValue to safely call this function.") {
 
#define R__SUGGEST_ALTERNATIVE(ALTERNATIVE)
#define ClassDefOverride(name, id)
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void value
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t Atom_t Time_t type
Common abstract base class for objects that represent a value and a "shape" in RooFit.
Abstract base class for objects that represent a discrete value that can be set from the outside,...
A space to attach TBranches.
virtual value_type getCurrentIndex() const
Return index number of current state.
RooArgSet * _nset
! Normalization set to be used for evaluation of RooAbsPdf contents
RooAbsRealLValue is the common abstract base class for objects that represent a real value that may a...
Abstract base class for objects that represent a real value and implements functionality common to al...
double getVal(const RooArgSet *normalisationSet=nullptr) const
Evaluate object.
Abstract interface for RooAbsArg proxy classes.
RooAbsArg * _owner
Pointer to owner of proxy.
bool _ownArg
If true proxy owns contents.
RooAbsArg * owner() const
Returns the owner of this proxy.
RooAbsArg * _arg
Pointer to content of proxy.
bool changePointer(const RooAbsCollection &newServerSet, bool nameChange=false, bool factoryInitMode=false) override
Change proxied object to object of same name in given list.
RooArgSet is a container object that can hold multiple RooAbsArg objects.
TObject * Clone(const char *newName=nullptr) const override
Make a clone of an object using the Streamer facility.
LValue_t * lvptr(RooAbsArg *)
Return l-value pointer to contents.
bool hasRange(const char *rangeName) const
Check if the stored object has a range with the given name.
T & operator*() const
Return reference to the proxied object.
T::value_type retrieveValue(const RooAbsCategory &cat) const
Retrieve index state from a category.
RooTemplateProxy(const char *theName, RooAbsArg *owner, const RooTemplateProxy< U > &other, bool allowWrongTypes=false)
Copy from an existing proxy.
RooTemplateProxy< T > & operator=(typename T::value_type value)
Assign a new value to the object pointed to by the proxy.
bool hasMin(const char *rname=nullptr) const
Check if the range has a lower bound. This requires the payload to be RooAbsRealLValue or derived.
U & putOwnedArg(std::unique_ptr< U > ownedArg)
Move a new object held and owned by proxy.
RooTemplateProxy< T > & operator=(const std::string &newState)
Set a category state using its state name. This function can only work for category-type proxies.
const LValue_t * lvptr(const RooAbsArg *) const
Return l-value pointer to contents.
RooTemplateProxy(const char *theName, const char *desc, RooAbsArg *owner, T &ref, bool valueServer=true, bool shapeServer=false, bool proxyOwnsArg=false)
Constructor with owner and proxied object.
const LValue_t * lvptr(const LValue_t *) const
Return l-value pointer to contents.
RooTemplateProxy(const char *theName, const char *desc, RooAbsArg *owner, Bool valueServer=true, bool shapeServer=false, bool proxyOwnsArg=false)
Constructor with owner.
const char * label() const
Get the label of the current category state. This function only makes sense for category proxies.
bool hasMax(const char *rname=nullptr) const
Check if the range has a upper bound. This requires the payload to be RooAbsRealLValue or derived.
double max(const char *rname=nullptr) const
Query upper limit of range. This requires the payload to be RooAbsRealLValue or derived.
T * operator->() const
Member access operator to proxied object.
LValue_t * lvptr(LValue_t *)
Return l-value pointer to contents.
T::value_type retrieveValue(const RooAbsReal &real) const
Retrieve value from a real-valued object.
bool setArg(T &newRef)
Change object held in proxy into newRef.
U & emplaceOwnedArg(ConstructorArgs &&... constructorArgs)
Create a new object held and owned by proxy.
const T & arg() const
Return reference to object held in proxy.
double min(const char *rname=nullptr) const
Query lower limit of range. This requires the payload to be RooAbsRealLValue or derived.
typename std::conditional< std::is_base_of< RooAbsReal, T >::value, RooAbsRealLValue, RooAbsCategoryLValue >::type LValue_t
Are we a real-valued proxy or a category proxy?
const char * GetName() const override
Returns name of object.
Mother of all ROOT objects.