r109: reorganized header files
[ctsim.git] / include / array2d.h
index 30b92d474d264b6025bc79bcaa7e7f6cda808f92..5eb23b3804b3e66424399ff806f99672da05cc71 100644 (file)
@@ -9,8 +9,14 @@
 **  This is part of the CTSim program
 **  Copyright (C) 1983-2000 Kevin Rosenberg
 **
-**  $Id: array2d.h,v 1.3 2000/06/09 01:35:33 kevin Exp $
+**  $Id: array2d.h,v 1.5 2000/06/19 19:04:05 kevin Exp $
 **  $Log: array2d.h,v $
+**  Revision 1.5  2000/06/19 19:04:05  kevin
+**  reorganized header files
+**
+**  Revision 1.4  2000/06/09 11:03:08  kevin
+**  Made ImageFile inherit from Array2dFile
+**
 **  Revision 1.3  2000/06/09 01:35:33  kevin
 **  Convert MPI structure to C++ class
 **
 #ifndef ARRAY2D_H
 #define ARRAY2D_H
 
-#include <kstddef.h>
+#include "ctsupport.h"
+
 
 template<class T> 
 class Array2d {
- private:
-    unsigned int nx;
-    unsigned int ny;
-
  public:
-
-    T** array_data;
-
     Array2d (unsigned int x, unsigned int y)
+       : nx(x), ny(y), array_data(0)
        {
-           nx = x;
-           ny = y;
-           array_data = new T*[nx];
-           
-           for (unsigned int i = 0; i < nx; i++)
-               array_data[i] = new T[ny];
+           allocArray();
        }
 
+    Array2d (void)
+       : array_data(0), nx(0), ny(0)
+       {}
 
     ~Array2d ()
        {
-           for (int i = 0; i < nx; i++)
-               delete array_data[i];
-           delete array_data;
+           deleteArray();
        }
     
+    void initSetSize (unsigned int x, unsigned int y)
+       {
+           nx = x;
+           ny = y;
+           deleteArray();
+           allocArray();
+       }
+
     T** getArray (void) const
        { return array_data; }
 
     T* getColumn (unsigned int x) const
-       { return array_data[x]; }
+       { return (array_data ? array_data[x] : NULL); }
 
     T getPoint (unsigned int x, unsigned int y) const
-       { return (array_data[x][y]); }
+       { return (array_data ? array_data[x][y] : NULL); }
 
     unsigned int sizeofPixel (void) const 
        {  return sizeof(T); }
@@ -79,6 +84,33 @@ class Array2d {
 
     unsigned int sizeofArray (void) const
        { return (sizeof(T) * nx * ny); }
+
+
+ private:
+    unsigned int nx;
+    unsigned int ny;
+    T** array_data;
+
+    void allocArray (void)
+       {
+           array_data = new T*[nx];
+           
+           for (unsigned int i = 0; i < nx; i++)
+               array_data[i] = new T[ny];
+       }
+
+    void deleteArray (void)
+       {
+           if (array_data) {
+               for (int i = 0; i < nx; i++)
+                   delete array_data[i];
+               delete array_data;
+           }
+       }
+
+
+    Array2d& operator= (const Array2d& rhs);
+    Array2d (const Array2d& rhs);  // copy constructor
 };