Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Refactor Window Manager interaction (Qt 6 version) #2029

Closed
wants to merge 69 commits into from

Conversation

gfgit
Copy link
Member

@gfgit gfgit commented Feb 21, 2024

Depends on #2024 (Qt6 port)

This is a replacement for #2007 rebased on Qt6 port

Main differences with initial idea:

  • Now ILXQtTaskbarAbstractBackend is stored globally inside LXQtPanelApplication (infact I should drop "taskbar" part of the name)
  • LXQtPanel uses this class for auto-hide logic (not sure if it's working yet)

TODO: port other plugins which currently directly use X11 to use this abstract interface

@gfgit
Copy link
Member Author

gfgit commented Feb 22, 2024

@stefonarch I've made some testing on KWin Wayland. This is the desktop file I'm using:

[Desktop Entry]
GenericName=Panel
Name=LXQt Panel
Comment=LXQt Panel
Categories=Qt;KDE;Utility;
Keywords=LXQt;Panel
Exec=/usr/local/bin/lxqt-panel
Icon=spectacle
Type=Application
StartupNotify=false
X-KDE-Wayland-Interfaces=org_kde_plasma_window_management

Named lxqt-panel.desktop

It works putting in one of these locations:

  1. /usr/share/applications
  2. /usr/local/share/applications
  3. ~/.local/share/applications/lxqt-panel.desktop

Editing the autostart file inside /etc/xdg/autostart does not affect KWin granting org_kde_plasma_window_management access.

Please test again just to make sure you don't have a typo in your file

@stefonarch
Copy link
Member

stefonarch commented Feb 22, 2024

Please test again just to make sure you don't have a typo in your file

Done, negative. There has to be some hidden difference somewhere. I'll test on the other Vm with the dev edition later.

@stefonarch
Copy link
Member

Do you launch it with dolphin? I always used pcmanfm and removed dolphin, at least on the VM with stable.

@gfgit
Copy link
Member Author

gfgit commented Feb 22, 2024

Do you launch it with dolphin? I always used pcmanfm and removed dolphin, at least on the VM with stable.

Test launching from:

  1. Qt Creator "Run" button
  2. Konsole lxqt-panel
  3. Directly from plasma panel's application launcher

Qt Creator and Konsole are opened from plasma application launcher

@gfgit
Copy link
Member Author

gfgit commented Feb 22, 2024

Also in my .desktop the Exec path is /usr/local vecause that's where CMake installs by default. Did you change install location?

@gfgit
Copy link
Member Author

gfgit commented Feb 22, 2024

Did some more tests. Apparently Exec path must be absolute for it to work.
Putting just:

Exec=lxqt-panel

will not work and taskbar will be empty.

I also tried setting desktop file in application start with:

QGuiApplication::setDesktopFileName(QLatin1String("lxqt-panel"));

but it doesn't seem to change anything. KDE has KService class which is able to deduce desktop file based on executable path so probably it was already detecting it.

@gfgit
Copy link
Member Author

gfgit commented Feb 22, 2024

Also putting OnlyShowIn=LXQt; seems to break behavior.
Maybe this makes KWin skip the file so behavior is identical to situation without desktop file.

OnlyShowIn=LXQt;KDE

Fixes the problem.
This problem might not appear if running plain LXQt session and not a Plasma session + LXQt Panel

@stefonarch
Copy link
Member

Now on the dev edition VM, tried everything except QtCreator, I can't still reproduce what happens at your side.
Installation is in /usr/local/, desktop file the same...

@stefonarch
Copy link
Member

Oooops, looks like I'm on wayland_taskbar branch.... recompiling

@gfgit
Copy link
Member Author

gfgit commented Feb 22, 2024

Oooops, looks like I'm on wayland_taskbar branch.... recompiling

No wait. wayland_taskbar is the correct branch with last commit about panel alignment.
I have too many branches :)

@stefonarch
Copy link
Member

stefonarch commented Feb 22, 2024

Oooops, looks like I'm on wayland_taskbar branch.... recompiling

No wait. wayland_taskbar is the correct branch with last commit about panel alignment. I have too many branches :)

Yep, I see, this panel from the PR here dumps core with default config on wayland ;) and without config I didn't find it (transparent in middle of the screen I guess).

It's a pity, thought I found the reason...
Maybe the solution is to try with foreign-toplevel-management-unstable ;)

@stefonarch
Copy link
Member

stefonarch commented Feb 22, 2024

But anyway, it shouldn't dump core on wayland, sorry no C&P from that:

screen_area_gio_14:12:21_

fixed screenshot ;)

