>>> ebusd: Building community/ebusd 23.2-r0 (using abuild 3.12.0-r0) started Wed, 25 Oct 2023 07:04:09 +0000 >>> ebusd: Checking sanity of /home/buildozer/aports/community/ebusd/APKBUILD... >>> ebusd: Analyzing dependencies... >>> ebusd: Installing for build: build-base argp-standalone cmake mosquitto-dev openssl-dev samurai (1/12) Installing argp-standalone (1.5.0-r1) (2/12) Installing libbz2 (1.0.8-r6) (3/12) Installing xz-libs (5.4.4-r0) (4/12) Installing libarchive (3.7.2-r0) (5/12) Installing rhash-libs (1.4.4-r0) (6/12) Installing libuv (1.46.0-r0) (7/12) Installing cmake (3.27.7-r2) (8/12) Installing mosquitto-libs++ (2.0.18-r0) (9/12) Installing mosquitto-dev (2.0.18-r0) (10/12) Installing openssl-dev (3.1.4-r0) (11/12) Installing samurai (1.2-r5) (12/12) Installing .makedepends-ebusd (20231025.070412) Executing busybox-1.36.1-r13.trigger OK: 315 MiB in 113 packages >>> ebusd: Cleaning up srcdir >>> ebusd: Cleaning up pkgdir >>> ebusd: Cleaning up tmpdir >>> ebusd: Fetching https://distfiles.alpinelinux.org/distfiles/v3.19//ebusd-23.2.tar.gz % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0 0 146 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0 curl: (22) The requested URL returned error: 404 >>> ebusd: Fetching ebusd-23.2.tar.gz::https://github.com/john30/ebusd/archive/refs/tags/23.2.tar.gz % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0 100 555k 0 555k 0 0 1055k 0 --:--:-- --:--:-- --:--:-- 2027k >>> ebusd: Fetching https://distfiles.alpinelinux.org/distfiles/v3.19//ebusd-23.2.tar.gz >>> ebusd: Checking sha512sums... ebusd-23.2.tar.gz: OK >>> ebusd: Unpacking /var/cache/distfiles/ebusd-23.2.tar.gz... -- The C compiler identification is GNU 13.2.1 -- The CXX compiler identification is GNU 13.2.1 -- Detecting C compiler ABI info -- Detecting C compiler ABI info - done -- Check for working C compiler: /usr/bin/gcc - skipped -- Detecting C compile features -- Detecting C compile features - done -- Detecting CXX compiler ABI info -- Detecting CXX compiler ABI info - done -- Check for working CXX compiler: /usr/bin/g++ - skipped -- Detecting CXX compile features -- Detecting CXX compile features - done fatal: not a git repository (or any of the parent directories): .git -- Looking for arpa/inet.h -- Looking for arpa/inet.h - found -- Looking for dirent.h -- Looking for dirent.h - found -- Looking for fcntl.h -- Looking for fcntl.h - found -- Looking for netdb.h -- Looking for netdb.h - found -- Looking for poll.h -- Looking for poll.h - found -- Looking for pthread.h -- Looking for pthread.h - found -- Looking for sys/ioctl.h -- Looking for sys/ioctl.h - found -- Looking for sys/select.h -- Looking for sys/select.h - found -- Looking for sys/time.h -- Looking for sys/time.h - found -- Looking for syslog.h -- Looking for syslog.h - found -- Looking for time.h -- Looking for time.h - found -- Looking for termios.h -- Looking for termios.h - found -- Looking for cfsetspeed -- Looking for cfsetspeed - found -- Looking for pthread_setname_np -- Looking for pthread_setname_np - found -- Looking for pselect -- Looking for pselect - found -- Looking for ppoll -- Looking for ppoll - found -- Looking for linux/serial.h -- Looking for linux/serial.h - not found -- Looking for dev/usb/uftdiio.h -- Looking for dev/usb/uftdiio.h - not found -- Looking for argp_parse -- Looking for argp_parse - not found -- contrib enabled -- MQTT enabled -- KNX enabled -- SSL enabled -- Performing Test HAVE_DIRECT_FLOAT_FORMAT -- Performing Test HAVE_DIRECT_FLOAT_FORMAT - Success -- Configuring done (1.1s) -- Generating done (0.0s) -- Build files have been written to: /home/buildozer/aports/community/ebusd/src/ebusd-23.2/build [1/46] Building CXX object src/tools/CMakeFiles/ebuspicloader.dir/intelhex/intelhexclass.cpp.o [2/46] Building CXX object src/tools/CMakeFiles/ebuspicloader.dir/ebuspicloader.cpp.o [3/46] Building CXX object src/tools/CMakeFiles/ebusctl.dir/ebusctl.cpp.o [4/46] Building CXX object src/lib/ebus/test/CMakeFiles/test_message.dir/test_message.cpp.o [5/46] Building CXX object src/lib/ebus/test/CMakeFiles/test_data.dir/test_data.cpp.o [6/46] Building CXX object src/lib/ebus/test/CMakeFiles/test_symbol.dir/test_symbol.cpp.o [7/46] Building CXX object src/lib/ebus/test/CMakeFiles/test_filereader.dir/test_filereader.cpp.o [8/46] Building CXX object src/lib/ebus/contrib/test/CMakeFiles/test_contrib.dir/test_tem.cpp.o [9/46] Building CXX object src/lib/ebus/contrib/CMakeFiles/ebuscontrib.dir/tem.cpp.o [10/46] Building CXX object src/lib/ebus/contrib/CMakeFiles/ebuscontrib.dir/contrib.cpp.o [11/46] Building CXX object src/lib/knx/CMakeFiles/knx.dir/knx.cpp.o [12/46] Building CXX object src/lib/ebus/CMakeFiles/ebus.dir/stringhelper.cpp.o [13/46] Building CXX object src/lib/ebus/CMakeFiles/ebus.dir/message.cpp.o [14/46] Building CXX object src/lib/ebus/CMakeFiles/ebus.dir/device.cpp.o [15/46] Building CXX object src/lib/ebus/CMakeFiles/ebus.dir/data.cpp.o [16/46] Building CXX object src/lib/ebus/CMakeFiles/ebus.dir/datatype.cpp.o [17/46] Building CXX object src/lib/ebus/CMakeFiles/ebus.dir/filereader.cpp.o [18/46] Building CXX object src/lib/ebus/CMakeFiles/ebus.dir/symbol.cpp.o [19/46] Building CXX object src/lib/ebus/CMakeFiles/ebus.dir/result.cpp.o [20/46] Building CXX object src/lib/utils/CMakeFiles/utils.dir/httpclient.cpp.o [21/46] Building CXX object src/lib/utils/CMakeFiles/utils.dir/rotatefile.cpp.o [22/46] Building CXX object src/lib/utils/CMakeFiles/utils.dir/clock.cpp.o [23/46] Building CXX object src/lib/utils/CMakeFiles/utils.dir/thread.cpp.o [24/46] Building CXX object src/lib/utils/CMakeFiles/utils.dir/tcpsocket.cpp.o [25/46] Building CXX object src/lib/utils/CMakeFiles/utils.dir/log.cpp.o [26/46] Building CXX object src/ebusd/CMakeFiles/ebusd.dir/knxhandler.cpp.o [27/46] Building CXX object src/ebusd/CMakeFiles/ebusd.dir/mqtthandler.cpp.o [28/46] Building CXX object src/ebusd/CMakeFiles/ebusd.dir/main.cpp.o [29/46] Building CXX object src/ebusd/CMakeFiles/ebusd.dir/scan.cpp.o [30/46] Building CXX object src/ebusd/CMakeFiles/ebusd.dir/mainloop.cpp.o [31/46] Building CXX object src/ebusd/CMakeFiles/ebusd.dir/network.cpp.o [32/46] Building CXX object src/ebusd/CMakeFiles/ebusd.dir/request.cpp.o [33/46] Building CXX object src/ebusd/CMakeFiles/ebusd.dir/datahandler.cpp.o [34/46] Building CXX object src/ebusd/CMakeFiles/ebusd.dir/bushandler.cpp.o In file included from /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/lib/knx/knx.cpp:30: /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/lib/knx/knxnet.h: In member function 'const char* ebusd::KnxNetConnection::send(ebusd::knx_transfer_t, ebusd::knx_addr_t, int, const uint8_t*)': /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/lib/knx/knxnet.h:647:32: warning: conversion from 'size_t' {aka 'unsigned int'} to 'uint16_t' {aka 'short unsigned int'} may change value [-Wconversion] 647 | h->totalLength.raw = htons(totalLen); | ^~~~~~~~ /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/lib/knx/knxnet.h:664:31: warning: conversion from 'int' to 'uint8_t' {aka 'unsigned char'} may change value [-Wconversion] 664 | l->informationLength = len-1; // subtracting the TPCI/APCI | ~~~^~ /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/lib/knx/knxnet.h:675:12: warning: conversion from 'int' to 'uint8_t' {aka 'unsigned char'} may change value [-Wconversion] 675 | d[0] = tpci; | ^~~~ [35/46] Linking CXX static library src/lib/knx/libknx.a [36/46] Linking CXX static library src/lib/ebus/contrib/libebuscontrib.a /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/lib/utils/httpclient.cpp: In function 'int ebusd::bioInfoCallback(BIO*, int, int)': /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/lib/utils/httpclient.cpp:175:26: warning: unused parameter 'bio' [-Wunused-parameter] 175 | int bioInfoCallback(BIO *bio, int state, int res) { | ~~~~~^~~ /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/lib/utils/httpclient.cpp: In member function 'bool ebusd::HttpClient::request(const std::string&, const std::string&, const std::string&, std::string*, bool*, time_t*)': /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/lib/utils/httpclient.cpp:450:27: warning: unused parameter 'time' [-Wunused-parameter] 450 | bool* repeatable, time_t* time) { | ~~~~~~~~^~~~ [37/46] Linking CXX static library src/lib/utils/libutils.a /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/tools/intelhex/intelhexclass.cpp: In function 'std::istream& operator>>(std::istream&, intelhex&)': /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/tools/intelhex/intelhexclass.cpp:833:40: warning: 'byteRead' may be used uninitialized [-Wmaybe-uninitialized] 833 | ihLocal.ucToHexString(byteRead); | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~ /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/tools/intelhex/intelhexclass.cpp:330:17: note: 'byteRead' was declared here 330 | unsigned char byteRead; | ^~~~~~~~ /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/tools/ebuspicloader.cpp: In function 'error_t parse_opt(int, char*, argp_state*)': /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/tools/ebuspicloader.cpp:247:45: warning: comparison of integer expressions of different signedness: 'uint32_t' {aka 'unsigned int'} and 'int' [-Wsign-compare] 247 | if (!setGatewayBits || setGatewayBits == ((1 << (32 - setMaskLen)) - 1)) { | ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/tools/ebuspicloader.cpp:271:33: warning: comparison of integer expressions of different signedness: 'uint32_t' {aka 'unsigned int'} and 'int' [-Wsign-compare] 271 | if ((setGatewayBits >> 5) == ((1<<((32-setMaskLen)-5))-1)) { | ~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [38/46] Linking CXX executable src/tools/ebuspicloader In file included from /usr/include/c++/13.2.1/map:62, from /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/ebusd/knxhandler.h:22, from /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/ebusd/knxhandler.cpp:23: /usr/include/c++/13.2.1/bits/stl_tree.h: In member function 'std::pair std::_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::_M_get_insert_hint_unique_pos(const_iterator, const key_type&) [with _Key = unsigned int; _Val = std::pair; _KeyOfValue = std::_Select1st >; _Compare = std::less; _Alloc = std::allocator >]': /usr/include/c++/13.2.1/bits/stl_tree.h:2210:5: note: parameter passing for argument of type 'std::_Rb_tree, std::_Select1st >, std::less, std::allocator > >::const_iterator' changed in GCC 7.1 2210 | _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ /usr/include/c++/13.2.1/bits/stl_tree.h: In member function 'std::_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator std::_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::_M_emplace_hint_unique(const_iterator, _Args&& ...) [with _Args = {const std::piecewise_construct_t&, std::tuple, std::tuple<>}; _Key = long long unsigned int; _Val = std::pair; _KeyOfValue = std::_Select1st >; _Compare = std::less; _Alloc = std::allocator >]': /usr/include/c++/13.2.1/bits/stl_tree.h:2458:7: note: parameter passing for argument of type 'std::_Rb_tree, std::_Select1st >, std::less, std::allocator > >::const_iterator' changed in GCC 7.1 2458 | _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ In file included from /usr/include/c++/13.2.1/map:63: /usr/include/c++/13.2.1/bits/stl_map.h: In member function 'std::map<_Key, _Tp, _Compare, _Alloc>::mapped_type& std::map<_Key, _Tp, _Compare, _Alloc>::operator[](key_type&&) [with _Key = long long unsigned int; _Tp = int; _Compare = std::less; _Alloc = std::allocator >]': /usr/include/c++/13.2.1/bits/stl_map.h:532:44: note: parameter passing for argument of type 'std::_Rb_tree, std::_Select1st >, std::less, std::allocator > >::const_iterator' changed in GCC 7.1 532 | __i = _M_t._M_emplace_hint_unique(__i, std::piecewise_construct, | ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 533 | std::forward_as_tuple(std::move(__k)), | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 534 | std::tuple<>()); | ~~~~~~~~~~~~~~~ In file included from /usr/include/c++/13.2.1/map:62, from /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/ebusd/mqtthandler.h:24, from /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/ebusd/mqtthandler.cpp:23: /usr/include/c++/13.2.1/bits/stl_tree.h: In member function 'std::_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator std::_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::_M_emplace_hint_unique(const_iterator, _Args&& ...) [with _Args = {const std::piecewise_construct_t&, std::tuple, std::tuple<>}; _Key = long long unsigned int; _Val = std::pair; _KeyOfValue = std::_Select1st >; _Compare = std::less; _Alloc = std::allocator >]': /usr/include/c++/13.2.1/bits/stl_tree.h:2458:7: note: parameter passing for argument of type 'std::_Rb_tree, std::_Select1st >, std::less, std::allocator > >::const_iterator' changed in GCC 7.1 2458 | _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ In file included from /usr/include/c++/13.2.1/map:63: /usr/include/c++/13.2.1/bits/stl_map.h: In member function 'std::map<_Key, _Tp, _Compare, _Alloc>::mapped_type& std::map<_Key, _Tp, _Compare, _Alloc>::operator[](key_type&&) [with _Key = long long unsigned int; _Tp = int; _Compare = std::less; _Alloc = std::allocator >]': /usr/include/c++/13.2.1/bits/stl_map.h:532:44: note: parameter passing for argument of type 'std::_Rb_tree, std::_Select1st >, std::less, std::allocator > >::const_iterator' changed in GCC 7.1 532 | __i = _M_t._M_emplace_hint_unique(__i, std::piecewise_construct, | ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 533 | std::forward_as_tuple(std::move(__k)), | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 534 | std::tuple<>()); | ~~~~~~~~~~~~~~~ In file included from /usr/include/c++/13.2.1/map:62, from /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/lib/ebus/message.h:26, from /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/lib/ebus/message.cpp:19: /usr/include/c++/13.2.1/bits/stl_tree.h: In member function 'std::_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator std::_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::_M_emplace_hint_unique(const_iterator, _Args&& ...) [with _Args = {const std::piecewise_construct_t&, std::tuple, std::tuple<>}; _Key = long long unsigned int; _Val = std::pair >; _KeyOfValue = std::_Select1st > >; _Compare = std::less; _Alloc = std::allocator > >]': /usr/include/c++/13.2.1/bits/stl_tree.h:2458:7: note: parameter passing for argument of type 'std::_Rb_tree >, std::_Select1st > >, std::less, std::allocator > > >::const_iterator' changed in GCC 7.1 2458 | _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ In file included from /usr/include/c++/13.2.1/map:63: In member function 'std::map<_Key, _Tp, _Compare, _Alloc>::mapped_type& std::map<_Key, _Tp, _Compare, _Alloc>::operator[](const key_type&) [with _Key = long long unsigned int; _Tp = std::vector; _Compare = std::less; _Alloc = std::allocator > >]', inlined from 'ebusd::result_t ebusd::MessageMap::add(bool, ebusd::Message*, bool)' at /home/buildozer/aports/community/ebusd/src/ebusd-23.2/src/lib/ebus/message.cpp:1876:22: /usr/include/c++/13.2.1/bits/stl_map.h:513:44: note: parameter passing for argument of type 'std::_Rb_tree >, std::_Select1st > >, std::less, std::allocator > > >::const_iterator' changed in GCC 7.1 513 | __i = _M_t._M_emplace_hint_unique(__i, std::piecewise_construct, | ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 514 | std::tuple(__k), | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 515 | std::tuple<>()); | ~~~~~~~~~~~~~~~ [39/46] Linking CXX static library src/lib/ebus/libebus.a [40/46] Linking CXX executable src/tools/ebusctl [41/46] Linking CXX executable src/lib/ebus/test/test_message [42/46] Linking CXX executable src/lib/ebus/test/test_symbol [43/46] Linking CXX executable src/lib/ebus/test/test_filereader [44/46] Linking CXX executable src/lib/ebus/contrib/test/test_contrib [45/46] Linking CXX executable src/ebusd/ebusd [46/46] Linking CXX executable src/lib/ebus/test/test_data Internal ctest changing into directory: /home/buildozer/aports/community/ebusd/src/ebusd-23.2/build Test project /home/buildozer/aports/community/ebusd/src/ebusd-23.2/build Start 1: contrib Start 2: filereader Start 3: symbol Start 4: data Start 5: message 1/5 Test #1: contrib .......................... Passed 0.00 sec 2/5 Test #2: filereader ....................... Passed 0.00 sec 3/5 Test #3: symbol ........................... Passed 0.00 sec 4/5 Test #4: data ............................. Passed 0.01 sec 5/5 Test #5: message .......................... Passed 4.01 sec 100% tests passed, 0 tests failed out of 5 Total Test time (real) = 4.01 sec >>> ebusd: Entering fakeroot... -- Install configuration: "MinSizeRel" -- Installing: /home/buildozer/aports/community/ebusd/pkg/ebusd/etc/ebusd/mqtt-hassio.cfg -- Installing: /home/buildozer/aports/community/ebusd/pkg/ebusd/etc/ebusd/mqtt-integration.cfg -- Installing: /home/buildozer/aports/community/ebusd/pkg/ebusd/etc/ebusd/knx.cfg -- Installing: /home/buildozer/aports/community/ebusd/pkg/ebusd/usr/bin/ebusd -- Installing: /home/buildozer/aports/community/ebusd/pkg/ebusd/usr/bin/ebusctl -- Installing: /home/buildozer/aports/community/ebusd/pkg/ebusd/usr/bin/ebuspicloader >>> ebusd*: Running postcheck for ebusd >>> ebusd*: Preparing package ebusd... >>> ebusd*: Stripping binaries >>> ebusd*: Scanning shared objects >>> ebusd*: Tracing dependencies... so:libc.musl-armv7.so.1 so:libcrypto.so.3 so:libgcc_s.so.1 so:libmosquitto.so.1 so:libssl.so.3 so:libstdc++.so.6 >>> ebusd*: Package size: 532.0 KB >>> ebusd*: Compressing data... >>> ebusd*: Create checksum... >>> ebusd*: Create ebusd-23.2-r0.apk >>> ebusd: Build complete at Wed, 25 Oct 2023 07:04:46 +0000 elapsed time 0h 0m 37s >>> ebusd: Cleaning up srcdir >>> ebusd: Cleaning up pkgdir >>> ebusd: Uninstalling dependencies... (1/12) Purging .makedepends-ebusd (20231025.070412) (2/12) Purging argp-standalone (1.5.0-r1) (3/12) Purging cmake (3.27.7-r2) (4/12) Purging mosquitto-dev (2.0.18-r0) (5/12) Purging mosquitto-libs++ (2.0.18-r0) (6/12) Purging openssl-dev (3.1.4-r0) (7/12) Purging samurai (1.2-r5) (8/12) Purging libarchive (3.7.2-r0) (9/12) Purging libbz2 (1.0.8-r6) (10/12) Purging libuv (1.46.0-r0) (11/12) Purging rhash-libs (1.4.4-r0) (12/12) Purging xz-libs (5.4.4-r0) Executing busybox-1.36.1-r13.trigger OK: 270 MiB in 101 packages >>> ebusd: Updating the community/armv7 repository index... >>> ebusd: Signing the index...