[Date Prev][Date Next] [Thread Prev][Thread Next] [Date Index] [Thread Index]

Bug#1012958: keyman: ftbfs with GCC-12



Package: src:keyman
Version: 15.0.235-1
Severity: normal
Tags: sid bookworm
User: debian-gcc@lists.debian.org
Usertags: ftbfs-gcc-12

[This bug is targeted to the upcoming bookworm 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-12/g++-12, but succeeds to build with gcc-11/g++-11. The
severity of this report will be raised before the bookworm release.

The full build log can be found at:
http://qa-logs.debian.net/2022/06/09/gcc12/keyman_15.0.235-1_unstable_gcc12.log
The last lines of the build log are at the end of this report.

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

  apt-get -t=experimental install g++ 

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-11/porting_to.html

GCC 11 defaults to the GNU++17 standard.  If your package installs
header files in /usr/include, please don't work around C++17 issues
by choosing a lower C++ standard for the package build, but fix these
issues to build with the C++17 standard.

[...]
config.status: creating po/Makefile
# keyman-config
make[1]: Leaving directory '/<<PKGBUILDDIR>>'
   debian/rules override_dh_auto_build
make[1]: Entering directory '/<<PKGBUILDDIR>>'
# keymankeyboardprocessor
cd common/core/desktop && ./build.sh build

VERSION: 15.0.235
TIER: beta
PLATFORM: native
CONFIGURE: false
CLEAN: false
BUILD_CPP: true
TESTS_CPP: false
INSTALL_CPP: false
UNINSTALL_CPP: false
MESON_TARGET: release
TARGET_PATH: /<<PKGBUILDDIR>>/common/core/desktop/build

======= Building C++ library for linux =======
[1/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/json.cpp.o
[2/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/option.cpp.o
[3/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/km_kbp_processevent_api.cpp.o
[4/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/keyboard.cpp.o
[5/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/km_kbp_options_api.cpp.o
[6/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/km_kbp_debug_api.cpp.o
[7/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_consts.cpp.o
[8/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/km_kbp_context_api.cpp.o
[9/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/km_kbp_keyboard_api.cpp.o
[10/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_conversion.cpp.o
[11/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_capslock.cpp.o
[12/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_actions.cpp.o
[13/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/km_kbp_state_api.cpp.o
[14/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/state.cpp.o
[15/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_context.cpp.o
[16/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_debug.cpp.o
[17/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_debugger.cpp.o
[18/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_processevent.cpp.o
[19/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_file.cpp.o
FAILED: src/libkmnkbp0.so.0.0.0.p/kmx_kmx_file.cpp.o 
c++ -Isrc/libkmnkbp0.so.0.0.0.p -Isrc -I../../../src -fdiagnostics-color=always -D_FILE_OFFSET_BITS=64 -Wall -Winvalid-pch -Wnon-virtual-dtor -Werror -std=c++14 -O3 -g -O2 -ffile-prefix-map=/<<PKGBUILDDIR>>=. -fstack-protector-strong -Wformat -Werror=format-security -Wdate-time -D_FORTIFY_SOURCE=2 -fPIC -isystem../../../include -isysteminclude -DKMN_KBP_EXPORTING -Wall -Wctor-dtor-privacy -Wdouble-promotion -Wendif-labels -Wextra -Wno-unknown-pragmas -Wno-missing-field-initializers -Wnon-virtual-dtor -Wshadow -fvisibility=hidden -fvisibility-inlines-hidden -MD -MQ src/libkmnkbp0.so.0.0.0.p/kmx_kmx_file.cpp.o -MF src/libkmnkbp0.so.0.0.0.p/kmx_kmx_file.cpp.o.d -o src/libkmnkbp0.so.0.0.0.p/kmx_kmx_file.cpp.o -c ../../../src/kmx/kmx_file.cpp
../../../src/kmx/kmx_file.cpp: In member function ‘KMX_BOOL km::kbp::kmx::KMX_ProcessEvent::LoadKeyboard(km_kbp_path_name, km::kbp::kmx::tagKEYBOARD**)’:
../../../src/kmx/kmx_file.cpp:186:12: error: ‘void operator delete(void*, std::size_t)’ called on pointer returned from a mismatched allocation function [-Werror=mismatched-new-delete]
  186 |     delete buf;
      |            ^~~
../../../src/kmx/kmx_file.cpp:159:28: note: returned from ‘void* operator new [](std::size_t)’
  159 |   buf = new KMX_BYTE[sz * 3];
      |                            ^
../../../src/kmx/kmx_file.cpp:201:53: error: ‘void operator delete(void*, std::size_t)’ called on pointer returned from a mismatched allocation function [-Werror=mismatched-new-delete]
  201 |   if(kbp->dwIdentifier != FILEID_COMPILED) { delete buf; DebugLog("errNotFileID"); return FALSE; }
      |                                                     ^~~
../../../src/kmx/kmx_file.cpp:159:28: note: returned from ‘void* operator new [](std::size_t)’
  159 |   buf = new KMX_BYTE[sz * 3];
      |                            ^
cc1plus: all warnings being treated as errors
[20/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/utfcodec.cpp.o
[21/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_modifiers.cpp.o
[22/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_environment.cpp.o
[23/52] Compiling C++ object tests/unit/json/jsontest.p/jsontest.cpp.o
[24/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_xstring.cpp.o
[25/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/mock_mock_processor.cpp.o
[26/52] Compiling C++ object tests/unit/utftest/utftest.p/utftest.cpp.o
[27/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_options.cpp.o
[28/52] Compiling C++ object src/libkmnkbp0.so.0.0.0.p/kmx_kmx_processor.cpp.o
ninja: build stopped: subcommand failed.
make[1]: *** [debian/rules:36: override_dh_auto_build] Error 1
make[1]: Leaving directory '/<<PKGBUILDDIR>>'
make: *** [debian/rules:16: build] Error 2
dpkg-buildpackage: error: debian/rules build subprocess returned exit status 2


Reply to: