this post was submitted on 14 Jun 2024
43 points (100.0% liked)

Programming

17313 readers
258 users here now

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you're posting long videos try to add in some form of tldr for those who don't want to watch videos

Wormhole

Follow the wormhole through a path of communities [email protected]



founded 2 years ago
MODERATORS
 

A note from earlier today says the HTML edition will be available soon. I assume that means it will show up here: https://pubs.opengroup.org/onlinepubs/9699919799/

you are viewing a single comment's thread
view the rest of the comments
[–] joelthelion 1 points 5 months ago (1 children)

Is posix still relevant in any way?

[–] [email protected] 14 points 5 months ago (1 children)
[–] [email protected] 2 points 5 months ago (1 children)
[–] [email protected] 5 points 5 months ago (1 children)

Because it's the foundation of a lot of cross-platform code, from the standard libraries in various programming languages to innumerable shell scripts.

Unless all the computing devices you use run Windows, you probably depend on POSIX, whether you have direct contact with it or not.

[–] [email protected] -4 points 5 months ago* (last edited 5 months ago) (3 children)

Shell scripts were a mistake. The weirdness you have to remember to safely stop executing when something fails is mind-boggling.

I'm so glad nushell exists and doesn't need any configuring to just do the reasonable thing and stop executing when something fails.

[–] bhamlin 3 points 5 months ago* (last edited 5 months ago) (1 children)

Shell scripts were a mistake.

I understand 1000% but I'm not sure I agree. With the peevishness of C and latent autism of assembly, something compiled or otherwise binary isn't always simple and straightforward. Sometimes, you have a task that only needs to be done three times, and just replaying the commands is sufficient.

sh, ash, and bash are all kinda dumb. Absolutely. But there are other shells that are significantly better. csh and zsh are both great. ksh has some history on it but is good too. But "shell scripts" don't have to be in your shell language. The hashbang line will let you make a command file and so long as you can describe the command line you can get most shells to run it. Be that language ~~line noise~~ perl or python or even go.

[–] [email protected] 2 points 5 months ago* (last edited 5 months ago)

As a long time former ZSH user, I'll definitely include ZSH in shell languages to avoid for scripting.

The problem is simply the number of rules and incantations to slavishly include everywhere to make your script bail on error. set -e is not enough by far.

Python with plumbum or nushell are definitely better.

[–] [email protected] 1 points 5 months ago* (last edited 5 months ago) (1 children)

Shell scripts were a mistake. The weirdness you have to remember to safely stop executing when something fails is mind-boggling.

nushell scripts aren't shellscripts?

[–] [email protected] 1 points 5 months ago

I usually write “POSIXy shell” but I thought that was clear from context this time.

The problem is that exit statuses !=0 aren't treated as error by default (with a way to turn that off for individual expressions). Instead you have to set multiple settings and avoid certain constructs in bash/ZSH/...

Everything that works like a modern programming language by default is fine of course

[–] [email protected] 1 points 5 months ago (1 children)

All you need to do is set -e at the start of the script to stop on a non-0 exit code. And quote variables to prevent globbing.

[–] [email protected] 1 points 5 months ago (2 children)

Oh you sweet summer child.

If you don't use pipes or command substitutions, set -e gets you a fair part of the way there.

If you're interested, I can look up the rest of the arcane incantations necessary.

[–] [email protected] 1 points 5 months ago (1 children)

Here's a neat tidbit. Using curl without -f --fail will make non-2xx status codes return success, so set -e won't help there.

[–] [email protected] 1 points 5 months ago

Yeah, and that's just one of many many things to consider.