Commit Graph

1495 Commits

Author SHA1 Message Date
Alexey Edelev cc5f89d5a4 Move assign the serialized buffer in QProtobufSerializerImpl::serializeMessageFieldEnd
Small optimization bits.

Coverity-Id: 479440
Pickt-to: 6.8 6.9
Change-Id: I302a98564e77eaf3810e7e85457fc768a26f4c18
Reviewed-by: Tatiana Borisova <tatiana.borisova@qt.io>
2025-04-04 17:45:26 +02:00
Alexey Edelev d6586d97a1 Long live mutable getters
The functionality is desirable by some users, we re-enable it.
New API addresses the core issue that is partially related to
QTBUG-119912, but has wider concequences in blind use in user
projects. We add the 'mut' prefix to all mutable getters to make
the mutable access explicit. Overload approach leads to unwanted
detaches not only whe is used be moc-generated code, but also
in user projects if developers do not pay enough attention to
const modifiers of their variables/references. We declined to
restore it, dispite it was the better looking API, in favor to
the code safety.

This also reveals the code clashing scenario, when the overload
might happen if the message has both 'a' and 'mutA' fields in
its definition. This scenario is kindly forbidden by our generator,
and sanitized at very early stages. We expect that it won't happen
in user projects, but even if it will, the solution is to rename
the field when generating Qt code. The serialization/deserialization
do not depend on field naming directly. json_name attribute also
will help to workaround this.

The undocumented ALLOW_MUTABLE_GETTER_CONFLICTS option allows clashing
the mutable getter names, but its usage currently limited by our
internal code only. The reason unfixed QTBUG-119912 issue in moc.
Once the issue is fixed, the moc version check should get the proper
version, but not '99' as for now and the ALLOW_MUTABLE_GETTER_CONFLICTS
will become public.

Another design solution is the use of overloaded functions that
return pointers, like it's done it the reference protobuf. But this
kind of API leaves the pointer ownership undefined and decided to
not be used.

[ChangeLog][Protobuf] The generated messages now have the mutable
getters for the fiels of the message type. The getters have 'mut'
prefix and implicily allocate the respective fields if needed, so the
use of intermediate message objects is not required.

Task-number: QTBUG-119913
Change-Id: I09b9ee37e1fbbe37b9c3cb501e92442da8ad3e4b
Reviewed-by: Dennis Oberst <dennis.oberst@qt.io>
2025-04-04 17:45:22 +02:00
Dennis Oberst 4de7b5f2b5 ProtobufSerializer: fix potential overflow in encodeHeader
Ensure the fieldNumber remains within valid bounds before shifting.
Replace implicit conversions with explicit uint* casts.

Coverity-Id: 479441
Pick-to: 6.9 6.8
Change-Id: I82f9436f7fe89feab2fd60ff982c96631e390514
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-04-04 14:28:08 +02:00
Dennis Oberst 4b536e162d QProtobufSerializer: change fieldIndex to fieldNumber in encodeHeader
Pick-to: 6.9 6.8
Change-Id: I465aa746f0467933715091f6c5a1ba536b8313d2
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-04-04 14:28:04 +02:00
Dennis Oberst 9508b383f2 QtProtobufQtCoreTypes: skip missing copy when iterating segments
Coverity-Id: 479431
Pick-to: 6.9 6.8
Change-Id: I633424a034e19f39a1c072f25afd39adc3e7e440
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-04-04 14:28:01 +02:00
Dennis Oberst e0257e5d0b QtGrpc: add missing std::move
Coverity-Id: 479450
Coverity-Id: 479444
Pick-to: 6.9 6.8
Change-Id: I6d27da6ff7a11da7e52025e46d68beddb41e0395
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-04-04 14:27:53 +02:00
Dennis Oberst 5392ab2bf0 ProtobufDeserializer: fix uninitialized iterator member
Explicitly initialize m_it to avoid undefined behavior of uninitialized
class members.

