• RiderExMachina@lemmy.ml
    link
    fedilink
    English
    arrow-up
    13
    ·
    6 months ago

    I think there are two major hurdles keeping Linux adoption back (besides the obvious installation bit). The first is that our backwards compatibility is terrible. It is easier to get old versions of Windows software to run in Wine than it is to get some old Linux software to run natively.

    If something like Photoshop did finally release a Linux version, even if they only did one release to make 2% of people happy, it likely wouldn’t be able to run natively after 5 years.

    The second is a good graphical toolkit. Yes, GTK and Qt exist, but neither are as simple as WinForms or SwiftUI/Aqua.

    • Bulletdust@lemmy.ml
      link
      fedilink
      arrow-up
      24
      ·
      edit-2
      6 months ago

      I’ve got plenty of old software here under Linux that still runs fine to this day across a number of PC’s and even a Raspberry Pi that I use as a backup desktop. I honestly can’t see backwards compatibility being any more of an issue than it is under Windows - There’s a number of accounting packages released under Windows 7 that won’t run under Windows 10, the latest version of most popular browsers won’t run under Windows 7. Likewise, the latest version of MS Office 365 won’t run under Windows 8.

    • narc0tic_bird@lemm.ee
      link
      fedilink
      arrow-up
      20
      ·
      6 months ago

      Manual installation is one thing, but by far the biggest reason is OEM preinstalls. 98% of the people never install any operating system themselves, the devices just come with one and that’s the one that’ll be used.

        • pbjamm@beehaw.org
          link
          fedilink
          English
          arrow-up
          4
          ·
          6 months ago

          IIRC part of that issue was that the Windows version of the same computer was cheaper because of MS licensing. For Linux nerds at the time it made more sense to buy the Windows version and do what they had always done, reinstall with the Linux of their choice.

    • SSUPII@sopuli.xyz
      link
      fedilink
      arrow-up
      6
      ·
      6 months ago

      To allow modern windows to run legacy applications a lot of caution is given to updating libraries or fully new ones are given while keeping the older ones. Also static builds are more common on Windows, or come bundled with a copy of the required libraries as .dll files.

      • Let’s say an application requires libexample1. It works, the library is available too.
      • Eventually the application gets abandoned, but still works.
      • But eventually a libexample2 gets released that drastically changes how the library works. The program doesn’t work on this version. The older release of the library then get’s abandoned.
      • Distributions now start removing the package from the repositories as the older library is slowly requiring no longer supported releases of its own dependency.
      • Now application is borked

      Aplication could have still worked if it came bundled with its own copy of libexample1 and of its dependencies, or was statically linked.

      An example of this is Nero, a software kit for managing CD/DVD disc media. They made a build of some of their tools for Linux, meant to run on Debian 7. This builds were an experiment and got abandoned because of the very few users it had. Yet, these tools still work perfectly fine on Debian 12 despite being based on ancient libraries because it bundles all its requirements as a copy in its own proprietary blob.

      I talked about caution on updating libraries on Windows. You can find many deprecated methods in any native Windows library that will likely never be removed from the library binaries, as many applications require it. The new, better and more feature rich method is given a different name instead, and is pointed out in the documentation for the older method.

      Projects like FUSE are very nice for this, where an AppImave bundle of prebuilt binaries is given and can potencially not only be ran everywhere that can run FUSE but also in the future too.