LibU needs MaKL to configure and build.
The following commands should be sufficient to get MaKL installed on any Linux flavour or Darwin/MacOSX:
$ wget http://koanlogic.com/download/makl/makl-1.8.1.tar.gz $ tar zxf makl-1.8.1.tar.gz && cd makl-1.8.1 $ sh configure.sh $ su Password: **** # make install
Should your platform be one of Solaris, OpenSolaris, FreeBSD, PC-BSD, OpenBSD, NetBSD, DragonflyBSD or Windows (MinGW or Gygwin) take a look at the INSTALL
file in the top-level MaKL sources directory to track down specific variations on the theme.
Once MaKL is there, you can start downloading the package (always check the official LibU page for the latest version and related ChangeLog) and tailor it to your specific needs:
$ wget http://koanlogic.com/download/libu/libu-2.0.0.tar.gz $ tar zxf libu-2.0.0.tar.gz && cd libu-2.0.0
E.g. should you need to change the default installation path (which is /usr/local
), use:
$ makl-conf --prefix="/my/install/base/dir"
Debug symbols and warnings from the compiler can be switched on via --enable_debug
and --enable_warns
(use --enable_icc_warns
instead when working with the Intel C compiler):
$ makl-conf --enable_debug --enable_warns
Code profiling using gprof(1) can be activated via --enable_profile
, and in general any compiler flag can be passed to the build stage in the following way:
$ makl-conf --extra-cflags="-Wformat -Wno-format-extra-args -Wformat-security -Wformat-nonliteral -Wformat=2"
The --extra-xxx="val"
is indeed a powerful mechanism by which any Makefile variable XXX
(uppercase!) can be given an additional value val:
(ab)use it to tweak LDFLAGS
, SHLIB_LDFLAGS
, etc. as needed. Anyway if in doubt, or in search for exotic features, type "makl-conf -h"
to display the complete list of options: it's likely that what you are trying to achieve is already there.
By default LibU is compiled as static library, to also enable shared library build, supply the --enable_shared
flag.
The default is to build all the modules, but you can disable the inclusion of specific bits selectively using the following switches:
--no_hmap
: to disable the HMap module--no_config
: to disable the Configuration module--no_net
: to disable the Networking module--no_env
: to disable the Environment module--no_fs
: to disable the File system module--no_pwd
: to disable the Password module--no_list
: to disable the Lists module--no_array
: to disable the Dynamic Arrays module--no_ringbuffer
: to disable the Ring Buffer module--no_pqueue
: to disable the Priority Queues module--no_json
: to disable the JSON module--no_bst
: to disable the Binary Search Tree moduleAlso, some specific features regarding the networking code can be disabled at configuration:
--no_ipv6
: to disable IPv6 protocol support--no_sctp
: to disable SCTP protocol support--no_unixsock
: to disable UNIX IPC supportIf you need to enable compatibility with (some, not all) 1.X interfaces, specify the --compat_1x
command line switch.
When you are done with the configure step, you can build LibU bits and optionally test them:
$ makl $ makl -C test
And finally install it:
$ su Password: **** # makl install
You now are ready to play with your first LibU program:
$ cat main.c #include <u/libu.h> int facility = LOG_LOCAL0; int main (void) { u_con("Hello LibU world !"); return 0; }
Write a Makefile like the following:
$ cat Makefile include common.mk PROG = hellolibu SRCS = main.c LDADD += /path/to/install/prefix/lib/libu.a CFLAGS += -I/path/to/install/prefix/include include prog.mk
Then type:
$ makl && ./hellolibu
and enjoy !