/*****************************************************************************
 * Project: RooFit                                                           *
 * Package: RooFitCore                                                       *
 * @(#)root/roofitcore:$Id: RooMPSentinel.cxx 24285 2008-06-16 15:05:15Z wouter $
 * Authors:                                                                  *
 *   WV, Wouter Verkerke, UC Santa Barbara, verkerke@slac.stanford.edu       *
 *   DK, David Kirkby,    UC Irvine,         dkirkby@uci.edu                 *
 *                                                                           *
 * Copyright (c) 2000-2005, Regents of the University of California          *
 *                          and Stanford University. All rights reserved.    *
 *                                                                           *
 * Redistribution and use in source and binary forms,                        *
 * with or without modification, are permitted according to the terms        *
 * listed in LICENSE (http://roofit.sourceforge.net/license.txt)             *
 *****************************************************************************/

//////////////////////////////////////////////////////////////////////////////
//
// BEGIN_HTML
// RooMPSentinel is a singleton class that keeps track of all
// parellel execution processes for goodness-of-fit calculations.
// The primary task of RooMPSentinel is to terminate all server processes
// when the main ROOT process is exiting.
// END_HTML
//


#include "RooFit.h"

#include "RooMPSentinel.h"
#include "RooMPSentinel.h"
#include "RooRealMPFE.h"

ClassImp(RooMPSentinel)
  ;


//_____________________________________________________________________________
RooMPSentinel::RooMPSentinel() 
{
  // Constructor
}



//_____________________________________________________________________________
RooMPSentinel::~RooMPSentinel() 
{
  // Destructor. Terminate all parallel processes still registered with
  // the sentinel

  TIterator *iter = _mpfeSet.createIterator() ;
  RooRealMPFE* mpfe ;
  while((mpfe=(RooRealMPFE*)iter->Next())) {
    mpfe->standby() ;
  }
  delete iter ;
}
 


//_____________________________________________________________________________
void RooMPSentinel::add(RooRealMPFE& mpfe) 
{
  // Register given multi-processor front-end object with the sentinel

  _mpfeSet.add(mpfe,kTRUE) ;
}



//_____________________________________________________________________________
void RooMPSentinel::remove(RooRealMPFE& mpfe) 
{
  // Remove given multi-processor front-end object from the sentinel

  _mpfeSet.remove(mpfe,kTRUE) ;
}

Last change: Wed Jun 25 08:33:24 2008
Last generated: 2008-06-25 08:33

This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.