jalec 5c3a8ff977 render to tga 13 سال پیش
..
matlab 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 سال پیش
mosek 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 سال پیش
tetgen 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 سال پیش
EPS.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
EPS.h bd4d115fea major reorganization of directory structure 13 سال پیش
MCTables.hh 9f80dbdd02 minor updates to marching cubes 13 سال پیش
ONE.h bd4d115fea major reorganization of directory structure 13 سال پیش
PI.h bd4d115fea major reorganization of directory structure 13 سال پیش
ReAntTweakBar.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
ReAntTweakBar.h bd4d115fea major reorganization of directory structure 13 سال پیش
Timer.h 0c1a1ad9f5 added clock tick precision to the timer (macosx) 13 سال پیش
ZERO.h bd4d115fea major reorganization of directory structure 13 سال پیش
adjacency_list.cpp 21f9758feb added a few specializations 13 سال پیش
adjacency_list.h bd4d115fea major reorganization of directory structure 13 سال پیش
adjacency_matrix.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
adjacency_matrix.h bd4d115fea major reorganization of directory structure 13 سال پیش
all_pairs_distances.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
all_pairs_distances.h bd4d115fea major reorganization of directory structure 13 سال پیش
axis_angle_to_quat.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
axis_angle_to_quat.h bd4d115fea major reorganization of directory structure 13 سال پیش
basename.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
basename.h bd4d115fea major reorganization of directory structure 13 سال پیش
boundary_faces.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
boundary_faces.h 778c042ccf explicit templates matlab workspace and last commit before hunting bug in alec's skinning 13 سال پیش
canonical_quaternions.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
canonical_quaternions.h bd4d115fea major reorganization of directory structure 13 سال پیش
cat.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
cat.h bd4d115fea major reorganization of directory structure 13 سال پیش
cocoa_key_to_anttweakbar_key.cpp 1d90da86f8 unproject to zero plane 13 سال پیش
cocoa_key_to_anttweakbar_key.h bd4d115fea major reorganization of directory structure 13 سال پیش
colon.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
colon.h bd4d115fea major reorganization of directory structure 13 سال پیش
concat.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
concat.h bd4d115fea major reorganization of directory structure 13 سال پیش
cotangent.cpp 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 سال پیش
cotangent.h bd4d115fea major reorganization of directory structure 13 سال پیش
cotmatrix.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
cotmatrix.h bd4d115fea major reorganization of directory structure 13 سال پیش
create_index_vbo.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
create_index_vbo.h bd4d115fea major reorganization of directory structure 13 سال پیش
create_mesh_vbo.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
create_mesh_vbo.h bd4d115fea major reorganization of directory structure 13 سال پیش
create_shader_program.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
create_shader_program.h bd4d115fea major reorganization of directory structure 13 سال پیش
create_vector_vbo.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
create_vector_vbo.h bd4d115fea major reorganization of directory structure 13 سال پیش
cross.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
cross.h bd4d115fea major reorganization of directory structure 13 سال پیش
destroy_shader_program.cpp 9e49a8d87b fixed verbose and merged 13 سال پیش
destroy_shader_program.h bd4d115fea major reorganization of directory structure 13 سال پیش
diag.cpp b46010fc5f massmatrix 13 سال پیش
diag.h b46010fc5f massmatrix 13 سال پیش
dirname.cpp 9e49a8d87b fixed verbose and merged 13 سال پیش
dirname.h bd4d115fea major reorganization of directory structure 13 سال پیش
dot.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
dot.h bd4d115fea major reorganization of directory structure 13 سال پیش
edge_lengths.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
edge_lengths.h bd4d115fea major reorganization of directory structure 13 سال پیش
edges.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
edges.h bd4d115fea major reorganization of directory structure 13 سال پیش
edgetopology.cpp e1121d7171 fixed implementation of edge topology 13 سال پیش
edgetopology.h e1121d7171 fixed implementation of edge topology 13 سال پیش
example_fun.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
example_fun.h bd4d115fea major reorganization of directory structure 13 سال پیش
face_occurences.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
face_occurences.h bd4d115fea major reorganization of directory structure 13 سال پیش
faces_first.cpp 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 سال پیش
faces_first.h 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 سال پیش
file_contents_as_string.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
file_contents_as_string.h bd4d115fea major reorganization of directory structure 13 سال پیش
file_exists.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
file_exists.h bd4d115fea major reorganization of directory structure 13 سال پیش
find.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
find.h bd4d115fea major reorganization of directory structure 13 سال پیش
full.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
full.h bd4d115fea major reorganization of directory structure 13 سال پیش
get_seconds.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
get_seconds.h bd4d115fea major reorganization of directory structure 13 سال پیش
get_seconds_hires.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
get_seconds_hires.h bd4d115fea major reorganization of directory structure 13 سال پیش
gl_type_size.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
gl_type_size.h bd4d115fea major reorganization of directory structure 13 سال پیش
grad.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
grad.h bd4d115fea major reorganization of directory structure 13 سال پیش
igl_inline.h bd4d115fea major reorganization of directory structure 13 سال پیش
invert_diag.cpp 15ccf65951 invert diag 13 سال پیش
invert_diag.h 15ccf65951 invert diag 13 سال پیش
is_border_vertex.cpp adefe2d4aa added marching cubes implementation 13 سال پیش
is_border_vertex.h bd4d115fea major reorganization of directory structure 13 سال پیش
is_dir.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
is_dir.h bd4d115fea major reorganization of directory structure 13 سال پیش
is_file.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
is_file.h bd4d115fea major reorganization of directory structure 13 سال پیش
is_manifold.cpp 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 سال پیش
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 سال پیش
is_readable.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
is_readable.h bd4d115fea major reorganization of directory structure 13 سال پیش
is_symmetric.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
is_symmetric.h bd4d115fea major reorganization of directory structure 13 سال پیش
is_writable.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
is_writable.h bd4d115fea major reorganization of directory structure 13 سال پیش
launch_medit.cpp 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 سال پیش
launch_medit.h 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 سال پیش
limit_faces.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
limit_faces.h bd4d115fea major reorganization of directory structure 13 سال پیش
list_to_matrix.cpp 21f9758feb added a few specializations 13 سال پیش
list_to_matrix.h bd4d115fea major reorganization of directory structure 13 سال پیش
load_shader.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
load_shader.h bd4d115fea major reorganization of directory structure 13 سال پیش
lu_lagrange.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
lu_lagrange.h bd4d115fea major reorganization of directory structure 13 سال پیش
marching_cubes.cpp 9f80dbdd02 minor updates to marching cubes 13 سال پیش
marching_cubes.h 9f80dbdd02 minor updates to marching cubes 13 سال پیش
massmatrix.cpp 84b995054f fixed massmatrix 13 سال پیش
massmatrix.h b46010fc5f massmatrix 13 سال پیش
mat_max.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
mat_max.h bd4d115fea major reorganization of directory structure 13 سال پیش
mat_min.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
mat_min.h bd4d115fea major reorganization of directory structure 13 سال پیش
material_colors.h bd4d115fea major reorganization of directory structure 13 سال پیش
matrix_to_list.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
matrix_to_list.h bd4d115fea major reorganization of directory structure 13 سال پیش
max_size.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
max_size.h bd4d115fea major reorganization of directory structure 13 سال پیش
min_quad_dense.cpp 97e8cb20bd add use_lu as parameter to min_quad_dense 13 سال پیش
min_quad_dense.h 97e8cb20bd add use_lu as parameter to min_quad_dense 13 سال پیش
min_quad_with_fixed.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
min_quad_with_fixed.h bd4d115fea major reorganization of directory structure 13 سال پیش
min_size.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
min_size.h bd4d115fea major reorganization of directory structure 13 سال پیش
mode.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
mode.h bd4d115fea major reorganization of directory structure 13 سال پیش
moveFV.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
moveFV.h bd4d115fea major reorganization of directory structure 13 سال پیش
mvc.h adefe2d4aa added marching cubes implementation 13 سال پیش
normalize_quat.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
normalize_quat.h bd4d115fea major reorganization of directory structure 13 سال پیش
normalize_row_lengths.cpp 20641d7778 normalize rows disambiguation 13 سال پیش
normalize_row_lengths.h 20641d7778 normalize rows disambiguation 13 سال پیش
normalize_row_sums.cpp 20641d7778 normalize rows disambiguation 13 سال پیش
normalize_row_sums.h 20641d7778 normalize rows disambiguation 13 سال پیش
on_boundary.cpp 778c042ccf explicit templates matlab workspace and last commit before hunting bug in alec's skinning 13 سال پیش
on_boundary.h bd4d115fea major reorganization of directory structure 13 سال پیش
orth.h bd4d115fea major reorganization of directory structure 13 سال پیش
pathinfo.cpp 9e49a8d87b fixed verbose and merged 13 سال پیش
pathinfo.h bd4d115fea major reorganization of directory structure 13 سال پیش
per_corner_normals.cpp 21f9758feb added a few specializations 13 سال پیش
per_corner_normals.h bd4d115fea major reorganization of directory structure 13 سال پیش
per_face_normals.cpp 21f9758feb added a few specializations 13 سال پیش
per_face_normals.h bd4d115fea major reorganization of directory structure 13 سال پیش
per_vertex_normals.cpp 20641d7778 normalize rows disambiguation 13 سال پیش
per_vertex_normals.h bd4d115fea major reorganization of directory structure 13 سال پیش
plot_vector.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
plot_vector.h bd4d115fea major reorganization of directory structure 13 سال پیش
point_in_circle.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
point_in_circle.h bd4d115fea major reorganization of directory structure 13 سال پیش
pos.h bd4d115fea major reorganization of directory structure 13 سال پیش
print_gl_get.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
print_gl_get.h bd4d115fea major reorganization of directory structure 13 سال پیش
print_ijv.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
print_ijv.h bd4d115fea major reorganization of directory structure 13 سال پیش
print_program_info_log.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
print_program_info_log.h bd4d115fea major reorganization of directory structure 13 سال پیش
print_shader_info_log.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
print_shader_info_log.h bd4d115fea major reorganization of directory structure 13 سال پیش
project.cpp 9e49a8d87b fixed verbose and merged 13 سال پیش
project.h bd4d115fea major reorganization of directory structure 13 سال پیش
project_to_line.cpp a90c38cbe1 project to line 13 سال پیش
project_to_line.h a90c38cbe1 project to line 13 سال پیش
quat_conjugate.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
quat_conjugate.h bd4d115fea major reorganization of directory structure 13 سال پیش
quat_mult.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
quat_mult.h bd4d115fea major reorganization of directory structure 13 سال پیش
quat_to_mat.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
quat_to_mat.h bd4d115fea major reorganization of directory structure 13 سال پیش
read.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
read.h bd4d115fea major reorganization of directory structure 13 سال پیش
readDMAT.cpp 9e49a8d87b fixed verbose and merged 13 سال پیش
readDMAT.h 9e49a8d87b fixed verbose and merged 13 سال پیش
readMESH.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
readMESH.h bd4d115fea major reorganization of directory structure 13 سال پیش
readOBJ.cpp 21f9758feb added a few specializations 13 سال پیش
readOBJ.h bd4d115fea major reorganization of directory structure 13 سال پیش
readOFF.cpp 21f9758feb added a few specializations 13 سال پیش
readOFF.h 21f9758feb added a few specializations 13 سال پیش
removeDuplicates.cpp adefe2d4aa added marching cubes implementation 13 سال پیش
removeDuplicates.h adefe2d4aa added marching cubes implementation 13 سال پیش
removeUnreferenced.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
removeUnreferenced.h bd4d115fea major reorganization of directory structure 13 سال پیش
render_to_tga.cpp 5c3a8ff977 render to tga 13 سال پیش
render_to_tga.h 5c3a8ff977 render to tga 13 سال پیش
reorder.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
reorder.h bd4d115fea major reorganization of directory structure 13 سال پیش
repdiag.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
repdiag.h bd4d115fea major reorganization of directory structure 13 سال پیش
repmat.cpp b46010fc5f massmatrix 13 سال پیش
repmat.h bd4d115fea major reorganization of directory structure 13 سال پیش
report_gl_error.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
report_gl_error.h bd4d115fea major reorganization of directory structure 13 سال پیش
rotate_by_quat.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
rotate_by_quat.h bd4d115fea major reorganization of directory structure 13 سال پیش
rows_to_matrix.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
rows_to_matrix.h bd4d115fea major reorganization of directory structure 13 سال پیش
slice.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
slice.h bd4d115fea major reorganization of directory structure 13 سال پیش
slice_into.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
slice_into.h bd4d115fea major reorganization of directory structure 13 سال پیش
snap_to_canonical_view_quat.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
snap_to_canonical_view_quat.h bd4d115fea major reorganization of directory structure 13 سال پیش
sort.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
sort.h bd4d115fea major reorganization of directory structure 13 سال پیش
sparse.cpp b46010fc5f massmatrix 13 سال پیش
sparse.h bd4d115fea major reorganization of directory structure 13 سال پیش
speye.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
speye.h bd4d115fea major reorganization of directory structure 13 سال پیش
stdin_to_temp.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
stdin_to_temp.h bd4d115fea major reorganization of directory structure 13 سال پیش
sum.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
sum.h bd4d115fea major reorganization of directory structure 13 سال پیش
texture_from_tga.cpp 9e49a8d87b fixed verbose and merged 13 سال پیش
texture_from_tga.h bd4d115fea major reorganization of directory structure 13 سال پیش
tga.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
tga.h bd4d115fea major reorganization of directory structure 13 سال پیش
trackball.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
trackball.h bd4d115fea major reorganization of directory structure 13 سال پیش
transpose_blocks.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
transpose_blocks.h bd4d115fea major reorganization of directory structure 13 سال پیش
tt.cpp 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 سال پیش
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 سال پیش
uniform_type_to_string.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
uniform_type_to_string.h bd4d115fea major reorganization of directory structure 13 سال پیش
unproject.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
unproject.h 1d90da86f8 unproject to zero plane 13 سال پیش
unproject_to_zero_plane.cpp 1d90da86f8 unproject to zero plane 13 سال پیش
unproject_to_zero_plane.h 1d90da86f8 unproject to zero plane 13 سال پیش
upsample.cpp 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 سال پیش
upsample.h bd4d115fea major reorganization of directory structure 13 سال پیش
verbose.h 97e8cb20bd add use_lu as parameter to min_quad_dense 13 سال پیش
vf.cpp 21f9758feb added a few specializations 13 سال پیش
vf.h bd4d115fea major reorganization of directory structure 13 سال پیش
write.cpp bd4d115fea major reorganization of directory structure 13 سال پیش
write.h bd4d115fea major reorganization of directory structure 13 سال پیش
writeDMAT.cpp 9e49a8d87b fixed verbose and merged 13 سال پیش
writeDMAT.h bd4d115fea major reorganization of directory structure 13 سال پیش
writeMESH.cpp 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 سال پیش
writeMESH.h 1f70076a7a fixed optimization flags in some Makefiles, tetgen wraper, launch medit, mosek wrapper 13 سال پیش
writeOBJ.cpp 5fb4437450 fixed warnings in writeobj 13 سال پیش
writeOBJ.h bd4d115fea major reorganization of directory structure 13 سال پیش
writeOFF.cpp 21f9758feb added a few specializations 13 سال پیش
writeOFF.h bd4d115fea major reorganization of directory structure 13 سال پیش

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);

