/* MetaContour, version 0.1 -------------------------------------- */
/* Copyright(C) 2004, Brooks Moses */
/* */
/* This version of MetaContour is made available under the Gnu */
/* Public License; see metacontour_main.cc for details. */
/* */
/* This is a very pre-release version of MetaContour, distributed */
/* primarily as an example of a use of MetaPlot. It can be */
/* compiled with gcc using the line: */
/* */
/* g++ metacontour.cc cpoint.cc metacontour_main.cc */
/* */
/*-----------------------------------------------------------------*/
/* Class for 2D points with one data value each */
#include<string>
#include<valarray>
using namespace std;
class cparray {
valarray<cpoint>* a;
int i;
int j;
public:
cparray(int x, int y); // note: no default constructor
cparray(const cparray&);
cparray& operator=(const cparray&);
~cparray();
int size() const { return i*j; }
int i_dim() const { return i; }
int j_dim() const { return j; }
cpoint& operator()(int x, int y); // Fortran-style subscripts
cpoint operator()(int x, int y) const;