Coverity-Id: 479445
Change-Id: I6af28d118ae12a25d58d697535da185c8e1c47e1
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-04-04 14:27:49 +02:00
Dennis Oberst 99d09ea8be tools [generators]: Prefer error string over throwing
This is not a library. The tool should not recover here. Print the error
and exit the program.

Coverity-Id: 479436
Pick-to: 6.9 6.8
Change-Id: I97c24b325a037e19de17af9b246ba2bb2be76d78
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-04-04 14:27:34 +02:00
Dennis Oberst f66f3daffb ProtobufScalarJsonSerializers: fix overflowed return value
Restructure the limits check to be more compact by separating the
invariant from the variant. The latter is extracted into a constexpr
lambda check.

Fix the overflow by checking the ok flag and return a default
initialized T.

Coverity-Id: 479421
Change-Id: Ia50fcba5de1335c2a26478d10f89b2d9c5696c4b
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
Reviewed-by: Mårten Nordheim <marten.nordheim@qt.io>
2025-04-04 14:27:30 +02:00
Dennis Oberst f5b0365d35 tools [qtgrpcgen]: construct exportMacroFilename in place
saves a copy.

Coverity-Id: 479417
Pick-to: 6.9 6.8
Change-Id: I09d3d1a8e137ba9bbf0003825766b7907dff747a
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-04-04 14:27:27 +02:00
Dennis Oberst fd117e8f3a tools [utils]: misc. improvements
- sort / restructure header usage
- use utils::toAsciiLower, same as asciiToUpper()

Change-Id: Ic5e7a369cea64cdb561471fb8c1246036263698d
Pick-to: 6.9 6.8
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-04-04 14:27:24 +02:00
Dennis Oberst a335b71abe tools [utils]: directly emplace substrings into vector for split()
Saves a temporary.

Change-Id: I6851e6f941dfa593fb37f79a7ec19ce446753556
Pick-to: 6.9 6.8
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-04-04 14:27:19 +02:00
Dennis Oberst 0e6a9f6890 tools [utils]: implement trim as part of ltrim & rtrim
This is the only logical solution for this code...
As a drive-by make asciiSpacing constexpr and adjust capitalization.

Change-Id: I2cda5006a9eec94b80701d71e5c4000c3c852bf3
Pick-to: 6.9 6.8
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-04-04 14:27:16 +02:00
Dennis Oberst cb5cc69cb3 tools [utils]: fix invalid erase on ltrim()
When the string is entirely whitespace all characters except one gets
erased. Rather use size() to denote the end of the string.

Change-Id: I80bf92319d4725b9400e0f67e968e3cb8c27dd86
Pick-to: 6.9 6.8
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-04-04 14:27:12 +02:00
Dennis Oberst 839b9372f8 tools [utils]: implement file operation with std::filesystem
Coverity noticed inefficiencies of unneeded copies. Fix this by using
std::filesystem for these operations.

Coverity-Id: 479416
Pick-to: 6.9 6.8
Change-Id: I44666f4ca791763c13152c4861e78a122b8cfc50
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-04-04 14:27:09 +02:00
Dennis Oberst 4710cacf13 QProtobufPropertyOrdering: remove dead code for char_data alignment check
Coverity rightfully complained about dead code in the char_data
method, as ... % alignof(char) will never be non zero.

Fix this by removing the superfluous check.

As a drive-by remove unused parameters - they can be added if needed.

