/**************************************************************************** ** gmio ** Copyright Fougue (24 Jun. 2016) ** contact@fougue.pro ** ** 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". ****************************************************************************/ #include "stl_rw_common.h" #include "../../gmio_core/error.h" #include "../stl_error.h" #include "../stl_io.h" bool gmio_check_memblock(int *error, const struct gmio_memblock* mblock) { if (mblock == NULL || mblock->ptr == NULL) *error = GMIO_ERROR_NULL_MEMBLOCK; else if (mblock->size == 0) *error = GMIO_ERROR_INVALID_MEMBLOCK_SIZE; return gmio_no_error(*error); } bool gmio_check_memblock_size( int *error, const struct gmio_memblock *mblock, size_t minsize) { if (gmio_check_memblock(error, mblock) && mblock->size < minsize) *error = GMIO_ERROR_INVALID_MEMBLOCK_SIZE; return gmio_no_error(*error); } bool gmio_stl_check_mesh(int *error, const struct gmio_stl_mesh* mesh) { if (mesh == NULL || (mesh->triangle_count > 0 && mesh->func_get_triangle == NULL)) { *error = GMIO_STL_ERROR_NULL_FUNC_GET_TRIANGLE; } return gmio_no_error(*error); } bool gmio_stlb_check_byteorder(int* error, enum gmio_endianness byte_order) { if (byte_order != GMIO_ENDIANNESS_LITTLE && byte_order != GMIO_ENDIANNESS_BIG) { *error = GMIO_STL_ERROR_UNSUPPORTED_BYTE_ORDER; } return gmio_no_error(*error); } bool gmio_stla_check_float32_precision(int *error, uint8_t prec) { if (prec == 0 || prec > 9) *error = GMIO_STL_ERROR_INVALID_FLOAT32_PREC; return gmio_no_error(*error); }