//*CMZ : 1.03/06 27/10/97 03.23.58 by Fons Rademakers
//*-- Author : Rene Brun 06/03/95
//*KEEP,CopyRight,T=C.
/*************************************************************************
* Copyright(c) 1995-1999, The ROOT System, All rights reserved. *
* Authors: Rene Brun and Fons Rademakers. *
* *
* For the licensing terms see $ROOTSYS/AA_LICENSE. *
* For the list of contributors see $ROOTSYS/AA_CREDITS. *
*************************************************************************/
//*KEND.
//////////////////////////////////////////////////////////////////////////
// //
// TArrayD //
// //
// Array of doubles (64 bits per element). //
// //
//////////////////////////////////////////////////////////////////////////
//*KEEP,TArrayD.
#include "TArrayD.h"
//*KEEP,TBuffer.
#include "TBuffer.h"
//*KEND.
ClassImp(TArrayD)
//______________________________________________________________________________
TArrayD::TArrayD()
{
// Default TArrayD ctor.
fArray = 0;
}
//______________________________________________________________________________
TArrayD::TArrayD(Int_t n)
{
// Create TArrayD object and set array size to n doubles.
fArray = 0;
if (n > 0) Set(n);
}
//______________________________________________________________________________
TArrayD::TArrayD(Int_t n, Double_t *array)
{
// Create TArrayD object and initialize it with values of array.
fArray = 0;
Set(n, array);
}
//______________________________________________________________________________
TArrayD::TArrayD(const TArrayD &array)
{
// Copy constructor.
fArray = 0;
Set(array.fN, array.fArray);
}
//______________________________________________________________________________
TArrayD &TArrayD::operator=(const TArrayD &rhs)
{
// TArrayD assignment operator.
if (this != &rhs)
Set(rhs.fN, rhs.fArray);
return *this;
}
//______________________________________________________________________________
TArrayD::~TArrayD()
{
// Delete TArrayD object.
delete [] fArray;
fArray = 0;
}
//______________________________________________________________________________
void TArrayD::Adopt(Int_t n, Double_t *arr)
{
// Adopt array arr into TArrayD, i.e. don't copy arr but use it directly
// in TArrayD. User may not delete arr, TArrayD dtor will do it.
if (fArray)
delete [] fArray;
fN = n;
fArray = arr;
}
//______________________________________________________________________________
void TArrayD::AddAt(Double_t c, Int_t i)
{
// Add double c at position i. Check for out of bounds.
if (!BoundsOk("TArrayD::AddAt", i))
i = 0;
fArray[i] = c;
}
//______________________________________________________________________________
void TArrayD::Set(Int_t n)
{
// Set array size of TArrayD object to n doubles.
// If n<0 leave array unchanged.
if (n < 0) return;
if (fArray && fN != n) {
delete [] fArray;
fArray = 0;
}
fN = n;
if (fN == 0) return;
if (!fArray) fArray = new Double_t[fN];
for (Int_t i = 0; i < fN; i++)
fArray[i] = 0;
}
//______________________________________________________________________________
void TArrayD::Set(Int_t n, Double_t *array)
{
// Set array size of TArrayD object to n doubles and copy array.
// If n<0 leave array unchanged.
if (n < 0) return;
if (fArray && fN != n) {
delete [] fArray;
fArray = 0;
}
fN = n;
if (fN == 0) return;
if (!fArray) fArray = new Double_t[fN];
for (Int_t i = 0; i < fN; i++)
fArray[i] = array[i];
}
//_______________________________________________________________________
void TArrayD::Streamer(TBuffer &b)
{
// Stream a TArrayD object.
if (b.IsReading()) {
fN = b.ReadArray(fArray);
} else {
b.WriteArray(fArray, fN);
}
}
//_______________________________________________________________________
TBuffer &operator>>(TBuffer &buf, TArrayD *&obj)
{
// Read TArrayD object from buffer. Declared in ClassDef.
obj = (TArrayD *) TArray::ReadArray(buf, TArrayD::Class());
return buf;
}
ROOT page - Class index - Top of the page
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.