Coverity-Id: 479414
Pick-to: 6.9 6.8
Change-Id: Ie3f2b14cbf3e18c76deae491c099ccf7ec8b7716
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-04-04 14:27:05 +02:00
Qt Submodule Update Bot 74ed4c3437 Update dependencies on 'dev' in qt/qtgrpc
Change-Id: I753a63b6a7d42b83b2c9d2b51ebe7a0acac3781d
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2025-04-03 15:51:12 +00:00
Qt Submodule Update Bot 823302ea42 Update dependencies on 'dev' in qt/qtgrpc
Change-Id: I9f84b8cf226507f591bad07573e6a6e51cebc11b
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2025-04-01 12:48:41 +00:00
Qt Submodule Update Bot 878c67dce3 Update dependencies on 'dev' in qt/qtgrpc
Change-Id: I9ccef3f593339a2612ba959bd5fa24faf3802268
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2025-03-29 16:10:18 +00:00
Qt Submodule Update Bot eda9ac0443 Update dependencies on 'dev' in qt/qtgrpc
Change-Id: I18908f560cad1cd8ca3848e098a521793463b0e2
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2025-03-19 17:33:54 +00:00
Alexey Edelev 514769d1bd Adapt the generator code to be compatible with protobuf >= 30
The newer protobuf version uses string_views as the return value.
Wrap the respecitive API with constructing std::string and update
some of the util functions to accept std::string_view arguments
but not plain std::string.

Fixes: QTBUG-134885
Pick-to: 6.8 6.9
Change-Id: I8bc06c46167a8b1bc0dca36242249e672ffcccd3
Reviewed-by: Tatiana Borisova <tatiana.borisova@qt.io>
Reviewed-by: Dennis Oberst <dennis.oberst@qt.io>
2025-03-19 15:15:37 +01:00
Alexey Edelev 12cb9d24e7 Add the missing copyrights to QtProtobufProperties.cmake.in
Pick-to: 6.8 6.9
Change-Id: I4831e7f993a01aeb75af1fd96a3295e4cb42e7c7
Reviewed-by: Dennis Oberst <dennis.oberst@qt.io>
2025-03-19 13:12:30 +01:00
Alexey Edelev b8b8dd9fe2 Avoid storing absolute paths to protobuf module includes
Sanitize proto includes to ensure the generated
<Module>ProtobufProperties.cmake is fully relocatable.

Drive-by, ensure that includes do not contain duplicates.

Task-number: QTBUG-130113
Change-Id: I64f56d497d412705f174a027f711b90ad7614abf
Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
2025-03-19 11:35:45 +01:00
Alexey Edelev 53f2963d56 Avoid storing proto_files-NOTFOUND in _qt_internal_proto_files
Ensure we store values correct way.

Pick-to: 6.8 6.9
Change-Id: I89ec10e41969a001d34a73a0fdd77a661b7c9506
Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
2025-03-19 10:47:50 +01:00
Alexey Edelev 252c5467de Add the hint to find the host grpc_cpp_plugin when crosscompiling
gRPC doesn't provide the smart tool lookup when crosscompiling.
So gRPC lookup is unable to find the grpc_cpp_plugin plugin when
crosscompiling examples. Use find_program to find the plugin in
host paths.

Pick-to: 6.8 6.9
Fixes: QTBUG-134647
Change-Id: I961b180b348dee4f1b2f2523be225d3003847e4c
Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
Reviewed-by: Dennis Oberst <dennis.oberst@qt.io>
2025-03-18 18:08:13 +01:00
Alexey Edelev 428e3d07b9 Fix the cmdLineInvalidExportMacro
The test was faulty positive because of invalid command line.
The input file name was missing there, so protoc was failing to
generate code, but didn't test the actual invalid EXPORT_MACRO name.

Pick-to: 6.8 6.9
Change-Id: Ib57235fb22c740dc30aec58076833c8f6de4a250
Reviewed-by: Dennis Oberst <dennis.oberst@qt.io>
2025-03-18 15:30:10 +01:00
Lucie Gérard 2bc78bfb7d Update licensing of files with infrastructure type
A QUIP 18[1] update sets git files, REUSE.toml and licenseRule.json
as infrastructure type files. They are licensed with:
LicenseRef-Qt-Commercial OR BSD-3-Clause

[1]: https://contribute.qt-project.org/quips/18

