/*****************************************************************************
 * 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
// RooAbsDataStore is the abstract base class for data collection that
// use a TTree as internal storage mechanism
// END_HTML
//

#include "RooFit.h"
#include "RooMsgService.h"
#include "RooAbsDataStore.h"

#include "Riostream.h"
#include <iomanip>
#include "TClass.h"

using namespace std ;

ClassImp(RooAbsDataStore)
;


//_____________________________________________________________________________
RooAbsDataStore::RooAbsDataStore() 
{
  // Default constructor
  _iterator = _vars.createIterator() ;
  _cacheIter = _cachedVars.createIterator() ;
  _doDirtyProp = kTRUE ;
}




//_____________________________________________________________________________
RooAbsDataStore::RooAbsDataStore(const char* name, const char* title, const RooArgSet& vars) : 
  TNamed(name,title)
{
  // Default constructor

  // clone the fundamentals of the given data set into internal buffer
  _vars.add(vars) ;

  _iterator = _vars.createIterator() ;
  _cacheIter = _cachedVars.createIterator() ;
  _doDirtyProp = kTRUE ;
}




//_____________________________________________________________________________
RooAbsDataStore::RooAbsDataStore(const RooAbsDataStore& other, const char* newname) : TNamed(other), RooPrintable(other)
{
  if (newname) {
    SetName(newname) ;
  }
  _vars.add(other._vars) ;
  _iterator = _vars.createIterator() ;
  _cacheIter = _cachedVars.createIterator() ;
  _doDirtyProp = other._doDirtyProp ;
}



//_____________________________________________________________________________
RooAbsDataStore::RooAbsDataStore(const RooAbsDataStore& other, const RooArgSet& vars, const char* newname) : TNamed(other), RooPrintable(other)
{
  if (newname) {
    SetName(newname) ;
  }
  _vars.add(vars) ;
  _iterator = _vars.createIterator() ;
  _cacheIter = _cachedVars.createIterator() ;
  _doDirtyProp = other._doDirtyProp ;
}



//_____________________________________________________________________________
RooAbsDataStore::~RooAbsDataStore()
{
  // Destructor
  delete _iterator ;
  delete _cacheIter ;
}



//_____________________________________________________________________________
Bool_t RooAbsDataStore::valid() const 
{
  // Return true if currently loaded coordinate is considered valid within
  // the current range definitions of all observables
  return kTRUE ;
}


//_____________________________________________________________________________
void RooAbsDataStore::printName(ostream& os) const 
{
  // Print name of dataset

  os << GetName() ;
}



//_____________________________________________________________________________
void RooAbsDataStore::printTitle(ostream& os) const 
{
  // Print title of dataset
  os << GetTitle() ;
}



//_____________________________________________________________________________
void RooAbsDataStore::printClassName(ostream& os) const 
{
  // Print class name of dataset
  os << IsA()->GetName() ;
}



//_____________________________________________________________________________
void RooAbsDataStore::printValue(ostream& os) const 
{
  // Print value of the dataset, i.e. the sum of weights contained in the dataset
  os << numEntries() << " entries" ;
}



//_____________________________________________________________________________
void RooAbsDataStore::printArgs(ostream& os) const 
{
  // Print argument of dataset, i.e. the observable names

  os << "[" ;    
  _iterator->Reset() ;
  RooAbsArg* arg ;
  Bool_t first(kTRUE) ;
  while((arg=(RooAbsArg*)_iterator->Next())) {
    if (first) {
      first=kFALSE ;
    } else {
      os << "," ;
    }
    os << arg->GetName() ;
  }
  os << "]" ;
}






//_____________________________________________________________________________
Int_t RooAbsDataStore::defaultPrintContents(Option_t* /*opt*/) const 
{
  // Define default print options, for a given print style

  return kName|kClassName|kArgs|kValue ;
}