@gfgit
Copy link
Member Author

gfgit commented Feb 22, 2024

Yep, I see, this panel from the PR here dumps core with default config on wayland ;) and without config I didn't find it (transparent in middle of the screen I guess).

This is interesting. How can I reproduce?

Maybe the solution is to try with foreign-toplevel-management-unstable ;)

It depends on compositor. Right now:

  • KWin supports only org_kde_plasma_window_management
  • wlroots based compositor support only: foreign-toplevel-management-unstable
  • KWinFT seems to support both

@stefonarch
Copy link
Member

stefonarch commented Feb 22, 2024

This is interesting. How can I reproduce?

Openbox session, make sure to be able to open konsole from right click on desktop:

kwin_wayland konsole and inside the nested session lxqt-panel with the default panel.conf from /usr/local/share/lxqt/ in `~/.config/lxqt/

without config it works, But I disabled all plugins which won't work anyway on wayland.

But it should segfault on plasma session too I think.

@gfgit
Copy link
Member Author

gfgit commented Feb 22, 2024

This is interesting. How can I reproduce?

Openbox session, make sure to be able to open konsole from right click on desktop:

kwin_wayland konsole and inside the nested session lxqt-panel with the default panel.conf from /usr/local/share/lxqt/ in `~/.config/lxqt/

without config it works, But I disabled all plugins which won't work anyway on wayland.

But it should segfault on plasma session too I think.

We are talking about refactor_taskbar_qt6 branch right? With all plugins enabled compile time?

@gfgit
Copy link
Member Author

gfgit commented Feb 22, 2024

I need porting the sysstat plugin to Qt6

Done!

@gfgit gfgit force-pushed the refactor_taskbar_qt6 branch from ea6c1ab to a5d6b81 Compare February 22, 2024 13:41
@stefonarch
Copy link
Member

I need porting the sysstat plugin to Qt6

Yes, and switch to dbusmenu-lxqt in statusnotifier.

We are talking about refactor_taskbar_qt6 branch right? With all plugins enabled compile time?

Yes, but disabled all those which won't work on wayland plus statusnotifier and sysstat too. No issue on openbox, crashes in Plasma-session too. If [taskbar] section
is removed from panel.conf no issue, but adding it from menu it crashes again. Menu and calendar won't open nothing. There IS wayland code here ;) it's on top.

@gfgit
Copy link
Member Author

gfgit commented Feb 22, 2024

@stefonarch
Steps I've followed:

  • Rebased refactor_taskbar_qt6 branch on top of latest wip_qt6 changes (And then rebased wayland_taskbar on top of refactor_taskbar_qt6)
  • I've cleared CMake config and enabled ALL plugins
  • Rebuilt branch refactor_taskbar_qt6 and installed under /usr/local
  • Copied panel.conf from refactor_taskbar_qt6 branch (same as in master) to /usr/local/share/lxqt/ and ~/.config/lxqt

Contents of ~/.config/lxqt.conf file:

[General]
__userfile__=true
theme=/usr/local/share/lxqt/themes/KDE-Plasma/

Contents of /usr/share/applications/lxqt-panel.desktop file:

[Desktop Entry]
Type=Application
TryExec=lxqt-panel
#Exec=lxqt-panel
Exec=/usr/local/bin/lxqt-panel
OnlyShowIn=LXQt;KDE
X-LXQt-Module=true

X-KDE-Wayland-Interfaces=org_kde_plasma_window_management

Name=Panel

Tests:

  1. Open Konsole from Plasma Wayland Application Launcher. Run lxqt-panel
    I get ASSERT failure in createWMBackend(): "Only X11 supported!", file /home/filippo/lxqt/lxqt-panel/panel/lxqtpanelapplication.cpp, line 50 which is expected

  2. From same Konsole I run QT_QPA_PLATFORM=xcb lxqt-panel
    Panel opens correctly but being an X11 client it cannot access Wayland windows, so taskbar is empty.
    If I launch Okular from Fancy Menu (and no previous instance was running) it will inherit QT_QPA_PLATFORM=xcb
    So it will be the only app shown in taskbar

@stefonarch
Copy link
Member

I'll test later this evening. What about dbusmenu-lxqt?

@gfgit
Copy link
Member Author

gfgit commented Feb 22, 2024