Pick-to: 6.9 6.8
Change-Id: Ib3bbda05a9b150dc9f7da564cd3bdc2691a749cc
Reviewed-by: Joerg Bornemann <joerg.bornemann@qt.io>
2025-03-13 15:14:53 +01:00
Dennis Oberst c0496671be qtgrpc_chat_server: Compile certificates into the application
The previous approach was error-prone, as using TARGET_FILE_DIR
hard-coded the path to the build directory and ignored install locations
entirely.

Fix this by using a more reliable approach: embedding the certificate
strings directly into the application.

Pick-to: 6.9 6.9.0 6.8 6.8.3
Change-Id: Ifb883891fd55bb023e7f9828f9c422ea3e5d1c3e
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-03-13 13:11:23 +01:00
Alexey Edelev 662dac4244 Fix the spamming with DATA/HEADER frames before the SETTINGS negotiation
Ensure that we received the connection SETTINGS from server before
sending the very first HEADER/DATA frame using the stream.

It's the expected flow for HTTP/2 communication, we are lucky that gRPC
servers accept us.

Drive-by change the way we handle the missing HTTP/2 connection. It's
the exceptional situation, when we failed to acquire the connection
using QHttp2Connection::createDirectConnection call, so make assertion
at this point.

Dive-by fix the "dead" Http2Handlers in m_activeHandlers, which were
eaten by "expired" pointer state(Users declined to keep QGrpcOperation
pointers alive).

Task-number: QTBUG-133254
Pick-to: 6.8 6.9 6.9.0
Change-Id: Icb19d12c54662a3b13e080da5cece5885fd767d9
Reviewed-by: Dennis Oberst <dennis.oberst@qt.io>
2025-03-12 11:00:57 +01:00
Alexey Edelev 33492a97a1 Add the missing include of q20utility.h
Ammends 56eee95a7c

Pick-to: 6.9 6.9.0 6.8
Change-Id: I35a4cd089a066b96d1f1ef4c10f0437092f9f4fb
Reviewed-by: Dennis Oberst <dennis.oberst@qt.io>
2025-03-10 09:25:58 +01:00
Matti Paaso 232a9b4021 Fix Axivion analysis configuration for protobuf
Library file name corrected and missing library added.

Task-number: QTQAINFRA-6969
Change-Id: Ibee0e0061e35ec7d14c38ad8a3a79994621428b4
Reviewed-by: Toni Saario <toni.saario@qt.io>
2025-03-10 08:47:43 +02:00
Alexey Edelev d8cfe543c4 Encourage to use vcpkg when building Vehicle example
Pick-to: 6.9
Task-number: QTBUG-132738
Change-Id: Ia154527e3dd337d8637deca0f04afecd23b02d2c
Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
2025-03-07 11:11:06 +01:00
Alexey Edelev 019240aae0 Add vcpkg.json for the QtGRPC Vehicle example
Use the vcpkg manifest to configure and build QtGRPC the example.
This allows to automate the dependency installation using vcpkg.

Pick-to: 6.9
Task-number: QTBUG-132738
Change-Id: I7ba9d5a2c1186d1a70f3dc3a39117d86f2269271
Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
2025-03-07 11:11:02 +01:00
Alexey Edelev 30d983f27b Encourage to use vcpkg when building magic8ball example
Pick-to: 6.9
Task-number: QTBUG-132738
Change-Id: Ib13a5cfc82b64570a76ec9494d9bdb1a3b773695
Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
2025-03-07 11:10:58 +01:00
Alexey Edelev 413cc7c831 Add vcpkg.json for the QtGRPC chat example
Use the vcpkg manifest to configure and build QtGRPC chat example.
This allows automating the dependency installation using vcpkg.

Pick-to: 6.9
Task-number: QTBUG-132738
Change-Id: Iafcb8e144d51f1af0d775869550f003c997d106a
Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
2025-03-07 11:10:54 +01:00
Alexey Edelev 0925534e6c Add vcpkg.json for the QtProtobuf sensors example
Use the vcpkg manifest to configure and build QtProtobuf sensors
example. This allows automating the dependency installation using
vcpkg.

