this post was submitted on 29 Apr 2025
863 points (97.5% liked)

linuxmemes

24686 readers
1580 users here now

Hint: :q!


Sister communities:


Community rules (click to expand)

1. Follow the site-wide rules

2. Be civil
  • Understand the difference between a joke and an insult.
  • Do not harrass or attack users for any reason. This includes using blanket terms, like "every user of thing".
  • Don't get baited into back-and-forth insults. We are not animals.
  • Leave remarks of "peasantry" to the PCMR community. If you dislike an OS/service/application, attack the thing you dislike, not the individuals who use it. Some people may not have a choice.
  • Bigotry will not be tolerated.
  • 3. Post Linux-related content
  • Including Unix and BSD.
  • Non-Linux content is acceptable as long as it makes a reference to Linux. For example, the poorly made mockery of sudo in Windows.
  • No porn, no politics, no trolling or ragebaiting.
  • 4. No recent reposts
  • Everybody uses Arch btw, can't quit Vim, <loves/tolerates/hates> systemd, and wants to interject for a moment. You can stop now.
  • 5. πŸ‡¬πŸ‡§ Language/язык/Sprache
  • This is primarily an English-speaking community. πŸ‡¬πŸ‡§πŸ‡¦πŸ‡ΊπŸ‡ΊπŸ‡Έ
  • Comments written in other languages are allowed.
  • The substance of a post should be comprehensible for people who only speak English.
  • Titles and post bodies written in other languages will be allowed, but only as long as the above rule is observed.
  • 6. (NEW!) Regarding public figuresWe all have our opinions, and certain public figures can be divisive. Keep in mind that this is a community for memes and light-hearted fun, not for airing grievances or leveling accusations.
  • Keep discussions polite and free of disparagement.
  • We are never in possession of all of the facts. Defamatory comments will not be tolerated.
  • Discussions that get too heated will be locked and offending comments removed.
  • Β 

    Please report posts and comments that break these rules!


    Important: never execute code or follow advice that you don't understand or can't verify, especially here. The word of the day is credibility. This is a meme community -- even the most helpful comments might just be shitposts that can damage your system. Be aware, be smart, don't remove France.

    founded 2 years ago
    MODERATORS
     
    you are viewing a single comment's thread
    view the rest of the comments
    [–] bjoern_tantau@swg-empire.de 84 points 1 day ago (5 children)

    For me it is the "Windowsy" feeling of downloading an executable from some website. I prefer having all my packages managed in one place.

    Interesting you compare it to Windows, given how in OS X you literally just drag applications into your Applications folder to install them.

    [–] MoonlightFox@lemmy.world 30 points 1 day ago (1 children)

    Makes sense, I kinda like it from a distributor standpoint. Flatpak is my favorite though.

    [–] cecilkorik@lemmy.ca 26 points 23 hours ago (5 children)

    For simple "apps" it is fine, but my computer is not a phone and I don't use it like one. I mostly don't want simple apps that have their own little sandbox to play in.

    I want full-scale applications that are so big they have to use system libraries to keep their disk size down. I also don't want them in a sandbox. I want them to have full access to the system to do everything they need to do, I want them to integrate with far-flung parts of the system and other applications too. I only use applications I trust and don't want them constantly pestering me about configuring permissions and access in just the right ways and opening all the right doors and ports and directories to make them work, I trust them by installing them, they have permission, and the easier they make it to access everything I will inevitably be asking them to access, the happier I am.

    My practical concern with distribution methods like AppImage and Flatpak is that now I have to do a lot of extra thinking every time I'm installing anything. To pick how I'm going to install something, I have to solve the matrix of "what kind of distribution method do I prefer for this type of software" combined with "what distribution methods are available for this software" and "what versions are the available distribution methods for this software" and "what distribution method provides the best way for this software to get updates".

    In the olden days, when the distro's package manager was the only choice, all I had to care about was "is it available in my distro" and the decision tree was complete. I appreciate all the availability of choice that things like AppImage provide, but it doesn't actually make it easier for me, it just makes it easier for the packager of the software. They're doing less, but making more work for me, as a user. Distro packages are a lot of work for the maintainer precisely because they at least make an effort to solve many of these issues for the user. The value-add that maintainers provide is real.

    [–] Samueru_sama@programming.dev 4 points 10 hours ago

    omg I cannot fucking believe that while I was typing this I just saw another distro package nonsense:

    There is this very good tool called soar which I use for static binaries. (It also has support for appimages but to be honest it is not as good as AM rn).

    Well we just got a complain that fastfetch is not displaying the package count of soar, which fastfetch is able to do.

    Turns out this is because the archlinux package is built without SQLITE3 which is needed for that feature to work 😫

    And what's worse is that account registrations are disabled in the archlinux gitlab, so I have to jump thru some hoops to get a basic bug report filed...

    [–] Samueru_sama@programming.dev 4 points 11 hours ago

    I want full-scale applications that are so big they have to use system libraries to keep their disk size down

    Linux is in such sad state that dynamic linking is abused to the point that it actually increases the storage usage. Just to name a few examples I know:

    most distros ship a full blown libLLVM.so, this library is a massive monolith used for a bunch of stuff, it is also used for compiling and here comes the issue, by default distros build this lib with support for the following targets:

    -- Targeting AArch64
    -- Targeting AMDGPU
    -- Targeting ARM
    -- Targeting AVR
    -- Targeting BPF
    -- Targeting Hexagon
    -- Targeting Lanai
    -- Targeting LoongArch
    -- Targeting Mips
    -- Targeting MSP430
    -- Targeting NVPTX
    -- Targeting PowerPC
    -- Targeting RISCV
    -- Targeting Sparc
    -- Targeting SystemZ
    -- Targeting VE
    -- Targeting WebAssembly
    -- Targeting X86
    -- Targeting XCore
    

    Gentoo used to offer you the option to limit the targets and make libLLVM.so much smaller, but now rust applications that link to llvm have issues with this with caused them to remove that feature...

    Another is libicudata, that's a 30 MiB lib that all GTK applications end up linking to for nothing, because it is a dependency of libxml2, which distros override to build with icu support (by default this lib does not link to libicudata) and what's more sad is that the depenency to libxml2 comes because of transitive dependency to libappstream, yes that appstream that I don't even know why most applications would need to link to this.

    And then there is archlinux that for some reason builds libopus to be 5 MiB when most other distros have this lib <500 KiB

    Sure dynamic linking in the case of something like the coreutils, where you are going to have a bunch of small binaries makes sense, except you now have stuff like busybox which is a single static bin that acts as each of the different tools by checking the name of the symlink that launched it and it is very tiny at 1 MiB and it provides all your basic unix tools including a very good shell.

    Even Linus was surprised by how much dynamic linking is abused today: https://lore.kernel.org/lkml/CAHk-=whs8QZf3YnifdLv57+FhBi5_WeNTG1B-suOES=RcUSmQg@mail.gmail.com/

    To pick how I’m going to install something,

    https://github.com/ivan-hc/AM

    I have all these applications using 3.2 GIB of storage while the flatpak equivalent actually uses 14 GiB πŸ’€: https://i.imgur.com/lvxjkTI.png

    flatpak is actually sold on the idea that shared dependencies are good, you have flatpak runtimes and different flatpaks can share, the problem here is that those runtimes are huge on their own, the gnome runtime is like 2.5 GiB which is very close to all those 57 applications I have as appimage and static binaries.

    but it doesn’t actually make it easier for me, it just makes it easier for the packager of the software

    Well I no longer have to worry about the following issue:

    • My application breaking because of a distro update, I actually now package kdeconnect as an appimage because a while ago it was broken for 2 months on archlinux. The only app I heavily rely from my distro now is distrobox.

    • I also get the latest updates and fixes as soon as upstream releases a new update, with distro packaging you are waiting a week at best to get updates. And I also heard some horror stories before from a dev where they were told that they had to wait to push an update for their distro package and the only way to speed it up was if it was a security fix.

    • And not only you have to make sure the app is available in your distro packages, you also have to make sure it is not abandoned, I had this issue with voidlinux when I discovered the deadbeef package was insanely out of date.

    • Another issue I have with distro packages in general is that everything needs elevated rights to be installed, I actually often hear this complains from linux newbies that they need to type sudo for everything and it doesn't have to be this way, AM itself can be installed as appman which makes it able to work on your HOME with all its features. And you can take your HOME and drop it in any other distro and be ready to go as well.

    [–] MrQuallzin@lemmy.world 21 points 23 hours ago

    It doesn't sound like they're making more work for you. It sounds like you're making more work for yourself, and it sounds exhausting.

    [–] Cenzorrll@lemmy.world 1 points 18 hours ago

    I agree, there's a place for flatpaks and appimages, but for the most part my computer isn't it. If I was setting it up as more of an appliance or as a work computer in a fleet of devices, sure they'd be great. I installed VLC in it's flatpak form on accident once and it was worthless because the entire reason I installed it was to watch either a DVD or Blu-ray, and it didn't have the libraries to read the disc. It took me far longer than I'm willing to admit to figure out it was because flatpak. I'm sure there's a way to work around that, but at that point I was done with any flatpaks for anything that might need additional anything.

    They do cut down on needing multiple versions of the same package, so I'll sometimes install the flatpak version to try something out if I'm not sure it's what I want.

    [–] notabot@lemm.ee 0 points 18 hours ago

    I couldn't agree more. Occasionally I'll use an appimage where something is not packaged for my distro version and I only need it temporarily.

    Maybe I'm just long in the tooth, but linux used to be a simple, quite elegant system, with different distros providing different focuses, whether they were trying to be windows clones, something that a business could bank on being there in ten years, or something for those who like to tinker. The common theme throughout was 'the unix way', each individual tool was simple, did one job, and did it well. Now we seem to be moving to a much more homogenous ecosystem of distros with tooling that tries to be everything all at once, and often, not very well.

    [–] Monstrosity@lemm.ee 10 points 1 day ago (1 children)
    [–] bjoern_tantau@swg-empire.de 13 points 23 hours ago (2 children)

    And the added work with keeping them updated.

    [–] Samueru_sama@programming.dev 1 points 18 hours ago

    AppImage is meant to be updated using the embedded zsync info the runtime, that is the user should never have to open the app to update it.

    The user needs to have something like AM, appimagelauncher or appimaged that is then able to parse the info and update the appimages using appimageupdatetool

    This method also provides delta updates, meaning it doesn't download the entire app but only a diff, see this test with CPU-X where it downloaded 2.65 MiB to update the app: