Hacker News new | ask | show | jobs
by goku12 657 days ago
I'm using both Make and Just in a single project. A cursory look might give the impression that Just is just another replacement for Make, offering no additional benefits. But I started the project with just Make (since it's already in the system) and then moved some tasks to Just. Meanwhile, I still find the Makefile useful. Both of them 'feel' as if they're designed to do jobs of different nature. Make is designed to efficiently express file dependency hierarchies and take action to keep everything up to date. Just is designed to do a bunch of dependent tasks (nothing about file dependencies) and has features more suited to that. This is a difference that cannot be easily explained, unless you've tried and experienced it. Sure, you can argue that Make does everything that Just does. But it feels like you need more boilerplate in Make for such tasks (like phony).

Here are some of the differences I can recollect. Remember, you won't appreciate it until you try it.

- All tasks in just are phony. No file timestamp checks

- Just recipes can be in any scripting language within the same file. For example, you can write one recipe in bash, another in python and a third in perl, etc.

- Each line in a recipe in Make is executed in a different shell. You can't share variables between lines without using shell tricks. The same is the default for just as well. However, Just also allows you to write an entire recipe as a single script using shebang.

- Shell execution during variable assignment is done using backticks in just (just like bash). Make uses special function 'shell' for this.

- Recipe targets in Just can have parameters like bash functions do.

- Help strings for targets is easy in Just. You just place the string above the recipe. It's shown when you list the targets. Something similar can be done with Make, but using an additional hacky script.

- Just has a CLI to view and select targets. An emacs package also exists for the same.

- Some recipes can be private and wont show up in the listing.

- Just gives you the option to execute a recipe in the same directory as the Justfile, or in the current directory. It's a bit more complicated to do that in Makefile without the shell tricks.