summaryrefslogtreecommitdiff
path: root/INSTALL
blob: 005a1aab804f48b8761b0b2aefd572da9eea9b46 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
= INSTALL for Fluxbox

== TL;DR Instructions

    $ ./configure
    $ make

and then as root

    $ make install

== Compilation and Installation

   The `configure' shell script attempts to guess correct values for
various system-dependent variables used during compilation.  It uses
those values to create a `Makefile' in each directory in the
Fluxbox source tree.

Finally, it creates a shell script `config.status' that you can run
in the future to recreate the current configuration, a file
`config.cache' that saves the results of its tests to speed up
reconfiguring, and a file `config.log' containing compiler output
(useful mainly for debugging `configure').

   If you need to do unusual things to compile Fluxbox, please try
to figure out how `configure' could check whether to do them, and mail
diffs or instructions to fluxbox-developers list (see www.fluxbox.org) 
so they can be considered for the next release.  If at some point 
`config.cache' contains results you don't want to keep, you may remove 
or edit it.

   The file `configure.in' is used to create `configure' by a program
called `autoconf'.  You only need `configure.in' if you want to change
it or regenerate `configure' using a newer version of `autoconf'.

The simplest way to compile this package is:

  1. `cd' to the directory containing the package's source code and type
     `./configure' to configure the package for your system.  If you're
     using `csh' on an old version of System V, you might need to type
     `sh ./configure' instead to prevent `csh' from trying to execute
     `configure' itself.

     Running `configure' takes awhile.  While running, it prints some
     messages telling which features it is checking for.

  2. Type `make' to compile the package.

  3. Type `make install' to install the programs and any data files and
     documentation.

  4. You can remove the program binaries and object files from the
     source code directory by typing `make clean'.  To also remove the
     files that `configure' created (so you can compile the package for
     a different kind of computer), type `make distclean'. 


== Compilers and Options

   Some systems require unusual options for compilation or linking that
the `configure' script does not know about.  You can give `configure'
initial values for variables by setting them in the environment.  Using
a Bourne-compatible shell, you can do that on the command line like
this:
     CC=c89 CFLAGS=-O2 LIBS=-lposix ./configure

Or on systems that have the `env' program, you can do it like this:
     env CPPFLAGS=-I/usr/local/include LDFLAGS=-s ./configure

=== Cross-Compiler for Microsoft Windows:

You'll want mingw-cross-env installed, with libX11 and mingw-catgets built.
A configure line that works is:

    $ ./configure \
        --prefix=/ \
        --host=i686-pc-mingw32 \
        --disable-imlib2 \
        --disable-xmb \
        --disable-slit \
        --disable-remember \
        --disable-toolbar \
        --disable-fribidi \
        --disable-nls \
        --disable-xft \
        LIBS="-lxcb -lXdmcp -lXau -lpthread -lws2_32"

Then, build and install with

    $ make install DESTDIR=$(pwd)/stage

You can then copy the whole "stage" directory to a Windows machine and
run it on your choice of X server.



== Optional Features

Fluxbox supports the XShape extension of X11R6.  This support is enabled by
default, but may be overridden by specifying `--disable-shape' on the configure
script's command line.

Fluxbox supports Window Maker dockapps (warning: restarts from wmaker to
fluxbox don't always handle dockapps correctly) with a gadget called the Slit.
The Slit is compiled into Fluxbox by default, but may be overridden by
specifying `--disable-slit' on the configure script's command line.

Fluxbox supports a rendering effect called "faked interlacing" which darkens
every other line in rendered images.  This support works only for gradient
images.  It is compiled in by default, but may be overridden by specifying
`--disable-interlace' on the configure script's command line. 

Fluxbox uses a timer which allows it to periodically flush its pixmap
cache. It is enabled by default, but may be overridden by specifying
'--disable-timed-cache' on the configure script's command line.

Also, `configure' can usually find the X include and library files
automatically, but if it doesn't, you can use the `configure'
options `--x-includes=DIR' and `--x-libraries=DIR' to specify
their locations.