Show HN: TUI for managing XDG default applications

(github.com)

120 points | by mitjafelicijan 21 hours ago

10 comments

  • coppsilgold 11 hours ago
    I usually just edit ~/.config/mimeapps.list directly.

    I can see how that tool can be useful, but only if it's included in official repos. Editing mimeapps.list is simpler than the hassle of downloading and building this tool.

  • piskov 13 hours ago
    Thank god it’s not another React, Solid, Typescript, what have you, web abomination inside the terminal (claude code, opencode, I’m looking at you).

    Bravo!

    • codethief 8 hours ago
      > claude code, opencode, I’m looking at you

      Could you elaborate? I mean, I get the usual criticism of web/Electron-based desktop applications (slow, includes a whole Chrome engine, non-native UI, …) but Claude Code isn't one of them?

    • thehamkercat 13 hours ago
      That's where codex-cli shines (rust)

      the startup time is crazy, you can start writing as soon as you hit the command

      (I don't use codex, just noticed that it's crazy fast)

      • DrammBA 9 hours ago
        Sadly the fast startup time is overshadowed by the slow response time of the codex agent
  • jwrallie 19 hours ago
    Just by reading the title, I’m sold! This should be very useful specially if you are not using a desktop environment that manages the default apps.

    I always alias open to xdg-open, it’s so useful to open a file directly from the terminal.

    • mitjafelicijan 18 hours ago
      That was the exact reason for it. I made my own window manager for fun and was missing a simple way of changing default apps.
  • fouc 16 hours ago
    At first I thought it was going to be some kind of solution to force all linux apps to adhere to the XDG Base Directory Specification, until I realized this related to a different specification altogether (XDG MIME Applications specification).
    • jedahan 15 hours ago
      Making home read-only can get there, and I can't find the project that forced using XDG paths. I think it used LD_PRELOAD or somesuch trick.

      edit: https://soc.me/standards/defending-home

      • ekipan 11 hours ago
        Strange. Middle-clicking the link opens a HackerNews frontpage, but copypasting into a new tab shows the article. Presumably the server shoos away referer links? To reduce load maybe somehow? Or maybe something's weird in my own configuration idk.
        • IAmLiterallyAB 3 hours ago
          They explicitly check if the referrer is hackernews and do that.
        • mitjafelicijan 9 hours ago
          I had the same issue as you. Had to copy and paste the link.
  • sourcegrift 20 hours ago
    No one on earth has so far managed to get xdg default apps work on Linux. I've been failing since 19 years personally. If you've really succeded then congratulations!
    • nickjj 19 hours ago
      > No one on earth has so far managed to get xdg default apps work on Linux.

      I've only been using Linux for a few weeks but what am I missing here?

      I set a bunch of mime types in `~/.config/mimeapps.list` which are assigned to desktop apps and they all open perfectly with `xdg-open` or when I launch them through a file manager.

      It is documented in the XDG specification https://specifications.freedesktop.org/mime-apps/latest/file....

      • forgotpwd16 19 hours ago
        For me currently, when trying to open a `text/markdown` file, there's a disassociation between what my file manager (Caja) runs (own bin/emacs script; was under the impression it was auto-creating a .desktop file), what mimeapps.list have (emacs.desktop), and what `xdg-open` runs (Firefox for some reason).
        • TingPing 14 hours ago
          Older desktops don’t follow the specs and xdg-open does different things based on the desktop, so they indeed can get out of sync.

          I’d have to look into your specific case but `gio mime` and `gio open` do the right things.

      • sam_lowry_ 15 hours ago
        > what am I missing here?

        There are gotchas, for instance Chrom,{e,ium} insists on XDG_DESKTOP_DIR != XDG_DOWNLOAD_DIR.

        See this bug report from a confused user: https://issues.chromium.org/issues/41076564

        • mikkupikku 14 hours ago
          > also of note, we (mostly) don't allow ~/Desktop as the download dir for security reasons

          This isn't an XDG issue. It's a chromium engineers being silly pricks that think they know better than the power users who obviously went out of their way to create such a configuration. Also I bet it would work if you set your XDG_DESKTOP_DIR to ~/Download/

    • saturn_vk 16 hours ago
      Great. I must be living on the moon then. I guess gnome work great there since it manages this part
      • mitjafelicijan 16 hours ago
        Gnome has done an amazing job at this, I agree. You don't even notice this issue.
        • t-3 13 hours ago
          It's when I want to use a non-systemd, no-DE environment that xdg-stuff becomes very annoying, but that's usually because applications assume a certain setup rather than any fault of xdg. eg. Wayland is very stupid about requiring a certain xdg setup to run at all.
    • mitjafelicijan 18 hours ago
      I probably haven't. :) They are a nightmare indeed. But it does help a little.
  • ranger_danger 19 hours ago
    Feature suggestion: The ability to add/remove more specific mime entries such as video/mp4
    • mitjafelicijan 18 hours ago
      I haven't thought about this. That makes sense. I will add this.
  • untech 20 hours ago
    Looks neat!
  • renewiltord 11 hours ago
    These days I pretty much write this kind of software in ratatui with LLM when I need it. But the idea is nice. I like that. LLMs are the return of the value of the ideas guy!

    But this seems human-written? Then it is interesting. Thank you for sharing.

    • mitjafelicijan 11 hours ago
      Yeah, I did write it myself, yes. It's actually a very simple program.

      I heard so many great things about ratatui. I am, however, not well versed in Rust. Only did a couple of toy little things in it.

  • cda2100 20 hours ago
    [flagged]
    • JonAtkinson 20 hours ago
      Who are you to tell people what to be proud of, and and what to want to share?
    • rolymath 19 hours ago
      Either you're so lame that you created an account just to say this, or you don't have the courage to say it from your real account.

      Either way, why don't you show us some of the stuff you've made.

    • forgotpwd16 19 hours ago
      Ackchyually XDG default applications aren't set via env vars but through the `${XDG_CONFIG_HOME}/mimeapps.list` file manipulated (either via text editor if track desktop files yourself or, better) via `xdg-mime {query|default}` tool. This TUI is a replacement (doesn't wrap it) to this tool for this functionality, with twist that does multiple-defaults category-wise rather one-by-one ("word processor documents" rather odt/doc/docx).

      Compared to what slopcalypse has brought, this one (project; vibe coded maybe, certainly not slop) at very least is useful (also is quite short; within a sea of thousand LOC generated in 1s this is refreshing).

    • ranger_danger 20 hours ago
      What have you shown that's better?
  • roman_soldier 19 hours ago
    Nice, but problem with all these AI coded TUI's is we will have hundreds of them, best to stick to the built in linux commands, add aliases/abbreviations (fish) if required, do you need a TUI for everything? Sometimes the answer to "Should I write this?" Is no
    • mitjafelicijan 16 hours ago
      I do agree with some of your sentiment. But by that logic, nothing would ever be made.

      The same goes with aliases. Why not just use the actual commands. You give it your best shot, and sometimes something good comes out. And sometimes it's crap. That's life.

      And I made it for fun and to learn something. And it wasn't AI coded. It's like 200 lines. I wanted to learn termbox2.h a bit more than I already had.

      • brw 12 hours ago
        Yea I was pleasantly surprised by how simple the code is when I read it. Honestly a great example of what termbox2 is capable of. Very nice!

        And now I know about termbox2, which looks very cool. Looking through the example projects[1] in the README I also found ictree[2], which does exactly what I was looking for yesterday (turning the output of `find` into an ncdu-like/interactive tree interface). I didn't manage to find something for that through googling around or asking LLMs, but thanks to you posting this here I did, so thanks!

        [1] https://github.com/termbox/termbox2#examples

        [2] https://github.com/NikitaIvanovV/ictree

        • mitjafelicijan 11 hours ago
          This whole tool is much more a display of what termbox2 can do in couple of lines tbh :) You are so right about that.

          It's an amazing library. And all that juice in one stb-style header file. You just gotta love it.

          And if you are interested in such small libraries, I have a Github list with a bunch of them that I found.

          https://github.com/stars/mitjafelicijan/lists/stb-style-mini...

    • wolttam 16 hours ago
      Let people make and use what they want, you don’t have to use it.
    • mikkupikku 12 hours ago
      The nice thing about AI coded TUIs is they're so easy to make you can make the ones that suit you yourself and ignore the rest.
    • samtrack2019 15 hours ago
      reading the code, what make you think it was vibe coded?
    • jrm4 12 hours ago
      I absolutely fail to see the problem and I think the whole "best to stick to built in linux commands" is an utterly dinosaur-esque take that can, and will, and should, go extinct in the age of AI-assisted coding.
      • mitjafelicijan 12 hours ago
        It is interesting that somehow every conversation now pivots to LLM's. It's almost like people are paranoid or something. I have no issue with AI. But it should be used carefully when learning/working so you don't miss the little details that usually make a big difference later. But to each their own.

        It is just getting tiring that people assume more and more that things were written with AI for everything. It's like, OMG, can you stop it for a second. And who cares, really. Do your due diligence, check the code and decide for yourself. But maybe, this is just projection. Or a nice way of insulting/dismissing people, which I find quite funny.

        And like you said, the age of AI-assisted coding is already here. There is beauty in piping core utils together and being really productive with them. No doubt about it. But there are also new ways of computing emerging, and we should learn about that too.