Logo ROOT   6.08/07
Reference Guide
TArrayC.cxx
Go to the documentation of this file.
1 // @(#)root/cont:$Id$
2 // Author: Rene Brun 06/03/95
3 
4 /*************************************************************************
5  * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
6  * All rights reserved. *
7  * *
8  * For the licensing terms see $ROOTSYS/LICENSE. *
9  * For the list of contributors see $ROOTSYS/README/CREDITS. *
10  *************************************************************************/
11 
12 /** \class TArrayC
13 \ingroup Containers
14 Array of chars or bytes (8 bits per element).
15 */
16 
17 #include "TArrayC.h"
18 #include "TBuffer.h"
19 
20 
22 
23 ////////////////////////////////////////////////////////////////////////////////
24 /// Default TArrayC ctor.
25 
27 {
28  fArray = 0;
29 }
30 
31 ////////////////////////////////////////////////////////////////////////////////
32 /// Create TArrayC object and set array size to n chars.
33 
35 {
36  fArray = 0;
37  if (n > 0) Set(n);
38 }
39 
40 ////////////////////////////////////////////////////////////////////////////////
41 /// Create TArrayC object and initialize it with values of array.
42 
44 {
45  fArray = 0;
46  Set(n, array);
47 }
48 
49 ////////////////////////////////////////////////////////////////////////////////
50 /// Copy constructor.
51 
52 TArrayC::TArrayC(const TArrayC &array) : TArray(array)
53 {
54  fArray = 0;
55  Set(array.fN, array.fArray);
56 }
57 
58 ////////////////////////////////////////////////////////////////////////////////
59 /// TArrayC assignment operator.
60 
62 {
63  if (this != &rhs)
64  Set(rhs.fN, rhs.fArray);
65  return *this;
66 }
67 
68 ////////////////////////////////////////////////////////////////////////////////
69 /// Delete TArrayC object.
70 
72 {
73  delete [] fArray;
74  fArray = 0;
75 }
76 
77 ////////////////////////////////////////////////////////////////////////////////
78 /// Adopt array arr into TArrayC, i.e. don't copy arr but use it directly
79 /// in TArrayC. User may not delete arr, TArrayC dtor will do it.
80 
82 {
83  if (fArray)
84  delete [] fArray;
85 
86  fN = n;
87  fArray = arr;
88 }
89 
90 ////////////////////////////////////////////////////////////////////////////////
91 /// Add char c at position i. Check for out of bounds.
92 
94 {
95  if (!BoundsOk("TArrayC::AddAt", i)) return;
96  fArray[i] = c;
97 }
98 
99 ////////////////////////////////////////////////////////////////////////////////
100 /// Set size of this array to n chars.
101 /// A new array is created, the old contents copied to the new array,
102 /// then the old array is deleted.
103 /// This function should not be called if the array was declared via Adopt.
104 
106 {
107  if (n < 0) return;
108  if (n != fN) {
109  Char_t *temp = fArray;
110  if (n != 0) {
111  fArray = new Char_t[n];
112  if (n < fN) memcpy(fArray,temp, n*sizeof(Char_t));
113  else {
114  memcpy(fArray,temp,fN*sizeof(Char_t));
115  memset(&fArray[fN],0,(n-fN)*sizeof(Char_t));
116  }
117  } else {
118  fArray = 0;
119  }
120  if (fN) delete [] temp;
121  fN = n;
122  }
123 }
124 
125 ////////////////////////////////////////////////////////////////////////////////
126 /// Set size of this array to n chars and set the contents.
127 /// This function should not be called if the array was declared via Adopt.
128 
129 void TArrayC::Set(Int_t n, const Char_t *array)
130 {
131  if (fArray && fN != n) {
132  delete [] fArray;
133  fArray = 0;
134  }
135  fN = n;
136  if (fN == 0) return;
137  if (array == 0) return;
138  if (!fArray) fArray = new Char_t[fN];
139  memmove(fArray, array, n*sizeof(Char_t));
140 }
141 
142 ////////////////////////////////////////////////////////////////////////////////
143 /// Stream a TArrayC object.
144 
145 void TArrayC::Streamer(TBuffer &b)
146 {
147  if (b.IsReading()) {
148  Int_t n;
149  b >> n;
150  Set(n);
151  b.ReadFastArray(fArray,n);
152  } else {
153  b << fN;
154  b.WriteFastArray(fArray, fN);
155  }
156 }
157 
Abstract array base class.
Definition: TArray.h:33
TArrayC()
Default TArrayC ctor.
Definition: TArrayC.cxx:26
Bool_t IsReading() const
Definition: TBuffer.h:83
virtual ~TArrayC()
Delete TArrayC object.
Definition: TArrayC.cxx:71
void Set(Int_t n)
Set size of this array to n chars.
Definition: TArrayC.cxx:105
void Adopt(Int_t n, Char_t *array)
Adopt array arr into TArrayC, i.e.
Definition: TArrayC.cxx:81
return c
Buffer base class used for serializing objects.
Definition: TBuffer.h:42
TArrayC & operator=(const TArrayC &rhs)
TArrayC assignment operator.
Definition: TArrayC.cxx:61
int Int_t
Definition: RtypesCore.h:41
Bool_t BoundsOk(const char *where, Int_t at) const
Definition: TArray.h:79
Int_t fN
Definition: TArray.h:40
virtual void ReadFastArray(Bool_t *b, Int_t n)=0
virtual void WriteFastArray(const Bool_t *b, Int_t n)=0
#define ClassImp(name)
Definition: Rtypes.h:279
char Char_t
Definition: RtypesCore.h:29
void AddAt(Char_t c, Int_t i)
Add char c at position i. Check for out of bounds.
Definition: TArrayC.cxx:93
Char_t * fArray
Definition: TArrayC.h:32
you should not use this method at all Int_t Int_t Double_t Double_t Double_t Int_t Double_t Double_t Double_t Double_t b
Definition: TRolke.cxx:630
const Int_t n
Definition: legend1.C:16
Array of chars or bytes (8 bits per element).
Definition: TArrayC.h:29