/*
* 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 .
*/
static const char rcsid[] = "@(#)raslib, r_Marray_Type: $Header: /home/rasdev/CVS-repository/rasdaman/raslib/marraytype.cc,v 1.7 2003/12/27 23:01:21 rasdev Exp $";
#include "raslib/marraytype.hh"
#include "raslib/basetype.hh"
#include "raslib/error.hh"
#include "raslib/rminit.hh"
r_Marray_Type::r_Marray_Type()
: r_Type(),
baseType(NULL)
{
}
r_Marray_Type::r_Marray_Type(const r_Base_Type& newBaseType)
: r_Type(),
baseType((r_Base_Type*)newBaseType.clone())
{
}
r_Marray_Type::r_Marray_Type(const r_Marray_Type& oldObj) throw (r_Error)
: r_Type(oldObj)
{
if (oldObj.baseType)
baseType = (r_Base_Type*)oldObj.baseType->clone();
else {
RMInit::logOut << "r_Marray_Type::r_Marray_Type( oldObj ) the element type is NULL." << endl;
throw r_Error(MARRAYTYPEHASNOELEMENTTYPE);
}
}
const r_Marray_Type&
r_Marray_Type::operator=(const r_Marray_Type& oldObj) throw (r_Error)
{
// Gracefully handle self assignment
if (this == &oldObj)
return *this;
r_Type::operator=(oldObj);
if (baseType)
{
delete baseType;
baseType = 0;
}
if (oldObj.baseType)
baseType = (r_Base_Type*)oldObj.baseType->clone();
else {
RMInit::logOut << "r_Marray_Type::operator=( oldObj ) the element type is NULL." << endl;
throw r_Error(MARRAYTYPEHASNOELEMENTTYPE);
}
return *this;
}
bool
r_Marray_Type::isMarrayType() const
{
return true;
}
const r_Base_Type&
r_Marray_Type::base_type() const
{
return *baseType;
}
r_Type*
r_Marray_Type::clone() const
{
return new r_Marray_Type(*this);
}
r_Type::r_Type_Id
r_Marray_Type::type_id() const
{
return MARRAYTYPE;
}
void
r_Marray_Type::convertToLittleEndian(char* cells, r_Area noCells) const
{
}
void
r_Marray_Type::convertToBigEndian(char* cells, r_Area noCells) const
{
}
void
r_Marray_Type::print_status(std::ostream& s) const
{
s << "marray< ";
baseType->print_status(s);
s << " >";
}
r_Marray_Type::~r_Marray_Type()
{
if (baseType)
delete baseType;
}
std::ostream &operator<<( std::ostream &str, const r_Marray_Type &type )
{
type.print_status(str);
return str;
}