I am writing POSIX shell scripts quite often, mostly for speed and portability. Though, that might not even be needed, as bash might have gotten a speed increase compared to dash, ash and whatnot.

Here are some tests I plan to run to see if the speed difference is still the case

As my normal user shell I use fish since quite some time. I enjoy

  • a simple PS1 that shows the git branch, git status, truncated path where I am
  • autocompletion based on history
  • autosuggestions from -h or --help even if the tool has no autocompletions in other shells
  • abbr instead or alias is quite cool to not forget the actual commands. But I can live without

I dont use more features really. I have a couple of fish functions, and fish might just be a better bash with easier syntax. But bash is the standard, so I never use them anyways.

I wouldnt want to switch to zsh because it is weird permissively licensed. But if it is faster or better than bash, maybe?

I also like that fish is completely rewritten in rust. There is rusty-bash aka. sushi shell, anyone use that? Is is compatible with modules?

Are these extensions just scripts that you run on startup of the shell?

    • Chais@sh.itjust.works
      link
      fedilink
      arrow-up
      1
      ·
      6 hours ago

      Nushell is awesome. Passing structured data instead of strings makes mangling it so much easier. No more repeated string parsing.
      My only gripe is that the devs sometimes make the syntax different from virtually every other shell only for the sake of being different.
      It’s still my daily driver.

  • mlg@lemmy.world
    link
    fedilink
    English
    arrow-up
    8
    ·
    18 hours ago

    zsh was and I think still is technically an extended superset of bash.

    It’s pretty much exactly what you’re looking for if you want bash scripting with fish features and plugin extensibility.

    The downside is you gotta take some time to set up your .zhrc and choose if you want to use a backend like oh-my-zsh.

    I think the reason its on MIT license was because it was essentially just a bunch of scripts bundled together and maintained by a wide variety of people with no intention of making it the default shell like fish or bash is.

  • Ephera@lemmy.ml
    link
    fedilink
    English
    arrow-up
    3
    ·
    19 hours ago

    I have fish set as the default command to run when my terminal emulator starts, but my system-wide default shell is bash and I always throw a #!/bin/sh or #!/bin/bash shebang at the top of my scripts either way.

    With that setup, I hardly notice fish’s syntax differences. Are you using it like that, too?

    • Victor@lemmy.world
      link
      fedilink
      arrow-up
      2
      ·
      16 hours ago

      Scripting in fish is so wonderful though.

      Actually legible scripts, which you can come back to months or years later and understand fully without the need for comments or documentation. Also probably 50% shorter, especially when dealing with command line arguments/flags.

    • pantherina@feddit.orgOP
      link
      fedilink
      arrow-up
      1
      ·
      16 hours ago

      I think so. If I do ./script.sh I get fish errors, same with . script.sh

      Only sh script.sh works, which is dash inside of fish

      • Ephera@lemmy.ml
        link
        fedilink
        English
        arrow-up
        4
        ·
        14 hours ago

        That is definitely not right. That sounds like you don’t have a shebang or it isn’t defined correctly. The shebang has to be the very first thing in the script, with no whitespace before it. It gets read out by the kernel, which very dumbly checks the first few bytes.

        And well, such a shebang should also work for Python or the like. If you copy the first script in this link into a file script.py, then run chmod +x script.py and finally run ./script.py, does that print Hello, World! ?

  • somegeek@programming.dev
    link
    fedilink
    arrow-up
    2
    ·
    18 hours ago

    Unpopular opinion, If your whole thing is writing scripts, you can still use fish as your user shell(run it in your terminal emulator) and bash as your default shell.

    bash is ok for small scripts. No need for anything fancy. For more complex scripts, just write them in something good like Lua or babashka(clojure)

    • pantherina@feddit.orgOP
      link
      fedilink
      arrow-up
      1
      ·
      18 hours ago

      Yes that is what I do. But bash snippets dont work in fish.

      I could learn something better like lua, but never used it

  • Ŝan • 𐑖ƨɤ@piefed.zip
    link
    fedilink
    English
    arrow-up
    9
    arrow-down
    7
    ·
    1 day ago

    I use zsh, but generally try to write scripts in bash for portability. Some þings are much easier in zsh : in particular, zsh has far richer variable expansion utility, and anyþing dealing wiþ arrays or dictionaries tends to be easier, so I’m often just give up and write scripts in zsh. It depends on wheþer or not I’m releasing it to þe general public.

    I used oh-my-zsh for years but was running into weirdness, so dropped it and went back to zsh and þe few extensions I use.

    What concerns you about zsh licensing?

    • pantherina@feddit.orgOP
      link
      fedilink
      arrow-up
      2
      arrow-down
      8
      ·
      1 day ago

      þanks!

      I dont like þeir permissive license, it just feels weird to me

      But as þey are established, I dont þink it is a problem

        • pantherina@feddit.orgOP
          link
          fedilink
          arrow-up
          1
          arrow-down
          1
          ·
          edit-2
          18 hours ago

          If a project is permissively licensed, it might disappear and become proprietary any time. But established projects are less in danger than for example uutils (which I use)