mirror of https://github.com/CGAL/cgal
314 lines
6.6 KiB
C++
314 lines
6.6 KiB
C++
// Copyright (c) 1997
|
|
// Utrecht University (The Netherlands),
|
|
// ETH Zurich (Switzerland),
|
|
// INRIA Sophia-Antipolis (France),
|
|
// Max-Planck-Institute Saarbruecken (Germany),
|
|
// and Tel-Aviv University (Israel). All rights reserved.
|
|
//
|
|
// This file is part of CGAL (www.cgal.org); you can redistribute it and/or
|
|
// modify it under the terms of the GNU Lesser General Public License as
|
|
// published by the Free Software Foundation; either version 3 of the License,
|
|
// or (at your option) any later version.
|
|
//
|
|
// Licensees holding a valid commercial license may use this file in
|
|
// accordance with the commercial license agreement provided with the software.
|
|
//
|
|
// This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
|
|
// WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
|
|
//
|
|
// $URL$
|
|
// $Id$
|
|
//
|
|
//
|
|
// Author(s) : Andreas Fabri
|
|
|
|
|
|
#ifndef CGAL_IO_H
|
|
#define CGAL_IO_H
|
|
|
|
|
|
#include <cstdio>
|
|
#include <string>
|
|
#include <iostream>
|
|
#include <CGAL/tags.h>
|
|
#include <CGAL/IO/io_tags.h>
|
|
#include <CGAL/IO/Color.h>
|
|
|
|
|
|
namespace CGAL {
|
|
|
|
class IO {
|
|
public:
|
|
CGAL_EXPORT static int mode;
|
|
enum Mode {ASCII = 0, PRETTY, BINARY};
|
|
};
|
|
|
|
template <class T, class F = ::CGAL::Null_tag >
|
|
class Output_rep {
|
|
const T& t;
|
|
public:
|
|
//! initialize with a const reference to \a t.
|
|
Output_rep( const T& tt) : t(tt) {}
|
|
//! perform the output, calls \c operator\<\< by default.
|
|
std::ostream& operator()( std::ostream& out) const { return (out << t); }
|
|
};
|
|
|
|
/*! \relates Output_rep
|
|
\brief stream output of the \c Output_rep calls its \c operator().
|
|
*/
|
|
template <class T, class F>
|
|
std::ostream&
|
|
operator<<( std::ostream& out, Output_rep<T,F> rep) {
|
|
return rep( out);
|
|
}
|
|
|
|
//! generic IO output format manipulator.
|
|
template <class T>
|
|
Output_rep<T>
|
|
oformat( const T& t) { return Output_rep<T>(t); }
|
|
|
|
//! generic IO output format manipulator with formatting tag.
|
|
template <class T, class F>
|
|
Output_rep<T,F>
|
|
oformat( const T& t, F) { return Output_rep<T,F>(t); }
|
|
|
|
|
|
|
|
/*!\brief
|
|
* input functor class created by the generic IO input manipulator.
|
|
*
|
|
* It holds a reference to the input object. Default implementation
|
|
* calls the stream input operator. Specializations can be written
|
|
* for external types not supporting our stream IO format.
|
|
*/
|
|
template <class T>
|
|
class Input_rep {
|
|
T& t;
|
|
public:
|
|
//! initialize with a reference to \a t.
|
|
Input_rep( T& tt) : t(tt) {}
|
|
//! perform the input, calls \c operator\>\> by default.
|
|
std::istream& operator()( std::istream& in) const { return (in >> t); }
|
|
};
|
|
|
|
/*! \relates Input_rep
|
|
\brief stream input to the \c Input_rep calls its \c operator().
|
|
*/
|
|
template <class T>
|
|
std::istream&
|
|
operator>>( std::istream& in, Input_rep<T> rep) {
|
|
return rep( in);
|
|
}
|
|
|
|
//! generic IO input format manipulator.
|
|
template <class T>
|
|
Input_rep<T>
|
|
iformat( T& t) { return Input_rep<T>(t); }
|
|
|
|
|
|
template <class T, class F = Null_tag >
|
|
class Benchmark_rep {
|
|
const T& t;
|
|
public:
|
|
//! initialize with a const reference to \a t.
|
|
Benchmark_rep( const T& tt) : t(tt) {}
|
|
//! perform the output, calls \c operator\<\< by default.
|
|
std::ostream& operator()( std::ostream& out) const {
|
|
return out << t;
|
|
}
|
|
|
|
// static function to get the benchmark name
|
|
static std::string get_benchmark_name() {
|
|
return "";
|
|
}
|
|
};
|
|
|
|
template <class T, class F>
|
|
std::ostream& operator<<( std::ostream& out, Benchmark_rep<T,F> rep) {
|
|
return rep( out);
|
|
}
|
|
|
|
template <class T>
|
|
Benchmark_rep<T> bmformat( const T& t) { return Benchmark_rep<T>(t); }
|
|
|
|
template <class T, class F>
|
|
Benchmark_rep<T,F> bmformat( const T& t, F) { return Benchmark_rep<T,F>(t); }
|
|
|
|
|
|
CGAL_EXPORT
|
|
IO::Mode
|
|
get_mode(std::ios& i);
|
|
|
|
CGAL_EXPORT
|
|
IO::Mode
|
|
set_ascii_mode(std::ios& i);
|
|
|
|
CGAL_EXPORT
|
|
IO::Mode
|
|
set_binary_mode(std::ios& i);
|
|
|
|
CGAL_EXPORT
|
|
IO::Mode
|
|
set_pretty_mode(std::ios& i);
|
|
|
|
CGAL_EXPORT
|
|
IO::Mode
|
|
set_mode(std::ios& i, IO::Mode m);
|
|
|
|
CGAL_EXPORT
|
|
bool
|
|
is_pretty(std::ios& i);
|
|
|
|
CGAL_EXPORT
|
|
bool
|
|
is_ascii(std::ios& i);
|
|
|
|
CGAL_EXPORT
|
|
bool
|
|
is_binary(std::ios& i);
|
|
|
|
|
|
inline std::istream& extract(std::istream& is, double &d)
|
|
{
|
|
#if defined( _MSC_VER ) && ( _MSC_VER > 1600 )
|
|
std::string s;
|
|
is >> s;
|
|
sscanf(s.c_str(), "%lf", &d);
|
|
#else
|
|
is >> d;
|
|
#endif
|
|
return is;
|
|
}
|
|
|
|
template < class T >
|
|
inline
|
|
void
|
|
write(std::ostream& os, const T& t, const io_Read_write&)
|
|
{
|
|
os.write(reinterpret_cast<const char*>(&t), sizeof(t));
|
|
}
|
|
|
|
|
|
template < class T >
|
|
inline
|
|
void
|
|
write(std::ostream& os, const T& t, const io_Operator&)
|
|
{
|
|
os << oformat(t);
|
|
}
|
|
|
|
|
|
template < class T >
|
|
inline
|
|
void
|
|
write(std::ostream& os, const T& t, const io_Extract_insert&)
|
|
{
|
|
insert(os, t);
|
|
}
|
|
|
|
|
|
template < class T >
|
|
inline
|
|
void
|
|
write(std::ostream& os, const T& t)
|
|
{
|
|
write(os, t, typename Io_traits<T>::Io_tag());
|
|
}
|
|
|
|
|
|
template < class T >
|
|
inline
|
|
void
|
|
read(std::istream& is, T& t, const io_Read_write&)
|
|
{
|
|
is.read(reinterpret_cast<char*>(&t), sizeof(t));
|
|
}
|
|
|
|
|
|
template < class T >
|
|
inline
|
|
void
|
|
read(std::istream& is, T& t, const io_Operator&)
|
|
{
|
|
is >> iformat(t);
|
|
}
|
|
|
|
|
|
template < class T >
|
|
inline
|
|
void
|
|
read(std::istream& is, T& t, const io_Extract_insert&)
|
|
{
|
|
extract(is, t);
|
|
}
|
|
|
|
|
|
template < class T >
|
|
inline
|
|
void
|
|
read(std::istream& is, T& t)
|
|
{
|
|
read(is, t, typename Io_traits<T>::Io_tag());
|
|
}
|
|
|
|
|
|
inline
|
|
std::ostream& operator<<( std::ostream& out, const Color& col)
|
|
{
|
|
switch(out.iword(IO::mode)) {
|
|
case IO::ASCII :
|
|
return out << static_cast<int>(col.red()) << ' '
|
|
<< static_cast<int>(col.green()) << ' '
|
|
<< static_cast<int>(col.blue());
|
|
case IO::BINARY :
|
|
write(out, static_cast<int>(col.red()));
|
|
write(out, static_cast<int>(col.green()));
|
|
write(out, static_cast<int>(col.blue()));
|
|
return out;
|
|
default:
|
|
return out << "Color(" << static_cast<int>(col.red()) << ", "
|
|
<< static_cast<int>(col.green()) << ", "
|
|
<< static_cast<int>(col.blue()) << ')';
|
|
}
|
|
}
|
|
|
|
inline
|
|
std::istream &operator>>(std::istream &is, Color& col)
|
|
{
|
|
int r = 0, g = 0, b = 0;
|
|
switch(is.iword(IO::mode)) {
|
|
case IO::ASCII :
|
|
is >> r >> g >> b;
|
|
break;
|
|
case IO::BINARY :
|
|
read(is, r);
|
|
read(is, g);
|
|
read(is, b);
|
|
break;
|
|
default:
|
|
std::cerr << "" << std::endl;
|
|
std::cerr << "Stream must be in ascii or binary mode" << std::endl;
|
|
break;
|
|
}
|
|
col = Color((unsigned char)r,(unsigned char)g,(unsigned char)b);
|
|
return is;
|
|
}
|
|
|
|
CGAL_EXPORT
|
|
const char* mode_name( IO::Mode m );
|
|
|
|
// From polynomial.h TODO: Where to put this?
|
|
CGAL_EXPORT
|
|
void swallow(std::istream &is, char d);
|
|
|
|
CGAL_EXPORT
|
|
void swallow(std::istream &is, const std::string& s );
|
|
|
|
#ifdef CGAL_HEADER_ONLY
|
|
#include <CGAL/IO/io_impl.h>
|
|
#endif // CGAL_HEADER_ONLY
|
|
|
|
} //namespace CGAL
|
|
|
|
#endif // CGAL_IO_H
|