2015-05-28 22:19:07 +08:00
|
|
|
/****************************************************************************
|
|
|
|
** gmio
|
|
|
|
** Copyright Fougue (2 Mar. 2015)
|
2015-07-13 17:42:03 +08:00
|
|
|
** contact@fougue.pro
|
2015-05-28 22:19:07 +08:00
|
|
|
**
|
|
|
|
** This software is a reusable library whose purpose is to provide complete
|
|
|
|
** I/O support for various CAD file formats (eg. STL)
|
|
|
|
**
|
|
|
|
** This software is governed by the CeCILL-B license under French law and
|
|
|
|
** abiding by the rules of distribution of free software. You can use,
|
|
|
|
** modify and/ or redistribute the software under the terms of the CeCILL-B
|
|
|
|
** license as circulated by CEA, CNRS and INRIA at the following URL
|
|
|
|
** "http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html".
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/*! \file stlb_header.h
|
|
|
|
* Declaration of gmio_stlb_header
|
2015-09-09 17:44:34 +08:00
|
|
|
*
|
|
|
|
* \addtogroup gmio_stl
|
|
|
|
* @{
|
2015-05-28 22:19:07 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef GMIO_STLB_HEADER_H
|
|
|
|
#define GMIO_STLB_HEADER_H
|
|
|
|
|
|
|
|
#include "stl_global.h"
|
2015-12-10 01:51:03 +08:00
|
|
|
#include "stl_constants.h"
|
2015-05-28 22:19:07 +08:00
|
|
|
|
|
|
|
/*! 80-byte data at the beginning of any STL binary file */
|
|
|
|
struct gmio_stlb_header
|
|
|
|
{
|
|
|
|
uint8_t data[GMIO_STLB_HEADER_SIZE];
|
|
|
|
};
|
|
|
|
|
2015-12-18 17:38:18 +08:00
|
|
|
GMIO_C_LINKAGE_BEGIN
|
|
|
|
|
|
|
|
/*! Returns a gmio_stlb_header object whose contents is a copy of \p str
|
|
|
|
*
|
|
|
|
* Only the first \c GMIO_STLB_HEADER_SIZE characters are copied.
|
|
|
|
*
|
|
|
|
* If the length of \p str is less than \c GMIO_STLB_HEADER_SIZE then the
|
|
|
|
* remaining bytes are filled with zeroes.
|
|
|
|
*/
|
|
|
|
GMIO_LIBSTL_EXPORT
|
|
|
|
struct gmio_stlb_header gmio_stlb_header_str(const char* str);
|
|
|
|
|
2016-01-13 22:17:18 +08:00
|
|
|
/*! Copies \p header into C string \p str
|
|
|
|
*
|
|
|
|
* It replaces non-printable bytes with \p replacement char.
|
2016-01-26 18:50:29 +08:00
|
|
|
* \p str must be at least \c GMIO_STLB_HEADER_SIZE+1 long, a terminating null
|
2016-01-13 22:17:18 +08:00
|
|
|
* character ('\0') is copied at position \c GMIO_STLB_HEADER_SIZE
|
|
|
|
*/
|
|
|
|
GMIO_LIBSTL_EXPORT
|
|
|
|
void gmio_stlb_header_to_printable_str(
|
|
|
|
const struct gmio_stlb_header* header, char* str, char replacement);
|
|
|
|
|
2015-12-18 17:38:18 +08:00
|
|
|
GMIO_C_LINKAGE_END
|
|
|
|
|
2015-05-28 22:19:07 +08:00
|
|
|
#endif /* GMIO_STLB_HEADER_H */
|
2015-09-09 17:44:34 +08:00
|
|
|
/*! @} */
|