diff --git a/.github/workflows/main-job.yml b/.github/workflows/main-job.yml index d8b978c1a..0901c7997 100644 --- a/.github/workflows/main-job.yml +++ b/.github/workflows/main-job.yml @@ -98,6 +98,13 @@ jobs: vtk: on int: int64_t + - os: ubuntu-20.04 + pattern: off + pointmap: off + scotch: on + vtk: on + int: int64_t + - os: ubuntu-20.04 pattern: off pointmap: off @@ -310,6 +317,13 @@ jobs: cd build ctest --timeout 7200 -VV -C ${{ inputs.cmake_build_type }} -j ${{ env.NJOBS }} + - name: Test Mmg with in64_t integers + # Run long tests only on ubuntu with pattern off, scotch on, vtk on and int64_t integers + if: matrix.os == 'ubuntu-20.04' && matrix.pattern == 'off' && matrix.scotch == 'on' && matrix.vtk == 'on' && matrix.int == 'int64_t' + run: | + cd build + ctest --timeout 7200 -VV -C ${{ inputs.cmake_build_type }} -j ${{ env.NJOBS }} + - name: Test non native I/Os of Mmg if: matrix.vtk == 'on' run: | diff --git a/cmake/testing/libmmg3d_tests.cmake b/cmake/testing/libmmg3d_tests.cmake index 5e0922b5c..704417f11 100644 --- a/cmake/testing/libmmg3d_tests.cmake +++ b/cmake/testing/libmmg3d_tests.cmake @@ -215,6 +215,11 @@ IF ( ELAS_FOUND AND NOT USE_ELAS MATCHES OFF ) "${PROJECT_SOURCE_DIR}/libexamples/mmg3d/LagrangianMotion_example0/tinyBoxt" "${CTEST_OUTPUT_DIR}/libmmg3d_LagrangianMotion_0-tinyBoxt.o" ) + IF (${MMG5_INT} MATCHES int64_t) + SET(passElasRegex "## Error: MMG5_velextLS: impossible to call elasticity library with int64 integers") + SET_PROPERTY(TEST libmmg3d_example4 + PROPERTY PASS_REGULAR_EXPRESSION "${passElasRegex}") + ENDIF () ENDIF () ADD_TEST(NAME libmmg3d_example6_io_0 diff --git a/cmake/testing/mmg2d_tests.cmake b/cmake/testing/mmg2d_tests.cmake index 8f3f861f4..07efdc1af 100644 --- a/cmake/testing/mmg2d_tests.cmake +++ b/cmake/testing/mmg2d_tests.cmake @@ -789,6 +789,12 @@ IF ( ELAS_FOUND AND NOT USE_ELAS MATCHES OFF ) -out ${CTEST_OUTPUT_DIR}/mmg2d_LagMotion2_circle-nsd3.o.mesh ) + IF (${MMG5_INT} MATCHES int64_t ) + SET(passElasRegex "## Error: MMG2D_velextLS: impossible to call elasticity library with int64 integers") + SET_PROPERTY(TEST mmg2d_LagMotion0_circle mmg2d_LagMotion1_circle mmg2d_LagMotion2_circle mmg2d_LagMotion2_circle-nsd3 + PROPERTY PASS_REGULAR_EXPRESSION "${passElasRegex}") + ENDIF() + ENDIF() ############################################################################### diff --git a/cmake/testing/mmg3d_tests.cmake b/cmake/testing/mmg3d_tests.cmake index c65407263..fa5baf52a 100644 --- a/cmake/testing/mmg3d_tests.cmake +++ b/cmake/testing/mmg3d_tests.cmake @@ -572,6 +572,12 @@ IF ( ELAS_FOUND AND NOT USE_ELAS MATCHES OFF ) -out ${CTEST_OUTPUT_DIR}/mmg3d_LagMotion2_tinyBoxt-nsd3.o.meshb ) + IF (${MMG5_INT} MATCHES int64_t ) + SET(passElasRegex "## Error: MMG5_velextLS: impossible to call elasticity library with int64 integers") + SET_PROPERTY(TEST mmg3d_LagMotion0_tinyBoxt mmg3d_LagMotion1_tinyBoxt mmg3d_LagMotion2_tinyBoxt mmg3d_LagMotion2_tinyBoxt-nsd3 + PROPERTY PASS_REGULAR_EXPRESSION "${passElasRegex}") + ENDIF() + ENDIF() ############################################################################## @@ -892,8 +898,11 @@ IF ( LONG_TESTS ) -sol ${MMG3D_CI_TESTS}/LagMotion1_boxt/boxt.sol -out ${CTEST_OUTPUT_DIR}/mmg3d_LagMotion2_boxt-boxt.o.meshb ) + IF (${MMG5_INT} MATCHES int64_t ) + SET_PROPERTY(TEST mmg3d_LagMotion0_boxt mmg3d_LagMotion1_boxt mmg3d_LagMotion2_boxt + PROPERTY PASS_REGULAR_EXPRESSION "${passElasRegex}") + ENDIF() ENDIF() - ENDIF() ############################################################################### diff --git a/src/mmg2d/inout_2d.c b/src/mmg2d/inout_2d.c index a2e57dad1..1d311d3a0 100644 --- a/src/mmg2d/inout_2d.c +++ b/src/mmg2d/inout_2d.c @@ -45,6 +45,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { ncor = nreq = nreqed = ntreq = nqreq = 0; bin = 0; iswp = 0; + bpos = 0; mesh->np = mesh->nt = mesh->na = mesh->xp = 0; nref = 0; @@ -182,7 +183,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->np,MMG5_SW,1,inm); - if(iswp) mesh->np=MMG5_SWAPBIN(mesh->np); + if(iswp) mesh->np=MMG5_swapbin(mesh->np); posnp = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -191,7 +192,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->nt,MMG5_SW,1,inm); - if(iswp) mesh->nt=MMG5_SWAPBIN(mesh->nt); + if(iswp) mesh->nt=MMG5_swapbin(mesh->nt); posnt = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -201,7 +202,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&ntreq,MMG5_SW,1,inm); - if(iswp) ntreq=MMG5_SWAPBIN(ntreq); + if(iswp) ntreq=MMG5_swapbin(ntreq); posntreq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -210,7 +211,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->nquad,MMG5_SW,1,inm); - if(iswp) mesh->nquad=MMG5_SWAPBIN(mesh->nquad); + if(iswp) mesh->nquad=MMG5_swapbin(mesh->nquad); posnq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -219,7 +220,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&nqreq,MMG5_SW,1,inm); - if(iswp) nqreq=MMG5_SWAPBIN(nqreq); + if(iswp) nqreq=MMG5_swapbin(nqreq); posnqreq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -228,7 +229,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&ncor,MMG5_SW,1,inm); - if(iswp) ncor=MMG5_SWAPBIN(ncor); + if(iswp) ncor=MMG5_swapbin(ncor); posncor = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -237,7 +238,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->na,MMG5_SW,1,inm); - if(iswp) mesh->na=MMG5_SWAPBIN(mesh->na); + if(iswp) mesh->na=MMG5_swapbin(mesh->na); posned = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -246,7 +247,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&nreqed,MMG5_SW,1,inm); - if(iswp) nreqed=MMG5_SWAPBIN(nreqed); + if(iswp) nreqed=MMG5_swapbin(nreqed); posreqed = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -255,7 +256,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&nreq,MMG5_SW,1,inm); - if(iswp) nreq=MMG5_SWAPBIN(nreq); + if(iswp) nreq=MMG5_swapbin(nreq); posreq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -320,7 +321,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { ppt->c[i] = (double) fc; } MMG_FREAD(&ppt->ref,MMG5_SW,1,inm); - if(iswp) ppt->ref=MMG5_SWAPBIN(ppt->ref); + if(iswp) ppt->ref=MMG5_swapbin(ppt->ref); } } else { if (!bin) { @@ -336,7 +337,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { if(iswp) ppt->c[i]=MMG5_swapd(ppt->c[i]); } MMG_FREAD(&ppt->ref,MMG5_SW,1,inm); - if(iswp) ppt->ref=MMG5_SWAPBIN(ppt->ref); + if(iswp) ppt->ref=MMG5_swapbin(ppt->ref); } } if ( ppt->ref < 0 ) { @@ -356,11 +357,11 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { } else { MMG_FREAD(&ped->a,MMG5_SW,1,inm); - if(iswp) ped->a=MMG5_SWAPBIN(ped->a); + if(iswp) ped->a=MMG5_swapbin(ped->a); MMG_FREAD(&ped->b,MMG5_SW,1,inm); - if(iswp) ped->b=MMG5_SWAPBIN(ped->b); + if(iswp) ped->b=MMG5_swapbin(ped->b); MMG_FREAD(&ped->ref,MMG5_SW,1,inm); - if(iswp) ped->ref=MMG5_SWAPBIN(ped->ref); + if(iswp) ped->ref=MMG5_swapbin(ped->ref); } if ( ped->ref < 0 ) { ped->ref = -ped->ref; @@ -382,10 +383,10 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { else { for (i=0 ; i<3 ; i++) { MMG_FREAD(&pt->v[i],MMG5_SW,1,inm); - if(iswp) pt->v[i]=MMG5_SWAPBIN(pt->v[i]); + if(iswp) pt->v[i]=MMG5_swapbin(pt->v[i]); } MMG_FREAD(&pt->ref,MMG5_SW,1,inm); - if(iswp) pt->ref=MMG5_SWAPBIN(pt->ref); + if(iswp) pt->ref=MMG5_swapbin(pt->ref); } for (i=0; i<3; i++) { ppt = &mesh->point[ pt->v[i] ]; @@ -425,7 +426,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { } else { MMG_FREAD(&i,MMG5_SW,1,inm); - if(iswp) i=MMG5_SWAPBIN(i); + if(iswp) i=MMG5_swapbin(i); } if ( i>mesh->nt ) { fprintf(stderr,"\n ## Warning: %s: required triangle number %8" MMG5_PRId "" @@ -460,10 +461,10 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { else { for (i=0 ; i<4 ; i++) { MMG_FREAD(&pq1->v[i],MMG5_SW,1,inm); - if(iswp) pq1->v[i]=MMG5_SWAPBIN(pq1->v[i]); + if(iswp) pq1->v[i]=MMG5_swapbin(pq1->v[i]); } MMG_FREAD(&pq1->ref,MMG5_SW,1,inm); - if(iswp) pq1->ref=MMG5_SWAPBIN(pq1->ref); + if(iswp) pq1->ref=MMG5_swapbin(pq1->ref); } for (i=0; i<4; i++) { ppt = &mesh->point[ pq1->v[i] ]; @@ -485,7 +486,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { } else { MMG_FREAD(&i,MMG5_SW,1,inm); - if(iswp) i=MMG5_SWAPBIN(i); + if(iswp) i=MMG5_swapbin(i); } if ( i>mesh->nquad ) { fprintf(stderr,"\n ## Warning: %s: required quadrilaterals number" @@ -511,7 +512,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { } else { MMG_FREAD(&ref,MMG5_SW,1,inm); - if(iswp) ref=MMG5_SWAPBIN(ref); + if(iswp) ref=MMG5_swapbin(ref); } ppt = &mesh->point[ref]; ppt->tag |= MG_CRN; @@ -528,7 +529,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { } else { MMG_FREAD(&ref,MMG5_SW,1,inm); - if(iswp) ref=MMG5_SWAPBIN(ref); + if(iswp) ref=MMG5_swapbin(ref); } ppt = &mesh->point[ref]; ppt->tag |= MG_REQ; @@ -546,7 +547,7 @@ int MMG2D_loadMesh(MMG5_pMesh mesh,const char *filename) { } else { MMG_FREAD(&ref,MMG5_SW,1,inm); - if(iswp) ref=MMG5_SWAPBIN(ref); + if(iswp) ref=MMG5_swapbin(ref); } ped = &mesh->edge[ref]; ped->tag |= MG_REQ; diff --git a/src/mmg2d/velextls_2d.c b/src/mmg2d/velextls_2d.c index fdcd2c174..40a3a47aa 100644 --- a/src/mmg2d/velextls_2d.c +++ b/src/mmg2d/velextls_2d.c @@ -341,6 +341,13 @@ int MMG2D_velextLS(MMG5_pMesh mesh,MMG5_pSol disp) { LSst *lsst; MMG5_int npf,*invperm; + /* LibElas is not compatible with int64: Check for int32 overflow */ + if ( sizeof(MMG5_int) == 8 ) { + fprintf(stderr,"\n ## Error: %s: impossible to call elasticity library" + " with int64 integers.\n",__func__); + return 0; + } + /* Creation of the data structure for storing the submesh */ lsst = LS_init(mesh->dim,mesh->ver,P1,1); diff --git a/src/mmg3d/inout_3d.c b/src/mmg3d/inout_3d.c index 7475932b3..d30096be6 100644 --- a/src/mmg3d/inout_3d.c +++ b/src/mmg3d/inout_3d.c @@ -136,6 +136,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { ncor = ned = npreq = ntreq = nqreq = nereq = nedreq = nr = ng = 0; nppar = nedpar = ntpar = nqpar = nepar = 0; iswp = 0; + bpos = ia = idn = ip = 0; mesh->np = mesh->nt = mesh->ne = 0; nref = 0; @@ -274,7 +275,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->npi,MMG5_SW,1,inm); - if(iswp) mesh->npi=MMG5_SWAPBIN(mesh->npi); + if(iswp) mesh->npi=MMG5_swapbin(mesh->npi); posnp = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -283,7 +284,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&npreq,MMG5_SW,1,inm); - if(iswp) npreq=MMG5_SWAPBIN(npreq); + if(iswp) npreq=MMG5_swapbin(npreq); posnpreq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -292,7 +293,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->nti,MMG5_SW,1,inm); - if(iswp) mesh->nti=MMG5_SWAPBIN(mesh->nti); + if(iswp) mesh->nti=MMG5_swapbin(mesh->nti); posnt = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -301,7 +302,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&ntreq,MMG5_SW,1,inm); - if(iswp) ntreq=MMG5_SWAPBIN(ntreq); + if(iswp) ntreq=MMG5_swapbin(ntreq); posntreq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -311,7 +312,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->nquad,MMG5_SW,1,inm); - if(iswp) mesh->nquad=MMG5_SWAPBIN(mesh->nquad); + if(iswp) mesh->nquad=MMG5_swapbin(mesh->nquad); posnq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -320,7 +321,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&nqreq,MMG5_SW,1,inm); - if(iswp) nqreq=MMG5_SWAPBIN(nqreq); + if(iswp) nqreq=MMG5_swapbin(nqreq); posnqreq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -329,7 +330,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->nei,MMG5_SW,1,inm); - if(iswp) mesh->nei=MMG5_SWAPBIN(mesh->nei); + if(iswp) mesh->nei=MMG5_swapbin(mesh->nei); posne = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -338,7 +339,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->nprism,MMG5_SW,1,inm); - if(iswp) mesh->nprism=MMG5_SWAPBIN(mesh->nprism); + if(iswp) mesh->nprism=MMG5_swapbin(mesh->nprism); posnprism = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -347,7 +348,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&nereq,MMG5_SW,1,inm); - if(iswp) nereq=MMG5_SWAPBIN(nereq); + if(iswp) nereq=MMG5_swapbin(nereq); posnereq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -356,7 +357,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&ncor,MMG5_SW,1,inm); - if(iswp) ncor=MMG5_SWAPBIN(ncor); + if(iswp) ncor=MMG5_swapbin(ncor); posncor = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -365,7 +366,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->nai,MMG5_SW,1,inm); - if(iswp) mesh->nai=MMG5_SWAPBIN(mesh->nai); + if(iswp) mesh->nai=MMG5_swapbin(mesh->nai); posned = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -374,7 +375,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&nedreq,MMG5_SW,1,inm); - if(iswp) nedreq=MMG5_SWAPBIN(nedreq); + if(iswp) nedreq=MMG5_swapbin(nedreq); posnedreq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -383,7 +384,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&nr,MMG5_SW,1,inm); - if(iswp) nr=MMG5_SWAPBIN(nr); + if(iswp) nr=MMG5_swapbin(nr); posnr = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -392,7 +393,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&ng,MMG5_SW,1,inm); - if(iswp) ng=MMG5_SWAPBIN(ng); + if(iswp) ng=MMG5_swapbin(ng); posnormal = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -401,7 +402,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->nc1,MMG5_SW,1,inm); - if(iswp) mesh->nc1=MMG5_SWAPBIN(mesh->nc1); + if(iswp) mesh->nc1=MMG5_swapbin(mesh->nc1); posnc1 = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -450,7 +451,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { ppt->c[i] = (double) fc; } MMG_FREAD(&ppt->ref,MMG5_SW,1,inm); - if(iswp) ppt->ref=MMG5_SWAPBIN(ppt->ref); + if(iswp) ppt->ref=MMG5_swapbin(ppt->ref); } } else { if (!bin) { @@ -462,7 +463,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { if(iswp) ppt->c[i]=MMG5_swapd(ppt->c[i]); } MMG_FREAD(&ppt->ref,MMG5_SW,1,inm); - if(iswp) ppt->ref=MMG5_SWAPBIN(ppt->ref); + if(iswp) ppt->ref=MMG5_swapbin(ppt->ref); } } @@ -554,10 +555,10 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { else { for (i=0 ; i<3 ; i++) { MMG_FREAD(&pt1->v[i],MMG5_SW,1,inm); - if(iswp) pt1->v[i]=MMG5_SWAPBIN(pt1->v[i]); + if(iswp) pt1->v[i]=MMG5_swapbin(pt1->v[i]); } MMG_FREAD(&pt1->ref,MMG5_SW,1,inm); - if(iswp) pt1->ref=MMG5_SWAPBIN(pt1->ref); + if(iswp) pt1->ref=MMG5_swapbin(pt1->ref); } if ( pt1->ref < 0 ) { pt1->ref = -pt1->ref; @@ -626,10 +627,10 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { else { for (i=0 ; i<4 ; i++) { MMG_FREAD(&pq1->v[i],MMG5_SW,1,inm); - if(iswp) pq1->v[i]=MMG5_SWAPBIN(pq1->v[i]); + if(iswp) pq1->v[i]=MMG5_swapbin(pq1->v[i]); } MMG_FREAD(&pq1->ref,MMG5_SW,1,inm); - if(iswp) pq1->ref=MMG5_SWAPBIN(pq1->ref); + if(iswp) pq1->ref=MMG5_swapbin(pq1->ref); } if ( pq1->ref < 0 ) { pq1->ref = -pq1->ref; @@ -702,11 +703,11 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { } else { MMG_FREAD(&pa->a,MMG5_SW,1,inm); - if(iswp) pa->a=MMG5_SWAPBIN(pa->a); + if(iswp) pa->a=MMG5_swapbin(pa->a); MMG_FREAD(&pa->b,MMG5_SW,1,inm); - if(iswp) pa->b=MMG5_SWAPBIN(pa->b); + if(iswp) pa->b=MMG5_swapbin(pa->b); MMG_FREAD(&pa->ref,MMG5_SW,1,inm); - if(iswp) pa->ref=MMG5_SWAPBIN(pa->ref); + if(iswp) pa->ref=MMG5_swapbin(pa->ref); } pa->tag |= MG_REF; if ( pa->ref < 0 ) { @@ -725,7 +726,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { } else { MMG_FREAD(&ia,MMG5_SW,1,inm); - if(iswp) ia=MMG5_SWAPBIN(ia); + if(iswp) ia=MMG5_swapbin(ia); } if(ia>na) { fprintf(stderr,"\n ## Warning: %s: ridge number %8" MMG5_PRId " ignored.\n", @@ -746,7 +747,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { } else { MMG_FREAD(&ia,MMG5_SW,1,inm); - if(iswp) ia=MMG5_SWAPBIN(ia); + if(iswp) ia=MMG5_swapbin(ia); } if(ia>na) { fprintf(stderr,"\n ## Warning: %s: required Edges number %8" MMG5_PRId "/%8" MMG5_PRId "" @@ -767,7 +768,7 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { } else { MMG_FREAD(&ia,MMG5_SW,1,inm); - if(iswp) ia=MMG5_SWAPBIN(ia); + if(iswp) ia=MMG5_swapbin(ia); } if(ia>na) { fprintf(stderr,"\n ## Warning: %s: parallel Edges number %8" MMG5_PRId "/%8" MMG5_PRId "" @@ -792,10 +793,10 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { else { for (i=0 ; i<4 ; i++) { MMG_FREAD(&pt->v[i],MMG5_SW,1,inm); - if(iswp) pt->v[i]=MMG5_SWAPBIN(pt->v[i]); + if(iswp) pt->v[i]=MMG5_swapbin(pt->v[i]); } MMG_FREAD(&ref,MMG5_SW,1,inm); - if(iswp) ref=MMG5_SWAPBIN(ref); + if(iswp) ref=MMG5_swapbin(ref); } if(ref < 0) { nref++; @@ -875,10 +876,10 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { else { for (i=0 ; i<6 ; i++) { MMG_FREAD(&pp->v[i],MMG5_SW,1,inm); - if(iswp) pp->v[i]=MMG5_SWAPBIN(pp->v[i]); + if(iswp) pp->v[i]=MMG5_swapbin(pp->v[i]); } MMG_FREAD(&ref,MMG5_SW,1,inm); - if(iswp) ref=MMG5_SWAPBIN(ref); + if(iswp) ref=MMG5_swapbin(ref); } pp->ref = ref; if ( pp-> ref < 0 ) { @@ -956,9 +957,9 @@ int MMG3D_loadMesh_opened(MMG5_pMesh mesh,FILE *inm,int bin) { } else { MMG_FREAD(&ip,MMG5_SW,1,inm); - if(iswp) ip=MMG5_SWAPBIN(ip); + if(iswp) ip=MMG5_swapbin(ip); MMG_FREAD(&idn,MMG5_SW,1,inm); - if(iswp) idn=MMG5_SWAPBIN(idn); + if(iswp) idn=MMG5_swapbin(idn); } if ( idn > 0 && ip < mesh->np+1 ) { if ( (mesh->info.iso ) && mesh->point[ip].xp == -1 ) { diff --git a/src/mmg3d/velextls_3d.c b/src/mmg3d/velextls_3d.c index 4414ddf78..3923f7de6 100644 --- a/src/mmg3d/velextls_3d.c +++ b/src/mmg3d/velextls_3d.c @@ -66,13 +66,6 @@ MMG5_int* MMG5_packLS(MMG5_pMesh mesh,MMG5_pSol disp,LSst *lsst,MMG5_int *npfin) int refdirh,refdirnh; int8_t i,j,jface; - /* LibElas is not compatible with int64: Check for int32 overflow */ - if ( mesh->np > INT_MAX || mesh->ne > INT_MAX ) { - fprintf(stderr,"\n ## Error: %s: impossible to call elasticity library" - " with int64 integers.\n",__func__); - return NULL; - } - nlay = 20; refdirh = 0; refdirnh = 1; @@ -401,6 +394,13 @@ int MMG5_velextLS(MMG5_pMesh mesh,MMG5_pSol disp) { LSst *lsst; MMG5_int npf,*invperm; + /* LibElas is not compatible with int64: Check for int32 overflow */ + if ( mesh->np > INT_MAX || mesh->ne > INT_MAX || sizeof(MMG5_int) == 8 ) { + fprintf(stderr,"\n ## Error: %s: impossible to call elasticity library" + " with int64 integers.\n",__func__); + return 0; + } + /* Creation of the data structure for the submesh */ lsst = LS_init(mesh->dim,mesh->ver,P1,1); invperm = MMG5_packLS(mesh,disp,lsst,&npf); diff --git a/src/mmgs/inout_s.c b/src/mmgs/inout_s.c index c5c3268aa..41c6db6d2 100644 --- a/src/mmgs/inout_s.c +++ b/src/mmgs/inout_s.c @@ -60,6 +60,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { ncor = nri = ng = nedreq = nq = ntreq = 0; bin = 0; iswp = 0; + bpos = ia = idn = ip = 0; mesh->np = mesh->nt = mesh->nti = mesh->npi = 0; nref = 0; @@ -189,7 +190,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->npi,MMG5_SW,1,inm); - if(iswp) mesh->npi=MMG5_SWAPBIN(mesh->npi); + if(iswp) mesh->npi=MMG5_swapbin(mesh->npi); posnp = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -198,7 +199,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&npreq,MMG5_SW,1,inm); - if(iswp) npreq=MMG5_SWAPBIN(npreq); + if(iswp) npreq=MMG5_swapbin(npreq); posnpreq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -207,7 +208,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->nti,MMG5_SW,1,inm); - if(iswp) mesh->nti=MMG5_SWAPBIN(mesh->nti); + if(iswp) mesh->nti=MMG5_swapbin(mesh->nti); posnt = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -216,7 +217,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&ntreq,MMG5_SW,1,inm); - if(iswp) ntreq=MMG5_SWAPBIN(ntreq); + if(iswp) ntreq=MMG5_swapbin(ntreq); posntreq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -225,7 +226,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&nq,MMG5_SW,1,inm); - if(iswp) nq=MMG5_SWAPBIN(nq); + if(iswp) nq=MMG5_swapbin(nq); posnq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -234,7 +235,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&ncor,MMG5_SW,1,inm); - if(iswp) ncor=MMG5_SWAPBIN(ncor); + if(iswp) ncor=MMG5_swapbin(ncor); posncor = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -243,7 +244,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->na,MMG5_SW,1,inm); - if(iswp) mesh->na=MMG5_SWAPBIN(mesh->na); + if(iswp) mesh->na=MMG5_swapbin(mesh->na); posned = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -252,7 +253,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&nedreq,MMG5_SW,1,inm); - if(iswp) nedreq=MMG5_SWAPBIN(nedreq); + if(iswp) nedreq=MMG5_swapbin(nedreq); posnedreq = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -261,7 +262,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&nri,MMG5_SW,1,inm); - if(iswp) nri=MMG5_SWAPBIN(nri); + if(iswp) nri=MMG5_swapbin(nri); posnr = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -270,7 +271,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&ng,MMG5_SW,1,inm); - if(iswp) ng=MMG5_SWAPBIN(ng); + if(iswp) ng=MMG5_swapbin(ng); posnormal = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -279,7 +280,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { MMG_FREAD(&bpos,MMG5_SW,1,inm); //NulPos if(iswp) bpos=MMG5_swapbin(bpos); MMG_FREAD(&mesh->nc1,MMG5_SW,1,inm); - if(iswp) mesh->nc1=MMG5_SWAPBIN(mesh->nc1); + if(iswp) mesh->nc1=MMG5_swapbin(mesh->nc1); posnc1 = ftell(inm); rewind(inm); fseek(inm,bpos,SEEK_SET); @@ -323,7 +324,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { ppt->c[i] = (double) fc; } MMG_FREAD(&ppt->ref,MMG5_SW,1,inm); - if(iswp) ppt->ref=MMG5_SWAPBIN(ppt->ref); + if(iswp) ppt->ref=MMG5_swapbin(ppt->ref); } } else { if (!bin) { @@ -335,7 +336,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { if(iswp) ppt->c[i]=MMG5_swapd(ppt->c[i]); } MMG_FREAD(&ppt->ref,MMG5_SW,1,inm); - if(iswp) ppt->ref=MMG5_SWAPBIN(ppt->ref); + if(iswp) ppt->ref=MMG5_swapbin(ppt->ref); } } if ( ppt->ref < 0 ) { @@ -357,10 +358,10 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { else { for (i=0 ; i<3 ; i++) { MMG_FREAD(&pt1->v[i],MMG5_SW,1,inm); - if(iswp) pt1->v[i]=MMG5_SWAPBIN(pt1->v[i]); + if(iswp) pt1->v[i]=MMG5_swapbin(pt1->v[i]); } MMG_FREAD(&pt1->ref,MMG5_SW,1,inm); - if(iswp) pt1->ref=MMG5_SWAPBIN(pt1->ref); + if(iswp) pt1->ref=MMG5_swapbin(pt1->ref); } for (i=0; i<3; i++) { ppt = &mesh->point[pt1->v[i]]; @@ -412,12 +413,12 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { else { for (i=0 ; i<3 ; i++) { MMG_FREAD(&pt1->v[i],MMG5_SW,1,inm); - if(iswp) pt1->v[i]=MMG5_SWAPBIN(pt1->v[i]); + if(iswp) pt1->v[i]=MMG5_swapbin(pt1->v[i]); } MMG_FREAD(&pt2->v[2],MMG5_SW,1,inm); - if(iswp) pt2->v[2]=MMG5_SWAPBIN(pt2->v[2]); + if(iswp) pt2->v[2]=MMG5_swapbin(pt2->v[2]); MMG_FREAD(&pt1->ref,MMG5_SW,1,inm); - if(iswp) pt1->ref=MMG5_SWAPBIN(pt1->ref); + if(iswp) pt1->ref=MMG5_swapbin(pt1->ref); } if ( pt1->ref < 0 ) { pt1->ref = -pt1->ref; @@ -493,11 +494,11 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { } else { MMG_FREAD(&mesh->edge[k].a,MMG5_SW,1,inm); - if(iswp) mesh->edge[k].a=MMG5_SWAPBIN(mesh->edge[k].a); + if(iswp) mesh->edge[k].a=MMG5_swapbin(mesh->edge[k].a); MMG_FREAD(&mesh->edge[k].b,MMG5_SW,1,inm); - if(iswp) mesh->edge[k].b=MMG5_SWAPBIN(mesh->edge[k].b); + if(iswp) mesh->edge[k].b=MMG5_swapbin(mesh->edge[k].b); MMG_FREAD(&mesh->edge[k].ref,MMG5_SW,1,inm); - if(iswp) mesh->edge[k].ref=MMG5_SWAPBIN(mesh->edge[k].ref); + if(iswp) mesh->edge[k].ref=MMG5_swapbin(mesh->edge[k].ref); } if ( mesh->edge[k].ref < 0 ) { mesh->edge[k].ref = -mesh->edge[k].ref; @@ -518,7 +519,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { } else { MMG_FREAD(&ia,MMG5_SW,1,inm); - if(iswp) ia=MMG5_SWAPBIN(ia); + if(iswp) ia=MMG5_swapbin(ia); } if ( (ia>na) || (ia<0) ) { fprintf(stderr,"\n ## Warning: %s: ridge number %8" MMG5_PRId " ignored.\n", @@ -539,7 +540,7 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { } else { MMG_FREAD(&ia,MMG5_SW,1,inm); - if(iswp) ia=MMG5_SWAPBIN(ia); + if(iswp) ia=MMG5_swapbin(ia); } if ( (ia>na) || (ia<0) ) { fprintf(stderr,"\n ## Warning: %s: required edge number %8" MMG5_PRId " ignored\n", @@ -609,9 +610,9 @@ int MMGS_loadMesh(MMG5_pMesh mesh, const char *filename) { } else { MMG_FREAD(&ip,MMG5_SW,1,inm); - if(iswp) ip=MMG5_SWAPBIN(ip); + if(iswp) ip=MMG5_swapbin(ip); MMG_FREAD(&idn,MMG5_SW,1,inm); - if(iswp) idn=MMG5_SWAPBIN(idn); + if(iswp) idn=MMG5_swapbin(idn); } if ( idn > 0 && ip < mesh->np+1 ) memcpy(&mesh->point[ip].n,&norm[3*(idn-1)+1],3*sizeof(double));