/*
* 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 .
/
/**
* INCLUDE: csv.hh
*
* MODULE: conversion
*
* CLASSES: r_Conv_CSV
*
* COMMENTS:
*
* Provides interface to convert data to other formats.
*
*/
#ifndef _R_CONV_CSV_HH_
#define _R_CONV_CSV_HH_
#include "conversion/convertor.hh"
#include
//@ManMemo: Module {\bf conversion}
/*@Doc:
CSV convertor class.
Supported parameters are
\begin{tabular}{lcl}
comptype && string && the compression type to use (see below)\\
quality && int && quality parameter for JPEG compression\\
skiphuff && int && skipping parameter for Huffman coding\\
\end{tabular}
The compression type defaults to deflate but may be one of the
following
\begin{tabular}{ll}
none && no compression\\
rle && Run Length Coding\\
huffman && Huffman coding\\
deflate && ZIP deflate\\
\end{tabular}
*/
class r_Conv_CSV : public r_Convertor
{
public:
/// constructor using an r_Type object. Exception if the type isn't atomic.
r_Conv_CSV( const char *src, const r_Minterval &interv, const r_Type *tp) throw(r_Error);
/// constructor using convert_type_e shortcut
r_Conv_CSV( const char *src, const r_Minterval &interv, int tp ) throw(r_Error);
/// destructor
~r_Conv_CSV( void );
/// convert to CSV
virtual r_convDesc &convertTo( const char *options=NULL ) throw(r_Error);
/// convert from CSV
virtual r_convDesc &convertFrom( const char *options=NULL ) throw(r_Error);
/// cloning
virtual r_Convertor *clone( void ) const;
/// identification
virtual const char *get_name( void ) const;
virtual r_Data_Format get_data_format( void ) const;
private:
template
void print(std::ofstream &f, baseType* val, int *dims, int dim);
};
#endif