Goals/Wayland: Difference between revisions

From KDE Community Wiki
(add link to bugs with wayland in their title)
(9 intermediate revisions by 3 users not shown)
Line 3: Line 3:
KDE community has [https://phabricator.kde.org/T11081 elected] to finalize the transition to Wayland and embrace the future of desktop.
KDE community has [https://phabricator.kde.org/T11081 elected] to finalize the transition to Wayland and embrace the future of desktop.


Wayland has been a great interest and effort to the KDE community as it aligns with its values and goals : security, lightweight and beauty.
Wayland has been of great interest and effort to the KDE community as it aligns with its values and goals to produce software that is secure, lightweight and beautiful. See more about Wayland in our [https://community.kde.org/KWin/Wayland Wayland page].


This goal will articulate in tracking down and fixing the issues that keeps our software from achieving feature parity with the venerable X Window system.
[[File:Wayland-logo-png-transparent.png|frameless|right|Wayland logo]]
Our focus will be our own community software, KWin, Plasma and Apps but will also be about helping the wider free software community to advance Wayland feature set.


This is an ambitious goal, it cannot be a small team effort, we invite the wider community to participate.
This goal will prioritize tracking down and fixing the issues that keep our software from achieving feature parity with the venerable X Window system. Our focus will be our own community software--KWin, Plasma and Apps--but will also be about helping the wider free software community to advance the Wayland feature set.
 
This is an ambitious goal. It cannot be a small team effort, and we invite the wider community to participate.
 
== How to help ==
 
There are a few ways to help this goal, some requiring no specialized skills.
 
=== Bug triaging ===
In order to fix bugs, we need to have precise reporting. Often we need to reproduce the issues reported, verify that bug reports include relevant information, request additional information, etc.
 
All of those actions are essential to the community to be able to fix the issues, and anyone can help.
See the [https://bugs.kde.org/buglist.cgi?bug_status=UNCONFIRMED&bug_status=CONFIRMED&bug_status=ASSIGNED&bug_status=NEEDSINFO&bug_status=REOPENED&keywords=wayland%2C%20&keywords_type=allwords&list_id=1662528&query_format=advanced reported Wayland bugs] that you can help triage.
 
=== Testing ===
You can run plasma or a KDE Application and [https://community.kde.org/Get_Involved/Issue_Reporting report an issue] you've encountered in the bug tracker and mark it with the keyword "wayland".
You don't need a Wayland session to test apps in Wayland; just ''startplasmacompositor dolphin'' to try it out within Wayland.
 
=== Developing ===
There are different ways you can contribute with code. Pick a Wayland bug from among the [https://bugs.kde.org/buglist.cgi?bug_status=UNCONFIRMED&bug_status=CONFIRMED&bug_status=ASSIGNED&bug_status=NEEDSINFO&bug_status=REOPENED&keywords=wayland%2C%20&keywords_type=allwords&list_id=1662528&query_format=advanced known bugs] and give it a shot!
 
The simplest way would be to send patches for an application to fix their Wayland shortcomings. [https://community.kde.org/Guidelines_and_HOWTOs/Wayland_Porting_Notes The wayland porting notes] may be helpful.
 
For more advanced contributions, you can try to fix a plasma Wayland issue by setting up a [https://community.kde.org/Get_Involved/development plasma developer environment] and sending a patch to [https://community.kde.org/Infrastructure/Phabricator phabricator]. And finally you can hack on KWin and Kwayland and following the [https://community.kde.org/Get_Involved/development developer environment setup] documentation. Start your journey with ''kdesrc-build kwin''.


== Documentation ==
== Documentation ==
We have a few documentation pages to help with debugging and fixing bugs.
We have a few documentation pages to help with debugging and fixing bugs:
* For [https://community.kde.org/KWin/Wayland Wayland debugging tips and general information]
* For [https://community.kde.org/KWin/Wayland Wayland debugging tips and general information]
* For app developers and maintainers we have a documentation to [https://community.kde.org/Guidelines_and_HOWTOs/Wayland_Porting_Notes help porting to wayland]
* For app developers and maintainers we have a documentation to [https://community.kde.org/Guidelines_and_HOWTOs/Wayland_Porting_Notes help porting to Wayland]
* For new developers contributor wanting [https://community.kde.org/Get_Involved/development to start hacking]
* For new developer contributors wanting [https://community.kde.org/Get_Involved/development to start hacking]


== KDE community projects ==
== KDE community projects ==


=== KWin and KWayland ===
=== KWin and KWayland ===
Work board is located at https://phabricator.kde.org/project/view/98/
KWin is the KDE Wayland compositor, representing the main component establishing a Wayland session.
KWayland is an essential library wrapping low-level Wayland API to higher-level Qt-Style API.
Their work board is located at https://phabricator.kde.org/project/view/98/
      
      
=== Plasma ===
=== Plasma ===
Work board is located at https://phabricator.kde.org/project/view/99/
Plasma needs a lot of integration with Wayland and KWin to provide a smooth experience.
Its Wayland work board is located at https://phabricator.kde.org/project/view/99/


=== Apps ===
=== Apps ===
KDE has many great applications and we want to make sure they work flawlessly under Wayland.
KDE has many great applications and we want to make sure they work flawlessly under Wayland.
We will be helping the apps contributors testing and fixing their wayland support.
We will be helping the apps contributors testing and fixing their Wayland support.


== Upstream projects ==
== Upstream projects ==
===libinput===
===libinput===
[https://gitlab.freedesktop.org/libinput/libinput Libinput] as the input library for Wayland is a major dependency of Plasma and a few of our apps.
[https://gitlab.freedesktop.org/libinput/libinput Libinput] is the input library for Wayland, and a major dependency of Plasma and a few of our apps. We will probably need to work upstream to achieve our goal.
We will probably need to work with upstream, to achieve our goal.


=== Qt and QtWayland ===
=== Qt and QtWayland ===
We might encounter issues with Qt or QtWayland in which case we will work with the [https://www.qt.io/developers/ Qt company] to fix them.
[https://www.qt.io/ Qt] is the main framework upon which most of KDE software is built. As we have  advanced needs, we might encounter issues or limitations with Qt or QtWayland (the Wayland integration Qt module) in which case we will work with the [https://www.qt.io/developers/ Qt community] to address them.


=== SDDM ===
=== SDDM ===
[https://github.com/sddm/sddm SDDM] as our main desktop manager, will need some contribution of our community.
[https://github.com/sddm/sddm SDDM] is our main desktop manager and will need some contribution of our community to take full advantage of wayland.


== Currently reported Wayland bugs ==
== Currently reported Wayland bugs ==
You can find open bugs associated with Wayland with
You can find open bugs associated with Wayland keyword with
[https://bugs.kde.org/buglist.cgi?bug_status=UNCONFIRMED&bug_status=CONFIRMED&bug_status=ASSIGNED&bug_status=NEEDSINFO&bug_status=REOPENED&keywords=wayland%2C%20&keywords_type=allwords&list_id=1662528&query_format=advanced this query].
[https://bugs.kde.org/buglist.cgi?bug_status=UNCONFIRMED&bug_status=CONFIRMED&bug_status=ASSIGNED&bug_status=NEEDSINFO&bug_status=REOPENED&keywords=wayland%2C%20&keywords_type=allwords&list_id=1662528&query_format=advanced this query].
You can find bugs with wayland mentionned in their title with
[https://bugs.kde.org/buglist.cgi?bug_status=UNCONFIRMED&bug_status=CONFIRMED&bug_status=ASSIGNED&bug_status=REOPENED&bug_status=NEEDSINFO&keywords=wayland&keywords_type=nowords&list_id=1671211&order=changeddate%20DESC%2Cbug_status%20DESC%2Cproduct%2Cresolution%2Cpriority%2Cassigned_to%2Cbug_id&query_format=advanced&short_desc=wayland&short_desc_type=allwordssubstr this other query]

Revision as of 08:57, 17 October 2019

Intro

KDE community has elected to finalize the transition to Wayland and embrace the future of desktop.

Wayland has been of great interest and effort to the KDE community as it aligns with its values and goals to produce software that is secure, lightweight and beautiful. See more about Wayland in our Wayland page.

Wayland logo
Wayland logo

This goal will prioritize tracking down and fixing the issues that keep our software from achieving feature parity with the venerable X Window system. Our focus will be our own community software--KWin, Plasma and Apps--but will also be about helping the wider free software community to advance the Wayland feature set.

This is an ambitious goal. It cannot be a small team effort, and we invite the wider community to participate.

How to help

There are a few ways to help this goal, some requiring no specialized skills.

Bug triaging

In order to fix bugs, we need to have precise reporting. Often we need to reproduce the issues reported, verify that bug reports include relevant information, request additional information, etc.

All of those actions are essential to the community to be able to fix the issues, and anyone can help. See the reported Wayland bugs that you can help triage.

Testing

You can run plasma or a KDE Application and report an issue you've encountered in the bug tracker and mark it with the keyword "wayland". You don't need a Wayland session to test apps in Wayland; just startplasmacompositor dolphin to try it out within Wayland.

Developing

There are different ways you can contribute with code. Pick a Wayland bug from among the known bugs and give it a shot!

The simplest way would be to send patches for an application to fix their Wayland shortcomings. The wayland porting notes may be helpful.

For more advanced contributions, you can try to fix a plasma Wayland issue by setting up a plasma developer environment and sending a patch to phabricator. And finally you can hack on KWin and Kwayland and following the developer environment setup documentation. Start your journey with kdesrc-build kwin.

Documentation

We have a few documentation pages to help with debugging and fixing bugs:

KDE community projects

KWin and KWayland

KWin is the KDE Wayland compositor, representing the main component establishing a Wayland session. KWayland is an essential library wrapping low-level Wayland API to higher-level Qt-Style API. Their work board is located at https://phabricator.kde.org/project/view/98/

Plasma

Plasma needs a lot of integration with Wayland and KWin to provide a smooth experience. Its Wayland work board is located at https://phabricator.kde.org/project/view/99/

Apps

KDE has many great applications and we want to make sure they work flawlessly under Wayland. We will be helping the apps contributors testing and fixing their Wayland support.

Upstream projects

libinput

Libinput is the input library for Wayland, and a major dependency of Plasma and a few of our apps. We will probably need to work upstream to achieve our goal.

Qt and QtWayland

Qt is the main framework upon which most of KDE software is built. As we have advanced needs, we might encounter issues or limitations with Qt or QtWayland (the Wayland integration Qt module) in which case we will work with the Qt community to address them.

SDDM

SDDM is our main desktop manager and will need some contribution of our community to take full advantage of wayland.

Currently reported Wayland bugs

You can find open bugs associated with Wayland keyword with this query.

You can find bugs with wayland mentionned in their title with this other query