Checklist for Qt 6.0 inclusion: Difference between revisions

From Qt Wiki
Jump to navigation Jump to search
(Adding deadline information)
Line 54: Line 54:
Summary: <span style="color: green">Ready</span> | <span style="color: red">Not Ready</span>
Summary: <span style="color: green">Ready</span> | <span style="color: red">Not Ready</span>


Extenuation Circumstances/Other Comments:
Extenuating Circumstances/Other Comments:


=== State of Essential Modules ===
=== State of Essential Modules ===

Revision as of 10:19, 18 May 2020


This document is still in draft mode.

Qt 6 will introduce a lot of changes when compared to Qt 5. To begin with, Qt 6 requires C++17 which by itself excludes some compilers which were supported by Qt 5. Other changes are related to APIs, the build system (move from qmake to cmake as Qt's internal build system) or general infrastructure changes in the CI and test setup. Given the deadline for the Qt 6.0 release at the end of 2020, it is likely that not all Qt modules will be ready for the deadline set by the 6.0 release schedule.

Ready-For-Qt6-Inclusion

The general list of Qt release criteria (e.g. string freeze, API reviews done, branching) as outlined by the general releases notes of every Qt 5 release (e.g. release wiki for Qt 5.14) shall continue to apply. However those deadlines and gate criteria are considered to be as "too late" to make the final decision for inclusion. Therefore the notion of an earlier "Ready-for-Qt6-inclusion" checkpoint is being introduced. The current time suggestion for this checkpoint is end of June 2020. A more precise timeline will be suggested later on. Stay tuned.


During this earlier checkpoint each module is assessed against the criteria set out below. It is the maintainers responsibility to ensure that the data is provided for their module on this wiki page. The received feedback is used to evaluate the readiness of each individual module and in turn the readiness of Qt 6. It may also be used to define the list of Qt modules which are on track and may constitute a sufficiently large but nevertheless reduced set of Qt modules ready for Qt 6.0. If the set is deemed to small other considerations such as a delayed release schedule or feature drop may be considered.

If the release criteria are not met/stated maintainers may choose to release their module via the next minor release after 6.0 in the series.

Deadline

We want to have clarity on the list of 6.0 modules by end of June. Adding two weeks of deliberations based in the feedback implies that the 15. June 2020 is the deadline for the module data. To avoid dragging the process out due to missing information, no response implies the module is automatically not included in Qt 6.0.

Release Criteria

  • Port to cmake on target for completion
    • Target definition:
      • Library, examples & tests have been ported
      • The module is build & tested in the CI using cmake and tests pass
  • Continuous Integration for Qt 6
    • CI runs against qtbase/qtdeclarative SHA no older than 2 weeks
    • git repo is part of regular submodule update bot runs in dev (qt5.git/.gitmodules status != ignore)
    • Works with the supported platforms in CI for Qt 6.0
  • Backlog trajectory
    • Link to Jira stating the not completed and completed Qt 6.0 development tasks
  • Reviews
    • Initial review of public API done (is maintainer aware/happy of the current state?)
    • Are the API changes on track measured against the expectations
  • Porting/Documentation information available
    • Simple list of completed API changes which may later be used to write Qt6 migration docs
  • Other open comments serving as extenuating circumstances

Status per Module

Review Template

Module Name

CMake port: Complete | Not Complete (<Missing part>)

Pending Jira items: <link to Jira>

Recent CI SHA: Yes|No

gitmodules/submodule bot: ignored | active

Summary: Ready | Not Ready

Extenuating Circumstances/Other Comments:

State of Essential Modules

Note that the list of essential modules may be revised in light of Qt 6.0.

Qt Core

Qt GUI

Qt Multimedia

Qt Multimedia Widgets

Qt Network

Qt QML

Qt Quick

Qt Quick Controls 2

Qt Quick Dialogs

Qt Quick Layouts

Qt SQL

Qt Widgets

State of Add-on Modules

Active Qt

Qt 3D

Qt Android Extras

Qt Bluetooth

Qt Charts

Qt Concurrent

Qt D-Bus

Qt Data Visualization

Qt Gamepad

Qt Graphical Effects

Qt Help

Qt Image Formats

Qt Location

Qt Mac Extras

Qt Network Authorization

Qt OpenGL

Note, the contents of this module is different in Qt 6 compared to Qt 5. The old, deprecated, Qt 4 era QGL* classes are removed. Now it contains the QOpenGL* classes.

Qt OpenGL Widgets

Note, new in Qt 6. Contains QOpenGLWidget, which used to live in Qt Widgets in Qt 5.

Qt Platform Headers

Qt Positioning

Qt Printing Support

Qt Purchasing

Qt Quick 3D

Qt Quick Controls 1

Note, this module is deprecated in Qt 5.15 and therefore may no longer be shipped in Qt 6.

Qt Quick Extras

Qt Quick Timeline

Qt Quick WebGL

Qt Quick Widgets

Qt Remote Objects

Qt Script

Note, this module is deprecated in Qt 5.15 and therefore may no longer be shipped in Qt 6.

Qt SCXML

Qt Script Tools

Note, this module is deprecated in Qt 5.15 and therefore may no longer be shipped in Qt 6.

Qt Sensors

Qt Serial Bus

Qt Shader Tools

Note, new in Qt 6.

Qt Speech

Qt SVG

Qt UI Tools

Qt Virtual Keyboard

Qt WebChannel

Qt WebEngine

Qt WebSockets

Qt WebView

Qt Windows Extras

Qt X11 Extras

Qt XML

Qt XML Patterns

Note, this module is deprecated in Qt 5.15 and therefore may no longer be shipped in Qt 6.

Qt Wayland Compositor

Qt X11 Extras