Pick-to: 6.9
Task-number: QTBUG-132738
Change-Id: Icae7acf46d97d834a064d7663623757a7ec35742
Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
2025-03-07 11:10:50 +01:00
Alexey Edelev 9c03a6b0a7 Add vcpkg.json for the QtGRPC Magic 8 Ball example
Use the vcpkg manifest to configure and build QtGRPC Magic 8 Ball
example. This allows automating the dependency installation using
vcpkg.

Pick-to: 6.9
Task-number: QTBUG-132738
Change-Id: Idaf8ee948a0a304633e1fe9f63327391adec96d8
Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
2025-03-07 11:10:47 +01:00
Alexey Edelev 39f2692655 Remove the explicit setting of the accept-encoding header
QHttp2 implementation will make this favor for us, in general the
header is not mandatory for communication with gRPC server, but can
be used by other members of the network communication. Anyway it's
not the level of the gRPC channel where the header should be defined.

Pick-to: 6.9.0 6.9 6.8 6.8.3
Change-Id: I73fe3c780bfa373a724255dd26accf37f8a8ff50
Reviewed-by: Dennis Oberst <dennis.oberst@qt.io>
2025-03-06 16:43:49 +01:00
Dennis Oberst 81bc13aec3 Docs: Add transportation info for QGrpcHttp2Channel (unix-abstract)
We should be clearer about what transportation is used and when.
Otherwise, our users are left in the dark.

Task-number: QTBUG-134273
Change-Id: Ice58e2cd496fad472761bdb9022f0fd3280c265c
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-03-06 16:43:49 +01:00
Dennis Oberst 2f970bc3c2 Docs: Add transportation info for QGrpcHttp2Channel
We should be clearer about what transportation is used and when.
Otherwise, our users are left in the dark.

Task-number: QTBUG-134273
Pick-to: 6.9 6.9.0 6.8 6.8.3
Change-Id: I6d1da9236447521a53b197808c55c89c49fbd4c2
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-03-06 16:43:49 +01:00
Dennis Oberst 6a9810ed7f QGrpcHttp2Channel: Add QLocalSocket abstract namespace support
QLocalSocket supports abstract namespaces. Grpc also supports it. Simply
make it available through the 'unix-abstract' scheme.

Ref: https://grpc.github.io/grpc/core/md_doc_naming.html
Ref: https://doc.qt.io/qt-6/qlocalsocket.html#SocketOption-enum

[ChangeLog][GRPC][QGrpcHttp2Channel] Added abstract namespace support
for QLocalSocket communication through the "unix-abstract" scheme.

Fixes: QTBUG-134273
Change-Id: Iea2b608478e00504d7cdbdff735fcbfb618529d7
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-03-06 16:43:49 +01:00
Dennis Oberst 65358c24f6 QGrpcHttp2Channel: Add user-agent header
The protocol does not require a user-agent, but it is recommended to
provide a structured user-agent string. This helps diagnose issues more
effectively in heterogeneous environments.

Ref: https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md#user-agents

[ChangeLog][GRPC][QGrpcHttp2Channel] Added a structured user-agent
string to the request headers.

Task-number: QTBUG-133254
Change-Id: Ic312f2a3754108798bb7acc70e2d8bed4a891401
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-03-06 16:43:49 +01:00
Dennis Oberst 684e96caa3 QGrpcHttp2Channel: Use QByteArray directly for constructing headers
It doesn't make sense to use a view in this context. This would also be
more performant since it enables implicit sharing for the headers.

As a drive-by fix the Literals namespace usage to align what current
documentation says.

