// @(#)root/cont:$Id$
// Author: Rene Brun   06/03/95

/*************************************************************************
 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers.               *
 * All rights reserved.                                                  *
 *                                                                       *
 * For the licensing terms see $ROOTSYS/LICENSE.                         *
 * For the list of contributors see $ROOTSYS/README/CREDITS.             *
 *************************************************************************/

#ifndef ROOT_TArrayC
#define ROOT_TArrayC


//////////////////////////////////////////////////////////////////////////
//                                                                      //
// TArrayC                                                              //
//                                                                      //
// Array of chars or bytes (8 bits per element).                        //
//                                                                      //
//////////////////////////////////////////////////////////////////////////

#ifndef ROOT_TArray
#include "TArray.h"
#endif


class TArrayC : public TArray {

public:
   Char_t    *fArray;       //[fN] Array of fN chars

   TArrayC();
   TArrayC(Int_t n);
   TArrayC(Int_t n, const Char_t *array);
   TArrayC(const TArrayC &array);
   TArrayC    &operator=(const TArrayC &rhs);
   virtual    ~TArrayC();

   void          Adopt(Int_t n, Char_t *array);
   void          AddAt(Char_t c, Int_t i);
   Char_t        At(Int_t i) const ;
   void          Copy(TArrayC &array) const {array.Set(fN,fArray);}
   const Char_t *GetArray() const { return fArray; }
   Char_t       *GetArray() { return fArray; }
   Double_t      GetAt(Int_t i) const { return At(i); }
   Stat_t        GetSum() const {Stat_t sum=0; for (Int_t i=0;i<fN;i++) sum+=fArray[i]; return sum;}
   void          Reset(Char_t val=0)  {memset(fArray,val,fN*sizeof(Char_t));}
   void          Set(Int_t n);
   void          Set(Int_t n, const Char_t *array);
   void          SetAt(Double_t v, Int_t i) { AddAt((Char_t)v, i); }
   Char_t       &operator[](Int_t i);
   Char_t        operator[](Int_t i) const;

   ClassDef(TArrayC,1)  //Array of chars
};


#if defined R__TEMPLATE_OVERLOAD_BUG
template <>
#endif
inline TBuffer &operator>>(TBuffer &buf, TArrayC *&obj)
{
   // Read TArrayC object from buffer.

   obj = (TArrayC *) TArray::ReadArray(buf, TArrayC::Class());
   return buf;
}

#if defined R__TEMPLATE_OVERLOAD_BUG
template <>
#endif
inline TBuffer &operator<<(TBuffer &buf, const TArrayC *obj)
{
   // Write a TArrayC object into buffer
   return buf << (const TArray*)obj;
}

inline Char_t TArrayC::At(Int_t i) const
{
   if (!BoundsOk("TArrayC::At", i)) return 0;
   return fArray[i];
}

inline Char_t &TArrayC::operator[](Int_t i)
{
   if (!BoundsOk("TArrayC::operator[]", i))
      i = 0;
   return fArray[i];
}

inline Char_t TArrayC::operator[](Int_t i) const
{
   if (!BoundsOk("TArrayC::operator[]", i)) return 0;
   return fArray[i];
}

#endif
 TArrayC.h:1
 TArrayC.h:2
 TArrayC.h:3
 TArrayC.h:4
 TArrayC.h:5
 TArrayC.h:6
 TArrayC.h:7
 TArrayC.h:8
 TArrayC.h:9
 TArrayC.h:10
 TArrayC.h:11
 TArrayC.h:12
 TArrayC.h:13
 TArrayC.h:14
 TArrayC.h:15
 TArrayC.h:16
 TArrayC.h:17
 TArrayC.h:18
 TArrayC.h:19
 TArrayC.h:20
 TArrayC.h:21
 TArrayC.h:22
 TArrayC.h:23
 TArrayC.h:24
 TArrayC.h:25
 TArrayC.h:26
 TArrayC.h:27
 TArrayC.h:28
 TArrayC.h:29
 TArrayC.h:30
 TArrayC.h:31
 TArrayC.h:32
 TArrayC.h:33
 TArrayC.h:34
 TArrayC.h:35
 TArrayC.h:36
 TArrayC.h:37
 TArrayC.h:38
 TArrayC.h:39
 TArrayC.h:40
 TArrayC.h:41
 TArrayC.h:42
 TArrayC.h:43
 TArrayC.h:44
 TArrayC.h:45
 TArrayC.h:46
 TArrayC.h:47
 TArrayC.h:48
 TArrayC.h:49
 TArrayC.h:50
 TArrayC.h:51
 TArrayC.h:52
 TArrayC.h:53
 TArrayC.h:54
 TArrayC.h:55
 TArrayC.h:56
 TArrayC.h:57
 TArrayC.h:58
 TArrayC.h:59
 TArrayC.h:60
 TArrayC.h:61
 TArrayC.h:62
 TArrayC.h:63
 TArrayC.h:64
 TArrayC.h:65
 TArrayC.h:66
 TArrayC.h:67
 TArrayC.h:68
 TArrayC.h:69
 TArrayC.h:70
 TArrayC.h:71
 TArrayC.h:72
 TArrayC.h:73
 TArrayC.h:74
 TArrayC.h:75
 TArrayC.h:76
 TArrayC.h:77
 TArrayC.h:78
 TArrayC.h:79
 TArrayC.h:80
 TArrayC.h:81
 TArrayC.h:82
 TArrayC.h:83
 TArrayC.h:84
 TArrayC.h:85
 TArrayC.h:86
 TArrayC.h:87
 TArrayC.h:88
 TArrayC.h:89
 TArrayC.h:90
 TArrayC.h:91
 TArrayC.h:92
 TArrayC.h:93
 TArrayC.h:94
 TArrayC.h:95
 TArrayC.h:96
 TArrayC.h:97
 TArrayC.h:98
 TArrayC.h:99