binary_file_io.h
来自「CGAL is a collaborative effort of severa」· C头文件 代码 · 共 115 行
H
115 行
// 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.//// $Source: /CVSROOT/CGAL/Packages/Stream_support/include/CGAL/IO/binary_file_io.h,v $// $Revision: 1.2 $ $Date: 2004/11/22 19:06:06 $// $Name: $//// Author(s) : Lutz Kettner <kettner@mpi-sb.mpg.de>#ifndef CGAL_IO_BINARY_FILE_IO_H#define CGAL_IO_BINARY_FILE_IO_H#include <CGAL/basic.h>#include <CGAL/known_bit_size_integers.h>#include <iostream>CGAL_BEGIN_NAMESPACEinline voidI_Binary_write_integer32(std::ostream& out, Integer32 i) { out.write( (char*)(&i), 4);}inline voidI_Binary_write_float32(std::ostream& out, float f) { out.write( (char*)(&f), 4);}inline voidI_Binary_read_integer32(std::istream& in, Integer32& i) { in.read( (char*)(&i), 4);}inline voidI_Binary_read_float32(std::istream& in, float& f) { in.read( (char*)(&f), 4);}inline voidI_swap_to_big_endian( UInteger32& u) { (void) u;#ifdef CGAL_LITTLE_ENDIAN u = ((u >> 24) | (u << 24) | ((u >> 8) & 0xff00) | ((u << 8) & 0xff0000));#endif}inline voidI_swap_to_big_endian( Integer32& i) { // We need to use a union instead of the 2 lines below, // otherwise we get aliasing issues. // UInteger32& u = (UInteger32&)i; // I_swap_to_big_endian( u); union { Integer32 in; UInteger32 ui; } u; u.in = i; I_swap_to_big_endian(u.ui); i = u.in;}inline voidI_swap_to_big_endian( float& f) { // We need to use a union instead of the 2 lines below, // otherwise we get aliasing issues. // UInteger32& u = (UInteger32&)f; // I_swap_to_big_endian( u); union { UInteger32 ui; float fl; } u; u.fl = f; I_swap_to_big_endian(u.ui); f = u.fl;}inline voidI_Binary_write_big_endian_integer32(std::ostream& out, Integer32 i) { I_swap_to_big_endian( i); out.write( (char*)(&i), 4);}inline voidI_Binary_write_big_endian_float32(std::ostream& out, float f) { I_swap_to_big_endian( f); out.write( (char*)(&f), 4);}inline voidI_Binary_read_big_endian_integer32(std::istream& in, Integer32& i) { in.read( (char*)(&i), 4); I_swap_to_big_endian( i);}inline voidI_Binary_read_big_endian_float32(std::istream& in, float& f) { in.read( (char*)(&f), 4); I_swap_to_big_endian( f);}CGAL_END_NAMESPACE#endif // CGAL_IO_BINARY_FILE_IO_H
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?