From 73a05796bc9c3448aa40f6323cde881a0fc686b1 Mon Sep 17 00:00:00 2001 From: simon Date: Thu, 8 Apr 2004 14:40:14 +0000 Subject: [PATCH] Add installation instructions. git-svn-id: svn://svn.tartarus.org/sgt/halibut@4043 cda61777-01e9-0310-a592-d414129be87e --- INSTALL | 61 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Makefile | 10 +++++++++- 2 files changed, 70 insertions(+), 1 deletion(-) create mode 100644 INSTALL diff --git a/INSTALL b/INSTALL new file mode 100644 index 0000000..cb0259e --- /dev/null +++ b/INSTALL @@ -0,0 +1,61 @@ +Installation guide for Halibut +============================== + +This file is a guide to building and installing the documentation +utility `Halibut' from its source archive. + +If you are reading this, then you have probably already unpacked the +source archive somewhere. + +Building Halibut +---------------- + +If you have GNU make and gcc, you should simply be able to type +`make'. The Makefile will generate a `build' subdirectory, and will +put all the object files and binaries in there. + +Halibut unfortunately does not yet come with an autoconf-generated +makefile, so if you do not have these utilities then you will have +to do the build manually. Look in the master `Makefile' to find the +list of source modules (they will be listed on the line starting +`MODULES :=', and continued on lines starting `MODULES +='), compile +those files with the C compiler of your choice, and link them +together into a binary. In addition to the modules on that list, you +will also need to compile `version.c', and if you wish your Halibut +binary to identify itself with a version number then you will have +to define the preprocessor symbol `VERSION' to the required version +number string. On Unix this can be done with a command such as + + cc -c -DVERSION=\"0.9\" version.c + +Halibut's source files are intended to be almost entirely portable +ANSI C. If they fail to compile and run correctly on your compiler, +this might very well be considered a bug. + +Building the Halibut manual +--------------------------- + +Once you have built Halibut itself, you might well want to build its +manual. If you're using GNU make, you can do this just by changing +into the `doc' subdirectory and typing `make'. (This relies on the +Halibut binary you built in the previous step being present in the +`build' subdirectory.) + +Failing that, you will need to read the Makefile and run a manual +Halibut command, of the form + + halibut --text=halibut.txt --html blurb.but intro.but [...] index.but + +(The precise list of .but files is given at the top of doc/Makefile.) + +This will build plain text documentation in `halibut.txt', and a set +of HTML files (*.html). It will also build a short man page +`halibut.1', although this is by no means a replacement for the full +manual. + +Installing Halibut +------------------ + +Halibut requires no additional data files. Simply install the +binary, man page and full documentation in appropriate places for +your system. diff --git a/Makefile b/Makefile index bfd14a5..ae1a5c9 100644 --- a/Makefile +++ b/Makefile @@ -1,6 +1,14 @@ # Halibut master makefile -# Requires a compiler with -MD support, currently +# Currently depends on gcc, because: +# - the dependency tracking uses -MD in order to avoid needing an +# explicit `make depend' step +# - the definition of CFLAGS includes the gcc-specific flag +# `-Wall' +# +# Currently depends on GNU make, because: +# - the Makefile uses GNU ifdef / ifndef commands and GNU make `%' +# pattern rules # `make' from top level will build in directory `build' # `make BUILDDIR=foo' from top level will build in directory foo -- 2.11.0