Originally posted by Joe2021
View Post
Announcement
Collapse
No announcement yet.
XWayland 24.1 Planned For Release Next Month With Explicit Sync & Other Features
Collapse
X
-
Originally posted by caligula View Post
Outside the Linux world almost no developer writes native GUI apps anymore. Everything uses React / Vue / Svelte / Flutter. The developers simply don't have any experience writing native non-web apps.
imho its not just a lack of experience writing native guis though, its that the tooling and functionality offered by native apps accross the OS ecosystem falls far short of that necessary.
exceptions are android and ios, which both have their own rock solid gui development toolchain, and subsequently only make light use of HTML5 for their guis (native support for which ships with both ios and android, rather than having to bundle a CEF install like you do for macos/windows/linux)
closest competitor/alternative seems to be Qt, and besides being insanely expensive that is so chock full of bugs on wayland it is unusable (as seen recently with PCSX2 dumping their wayland backend in part due to the lack of Qt stability).
- Likes 1
Comment
-
Originally posted by mSparks View Postclosest competitor/alternative seems to be Qt, and besides being insanely expensive that is so chock full of bugs on wayland it is unusable (as seen recently with PCSX2 dumping their wayland backend in part due to the lack of Qt stability).
For those picking up on this as "news", please read the following list: PCSX2 still supports Wayland. It just prefers the XCB/XWayland platform by default. You can set the I_WANT_A_BROKEN_WAYLAND_...
The issue with PCSX2 is not in fact Qt stability. The largest issue causing all forms of hell with PCSX2 is that it is in fact a multi application program so it find Wayland protocol missing feature coming from failure to agree how to-do those features.- Inability to position windows => window position saving doesn't work, log window attaching (not merged yet) doesn't work
- Hacks in render-to-main because WL craps itself otherwise
mSparks do remember all KDE applications are Qt applications and they do work stability under Wayland. There is a catch of course none of your KDE applications are multi process application design.
- Likes 3
Comment
-
Originally posted by oiaohm View Post
Really you need to stop posting garbage.
For those picking up on this as "news", please read the following list: PCSX2 still supports Wayland. It just prefers the XCB/XWayland platform by default. You can set the I_WANT_A_BROKEN_WAYLAND_...
The issue with PCSX2 is not in fact Qt stability. The largest issue causing all forms of hell with PCSX2 is that it is in fact a multi application program so it find Wayland protocol missing feature coming from failure to agree how to-do those features.- Inability to position windows => window position saving doesn't work, log window attaching (not merged yet) doesn't work
- Hacks in render-to-main because WL craps itself otherwise
mSparks do remember all KDE applications are Qt applications and they do work stability under Wayland. There is a catch of course none of your KDE applications are multi process application design.
I was referring to this exact quote in the link you just posted:
-> It causes issues, most of which are caused by QtWayland
personally I'm inclined to recommend taking the word of a proven wayland developer rather than some random phoronix poster that is incapable of reading a github issue, and has proven time and again they dont have the slightest clue what they are talking about.Last edited by mSparks; 13 April 2024, 11:57 PM.
Comment
-
It causes issues, most of which are caused by QtWayland, some are caused by the protocol itself.
Next question did you look at the issues he posted against QtWayland and what they were resolved to. The answer is no you did not.
Originally posted by mSparks View Postpersonally I'm inclined to recommend taking the word of a proven wayland developer rather than some random phoronix poster that is incapable of reading a github issue, and has proven time and again they dont have the slightest clue what they are talking about.
This is the problem when you look at the QtWayland bugs the pcsx2 developer submitted and what the resolve to they resolve to Wayland protocol limitations most of the time.
Remember all the KDE applications also use QtWayland and that working without issue. So this brings back to what is so special about the pcsx2 case that it hits these problems so much.
Over 98% of applications on the desktop are not designed the way PCSX2 is.
Of course there is another bit that is important that you would have ignored.
KDE isn't too buggy, GNOME is a complete disaster.
mSparks you really do need to stop posting garbage based on of posts from people who really many not be qualified enough to tell what the real issue is. Remember QtWayland giving a developer trouble this can be a fault in QtWayland or a fault caused by a particular feature being missing from Wayland protocol that QtWayland trys to use no operation code for that end up causing issues. Yes the are quite a few cases where its the no operation code being used so that a function does not error just because Wayland protocol does not have a feature yet.
- Likes 2
Comment
-
Originally posted by oiaohm View PostmSparks do remember all KDE applications are Qt applications and they do work stability under Wayland.
Originally posted by oiaohm View PostThere is a catch of course none of your KDE applications are multi process application design.
Quite some KDE applications are split into a service and a UI process.
Kontact is essentially a single process variant of a multi process setup of the respective applications.
Their shared backend is multiple processes as well.
Kate, and likely a number of other applications, can delegate work to external tools, usually run as separate processes.
Plasma is essentially also a set of orchestrated processes (services and UI) with at least Plasma Shell, KWin and KRunner contributing to the overall UI.
- Likes 1
Comment
-
Originally posted by oiaohm View Post
Notice how mSparks did not quote the full line. Some he could identify as cased by the protocol.
" I was the one who implemented Wayland support in the first place, this isn't some "anti wayland" crusade. It causes issues, most of which are caused by QtWayland, some are caused by the protocol itself. I want nothing more than to see Wayland succeed, but at the moment, it is unusable for a majority of users."
Its very clear, no ambiguity there, doesn't matter which way you cut it or how many strawmen you build.
Originally posted by oiaohm View PostIs the pcsx2 developer a qt core developer or a Wayland protocol developer the answer is no he is not.
In the meantime, everyone will keep using React / Vue / Svelte / Flutter etc. with a healthy does of X11 for HPC on linux, swift on ios, android studio for android and even some directX for those microsofties who can stomach winblowsLast edited by mSparks; 14 April 2024, 04:14 AM.
- Likes 1
Comment
-
Originally posted by anda_skoa View PostI guess it depends on how one would define "multi process application"
Originally posted by mSparks View PostSeems you, me and him are all agreed, anybody who is not a qt core developer or a Wayland protocol developer should forget about wayland for a few decades until/if they get their shit together.
You click on a button in pcsx2 and popup appears. You have a 80% that the popup that has just appeared is from a different progress to the button you clicked. Now what is the odds of this in 98%+ of all applications out there. That right this does not happen at all. PCSX2 GUI design in it code is a true odd ball.
Originally posted by anda_skoa View PostQuite some KDE applications are split into a service and a UI process.
mSparks when something is having trouble it takes two to tango as they say. There are things about pcsx2 that make it not a common application design it hits a lot of corner cases that are not well supported at this stage.
Fixed link this is a 2020 presentation that was given in a few different conferences.
Flutter + Wayland is the best practice in embedded systems using Linux
Yes that is 2020 and in 2020 we were already seeing new soc chips released for embedded without X11 support.
Embedded Linux embedding for Flutter. Contribute to sony/flutter-embedded-linux development by creating an account on GitHub.
And it gets more fun mSparks
Display backend support
Wayland
Direct rendering module (DRM)
Generic Buffer Management (GBM)
EGLStream for NVIDIA devices
Users of flutter in embedded they don't have a healthy dose of X11 for quite a few years now.
mSparks like it or not there are a lot of use cases where wayland and weston are perfectly fine where X11 use to be but X11 in those use cases is no more.
mSparks wounder how many other things that you claim everyone uses also turn out to be like flutter use to support X11 but today does not support X11 at all. This is part of why upstream X11 on bare metal is running out of developers.Last edited by oiaohm; 14 April 2024, 01:44 PM.
- Likes 1
Comment
-
Originally posted by oiaohm View Post...
Flutter is only a good option on the more powerful end of the embedded spectrum. Even on android I'm not the biggest fan of flutter applications on super low end phones.
Comment
-
Originally posted by oiaohm View PostI should be more clear.
Lot's of different possibilities how processes interact
Originally posted by oiaohm View PostWhen I say multi progesses application. I mean multi progress GUI application in a very particular way that not common.
Originally posted by oiaohm View PostYou click on a button in pcsx2 and popup appears. You have a 80% that the popup that has just appeared is from a different progress to the button you clicked. Now what is the odds of this in 98%+ of all applications out there.
For example when you are in Kmail and create a new IMAP account, the backend service will create another IMAP handler.
And Kmail will then ask (via D-Bus) that handler process to show its configuration UI.
That UI appears to the user as a dialog of Kmail, because the two processes have exchanged the information necessary to associate the "foreign" window to be "transient to" Kmail's main window.
Outside of Qt we have basically all web browsers which launch one process per tab and integrate their buffers into their own UI.
Originally posted by oiaohm View PostThat right this does not happen at all. PCSX2 GUI design in it code is a true odd ball.
Originally posted by oiaohm View PostYes I was not referring to service/ui process multi process or . I am referring to multi process inside the UI part with pcsx2 this makes is very different to all the KDE applications.
- Likes 1
Comment
Comment