1
0
mirror of git://git.suckless.org/sbase synced 2025-01-20 14:20:42 +00:00
sbase/README
FRIGN 44bd931834 Add audit-section to README
Okay, so why another section?
The finished-section applies to general feature-completeness and
manual status. It somehow is not an indicator for general code-
clarity, so the audited-column reflects a thorough audit of the
underlying code and optimization.
Take a look at the upcoming basename(1)-patch for an example on
how this goes.
2015-02-28 14:42:26 +01:00

122 lines
5.6 KiB
Plaintext

sbase - suckless unix tools
===========================
sbase is a collection of unix tools that are inherently portable
across UNIX and UNIX-like systems.
The following tools are implemented ('*' == finished, '#' == UTF-8 support,
'=' == implicit UTF-8 support, '|' == audited):
UTILITY POSIX 2008 COMPLIANT MISSING OPTIONS
------- -------------------- ---------------
=* basename yes none
=* cal yes none
=* cat yes none
=* chgrp yes none
=* chmod yes none
=* chown yes none
=* chroot non-posix none
=* cksum yes none
=* cmp yes none
#* cols non-posix none
=* comm yes none
= cp yes none (-i)
=* cron non-posix none
#* cut yes none
=* date yes -u
=* dirname yes none
=* du yes none
=* echo yes none
=* env yes none
#* expand yes none
#* expr yes none
=* false yes none
= find yes none
#* fold yes none
=* grep yes none
=* head yes none
=* hostname non-posix none
=* kill yes none
=* link yes none
=* ln yes none
=* logger yes none
=* logname yes none
= ls no (-C), -S, -f, -m, -s, -x
=* md5sum non-posix none
=* mkdir yes none
=* mkfifo yes none
=* mktemp non-posix none
=* mv yes none (-i)
=* nice yes none
= nl no -d, -f, -h, -l, -p
=* nohup yes none
#* paste yes none
=* printenv non-posix none
#* printf yes none
=* pwd yes none
= readlink non-posix none
=* renice yes none
=* rm yes none (-i)
=* rmdir yes none
# sed
seq non-posix none
=* setsid non-posix none
= sha1sum non-posix none
= sha256sum non-posix none
= sha512sum non-posix none
=* sleep yes none
sort no -m, -o, -d, -f, -i
=* split yes none
=* sponge non-posix none
#* strings yes none
=* sync non-posix none
=* tail yes none
=* tar non-posix none
=* tee yes none
=* test yes none
= time no none (incorrect exit status)
=* touch yes none
#* tr yes none
=* true yes none
=* tty yes none
=* uname yes none
#* unexpand yes none
=* uniq yes none
=* unlink yes none
=* uudecode yes none
=* uuencode yes none
#* wc yes none
= xargs no -I, -L, -p, -s, -t, -x
=* yes non-posix none
The complement of sbase is ubase[1] which is Linux-specific and
provides all the non-portable tools. Together they are intended to
form a base system similar to busybox but much smaller and suckless.
Building
--------
To build sbase, simply type make. You may have to fiddle with
config.mk depending on your system.
You can also build sbase-box, which generates a single binary
containing all the required tools. You can then symlink the
individual tools to sbase-box.
Ideally you will want to statically link sbase. If you are on Linux
we recommend using musl-libc[2].
Portability
-----------
sbase has been compiled on a variety of different operating systems,
including Linux, *BSD, OSX, Haiku, Solaris, SCO OpenServer and others.
Various combinations of operating systems and architectures have also
been built.
You can build sbase with gcc, clang, tcc, nwcc and pcc.
[1] http://git.suckless.org/ubase/
[2] http://www.musl-libc.org/