-
Notifications
You must be signed in to change notification settings - Fork 2
Home
Casey's just
utility is such a useful tool; but, it has one thing that bothered me - the inability to inherently include recipes from other files. For those of us who work on many projects in parallel the ability to share recipes (effective code reuse / modularization) is an important feature. Its advantages are:
- provides for smaller more easily maintained files
- more cohesive file content
- shared recipes between projects
Allowing this flexibility also opens up some use cases which are not currently supported by the just
utility. That is why I created the justprep
program.
... is a ore-processor to the just
command/task runner. It provides the ability to include other just
file content into your main just
file using a set of keywords that you define. It also adds a short-hand way of specifying modules that are accessible from your main just
file.
justprep
is configured using System Environment Variables
- JUSTPREP_KEYWORDS specifies the inclusionary keywords that you want to use.
- JUSTPREP_MODULE_KEYWORD also allows you to specify the keyword that defines a module
-
JUSTPREP_FILENAME_IN defines the basename of files to look for that contain
justprep
keywords. -
JUSTPREP_FILENAME_OUT defines the basename of the file that
justprep
creates from its input files. Typically this value is "justfile" which is the default of thejust
program.
I use the bash
shell where I have jj
defined as a command executes justprep
and then just
like this:
alias jj='/usr/local/bin/justprep && just --no-dotenv'
I use the program direnv
which defines environment variables via a .envrc
file whenever I cd
into a directory. That is why I use the "--no-dotenv" option for the just
program.
... and yes. I use the Crystal implementation of justprep
rather than the Ruby gem implementation even though they are both the same. See Ruby And Crystal for details on why there are two implementations.
I have a common just
file that I include into all of my project specific just
files. I keep it in my $HOME
directory. .justfile
is the filename. It provides a common list/help pattern that I like to use.
In my project just
files I do this as the first "executable" line:
include ~/.justfile
My ~/.justfile looks something like this ...
# ~/.justfile # brew install just # gem install justprep OR brew install justprep for the Crystal version # alias jj='justprep && just' # # See: https://cheatography.com/linux-china/cheat-sheets/justfile/ # set positional-arguments := true set allow-duplicate-recipes := true set dotenv-load := false pwd := env_var('PWD') me := justfile() home := env_var('HOME') backup_dir := env_var('JUST_BACKUP_DIR') backup_file := trim_start_match(me, home) my_backup := backup_dir + backup_file # List available recipes @list: echo echo "Available Recipes at" echo "$PWD" echo "are:" echo just -l --list-prefix 'jj ' --list-heading '' echo # Show help/usage for "just" command help: list echo echo just --help # Backup all changed just files to $JUST_BACKUP_DIR @backup_all_just_files: backup_just.rb ################################################# ## Private recipies # Show private recipies @_show_private: # Show private recipies grep "^[@]_" {{justfile()}} # Show the differents between this justfile and is last backup @_just_diff_my_backup: @diff {{me}} {{my_backup}} @_just_restore_me_from_backup: echo echo "Do this because I will not ..." echo echo "cp -f {{my_backup}} {{me}}" echo # Edit the $JUSTPREP_FILENAME_IN file @_just_edit_me: $EDITOR {{me}}
You may have noticed the backup/restore recipes. I do not always keep my just
files in the repository. Sometimes I treat them like my engineering note files. BUT I always want to have backups of the just
files and the notes files available just in case I mess stuff up. Of course it would be much easier to just commit them to the git
repo but sometimes its nice to have a competitive advantage that is not shared with the rabble.