#ifdef __APPLE__
size_t number_of_vertices;
#else
int number_of_vertices;
#endif
if(1 != fscanf(mesh_file," %ld",&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));
#ifdef __APPLE__
size_t extra;
#else
int extra;
#endif
for(size_t i = 0;i {
double x,y,z;
if(4 != fscanf(mesh_file," %lg %lg %lg %ld",&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;
}
#ifdef __APPLE__
size_t number_of_triangles;
#else
int number_of_triangles;
#endif
if(1 != fscanf(mesh_file," %ld",&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
#ifdef __APPLE__
size_t tri[3];
#else
int tri[3];
#endif
for(size_t i = 0;i {
if(4 != fscanf(mesh_file," %ld %ld %ld %ld",&tri[0],&tri[1],&tri[2],&extra))
{
printf("Error: expecting triangle indices...\n");
return false;
}
for(size_t 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;
}
#ifdef __APPLE__
size_t number_of_tetrahedra;
#else
int number_of_tetrahedra;
#endif
if(1 != fscanf(mesh_file," %ld",&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
#ifdef __APPLE__
size_t a,b,c,d;
#else
int a,b,c,d;
#endif
for(size_t i = 0;i {
if(5 != fscanf(mesh_file," %ld %ld %ld %ld %ld",&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