OpenBox test:

  • From KDE Neon Developer: `sudo apt install openbox' (3.6.1-10)
  • Logout from Plasma Wayland and login in OpenBox session.
  • Right click on black screen, start Konsole
  • Inside Konsole run kwin_wayland lxqt-panel and same assert as above fires which is expected.

@gfgit
Copy link
Member Author

gfgit commented Feb 22, 2024

Yes, but disabled all those which won't work on wayland plus statusnotifier and sysstat too.

So which plugins have you enabled now exactly?

There IS wayland code here ;) it's on top.

This PR is not about wayland. wayland_taskbar has wayland code added on top of this PR
If this PR also has wayland code then I've made mistakes pushing branches

@gfgit gfgit force-pushed the refactor_taskbar_qt6 branch from a5d6b81 to b3d93fb Compare February 22, 2024 14:26
@stefonarch
Copy link
Member

stefonarch commented Feb 22, 2024

If this PR also has wayland code then I've made mistakes pushing branches

Rechecked, was my window rule in kwin. Too many DE configured ;)

@stefonarch
Copy link
Member

stefonarch commented Feb 22, 2024

Built with no changes to the PR, all plugins enabled and no error. But coredump when adding a taskbar under wayland is still the same. Without [taskbar] in panel.conf no issue. Under X11 all good.

#0  0x0000560b855de331 in LXQtTaskBar::settingsChanged() ()
[Current thread is 1 (Thread 0x7f55ae01ea40 (LWP 2600))]
(gdb) where
#0  0x0000560b855de331 in LXQtTaskBar::settingsChanged() ()
#1  0x00007f55af9c9572 in QObject::event(QEvent*) () at /lib/x86_64-linux-gnu/libQt6Core.so.6
#2  0x00007f55b0b67a66 in QFrame::event(QEvent*) () at /lib/x86_64-linux-gnu/libQt6Widgets.so.6
#3  0x00007f55b0bf40eb in QApplicationPrivate::notify_helper(QObject*, QEvent*) ()
    at /lib/x86_64-linux-gnu/libQt6Widgets.so.6
#4  0x00007f55afa63e18 in QCoreApplication::notifyInternal2(QObject*, QEvent*) ()
    at /lib/x86_64-linux-gnu/libQt6Core.so.6
#5  0x00007f55afa64530 in QCoreApplicationPrivate::sendPostedEvents(QObject*, int, QThreadData*) ()
    at /lib/x86_64-linux-gnu/libQt6Core.so.6
#6  0x00007f55af8632f7 in  () at /lib/x86_64-linux-gnu/libQt6Core.so.6
#7  0x00007f55af11bd3b in g_main_context_dispatch () at /lib/x86_64-linux-gnu/libglib-2.0.so.0
#8  0x00007f55af171258 in  () at /lib/x86_64-linux-gnu/libglib-2.0.so.0
#9  0x00007f55af1193e3 in g_main_context_iteration () at /lib/x86_64-linux-gnu/libglib-2.0.so.0
#10 0x00007f55af85e1f0 in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) ()
    at /lib/x86_64-linux-gnu/libQt6Core.so.6
#11 0x00007f55afa6604b in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) ()
    at /lib/x86_64-linux-gnu/libQt6Core.so.6
#12 0x00007f55afa67c7c in QCoreApplication::exec() () at /lib/x86_64-linux-gnu/libQt6Core.so.6
#13 0x0000560b8556abf9 in main ()
(gdb) 

@gfgit
Copy link
Member Author

gfgit commented Feb 22, 2024

I cannot reproduce. Can you put a breakpoint when settingsChanged() is emitted.

Anyway you are running Xcb panel under wayland, why you don't hit the assert on X11 display?

@stefonarch
Copy link
Member

I cannot reproduce. Can you put a breakpoint when settingsChanged() is emitted.

It happens on both machines here... another diff?
How can I set a breakpoint?

Anyway you are running Xcb panel under wayland, why you don't hit the assert on X11 display?

No, the panel runs always in xdg-shell if started on wayland. Usually I use an openbox session with a kwin_wayland konsole window for wayland tests (the panel has to be closed for that in openbox). I tested almost all features on openbox, no issues.

gfgit added 18 commits February 28, 2024 20:20
Also use it to get window icon
- Don't rely on global screen coordinates

- This will be needed for future Wayland port,
  Where we don't have global screen coordinates

- Keep compatible behavior on X11
This new window propery flag is needed to notify geometry changes
This will be used to avoid crashing panel in case no backend could be
created.
A warning message will be printed in this case.
@gfgit gfgit force-pushed the refactor_taskbar_qt6 branch from 65ea434 to 4b7cfd5 Compare February 28, 2024 19:31
@gfgit
Copy link
Member Author

gfgit commented Mar 26, 2024

Replaced by #2041

@gfgit gfgit closed this Mar 26, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants