dust3d/thirdparty/cgal/CGAL-4.13/include/CGAL/ImageIO/bmpendian_impl.h

259 lines
5.8 KiB
C
Executable File

// Copyright (c) 2005-2008 ASCLEPIOS Project, INRIA Sophia-Antipolis (France)
// All rights reserved.
//
// This file is part of the ImageIO Library, and as been adapted for
// 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.
//
// These files are provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
// WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
//
// $URL$
// $Id$
// SPDX-License-Identifier: LGPL-3.0+
//
//
// Author(s) : ASCLEPIOS Project (INRIA Sophia-Antipolis), Laurent Rineau
#ifdef CGAL_HEADER_ONLY
#define CGAL_INLINE_FUNCTION inline
#else
#define CGAL_INLINE_FUNCTION
#endif
/*
* These functions read and write our basic integer types from a little-endian
* file. The endian and word-size of the host machine will not affect this
* code. The only assumption made is that the C data type (char) is one byte
* long. This should be a safe assumption.
*/
#include <stdio.h>
#include <CGAL/ImageIO/bmptypes.h>
/*****************************************************************************
*
* Read functions. All read functions take an open file pointer as the first
* parameter and a pointer to data as the second parameter. The return value
* will be 0 on success, and EOF on failure. If successful, the second
* parameter will point to the data read.
*/
/*
* The CGAL_INT8 and CGAL_UINT8 types are stored as a single byte on disk. The INT8
* type is a signed integer with range (-128..127). The CGAL_UINT8 type is an
* unsigned integer with range (0..255).
*/
CGAL_INLINE_FUNCTION
int readINT8little(FILE *f, CGAL_INT8 *i)
{
int rc;
rc = fgetc(f);
if (rc == EOF)
return EOF;
*i = CGAL_INT8(rc & 0xff);
return 0;
}
CGAL_INLINE_FUNCTION
int readUINT8little(FILE *f, CGAL_UINT8 *i)
{
int rc;
rc = fgetc(f);
if (rc == EOF)
return EOF;
*i = CGAL_UINT8(rc & 0xff);
return 0;
}
/*
* The CGAL_INT16 and CGAL_UINT16 types are stored as two bytes on disk. The INT16 type
* is a signed integer with range (-32768..32767). The CGAL_UINT16 type is an
* unisgned integer with range (0..65535).
*/
CGAL_INLINE_FUNCTION
int readINT16little(FILE *f, CGAL_INT16 *i)
{
int rc;
CGAL_INT16 temp = 0;
temp = (fgetc(f) & 0xff);
rc = fgetc(f);
if (rc == EOF)
return EOF;
temp = temp | CGAL_INT16((rc & 0xff) << 8);
*i = temp;
return 0;
}
CGAL_INLINE_FUNCTION
int readUINT16little(FILE *f, CGAL_UINT16 *i)
{
int rc;
CGAL_UINT16 temp = 0;
temp = (fgetc(f) & 0xff);
rc = fgetc(f);
if (rc == EOF)
return EOF;
temp = CGAL_INT16(temp | ((rc & 0xff) << 8));
*i = temp;
return 0;
}
/*
* The CGAL_INT32 and CGAL_UINT32 types are stored as four bytes on disk. The INT32
* type is a signed integer with range (-2147483648..2147483647). The CGAL_UINT32
* type is an unisgned integer with range (0..4294967295).
*/
CGAL_INLINE_FUNCTION
int readINT32little(FILE *f, CGAL_INT32 *i)
{
int rc;
CGAL_INT32 temp = 0;
temp = ((long)fgetc(f) & 0xff);
temp = CGAL_INT32(temp | (((long)fgetc(f) & 0xff) << 8));
temp = CGAL_INT32(temp | (((long)fgetc(f) & 0xff) << 16));
rc = fgetc(f);
if (rc == EOF)
return EOF;
temp = CGAL_INT32(temp | (((long)rc & 0xff) << 24));
*i = temp;
return 0;
}
CGAL_INLINE_FUNCTION
int readUINT32little(FILE *f, CGAL_UINT32 *i)
{
int rc;
CGAL_UINT32 temp = 0;
temp = ((long)fgetc(f) & 0xff);
temp = CGAL_UINT32(temp | (((long)fgetc(f) & 0xff) << 8));
temp = CGAL_UINT32(temp | (((long)fgetc(f) & 0xff) << 16));
rc = fgetc(f);
if (rc == EOF)
return EOF;
temp = CGAL_UINT32(temp | (((long)rc & 0xff) << 24));
*i = temp;
return 0;
}
/*****************************************************************************
*
* Write functions. All write functions take an open file pointer as the first
* parameter and a data as the second parameter. The return value will be 0 on
* success, and EOF on failure. If successful, the second parameter will have
* been written to the open file.
*/
CGAL_INLINE_FUNCTION
int writeINT8little(FILE *f, CGAL_INT8 i)
{
return fputc(i, f);
}
CGAL_INLINE_FUNCTION
int writeUINT8little(FILE *f, CGAL_UINT8 i)
{
return fputc(i, f);
}
CGAL_INLINE_FUNCTION
int writeINT16little(FILE *f, CGAL_INT16 i)
{
int rc;
rc = fputc((i & 0xff), f);
if (rc == EOF)
return EOF;
return fputc(((i >> 8) & 0xff), f);
}
CGAL_INLINE_FUNCTION
int writeUINT16little(FILE *f, CGAL_UINT16 i)
{
int rc;
rc = fputc((i & 0xff), f);
if (rc == EOF)
return EOF;
return fputc(((i >> 8) & 0xff), f);
}
CGAL_INLINE_FUNCTION
int writeINT32little(FILE *f, CGAL_INT32 i)
{
int rc;
rc = fputc((i & 0xff), f);
if (rc == EOF)
return EOF;
rc = fputc(((i >> 8) & 0xff), f);
if (rc == EOF)
return EOF;
rc = fputc(((i >> 16) & 0xff), f);
if (rc == EOF)
return EOF;
return fputc(((i >> 24) & 0xff), f);
}
CGAL_INLINE_FUNCTION
int writeUINT32little(FILE *f, CGAL_UINT32 i)
{
int rc;
rc = fputc((i & 0xff), f);
if (rc == EOF)
return EOF;
rc = fputc(((i >> 8) & 0xff), f);
if (rc == EOF)
return EOF;
rc = fputc(((i >> 16) & 0xff), f);
if (rc == EOF)
return EOF;
return fputc(((i >> 24) & 0xff), f);
}
/*
* Formatting information for emacs in c-mode
*
* Local Variables:
* c-indent-level:4
* c-continued-statement-offset:4
* c-brace-offset:-4
* c-brace-imaginary-offset:0
* c-argdecl-indent:4
* c-label-offset:-4
* End:
*/