Pick-to: 6.9 6.9.0 6.8 6.8.3
Task-number: QTBUG-133254
Change-Id: I89be231de4b902d56d65d1729816681ce84ce90e
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-03-06 16:43:49 +01:00
Dennis Oberst 46238888f6 grpc benchmarks: miscellaneous improvements
* grpc async client now properly drains the completion queue upon
    finishing
  * server and clients now use the 'transport' option for setting up the
    communication. The server now supports multiple listening addresses.
  * Fix a "off by one" mismatch for the client RPC calls

Task-number: QTBUG-133254
Pick-to: 6.9 6.8
Change-Id: Iccbec72f77adb374f144c7cc1b9a8072fef00b5e
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-03-06 16:43:49 +01:00
Alexey Edelev 921212c1f7 Force the QAbstractSocket::LowDelayOption for Http2 channel
Reference gRPC channel does this, to disable the Nagle's algorithm
and reduce the latency for the small flow control frames like
WINDOW_UPDATE and PING.

TODO: We should probably allow to opt out this behavior using
QGrpcChannelOptions. See QTBUG-134428.

Task-number: QTBUG-134428
Task-number: QTBUG-133254
Pick-to: 6.8 6.8.3 6.9 6.9.0
Change-Id: I96efac97077c7e527198bae9ca00500629bd4800
Reviewed-by: Dennis Oberst <dennis.oberst@qt.io>
2025-03-06 16:43:49 +01:00
Rami Potinkara 56eee95a7c Fix Q_ASSERT comparison on x86 Android build
This patch fixes Q_ASSERT comparison between unsigned
integer and integer types on Android x86 build by using
C++20 compare function.

Fixes: QTBUG-134439
Pick-to: 6.9 6.9.0 6.8
Change-Id: I89e9a7384aad0fe908f4dd12680d3bf4770e6915
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-03-06 15:43:49 +00:00
Samuli Piippo 54837023ab qtgrpc chat example: don't deploy static lib
Remove deployment of the now static proto lib.

Amends 9437a1f2bd

Pick-to: 6.9
Change-Id: I5bdda6157842c665165ae9b14255778ce2ac0bc9
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
Reviewed-by: Dennis Oberst <dennis.oberst@qt.io>
2025-03-06 10:56:51 +02:00
Rami Potinkara dcc569f220 QGrpcHttp2Channel: Add HttpsScheme behind ssl config
This patch adds HttpsScheme variable definition behind
same ssl config where it is used in the source. This
fixes compile error on developer build for Android.

Fixes: QTBUG-134309
Pick-to: 6.9 6.9.0
Change-Id: I4d4425baa63f33724aff14b144339fb171e741d7
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
Reviewed-by: Dennis Oberst <dennis.oberst@qt.io>
2025-03-05 12:21:55 +00:00
Dennis Oberst 9437a1f2bd qtgrpc chat example: fix deployment
The deployment was incomplete. Fix it by:
 * Building the dependent qtgrpc_chat_client_proto library as
a static library
 * Add the server directory path for reading credentials universally

Amends: cb35d20adb.

Fixes: QTBUG-134266
Pick-to: 6.9.0 6.9 6.8.3 6.8
Change-Id: I0666c445fbce159436c5b084ffd77d4191e04213
Reviewed-by: Alexey Edelev <alexey.edelev@qt.io>
2025-03-05 07:58:29 +00:00
Topi Reinio fb72130351 Doc: Remove incorrect \fn comments
Remove \fn comments for QAbstractProtobufSerializer::(de)serializeObject().
These functions were dropped in 8ec55cb0cf.

Remove \fn for non-existent QProtobufRepeaterIterator constructor.

Remove unnecessary \fn commands from QAbstractProtobufSerializer, let QDoc
auto-tie the documentation instead.

Pick-to: 6.9 6.8
Task-number: QTBUG-134250
Change-Id: If49049a33a307a522b3275b114e879442432e4c4
Reviewed-by: Dennis Oberst <dennis.oberst@qt.io>
Reviewed-by: Paul Wicking <paul.wicking@qt.io>
2025-03-04 10:56:22 +00:00