Installation is simple, but as it is described in the Quickstart, you don’t need it to use
- Go to the
resourcesfolder. There is a
- Run some checks:
make check. You should get no errors.
- According to whether you have your
$HOME/.local/binfolder in the
- If so, run
make install PREFIX=$HOME/.local,
- else, run
sudo make install PREFIX=/usr.
- If so, run
Argbash has this audience:
- Users — people that use scripts that make use of
- Developers — people that use
Argbashto write scripts.
- Tinkerers — people that come in contact with
Argbashinternals, typically curious Developers.
bash >= 3.0— this is obvious, everybody needs
bash. There is only one exception — in cases of simple scripts, a
dashwill be enough for Users.
autoconf >= 2.63—
Argbashis written in a
m4language extension called
m4sugar, which is contained in
autoconf. Developers and Tinkerers need this.
autoconfis available on Linux, OSX, BSDs and can be installed on MS Windows.
test. If you have
autoconf, you probably have those already.
GNU Make >= 4.0— the project uses Makefiles to perform a wide variety of tasks, although it is more of interest to Tinkerers.
Argbash package consists of these scripts:
argbash, the main part of
Argbash. It is basically a wrapper around the
autom4teutility that uses the
Argbash“source code” located in the
srcdirectory. In course of an installation, both the script and the source are copied under the prefix — script goes to
$PREFIX/binand source to
argbashscript itself is generated using
Argbash. It can be (re)generated using a Makefile that can be found in the
yare major version numbers) that assist users in modifying their scripts in case that
Argbashchanges its API. For example,
Argbash 2.1.4(we say
Argbashof major version 2) has
Argbashof major version 3 will have scripts
The main Makefile¶
Makefile in the
resources folder can do many things:
make install [PREFIX=foo]runs the installation into the prefix you can specify (default is
$(HOME)/.local). This will install the
argbashscript (notice the missing
$PREFIX/bin(and some support files into
make develop [PREFIX=foo]is similar to
make install, but it installs a wrapper around the local
bin/argbash, so any change to the file will be immediatelly reflected for everybody who uses the system-wide one. This is inspired by Python’s
python setup.py developpattern.
make uninstall [PREFIX=foo]inverse of the above.
make bootstrapmakes (or updates) the
argbashscript (the script basically overwrites itself). Use the latter if previous update broke the current
../bin/argbashso it is not able to regenerate itself.
make examplescompiles examples from
.shfiles in the
make foo/bar.shgenerates a script provided that there is a
make foo/bar2.shgenerates a script provided that there is a
make checkruns the tests.
make version VERSION=1.0.0sets the projct’s version to all corners of the project where it should go.
make release [VERSION=1.0.0]refreshes date in the
ChangeLogand regenerates all of the stuff (and runs tests).
make tagtags the version.