//_____________________________________________________________________________
void RooAbsDataStore::printMultiline(ostream& os, Int_t /*content*/, Bool_t verbose, TString indent) const 
{
  // Detailed printing interface

  os << indent << "DataStore " << GetName() << " (" << GetTitle() << ")" << endl ;
  os << indent << "  Contains " << numEntries() << " entries" << endl;

  if (!verbose) {
    os << indent << "  Observables " << _vars << endl ;
  } else {
    os << indent << "  Observables: " << endl ;
    _vars.printStream(os,kName|kValue|kExtras|kTitle,kVerbose,indent+"  ") ;
  }

  if(verbose) {
    if (_cachedVars.getSize()>0) {
      os << indent << "  Caches " << _cachedVars << endl ;
    }
//     if(_truth.getSize() > 0) {
//       os << indent << "  Generated with ";
//       TString deeper(indent) ;
//       deeper += "   " ;
//       _truth.printStream(os,kName|kValue,kStandard,deeper) ;
//     }
  }
}



 RooAbsDataStore.cxx:1
 RooAbsDataStore.cxx:2
 RooAbsDataStore.cxx:3
 RooAbsDataStore.cxx:4
 RooAbsDataStore.cxx:5
 RooAbsDataStore.cxx:6
 RooAbsDataStore.cxx:7
 RooAbsDataStore.cxx:8
 RooAbsDataStore.cxx:9
 RooAbsDataStore.cxx:10
 RooAbsDataStore.cxx:11
 RooAbsDataStore.cxx:12
 RooAbsDataStore.cxx:13
 RooAbsDataStore.cxx:14
 RooAbsDataStore.cxx:15
 RooAbsDataStore.cxx:16
 RooAbsDataStore.cxx:17
 RooAbsDataStore.cxx:18
 RooAbsDataStore.cxx:19
 RooAbsDataStore.cxx:20
 RooAbsDataStore.cxx:21
 RooAbsDataStore.cxx:22
 RooAbsDataStore.cxx:23
 RooAbsDataStore.cxx:24
 RooAbsDataStore.cxx:25
 RooAbsDataStore.cxx:26
 RooAbsDataStore.cxx:27
 RooAbsDataStore.cxx:28
 RooAbsDataStore.cxx:29
 RooAbsDataStore.cxx:30
 RooAbsDataStore.cxx:31
 RooAbsDataStore.cxx:32
 RooAbsDataStore.cxx:33
 RooAbsDataStore.cxx:34
 RooAbsDataStore.cxx:35
 RooAbsDataStore.cxx:36
 RooAbsDataStore.cxx:37
 RooAbsDataStore.cxx:38
 RooAbsDataStore.cxx:39
 RooAbsDataStore.cxx:40
 RooAbsDataStore.cxx:41
 RooAbsDataStore.cxx:42
 RooAbsDataStore.cxx:43
 RooAbsDataStore.cxx:44
 RooAbsDataStore.cxx:45
 RooAbsDataStore.cxx:46
 RooAbsDataStore.cxx:47
 RooAbsDataStore.cxx:48
 RooAbsDataStore.cxx:49
 RooAbsDataStore.cxx:50
 RooAbsDataStore.cxx:51
 RooAbsDataStore.cxx:52
 RooAbsDataStore.cxx:53
 RooAbsDataStore.cxx:54
 RooAbsDataStore.cxx:55
 RooAbsDataStore.cxx:56
 RooAbsDataStore.cxx:57
 RooAbsDataStore.cxx:58
 RooAbsDataStore.cxx:59
 RooAbsDataStore.cxx:60
 RooAbsDataStore.cxx:61
 RooAbsDataStore.cxx:62
 RooAbsDataStore.cxx:63
 RooAbsDataStore.cxx:64
 RooAbsDataStore.cxx:65
 RooAbsDataStore.cxx:66
 RooAbsDataStore.cxx:67
 RooAbsDataStore.cxx:68
 RooAbsDataStore.cxx:69
 RooAbsDataStore.cxx:70
 RooAbsDataStore.cxx:71
 RooAbsDataStore.cxx:72
 RooAbsDataStore.cxx:73
 RooAbsDataStore.cxx:74
 RooAbsDataStore.cxx:75
 RooAbsDataStore.cxx:76
 RooAbsDataStore.cxx:77
 RooAbsDataStore.cxx:78
 RooAbsDataStore.cxx:79
 RooAbsDataStore.cxx:80
 RooAbsDataStore.cxx:81
 RooAbsDataStore.cxx:82
 RooAbsDataStore.cxx:83
 RooAbsDataStore.cxx:84
 RooAbsDataStore.cxx:85
 RooAbsDataStore.cxx:86
 RooAbsDataStore.cxx:87
 RooAbsDataStore.cxx:88
 RooAbsDataStore.cxx:89
 RooAbsDataStore.cxx:90
 RooAbsDataStore.cxx:91
 RooAbsDataStore.cxx:92
 RooAbsDataStore.cxx:93
 RooAbsDataStore.cxx:94
 RooAbsDataStore.cxx:95
 RooAbsDataStore.cxx:96
 RooAbsDataStore.cxx:97
 RooAbsDataStore.cxx:98
 RooAbsDataStore.cxx:99
 RooAbsDataStore.cxx:100
 RooAbsDataStore.cxx:101
 RooAbsDataStore.cxx:102
 RooAbsDataStore.cxx:103
 RooAbsDataStore.cxx:104
 RooAbsDataStore.cxx:105
 RooAbsDataStore.cxx:106
 RooAbsDataStore.cxx:107
 RooAbsDataStore.cxx:108
 RooAbsDataStore.cxx:109
 RooAbsDataStore.cxx:110
 RooAbsDataStore.cxx:111
 RooAbsDataStore.cxx:112
 RooAbsDataStore.cxx:113
 RooAbsDataStore.cxx:114
 RooAbsDataStore.cxx:115
 RooAbsDataStore.cxx:116
 RooAbsDataStore.cxx:117
 RooAbsDataStore.cxx:118
 RooAbsDataStore.cxx:119
 RooAbsDataStore.cxx:120
 RooAbsDataStore.cxx:121
 RooAbsDataStore.cxx:122
 RooAbsDataStore.cxx:123
 RooAbsDataStore.cxx:124
 RooAbsDataStore.cxx:125
 RooAbsDataStore.cxx:126
 RooAbsDataStore.cxx:127
 RooAbsDataStore.cxx:128
 RooAbsDataStore.cxx:129
 RooAbsDataStore.cxx:130
 RooAbsDataStore.cxx:131
 RooAbsDataStore.cxx:132
 RooAbsDataStore.cxx:133
 RooAbsDataStore.cxx:134
 RooAbsDataStore.cxx:135
 RooAbsDataStore.cxx:136
 RooAbsDataStore.cxx:137
 RooAbsDataStore.cxx:138
 RooAbsDataStore.cxx:139
 RooAbsDataStore.cxx:140
 RooAbsDataStore.cxx:141
 RooAbsDataStore.cxx:142
 RooAbsDataStore.cxx:143
 RooAbsDataStore.cxx:144
 RooAbsDataStore.cxx:145
 RooAbsDataStore.cxx:146
 RooAbsDataStore.cxx:147
 RooAbsDataStore.cxx:148
 RooAbsDataStore.cxx:149
 RooAbsDataStore.cxx:150
 RooAbsDataStore.cxx:151
 RooAbsDataStore.cxx:152
 RooAbsDataStore.cxx:153
 RooAbsDataStore.cxx:154
 RooAbsDataStore.cxx:155
 RooAbsDataStore.cxx:156
 RooAbsDataStore.cxx:157
 RooAbsDataStore.cxx:158
 RooAbsDataStore.cxx:159
 RooAbsDataStore.cxx:160
 RooAbsDataStore.cxx:161
 RooAbsDataStore.cxx:162
 RooAbsDataStore.cxx:163
 RooAbsDataStore.cxx:164
 RooAbsDataStore.cxx:165
 RooAbsDataStore.cxx:166
 RooAbsDataStore.cxx:167
 RooAbsDataStore.cxx:168
 RooAbsDataStore.cxx:169
 RooAbsDataStore.cxx:170
 RooAbsDataStore.cxx:171
 RooAbsDataStore.cxx:172
 RooAbsDataStore.cxx:173
 RooAbsDataStore.cxx:174
 RooAbsDataStore.cxx:175
 RooAbsDataStore.cxx:176
 RooAbsDataStore.cxx:177
 RooAbsDataStore.cxx:178
 RooAbsDataStore.cxx:179
 RooAbsDataStore.cxx:180
 RooAbsDataStore.cxx:181
 RooAbsDataStore.cxx:182
 RooAbsDataStore.cxx:183
 RooAbsDataStore.cxx:184
 RooAbsDataStore.cxx:185
 RooAbsDataStore.cxx:186
 RooAbsDataStore.cxx:187
 RooAbsDataStore.cxx:188
 RooAbsDataStore.cxx:189
 RooAbsDataStore.cxx:190
 RooAbsDataStore.cxx:191
 RooAbsDataStore.cxx:192
 RooAbsDataStore.cxx:193
 RooAbsDataStore.cxx:194
 RooAbsDataStore.cxx:195
 RooAbsDataStore.cxx:196
 RooAbsDataStore.cxx:197
 RooAbsDataStore.cxx:198
 RooAbsDataStore.cxx:199
 RooAbsDataStore.cxx:200
 RooAbsDataStore.cxx:201
 RooAbsDataStore.cxx:202
 RooAbsDataStore.cxx:203
 RooAbsDataStore.cxx:204
 RooAbsDataStore.cxx:205
 RooAbsDataStore.cxx:206
 RooAbsDataStore.cxx:207
 RooAbsDataStore.cxx:208
 RooAbsDataStore.cxx:209
 RooAbsDataStore.cxx:210
 RooAbsDataStore.cxx:211
 RooAbsDataStore.cxx:212
 RooAbsDataStore.cxx:213
 RooAbsDataStore.cxx:214
 RooAbsDataStore.cxx:215
 RooAbsDataStore.cxx:216
 RooAbsDataStore.cxx:217
 RooAbsDataStore.cxx:218