[petsc-dev] fix conflict between triangle and spai
Jed Brown
jed at jedbrown.org
Tue Apr 28 15:55:37 CDT 2020
Satish Balay via petsc-dev <petsc-dev at mcs.anl.gov> writes:
> I get the following error with triangle+spai build with gcc-10 [this is on linux though - ignore osx in PETSC_ARCH]
>
> CLINKER arch-ci-osx-cxx-pkgs-opt/lib/libpetsc.so.3.13.0
> /usr/bin/ld: /home/balay/petsc/arch-ci-osx-cxx-pkgs-opt/lib/libtriangle.a(triangle.o):/home/balay/petsc/arch-ci-osx-cxx-pkgs-opt/externalpackages/Triangle/src/triangle.c:667: multiple definition of `epsilon'; /home/balay/petsc/arch-ci-osx-cxx-pkgs-opt/lib/libspai.a(spai.o):(.bss+0x188): first defined here
>
>
> Matt,
>
> Any objection to this change to triangle?
>
> diff --git a/src/triangle.c b/src/triangle.c
> index 8e915a1..76f6d84 100644
> --- a/src/triangle.c
> +++ b/src/triangle.c
> @@ -664,7 +664,7 @@ long samples; /* Number of random samples for point location. */
> unsigned long randomseed; /* Current random number seed. */
>
> REAL splitter; /* Used to split REAL factors for exact multiplication. */
> -REAL epsilon; /* Floating-point machine epsilon. */
> +static REAL epsilon; /* Floating-point machine epsilon. */
> REAL resulterrbound;
> REAL ccwerrboundA, ccwerrboundB, ccwerrboundC;
> REAL iccerrboundA, iccerrboundB, iccerrboundC;
Can you make the rest of these static while you're at it?
More information about the petsc-dev
mailing list