I’ve been looking around for a scripting language that:

  • has a cli interpreter
  • is a “general purpose” language (yes, awk is touring complete but no way I’m using that except for manipulating text)
  • allows to write in a functional style (ie. it has functions like map, fold, etc and allows to pass functions around as arguments)
  • has a small disk footprint
  • has decent documentation (doesn’t need to be great: I can figure out most things, but I don’t want to have to look at the interpter source code to do so)
  • has a simple/straightforward setup (ideally, it should be a single executable that I can just copy to a remote system, use to run a script and then delete)

Do you know of something that would fit the bill?


Here’s a use case (the one I run into today, but this is a recurring thing for me).

For my homelab I need (well, want) to generate a luhn mod n check digit (it’s for my provisioning scripts to generate synchting device ids from their certificates).

I couldn’t find ready-made utilities for this and I might actually need might a variation of the “official” algorithm (IIUC syncthing had a bug in their initial implementation and decided to run with it).

I don’t have python (or even bash) available in all my systems, and so my goto language for script is usually sh (yes, posix sh), which in all honestly is quite frustrating for manipulating data.

  • Fonzie!@ttrpg.network
    link
    fedilink
    arrow-up
    7
    ·
    edit-2
    24 days ago

    Why aren’t python and bash be available in all your systems? Which languages would be?

    I would’ve recommended python, otherwise perl or Haskell (maybe Haskell’s too big) or something, but now I’m worried that whatever reason makes python undoable also makes perl etc. undoable

    • WatTyler@lemmy.zip
      link
      fedilink
      arrow-up
      3
      ·
      23 days ago

      Mate, I came on here to post Haskell as a semi-ironic ‘joke’ and it’s included in the top comment. You’ve made my day.

    • gomp@lemmy.mlOP
      link
      fedilink
      arrow-up
      0
      ·
      23 days ago

      Why aren’t python and bash be available in all your systems?

      Among others, I run stuff on alpine and openwrt.

      I don’t need to run these scripts everywhere (strictly speaking, I don’t need the homlab at all), but I was wondering if there’s something that I can adopt as a default goto solution without having to worry about how each system is packaged/configured.

      As for python, I doubt the full version would fit in my router plus as said I don’t want to deal with libraries/virtualenvs/… and (in the future) with which distro comes with python3 vs pyton4 (2 vs 3 was enough). Openwrt does have smaller python packages, but then I would be using different implementations on different systems: again something I’d rather not deal with.

      As for perl, it would be small enough, but I find it a bit archaic/esoteric (prejudice, I know), plus again I don’t want to deal with how every distro decides to package the different things (eg. openwrt has some 40+ packages for perl - if I were doing serious development that would be ok, but I don’t want to worry about that for just some scripts).

      • BaumGeist@lemmy.ml
        link
        fedilink
        arrow-up
        5
        ·
        23 days ago

        You’ve defined yourself into an impossible bind: you want something extremely portable, universal but with a small disk imprint, and you want it to be general purpose and versatile.

        The problem is that to be universal and general purpose, you need a lot of libraries to interact with whatever type of systems you might have it on (and the peculiarities of each), and you need libraries that do whatever type of interactions with those systems that you specify.

        E.g. under-the-hood, python’s open("<filename>", 'r') is a systemcall to the kernel. But is that Linux? BSD? Windows NT? Android? Mach?

        What if you want your script to run a CLI command in a subshell? Should it call “cmd”? or “sh”? or “powershell”? Okay, okay, now all you need it to do is show the contents of a file… But is the command “cat” or “type” or “Get-FileContents”?

        Or maybe you want to do more than simple read/write to files and string operations. Want to have graphics? That’s a library. Want serialization for data? That’s a library. Want to read from spreadsheets? That’s a library. Want to parse XML? That’s a library.

        So you’re looking at a single binary that’s several GBs in size, either as a standalone or a self-extracting installer.

        Okay, maybe you’ll only ever need a small subset of libraries (basic arithmetic, string manipulation, and file ops, all on standard glibc gnu systems ofc), so it’s not really “general purpose” anymore. So you find one that’s small, but it doesn’t completely fit your use case (for example, it can’t parse uci config files); you find another that does what you need it to, but also way too much and has a huge footprint; you find that perfect medium and it has a small, niche userbase… so the documentation is meager and it’s not easy to learn.

        At this point you realize that any language that’s both easy to learn and powerful enough to manage all instances of some vague notion of “computer” will necessarily evolve to being general purpose. And being general purpose requires dependencies. And dependencies reduce portability.

        At this point your options are: make your own language and interpreter that does exactly what you want and nothing more (so all the dependencies can be compiled in), or decide which criteria you are willing to compromise on.

      • mbirth@lemmy.ml
        link
        fedilink
        arrow-up
        2
        ·
        23 days ago

        Sounds like you want MicroPython. It’s definitely available on OpenWrt and AlpineLinux and has a very small footprint.

        If you don’t like Python, have a look at Lua/luajit.

      • Shareni@programming.dev
        link
        fedilink
        arrow-up
        0
        arrow-down
        1
        ·
        23 days ago

        if there’s something that I can adopt as a default goto solution without having to worry about how each system is packaged/configured.

        Go is probably your best bet. Simple to use, and you can compile it so it runs everywhere

        • maniii@lemmy.world
          link
          fedilink
          English
          arrow-up
          1
          ·
          22 days ago

          I found installing Go-sdk a total PiTA. It is okay as a developer environment. But bash + gnu utils + core utils seem much more sane to me.

          Of course I mostly work with Linux systems and hardly ever have to deal with Scripting for Windoze.

  • mub@lemmy.ml
    link
    fedilink
    arrow-up
    5
    ·
    22 days ago

    I honestly love Powershell, but haven’t tried the Linux version yet. I only use Bash on linux but it has a load of odd quirks that make it unpleasant to use imo. Can’t comment on anything else.

    • tankplanker@lemmy.world
      link
      fedilink
      arrow-up
      1
      ·
      21 days ago

      I use powershell for work as I need the m365 modules for work and its very flexible with decent module availability to plug in all sorts.

      However it absolutely sucks for large data handling, anything over 10k rows is just horrendous, I typically work with a few million rows. You can make it work with using .Net to process it within your script but its something to be aware of. Being able to extend with .Net can be extremely useful.

  • cerement@slrpnk.net
    link
    fedilink
    arrow-up
    5
    ·
    23 days ago

    another vote for Lua – lua5.4 is available for all 8 Alpine architectures, tiny installed size (120–200 kB) (and Alpine package only installs two files)

  • undrivendev@lemmy.world
    link
    fedilink
    arrow-up
    4
    ·
    21 days ago

    Python.

    Just remember to use pyenv for interpreter installation, version and environment management. It’s pretty straightforward that way and you have predictability.

    Don’t ever manually fiddle with the system python and/or libraries or you’ll break your system. You should just rely on the package manager for that.

  • mryessir@lemmy.sdf.org
    link
    fedilink
    arrow-up
    4
    ·
    22 days ago

    (Chicken) Scheme.

    Schemes have one of the best and most interactive interpreters Is general purpose, allows functional, procedural and OO programming, small disk size and compilable to native executables, Throughout documented and supplemented by years of research, simple setup.

    It also is CGI compatible, if necessary.

    • endofline@lemmy.ca
      link
      fedilink
      English
      arrow-up
      1
      ·
      22 days ago

      Bash? On windows it’s pretty much unusable even if you use cygwin. Python or Lua are the only reasonable suggestions here

    • flying_sheep@lemmy.ml
      link
      fedilink
      arrow-up
      1
      ·
      22 days ago

      Nah, gross. You need to set a bunch of global options to get sane behavior on errors.

      Nushell is shaping up really really nicely, and it’ll actually stop executing if something fails! Even if that happens in a pipe! And it’s not super eager to convert between arrays and strings if you use the wrong cryptic rune.

  • moonpiedumplings@programming.dev
    link
    fedilink
    arrow-up
    2
    ·
    edit-2
    22 days ago

    Not quite a scripting language, but I highly recommend you check out cosmo for your usecase. Cosmopolitan, and/or Actually Portable Executable (APE for short) is a project to compile a single binary in such a way that is is extremely portable, and that single binary can be copied across multiple operating systems and it will still just run. It supports, windows, linux, mac, and a few BSD’s.

    https://cosmo.zip/pub/cosmos/bin/ — this is where you can download precompiled binaries of certain things using cosmo.

    From my testing, the APE version of python works great, and is only 34 megabytes, + 12 kilobytes for the ape elf interpreter.

    In addition to python, cosmopolitan also has precompiled binaries of:

    • Janet 2.5 MB
    • Berry 4.0 MB
    • Python 34 MB
    • Php 11 MB
    • Lua 2.1 MB
    • Bash 5.1 MB

    And a few more, like tclsh, zsh, dash or emacs (53 MB), which I’m pretty sure can be used as an emacs lisp intepreter.

    And it should be noted these may require the ape elf interpeter, which is 12 kilobytes, or the ape assimilate program, which is 476 kilobytes.

    EDIT: It also looks like there is an APE version of perl, and the full executable is 24 MB.

    EDIT again: I found even more APE/cosmo binaries:

  • Possibly linux@lemmy.zip
    link
    fedilink
    English
    arrow-up
    2
    ·
    23 days ago

    Python is what you want. You can install it on just about any system.

    Other than that maybe Lua but that will be hell.

    • digdilem@lemmy.ml
      link
      fedilink
      English
      arrow-up
      1
      ·
      23 days ago

      Python is what you want. You can install it on just about any system.

      Perl and bash are already there, no need to install anything.

        • digdilem@lemmy.ml
          link
          fedilink
          English
          arrow-up
          2
          ·
          23 days ago

          Try it now - go on. Type “perl” and tell me what you get.

          And if you’re so certain it’s not used, try removing it and see how well your computer works afterwards.

        • neomachino@lemmy.world
          link
          fedilink
          arrow-up
          0
          ·
          23 days ago

          Is this the case? I don’t feel like I’ve ever had to install Perl but I’ve had to install Python plenty of times and I use both pretty frequently on a daily basis. Not to mention a newer version, older version, 2.7.4 instead of 2.7.3.

  • digdilem@lemmy.ml
    link
    fedilink
    English
    arrow-up
    3
    arrow-down
    1
    ·
    23 days ago

    Perl is already installed on most linux machines and unless you start delving into module usage, you won’t need to install anything else.

    Python is more fashionable, but needs installing on the host and environments can get complicated. I don’t think it scales as well as Perl, if that’s a concern of yours.

  • matcha_addict@lemy.lol
    link
    fedilink
    English
    arrow-up
    2
    ·
    23 days ago

    I’ve looked into this a lot actually. There see many options. I’ll highlight the pros and cons of each option.

    Lua: extremely lightweight, but standard library is lacking, and doesn’t include stuff like map or fold. But that would be easy to fix.

    Python: thicc standard library, but is not lightweight by any means. There are modifications made to be more shell like, such as xonsh

    Rash: based on scheme, very much functional but if you’re not used to lisp style, might take a bit to get used to it. This is actually my favorite option. It has a cli interpreter, and really pleasant to use. Cons is… Well it’s not very common

    You can honestly use any language. Even most compiled languages have a way to run immediately.

  • bruce965@lemmy.ml
    link
    fedilink
    arrow-up
    1
    ·
    edit-2
    24 days ago

    JavaScript through Node.js, or TypeScript through Deno if you like typed languages. They both check all your boxes (just check the size of the executables to make sure that it’s what you would consider “small footprint”).

    Both languages and runtimes are quite popular, so you will find any answers on StackOverflow.

    They are both single-executable with little dependencies, and Deno can also compile your scripts to self-contained executables.

    As a bonus, both support the vast and extensive NPM package repository where you can find all sort of libraries for even the most complex tasks.

    And they work with your favourite IDE or editor, not just syntax highlighting, but also contextual suggestions.

    • chunkystyles@sopuli.xyz
      link
      fedilink
      English
      arrow-up
      1
      ·
      22 days ago

      As a Java developer, and someone who never learned Python or other scripting languages, Node is my go-to scripting language. I’ve only come around to it for that in the past year or two. But it’s great.

    • gomp@lemmy.mlOP
      link
      fedilink
      arrow-up
      0
      ·
      23 days ago

      Installing node uses some 60MB (according to zypper on my current desktop). I’d rather have something small and possibly that consists of a single executable.

      As a bonus, both support the vast and extensive NPM package repository

      That’s not necessarily a feature :) Package repos are great if you are a developer (I am one) working primarily with that language, but are frustrating if you just want to run things.

      • bruce965@lemmy.ml
        link
        fedilink
        arrow-up
        1
        ·
        edit-2
        22 days ago

        I thought so. Although almost nothing for modern standards, 60MB is not exactly tiny. Sorry about that.

        On a different note, a repository is always a good thing imho. If you’d rather not have to worry about the dependency-pull step you can always include the dependencies with your sources, or just limit your code to using features included in the standard library.

  • tiredofsametab@fedia.io
    link
    fedilink
    arrow-up
    1
    ·
    23 days ago

    Perl or python for things likely to already be there. Maybe ruby or PHP if you must. I used to work in groovy a lot but I think it requires the JVM

    • atzanteol@sh.itjust.works
      link
      fedilink
      English
      arrow-up
      0
      arrow-down
      1
      ·
      23 days ago

      Perl requres the perl interpreter and python requires a python interpreter. Why is it bad that groovy also needs a vm?

      • digdilem@lemmy.ml
        link
        fedilink
        English
        arrow-up
        0
        ·
        23 days ago

        Perl’s core to most distros and will be there already. Python isn’t and can be quite heavy - plus some of are are still smarting over the major version change breaking everything and the need for complicated environments.

          • digdilem@lemmy.ml
            link
            fedilink
            English
            arrow-up
            0
            ·
            23 days ago

            I work at scale - deploying scripts to hundreds of linux machines and any package you install will be multiplied that many times on the backend storage. You don’t get the luxury of installing anything that isn’t essential.

            • atzanteol@sh.itjust.works
              link
              fedilink
              English
              arrow-up
              0
              arrow-down
              1
              ·
              23 days ago

              Ohhh, you work at scale do you? With… “hundreds” of Linux servers? And 50MB, which is basically a rounding error for most storage solutions, will break your bank? Sure Jan.

      • nyan@sh.itjust.works
        link
        fedilink
        arrow-up
        0
        ·
        23 days ago

        Last I checked, the JVM was larger than the standard Perl and Python interpreters, and had a much worse startup time (which is bad for short scripts).

          • nyan@sh.itjust.works
            link
            fedilink
            arrow-up
            1
            ·
            22 days ago

            Dude, I’ve worked with all these interpreters. The JVM’s startup is slow, although there’s been some improvement since the version 1.1 that I started out with. The interpreter speed is quite good once it gets going, so it remains a good choice for long-running or interactive programs where the startup is insignificant as a fraction of total program run-time, but if you’re running a script that takes only a fraction of a second to execute, the JVM’s startup can lengthen the time by an order of magnitude or more. Horses for courses and all that—I wouldn’t write a complex interactive GUI program in Perl, either.