[Debian-med-packaging] Bug#1097649: primer3: ftbfs with GCC-15

Matthias Klose doko at debian.org
Mon Feb 17 17:45:53 GMT 2025


Package: src:primer3
Version: 2.6.1-5
Severity: important
Tags: sid forky
User: debian-gcc at lists.debian.org
Usertags: ftbfs-gcc-15

[This bug is NOT targeted to the upcoming trixie release]

Please keep this issue open in the bug tracker for the package it
was filed for.  If a fix in another package is required, please
file a bug for the other package (or clone), and add a block in this
package. Please keep the issue open until the package can be built in
a follow-up test rebuild.

The package fails to build in a test rebuild on at least amd64 with
gcc-15/g++-15, but succeeds to build with gcc-14/g++-14. The
severity of this report will be raised before the forky release.

The full build log can be found at:
http://qa-logs.debian.net/2025/02/16/amd64exp/primer3_2.6.1-5_unstable_gccexp.log.gz
The last lines of the build log are at the end of this report.

To build with GCC 15, either set CC=gcc-15 CXX=g++-15 explicitly,
or install the gcc, g++, gfortran, ... packages from experimental.

  apt-get -t=experimental install g++ 

GCC 15 now defaults to the C23/C++23 standards, exposing many FTBFS.
Other Common build failures are new warnings resulting in build failures
with -Werror turned on, or new/dropped symbols in Debian symbols files.
For other C/C++ related build failures see the porting guide at
http://gcc.gnu.org/gcc-15/porting_to.html

[...]
  888 |   if ((pa->pick_left_primer) && ((&retval->fwd) != NULL )
      |                                                 ^~
libprimer3.h:927:15: note: ‘fwd’ declared here
  927 |   oligo_array fwd, intl, rev;
      |               ^~~
format_output.c:907:53: warning: the comparison will always evaluate as ‘true’ for the address of ‘intl’ will never be NULL [-Waddress]
  907 |   if ((pa->pick_internal_oligo) && ((&retval->intl) != NULL )
      |                                                     ^~
libprimer3.h:927:20: note: ‘intl’ declared here
  927 |   oligo_array fwd, intl, rev;
      |                    ^~~~
format_output.c:926:50: warning: the comparison will always evaluate as ‘true’ for the address of ‘rev’ will never be NULL [-Waddress]
  926 |   if ((pa->pick_right_primer) && ((&retval->rev) != NULL )
      |                                                  ^~
libprimer3.h:927:26: note: ‘rev’ declared here
  927 |   oligo_array fwd, intl, rev;
      |                          ^~~
read_boulder.c:106:15: error: conflicting types for ‘strtod’; have ‘double(void)’
  106 | extern double strtod();
      |               ^~~~~~
In file included from read_boulder.c:45:
/usr/include/stdlib.h:118:15: note: previous declaration of ‘strtod’ with type ‘double(const char * restrict,  char ** restrict)’
  118 | extern double strtod (const char *__restrict __nptr,
      |               ^~~~~~
read_boulder.c: In function ‘parse_double’:
read_boulder.c:1001:12: error: too many arguments to function ‘strtod’; expected 0, have 2
 1001 |     *out = strtod(datum, &nptr);
      |            ^~~~~~ ~~~~~
read_boulder.c:106:15: note: declared here
  106 | extern double strtod();
      |               ^~~~~~
make[2]: *** [Makefile:225: read_boulder.o] Error 1
make[2]: *** Waiting for unfinished jobs....
libprimer3.cc: In function ‘char* strstr_nocase(char*, char*)’:
libprimer3.cc:6168:29: warning: pointer ‘p’ used after ‘void free(void*)’ [-Wuse-after-free]
 6168 |     else {free(tmp); return p;}
      |                             ^
libprimer3.cc:6168:15: note: call to ‘void free(void*)’ here
 6168 |     else {free(tmp); return p;}
      |           ~~~~^~~~~
In file included from /usr/include/string.h:548,
                 from thal.c:43:
In function ‘strcpy’,
    inlined from ‘safe_malloc’ at thal.c:804:7,
    inlined from ‘calc_hairpin’ at thal.c:1922:19:
/usr/include/x86_64-linux-gnu/bits/string_fortified.h:81:10: warning: argument 1 null where non-null expected [-Wnonnull]
   81 |   return __builtin___strcpy_chk (__dest, __src, __glibc_objsize (__dest));
      |          ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/include/x86_64-linux-gnu/bits/string_fortified.h:81:10: note: in a call to built-in function ‘__builtin___memcpy_chk’
In function ‘strcpy’,
    inlined from ‘safe_malloc’ at thal.c:804:7,
    inlined from ‘calc_bulge_internal.isra’ at thal.c:2000:19:
/usr/include/x86_64-linux-gnu/bits/string_fortified.h:81:10: warning: argument 1 null where non-null expected [-Wnonnull]
   81 |   return __builtin___strcpy_chk (__dest, __src, __glibc_objsize (__dest));
      |          ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/include/x86_64-linux-gnu/bits/string_fortified.h:81:10: note: in a call to built-in function ‘__builtin___memcpy_chk’
In function ‘strcpy’,
    inlined from ‘safe_malloc’ at thal.c:804:7,
    inlined from ‘maxTM’ at thal.c:1542:19,
    inlined from ‘fillMatrix’ at thal.c:1473:16:
/usr/include/x86_64-linux-gnu/bits/string_fortified.h:81:10: warning: argument 1 null where non-null expected [-Wnonnull]
   81 |   return __builtin___strcpy_chk (__dest, __src, __glibc_objsize (__dest));
      |          ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/include/x86_64-linux-gnu/bits/string_fortified.h:81:10: note: in a call to built-in function ‘__builtin___memcpy_chk’
make[2]: Leaving directory '/build/reproducible-path/primer3-2.6.1/src'
dh_auto_build: error: cd src && make -j8 "INSTALL=install --strip-program=true" CPP=\$\(CXX\) returned exit code 2
make[1]: *** [debian/rules:20: override_dh_auto_build] Error 25
make[1]: Leaving directory '/build/reproducible-path/primer3-2.6.1'
make: *** [debian/rules:17: binary] Error 2
dpkg-buildpackage: error: debian/rules binary subprocess returned exit status 2



More information about the Debian-med-packaging mailing list