jalec 430c37544c ci before daniele moves to hg 13 yıl önce
..
matlab 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 yıl önce
mosek 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
tetgen 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
EPS.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
EPS.h bd4d115fea major reorganization of directory structure 13 yıl önce
MCTables.hh 9f80dbdd02 minor updates to marching cubes 13 yıl önce
ONE.h bd4d115fea major reorganization of directory structure 13 yıl önce
PI.h bd4d115fea major reorganization of directory structure 13 yıl önce
ReAntTweakBar.cpp 68298f45cc double precision rebar 13 yıl önce
ReAntTweakBar.h 88ab84a1d9 readDMAT binary 13 yıl önce
Timer.h 0c1a1ad9f5 added clock tick precision to the timer (macosx) 13 yıl önce
ZERO.h bd4d115fea major reorganization of directory structure 13 yıl önce
adjacency_list.cpp 21f9758feb added a few specializations 13 yıl önce
adjacency_list.h bd4d115fea major reorganization of directory structure 13 yıl önce
adjacency_matrix.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
adjacency_matrix.h bd4d115fea major reorganization of directory structure 13 yıl önce
all_pairs_distances.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
all_pairs_distances.h bd4d115fea major reorganization of directory structure 13 yıl önce
axis_angle_to_quat.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
axis_angle_to_quat.h bd4d115fea major reorganization of directory structure 13 yıl önce
basename.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
basename.h bd4d115fea major reorganization of directory structure 13 yıl önce
boundary_faces.cpp 0deb1ee265 boundary faces explicit template 13 yıl önce
boundary_faces.h 778c042ccf explicit templates matlab workspace and last commit before hunting bug in alec's skinning 13 yıl önce
canonical_quaternions.cpp 3888611403 compiles with skinning app 13 yıl önce
canonical_quaternions.h bd4d115fea major reorganization of directory structure 13 yıl önce
cat.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
cat.h bd4d115fea major reorganization of directory structure 13 yıl önce
cocoa_key_to_anttweakbar_key.cpp 430c37544c ci before daniele moves to hg 13 yıl önce
cocoa_key_to_anttweakbar_key.h bd4d115fea major reorganization of directory structure 13 yıl önce
colon.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
colon.h bd4d115fea major reorganization of directory structure 13 yıl önce
concat.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
concat.h bd4d115fea major reorganization of directory structure 13 yıl önce
cotangent.cpp 3888611403 compiles with skinning app 13 yıl önce
cotangent.h bd4d115fea major reorganization of directory structure 13 yıl önce
cotmatrix.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
cotmatrix.h bd4d115fea major reorganization of directory structure 13 yıl önce
create_index_vbo.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
create_index_vbo.h ad715f0020 hopefully fixed a bunch of missing includes for windows 13 yıl önce
create_mesh_vbo.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
create_mesh_vbo.h ad715f0020 hopefully fixed a bunch of missing includes for windows 13 yıl önce
create_shader_program.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
create_shader_program.h ad715f0020 hopefully fixed a bunch of missing includes for windows 13 yıl önce
create_vector_vbo.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
create_vector_vbo.h ad715f0020 hopefully fixed a bunch of missing includes for windows 13 yıl önce
cross.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
cross.h bd4d115fea major reorganization of directory structure 13 yıl önce
destroy_shader_program.cpp 9e49a8d87b fixed verbose and merged 13 yıl önce
destroy_shader_program.h ad715f0020 hopefully fixed a bunch of missing includes for windows 13 yıl önce
diag.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
diag.h b46010fc5f massmatrix 13 yıl önce
dirname.cpp 9e49a8d87b fixed verbose and merged 13 yıl önce
dirname.h bd4d115fea major reorganization of directory structure 13 yıl önce
dot.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
dot.h bd4d115fea major reorganization of directory structure 13 yıl önce
draw_point.cpp 0d4d643d08 draw point in Alec's 2d style 13 yıl önce
draw_point.h 430c37544c ci before daniele moves to hg 13 yıl önce
edge_lengths.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
edge_lengths.h bd4d115fea major reorganization of directory structure 13 yıl önce
edges.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
edges.h bd4d115fea major reorganization of directory structure 13 yıl önce
edgetopology.cpp e1121d7171 fixed implementation of edge topology 13 yıl önce
edgetopology.h e1121d7171 fixed implementation of edge topology 13 yıl önce
example_fun.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
example_fun.h bd4d115fea major reorganization of directory structure 13 yıl önce
face_occurences.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
face_occurences.h bd4d115fea major reorganization of directory structure 13 yıl önce
faces_first.cpp 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 yıl önce
faces_first.h 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 yıl önce
file_contents_as_string.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
file_contents_as_string.h bd4d115fea major reorganization of directory structure 13 yıl önce
file_exists.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
file_exists.h bd4d115fea major reorganization of directory structure 13 yıl önce
find.cpp 98be5f8569 fixed bug in render to tga 13 yıl önce
find.h 98be5f8569 fixed bug in render to tga 13 yıl önce
full.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
full.h bd4d115fea major reorganization of directory structure 13 yıl önce
get_seconds.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
get_seconds.h bd4d115fea major reorganization of directory structure 13 yıl önce
get_seconds_hires.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
get_seconds_hires.h bd4d115fea major reorganization of directory structure 13 yıl önce
gl_type_size.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
gl_type_size.h ad715f0020 hopefully fixed a bunch of missing includes for windows 13 yıl önce
grad.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
grad.h bd4d115fea major reorganization of directory structure 13 yıl önce
harwell_boeing.cpp 98be5f8569 fixed bug in render to tga 13 yıl önce
harwell_boeing.h 98be5f8569 fixed bug in render to tga 13 yıl önce
igl_inline.h bd4d115fea major reorganization of directory structure 13 yıl önce
invert_diag.cpp 98be5f8569 fixed bug in render to tga 13 yıl önce
invert_diag.h 15ccf65951 invert diag 13 yıl önce
is_border_vertex.cpp adefe2d4aa added marching cubes implementation 13 yıl önce
is_border_vertex.h bd4d115fea major reorganization of directory structure 13 yıl önce
is_dir.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
is_dir.h bd4d115fea major reorganization of directory structure 13 yıl önce
is_file.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
is_file.h bd4d115fea major reorganization of directory structure 13 yıl önce
is_manifold.cpp 4d8b3576f5 fixed warnings in daniele functions 13 yıl önce
is_manifold.h 1f7f30930c changed templates for tt to enable different types for F and TT,TTi (F might be unsigned but TT has to contain -1's) 13 yıl önce
is_readable.cpp 88ab84a1d9 readDMAT binary 13 yıl önce
is_readable.h bd4d115fea major reorganization of directory structure 13 yıl önce
is_symmetric.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
is_symmetric.h bd4d115fea major reorganization of directory structure 13 yıl önce
is_writable.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
is_writable.h bd4d115fea major reorganization of directory structure 13 yıl önce
launch_medit.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
launch_medit.h 98be5f8569 fixed bug in render to tga 13 yıl önce
limit_faces.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
limit_faces.h bd4d115fea major reorganization of directory structure 13 yıl önce
list_to_matrix.cpp 98be5f8569 fixed bug in render to tga 13 yıl önce
list_to_matrix.h bd4d115fea major reorganization of directory structure 13 yıl önce
load_shader.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
load_shader.h ad715f0020 hopefully fixed a bunch of missing includes for windows 13 yıl önce
lu_lagrange.cpp ad715f0020 hopefully fixed a bunch of missing includes for windows 13 yıl önce
lu_lagrange.h bd4d115fea major reorganization of directory structure 13 yıl önce
marching_cubes.cpp 9f80dbdd02 minor updates to marching cubes 13 yıl önce
marching_cubes.h 9f80dbdd02 minor updates to marching cubes 13 yıl önce
massmatrix.cpp 84b995054f fixed massmatrix 13 yıl önce
massmatrix.h b46010fc5f massmatrix 13 yıl önce
mat_max.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
mat_max.h bd4d115fea major reorganization of directory structure 13 yıl önce
mat_min.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
mat_min.h bd4d115fea major reorganization of directory structure 13 yıl önce
material_colors.h 3b56d427f7 fixed bug in ReAntTweakbar 13 yıl önce
matrix_to_list.cpp 98be5f8569 fixed bug in render to tga 13 yıl önce
matrix_to_list.h 98be5f8569 fixed bug in render to tga 13 yıl önce
max_size.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
max_size.h bd4d115fea major reorganization of directory structure 13 yıl önce
min_quad_dense.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
min_quad_dense.h 97e8cb20bd add use_lu as parameter to min_quad_dense 13 yıl önce
min_quad_with_fixed.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
min_quad_with_fixed.h 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
min_size.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
min_size.h bd4d115fea major reorganization of directory structure 13 yıl önce
mode.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
mode.h bd4d115fea major reorganization of directory structure 13 yıl önce
moveFV.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
moveFV.h bd4d115fea major reorganization of directory structure 13 yıl önce
mvc.h adefe2d4aa added marching cubes implementation 13 yıl önce
normalize_quat.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
normalize_quat.h bd4d115fea major reorganization of directory structure 13 yıl önce
normalize_row_lengths.cpp 20641d7778 normalize rows disambiguation 13 yıl önce
normalize_row_lengths.h 20641d7778 normalize rows disambiguation 13 yıl önce
normalize_row_sums.cpp 98be5f8569 fixed bug in render to tga 13 yıl önce
normalize_row_sums.h 98be5f8569 fixed bug in render to tga 13 yıl önce
on_boundary.cpp 778c042ccf explicit templates matlab workspace and last commit before hunting bug in alec's skinning 13 yıl önce
on_boundary.h bd4d115fea major reorganization of directory structure 13 yıl önce
orth.h bd4d115fea major reorganization of directory structure 13 yıl önce
pathinfo.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
pathinfo.h bd4d115fea major reorganization of directory structure 13 yıl önce
per_corner_normals.cpp 21f9758feb added a few specializations 13 yıl önce
per_corner_normals.h bd4d115fea major reorganization of directory structure 13 yıl önce
per_face_normals.cpp 21f9758feb added a few specializations 13 yıl önce
per_face_normals.h 98be5f8569 fixed bug in render to tga 13 yıl önce
per_vertex_normals.cpp 20641d7778 normalize rows disambiguation 13 yıl önce
per_vertex_normals.h 5aaf034493 indentation in per_vertex_normals 13 yıl önce
plot_vector.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
plot_vector.h bd4d115fea major reorganization of directory structure 13 yıl önce
point_in_circle.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
point_in_circle.h bd4d115fea major reorganization of directory structure 13 yıl önce
pos.h bd4d115fea major reorganization of directory structure 13 yıl önce
print_gl_get.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
print_gl_get.h ad715f0020 hopefully fixed a bunch of missing includes for windows 13 yıl önce
print_ijv.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
print_ijv.h bd4d115fea major reorganization of directory structure 13 yıl önce
print_program_info_log.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
print_program_info_log.h ad715f0020 hopefully fixed a bunch of missing includes for windows 13 yıl önce
print_shader_info_log.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
print_shader_info_log.h ad715f0020 hopefully fixed a bunch of missing includes for windows 13 yıl önce
project.cpp 9e49a8d87b fixed verbose and merged 13 yıl önce
project.h bd4d115fea major reorganization of directory structure 13 yıl önce
project_to_line.cpp 3888611403 compiles with skinning app 13 yıl önce
project_to_line.h a90c38cbe1 project to line 13 yıl önce
quat_conjugate.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
quat_conjugate.h bd4d115fea major reorganization of directory structure 13 yıl önce
quat_mult.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
quat_mult.h bd4d115fea major reorganization of directory structure 13 yıl önce
quat_to_mat.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
quat_to_mat.h bd4d115fea major reorganization of directory structure 13 yıl önce
read.cpp df3470adb9 read works with vector of vector 13 yıl önce
read.h df3470adb9 read works with vector of vector 13 yıl önce
readDMAT.cpp 88ab84a1d9 readDMAT binary 13 yıl önce
readDMAT.h d8c6aebae3 readDMAT for vectors of vectors 13 yıl önce
readMESH.cpp 3888611403 compiles with skinning app 13 yıl önce
readMESH.h bd4d115fea major reorganization of directory structure 13 yıl önce
readOBJ.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
readOBJ.h bd4d115fea major reorganization of directory structure 13 yıl önce
readOFF.cpp df3470adb9 read works with vector of vector 13 yıl önce
readOFF.h df3470adb9 read works with vector of vector 13 yıl önce
removeDuplicates.cpp adefe2d4aa added marching cubes implementation 13 yıl önce
removeDuplicates.h adefe2d4aa added marching cubes implementation 13 yıl önce
removeUnreferenced.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
removeUnreferenced.h bd4d115fea major reorganization of directory structure 13 yıl önce
render_to_tga.cpp 430c37544c ci before daniele moves to hg 13 yıl önce
render_to_tga.h 5c3a8ff977 render to tga 13 yıl önce
reorder.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
reorder.h bd4d115fea major reorganization of directory structure 13 yıl önce
repdiag.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
repdiag.h bd4d115fea major reorganization of directory structure 13 yıl önce
repmat.cpp b46010fc5f massmatrix 13 yıl önce
repmat.h bd4d115fea major reorganization of directory structure 13 yıl önce
report_gl_error.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
report_gl_error.h bd4d115fea major reorganization of directory structure 13 yıl önce
rotate_by_quat.cpp 3888611403 compiles with skinning app 13 yıl önce
rotate_by_quat.h bd4d115fea major reorganization of directory structure 13 yıl önce
rows_to_matrix.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
rows_to_matrix.h bd4d115fea major reorganization of directory structure 13 yıl önce
slice.cpp 3888611403 compiles with skinning app 13 yıl önce
slice.h bd4d115fea major reorganization of directory structure 13 yıl önce
slice_into.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
slice_into.h bd4d115fea major reorganization of directory structure 13 yıl önce
snap_to_canonical_view_quat.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
snap_to_canonical_view_quat.h bd4d115fea major reorganization of directory structure 13 yıl önce
sort.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
sort.h bd4d115fea major reorganization of directory structure 13 yıl önce
sparse.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
sparse.h bd4d115fea major reorganization of directory structure 13 yıl önce
speye.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
speye.h bd4d115fea major reorganization of directory structure 13 yıl önce
stdin_to_temp.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
stdin_to_temp.h bd4d115fea major reorganization of directory structure 13 yıl önce
sum.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
sum.h bd4d115fea major reorganization of directory structure 13 yıl önce
texture_from_tga.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
texture_from_tga.h ad715f0020 hopefully fixed a bunch of missing includes for windows 13 yıl önce
tga.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
tga.h bd4d115fea major reorganization of directory structure 13 yıl önce
trackball.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
trackball.h bd4d115fea major reorganization of directory structure 13 yıl önce
transpose_blocks.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
transpose_blocks.h bd4d115fea major reorganization of directory structure 13 yıl önce
tt.cpp 3888611403 compiles with skinning app 13 yıl önce
tt.h 1f7f30930c changed templates for tt to enable different types for F and TT,TTi (F might be unsigned but TT has to contain -1's) 13 yıl önce
uniform_type_to_string.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
uniform_type_to_string.h ad715f0020 hopefully fixed a bunch of missing includes for windows 13 yıl önce
unproject.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
unproject.h 1d90da86f8 unproject to zero plane 13 yıl önce
unproject_to_zero_plane.cpp 1d90da86f8 unproject to zero plane 13 yıl önce
unproject_to_zero_plane.h 1d90da86f8 unproject to zero plane 13 yıl önce
upsample.cpp 3888611403 compiles with skinning app 13 yıl önce
upsample.h 3888611403 compiles with skinning app 13 yıl önce
verbose.h 64cc763dd8 compiles on mac (bug fix in upsample) 13 yıl önce
vf.cpp 21f9758feb added a few specializations 13 yıl önce
vf.h bd4d115fea major reorganization of directory structure 13 yıl önce
write.cpp bd4d115fea major reorganization of directory structure 13 yıl önce
write.h bd4d115fea major reorganization of directory structure 13 yıl önce
writeDMAT.cpp ae1d358ed8 writedmat vectors 13 yıl önce
writeDMAT.h ae1d358ed8 writedmat vectors 13 yıl önce
writeMESH.cpp 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 yıl önce
writeMESH.h 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 yıl önce
writeOBJ.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
writeOBJ.h bd4d115fea major reorganization of directory structure 13 yıl önce
writeOFF.cpp 13020d0872 libigl.a and mosek/tetgen extras compile on redhat (with some warnings and removed deprecations), static library makefile for anttweakbar 13 yıl önce
writeOFF.h bd4d115fea major reorganization of directory structure 13 yıl önce

readMESH.cpp

#include "readMESH.h"

#include
#include "verbose.h"

template
IGL_INLINE bool igl::readMESH(
const std::string mesh_file_name,
std::vector > & V,
std::vector > & T,
std::vector > & F)
{
using namespace std;
using namespace igl;
FILE * mesh_file = fopen(mesh_file_name.c_str(),"r");
if(NULL==mesh_file)
{
fprintf(stderr,"IOError: %s could not be opened...",mesh_file_name.c_str());
return false;
}
#ifndef LINE_MAX
# define LINE_MAX 2048
#endif
char line[LINE_MAX];
bool still_comments;
V.clear();
T.clear();
F.clear();

// eat comments at beginning of file
still_comments= true;
while(still_comments)
{
fgets(line,LINE_MAX,mesh_file);
still_comments = (line[0] == '#' || line[0] == '\n');
}

char str[LINE_MAX];
sscanf(line," %s",str);
// check that first word is MeshVersionFormatted
if(0!=strcmp(str,"MeshVersionFormatted"))
{
fprintf(stderr,
"Error: first word should be MeshVersionFormatted not %s\n",str);
fclose(mesh_file);
return false;
}
int one = -1;
if(2 != sscanf(line,"%s %d",str,&one))
{
// 1 appears on next line?
fscanf(mesh_file," %d",&one);
}
if(one != 1)
{
fprintf(stderr,"Error: second word should be 1 not %d\n",one);
fclose(mesh_file);
return false;
}

// eat comments
still_comments= true;
while(still_comments)
{
fgets(line,LINE_MAX,mesh_file);
still_comments = (line[0] == '#' || line[0] == '\n');
}

sscanf(line," %s",str);
// check that third word is Dimension
if(0!=strcmp(str,"Dimension"))
{
fprintf(stderr,"Error: third word should be Dimension not %s\n",str);
fclose(mesh_file);
return false;
}
int three = -1;
if(2 != sscanf(line,"%s %d",str,&three))
{
// 1 appears on next line?
fscanf(mesh_file," %d",&three);
}
if(three != 3)
{
fprintf(stderr,"Error: only Dimension 3 supported not %d\n",three);
fclose(mesh_file);
return false;
}

// eat comments
still_comments= true;
while(still_comments)
{
fgets(line,LINE_MAX,mesh_file);
still_comments = (line[0] == '#' || line[0] == '\n');
}

sscanf(line," %s",str);
// check that fifth word is Vertices
if(0!=strcmp(str,"Vertices"))
{
fprintf(stderr,"Error: fifth word should be Vertices not %s\n",str);
fclose(mesh_file);
return false;
}

//fgets(line,LINE_MAX,mesh_file);

int number_of_vertices;
if(1 != fscanf(mesh_file," %d",&number_of_vertices) || number_of_vertices > 1000000000)
{
fprintf(stderr,"Error: expecting number of vertices less than 10^9...\n");
fclose(mesh_file);
return false;
}
// allocate space for vertices
V.resize(number_of_vertices,vector(3,0));
int extra;
for(int i = 0;i {
double x,y,z;
if(4 != fscanf(mesh_file," %lg %lg %lg %d",&x,&y,&z,&extra))
{
fprintf(stderr,"Error: expecting vertex position...\n");
fclose(mesh_file);
return false;
}
V[i][0] = x;
V[i][1] = y;
V[i][2] = z;
}

// eat comments
still_comments= true;
while(still_comments)
{
fgets(line,LINE_MAX,mesh_file);
still_comments = (line[0] == '#' || line[0] == '\n');
}

sscanf(line," %s",str);
// check that sixth word is Triangles
if(0!=strcmp(str,"Triangles"))
{
fprintf(stderr,"Error: sixth word should be Triangles not %s\n",str);
fclose(mesh_file);
return false;
}
int number_of_triangles;
if(1 != fscanf(mesh_file," %d",&number_of_triangles))
{
fprintf(stderr,"Error: expecting number of triangles...\n");
fclose(mesh_file);
return false;
}
// allocate space for triangles
F.resize(number_of_triangles,vector(3));
// triangle indices
int tri[3];
for(int i = 0;i {
if(4 != fscanf(mesh_file," %d %d %d %d",&tri[0],&tri[1],&tri[2],&extra))
{
printf("Error: expecting triangle indices...\n");
return false;
}
for(int j = 0;j<3;j++)
{
F[i][j] = tri[j]-1;
}
}

// eat comments
still_comments= true;
while(still_comments)
{
fgets(line,LINE_MAX,mesh_file);
still_comments = (line[0] == '#' || line[0] == '\n');
}

sscanf(line," %s",str);
// check that sixth word is Triangles
if(0!=strcmp(str,"Tetrahedra"))
{
fprintf(stderr,"Error: seventh word should be Tetrahedra not %s\n",str);
fclose(mesh_file);
return false;
}
int number_of_tetrahedra;
if(1 != fscanf(mesh_file," %d",&number_of_tetrahedra))
{
fprintf(stderr,"Error: expecting number of tetrahedra...\n");
fclose(mesh_file);
return false;
}
// allocate space for tetrahedra
T.resize(number_of_tetrahedra,vector(4));
// tet indices
int a,b,c,d;
for(int i = 0;i {
if(5 != fscanf(mesh_file," %d %d %d %d %d",&a,&b,&c,&d,&extra))
{
fprintf(stderr,"Error: expecting tetrahedra indices...\n");
fclose(mesh_file);
return false;
}
T[i][0] = a-1;
T[i][1] = b-1;
T[i][2] = c-1;
T[i][3] = d-1;
}
fclose(mesh_file);
return true;
}

#include
#include "list_to_matrix.h"


template
IGL_INLINE bool igl::readMESH(
const std::string str,
Eigen::PlainObjectBase& V,
Eigen::PlainObjectBase& T,
Eigen::PlainObjectBase& F)
{
std::vector > vV,vT,vF;
bool success = igl::readMESH(str,vV,vT,vF);
if(!success)
{
// readOBJ(str,vV,vTC,vN,vF,vFTC,vFN) should have already printed an error
// message to stderr
return false;
}
bool V_rect = igl::list_to_matrix(vV,V);
if(!V_rect)
{
// igl::list_to_matrix(vV,V) already printed error message to std err
return false;
}
bool T_rect = igl::list_to_matrix(vT,T);
if(!T_rect)
{
// igl::list_to_matrix(vT,T) already printed error message to std err
return false;
}
bool F_rect = igl::list_to_matrix(vF,F);
if(!F_rect)
{
// igl::list_to_matrix(vF,F) already printed error message to std err
return false;
}
assert(V.cols() == 3);
assert(T.cols() == 4);
assert(F.cols() == 3);
return true;
}

#ifndef IGL_HEADER_ONLY
// Explicit template specialization
// generated by autoexplicit.sh
template bool igl::readMESH, Eigen::Matrix, Eigen::Matrix >(std::basic_string, std::allocator >, Eigen::PlainObjectBase >&, Eigen::PlainObjectBase >&, Eigen::PlainObjectBase >&);
#endif