/* * This file is part of rasdaman community. * * Rasdaman community is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Rasdaman community is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with rasdaman community. If not, see . * * Copyright 2003, 2004, 2005, 2006, 2007, 2008, 2009 Peter Baumann / rasdaman GmbH. * * For more information please see * or contact Peter Baumann via . / /** * SOURCE: point.cc * * MODULE: raslib * CLASS: r_Point * * COMMENTS: * */ static const char rcsid[] = "@(#)raslib, r_Point: $Id: point.cc,v 1.22 2002/08/28 11:58:13 coman Exp $"; #include "point.hh" #include #ifdef __VISUALC__ #include #else #include #endif #include "raslib/rminit.hh" #include "raslib/error.hh" r_Point::r_Point( char* stringRep ) throw (r_Error) : dimensionality(1), streamInitCnt(0), points(NULL) { char charToken = 0; r_Range valueToken = 0; // for parsing the string std::istrstream str( stringRep, strlen(stringRep) + 1 ); // calculate dimensionality char* p = stringRep; while(p = strchr(++p, ',')) dimensionality++; // allocate space for intervals points = new r_Range[ dimensionality ]; str >> charToken; if(charToken != '[') { // error dimensionality = 0; delete[] points; points = NULL; throw r_Error(NOPOINT); } for( r_Dimension i=0; i> valueToken; points[i] = valueToken; if( i < dimensionality-1 ) { str >> charToken; if(charToken != ',') { // error dimensionality = 0; delete[] points; points = NULL; throw r_Error(NOPOINT); } } } } r_Point::r_Point( r_Dimension dim ) : dimensionality( dim ), streamInitCnt(0) { points = new r_Range[ dimensionality ]; for( r_Dimension i=0; i< dimensionality; i++ ) points[i] = 0; } r_Point& r_Point::operator<<( r_Range newElement ) throw( r_Einit_overflow ) { if( streamInitCnt >= dimensionality ) { RMInit::logOut << "r_Point::operator<<(" << newElement << ") already fully initialised" << endl; throw r_Einit_overflow(); } points[streamInitCnt++] = newElement; return *this; } r_Point::r_Point( r_Range p1, r_Range p2 ) : dimensionality(2), streamInitCnt(2) { points = new r_Range[dimensionality]; points[0] = p1; points[1] = p2; } r_Point::r_Point( r_Range p1, r_Range p2, r_Range p3 ) : dimensionality(3), streamInitCnt(3) { points = new r_Range[dimensionality]; points[0] = p1; points[1] = p2; points[2] = p3; } r_Point::r_Point( r_Range p1, r_Range p2, r_Range p3, r_Range p4 ) : dimensionality(4), streamInitCnt(4) { points = new r_Range[dimensionality]; points[0] = p1; points[1] = p2; points[2] = p3; points[3] = p4; } r_Point::r_Point( r_Range p1, r_Range p2, r_Range p3, r_Range p4, r_Range p5 ) : dimensionality(5), streamInitCnt(5) { points = new r_Range[dimensionality]; points[0] = p1; points[1] = p2; points[2] = p3; points[3] = p4; points[4] = p5; } r_Point::r_Point() : dimensionality(0), streamInitCnt(0), points(NULL) { } r_Point::r_Point( const r_Point& pt ) : dimensionality(pt.dimensionality), streamInitCnt(pt.streamInitCnt), points(new r_Range[pt.dimensionality]) { for( r_Dimension i=0; i= dimensionality ) { RMInit::logOut << "r_Point::operator[](" << i << ") const dimension out of bounds (" << dimensionality << ")" << endl; throw r_Eindex_violation( 0, dimensionality-1, i ); } return points[i]; } r_Range& r_Point::operator[]( r_Dimension i ) throw( r_Eindex_violation ) { if( i < 0 || i >= dimensionality ) { RMInit::logOut << "r_Point::operator[](" << i << ") dimension out of bounds (" << dimensionality << ")" << endl; throw r_Eindex_violation( 0, dimensionality-1, i ); } return points[i]; } const r_Point& r_Point::operator=( const r_Point& pt ) { if( this != &pt ) { if( points && dimensionality != pt.dimension() ) { delete[] points; points = NULL; } dimensionality = pt.dimension(); streamInitCnt = dimensionality; if( !points ) points = new r_Range[ dimensionality ]; for( r_Dimension i=0; i 0 ) { for( r_Dimension i=0; i