📄 io.h
字号:
// Copyright (c) 1997 Utrecht University (The Netherlands),// ETH Zurich (Switzerland), Freie Universitaet Berlin (Germany),// INRIA Sophia-Antipolis (France), Martin-Luther-University Halle-Wittenberg// (Germany), Max-Planck-Institute Saarbruecken (Germany), RISC Linz (Austria),// 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; version 2.1 of the License.// See the file LICENSE.LGPL distributed with CGAL.//// 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: svn+ssh://scm.gforge.inria.fr/svn/cgal/branches/CGAL-3.3-branch/iostream/include/CGAL/IO/io.h $// $Id: io.h 35276 2006-11-23 10:20:38Z hemmer $////// Author(s) : Andreas Fabri#ifndef CGAL_IO_H#define CGAL_IO_H#include <iostream>#include <CGAL/tags.h>#include <CGAL/IO/io_tags.h>#include <CGAL/IO/Color.h>CGAL_BEGIN_NAMESPACEclass IO {public: 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); }IO::Modeget_mode(std::ios& i);IO::Modeset_ascii_mode(std::ios& i);IO::Modeset_binary_mode(std::ios& i);IO::Modeset_pretty_mode(std::ios& i);IO::Modeset_benchmark_mode(std::ios& i);IO::Modeset_mode(std::ios& i, IO::Mode m);boolis_pretty(std::ios& i);boolis_ascii(std::ios& i);boolis_binary(std::ios& i);boolis_benchmark(std::ios& i);template < class T >inlinevoidwrite(std::ostream& os, const T& t, const io_Read_write&){ os.write(reinterpret_cast<const char*>(&t), sizeof(t));}template < class T >inlinevoidwrite(std::ostream& os, const T& t, const io_Operator&){ os << oformat(t);}template < class T >inlinevoidwrite(std::ostream& os, const T& t, const io_Extract_insert&){ insert(os, t);}template < class T >inlinevoidwrite(std::ostream& os, const T& t){ write(os, t, typename Io_traits<T>::Io_tag());}template < class T >inlinevoidread(std::istream& is, T& t, const io_Read_write&){ is.read(reinterpret_cast<char*>(&t), sizeof(t));}template < class T >inlinevoidread(std::istream& is, T& t, const io_Operator&){ is >> iformat(t);}template < class T >inlinevoidread(std::istream& is, T& t, const io_Extract_insert&){ extract(is, t);}template < class T >inlinevoidread(std::istream& is, T& t){ read(is, t, typename Io_traits<T>::Io_tag());}inlinestd::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()) << ')'; }}inlinestd::istream &operator>>(std::istream &is, Color& col){ int r, g, b; 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(r,g,b); return is;}const char* mode_name( IO::Mode m );CGAL_END_NAMESPACE#endif // CGAL_IO_H
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -