Revision 716fb731a3c8c9b583235feddac21006994d9626 authored by Kyle Cranmer on 03 August 2011, 22:09:36 UTC, committed by Kyle Cranmer on 03 August 2011, 22:09:36 UTC

git-svn-id: http://root.cern.ch/svn/root/branches/v5-30-00-patches@40446 27541ba8-7e3a-0410-8455-c3a389f83636
1 parent 0db9ccb
Raw File
RooMPSentinel.cxx
/*****************************************************************************
 * Project: RooFit                                                           *
 * Package: RooFitCore                                                       *
 * @(#)root/roofitcore:$Id$
 * 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) ;
}
back to top