[Development] Qt 5 types under consideration for deprecation / removal in Qt 6

Konstantin Tokarev annulen at yandex.ru
Sun Jun 9 00:27:21 CEST 2019



09.06.2019, 01:26, "Konstantin Tokarev" <annulen at yandex.ru>:
> 09.06.2019, 01:02, "Kevin Kofler" <kevin.kofler at chello.at>:
>>  Giuseppe D'Angelo via Development wrote:
>>>   In other words, the advantages of keeping the Qt equivalents start to be
>>>   (seriously) questioned. We're therefore left with the question of what
>>>   to do with these equivalents.
>>>
>>>   * We could play the catch-up game, but that requires a development
>>>   investment that is simply not there any more, and is even questionable
>>>   (is it the job of people developing Qt to rewrite algorithms widely
>>>   available elsewhere?).
>>>
>>>   * We could move the Qt equivalents into a "support library", maybe with
>>>   deprecation warnings, maybe without. I'm not sure of the traction of
>>>   this idea these days, but IIRC having "Qt4Support" was frowned upon when
>>>   Qt 5 was being shaped. (Thus QtAlgorithms was left in QtCore, deprecated.)
>>>
>>>   * We could just deprecate and tell people to migrate away. That's kind
>>>   of the whole point of this thread, and comes with all the annoyances,
>>>   and people reimplementing them downstream because they still want the
>>>   convenience of a qSort(vector) over std::sort(vector.begin(),
>>>   vector.end()).
>>>
>>>   * We could keep things where they are, supported, thus offering the
>>>   easier APIs; but simply reimplement them on top of the "upstream"
>>>   equivalents. (Ignore the possible ABI break.)
>>
>>  There is one option missing:
>>
>>  * We could just keep the Qt equivalent as is, without adding the features
>>    of the STL equivalent if there is no manpower to port them to the Qt
>>    equivalent. Developers using the Qt version are happy with the Qt version
>>    as is, and those that are not can always go and use the STL. There is no
>>    point in deprecating or splitting out those classes, they should just
>>    remain in QtCore where they belong.
>>
>>>   Here's where the "extension" bites us: if the Qt equivalent offered
>>>   something that upstream is not offering, and we can't reimplement it,
>>>   then what do we do? Dropping support for it would be, at best, an API
>>>   break; and at worst, a _silent_ behavioural change.
>>
>>  That's why you should just not do that, and instead keep the Qt
>>  implementation. Let the users decide for themselves whether they prefer the
>>  advantages of one (Qt) or the other (STL) implementation.
>>
>>  I, for one, don't give a darn about all those new C++11/14/whatever STL
>>  features. I don't want to touch the STL with a 10-foot pole! The best thing
>>  Qt can do with the STL is pretend it doesn't exist. (I wish QT_NO_STL were
>>  still supported!)
>
> Do you really wish to touch C++ with a ten foot pole? It's such a horrible,
> inconsistent, and complicated language! There are many higher-level languages
> on market which can make you more productive, and you surely won't need to use
> STL. Ever.

Oh sorry, I've forgotten to add a reference:

[1] https://yosefk.com/c++fqa/

-- 
Regards,
Konstantin




More information about the Development mailing list