Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/prusa3d/PrusaSlicer.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbubnikv <bubnikv@gmail.com>2017-10-03 11:57:16 +0300
committerbubnikv <bubnikv@gmail.com>2017-10-03 11:57:16 +0300
commita52a04550e2ee869712ac340bb4d459ba6be3058 (patch)
treef3d6d499bd50e30a7daae5da8c0c36b4f04406bd /xs/src/admesh/stlinit.cpp
parent84d4bf8fdb07b12754e8303c99cf8ff54ecac037 (diff)
Big endian fix, thanks to @hyperair for hints and initial implementation.
Diffstat (limited to 'xs/src/admesh/stlinit.cpp')
-rw-r--r--xs/src/admesh/stlinit.cpp18
1 files changed, 16 insertions, 2 deletions
diff --git a/xs/src/admesh/stlinit.cpp b/xs/src/admesh/stlinit.cpp
index f5110d394..84fc8d2c1 100644
--- a/xs/src/admesh/stlinit.cpp
+++ b/xs/src/admesh/stlinit.cpp
@@ -27,6 +27,7 @@
#include <assert.h>
#include <boost/nowide/cstdio.hpp>
+#include <boost/detail/endian.hpp>
#include "stl.h"
@@ -50,11 +51,15 @@ stl_initialize(stl_file *stl) {
stl->stats.volume = -1.0;
}
+#ifndef BOOST_LITTLE_ENDIAN
+extern void stl_internal_reverse_quads(char *buf, size_t cnt);
+#endif /* BOOST_LITTLE_ENDIAN */
+
void
stl_count_facets(stl_file *stl, const char *file) {
long file_size;
int header_num_facets;
- int num_facets;
+ uint32_t num_facets;
int i;
size_t s;
unsigned char chtest[128];
@@ -113,7 +118,12 @@ stl_count_facets(stl_file *stl, const char *file) {
}
/* Read the int following the header. This should contain # of facets */
- if((!fread(&header_num_facets, sizeof(int), 1, stl->fp)) || (num_facets != header_num_facets)) {
+ bool header_num_faces_read = fread(&header_num_facets, sizeof(uint32_t), 1, stl->fp);
+#ifndef BOOST_LITTLE_ENDIAN
+ // Convert from little endian to big endian.
+ stl_internal_reverse_quads((char*)&header_num_facets, 4);
+#endif /* BOOST_LITTLE_ENDIAN */
+ if (! header_num_faces_read || num_facets != header_num_facets) {
fprintf(stderr,
"Warning: File size doesn't match number of facets in the header\n");
}
@@ -268,6 +278,10 @@ stl_read(stl_file *stl, int first_facet, int first) {
stl->error = 1;
return;
}
+#ifndef BOOST_LITTLE_ENDIAN
+ // Convert the loaded little endian data to big endian.
+ stl_internal_reverse_quads((char*)&facet, 48);
+#endif /* BOOST_LITTLE_ENDIAN */
} else
/* Read a single facet from an ASCII .STL file */
{