Home | History | Annotate | Line # | Download | only in dist
configure.local.example revision 1.1.1.1.2.1
      1  1.1.1.1.2.1  pgoyette # Id: configure.local.example,v 1.13 2016/07/14 11:09:06 schwarze Exp 
      2          1.1  christos #
      3  1.1.1.1.2.1  pgoyette # Copyright (c) 2014, 2015, 2016 Ingo Schwarze <schwarze (a] openbsd.org>
      4          1.1  christos #
      5          1.1  christos # Permission to use, copy, modify, and distribute this software for any
      6          1.1  christos # purpose with or without fee is hereby granted, provided that the above
      7          1.1  christos # copyright notice and this permission notice appear in all copies.
      8          1.1  christos #
      9          1.1  christos # THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
     10          1.1  christos # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
     11          1.1  christos # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
     12          1.1  christos # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
     13          1.1  christos # WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
     14          1.1  christos # ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
     15          1.1  christos # OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
     16          1.1  christos 
     17          1.1  christos # For all settings documented in this file, there are reasonable
     18          1.1  christos # defaults and/or the ./configure script attempts autodetection.
     19          1.1  christos # Consequently, you only need to create a file ./configure.local
     20          1.1  christos # and put any of these settings into it if ./configure autodetection
     21          1.1  christos # fails or if you want to make different choices for other reasons.
     22          1.1  christos 
     23          1.1  christos # If autodetection fails, please tell <tech (a] mdocml.bsd.lv>.
     24          1.1  christos 
     25          1.1  christos # We recommend that you write ./configure.local from scratch and
     26          1.1  christos # only put the lines there you need.  This file contains examples.
     27          1.1  christos # It is not intended as a template to be copied as a whole.
     28          1.1  christos 
     29          1.1  christos # --- user settings relevant for all builds ----------------------------
     30          1.1  christos 
     31          1.1  christos # For -Tutf8 and -Tlocale operation, mandoc(1) requires <locale.h>
     32          1.1  christos # providing setlocale(3) and <wchar.h> providing wcwidth(3) and
     33          1.1  christos # putwchar(3) with a wchar_t storing UCS-4 values.  Theoretically,
     34          1.1  christos # the latter should be tested with the __STDC_ISO_10646__ feature
     35          1.1  christos # macro.  In practice, many <wchar.h> headers do not provide that
     36          1.1  christos # macro even though they treat wchar_t as UCS-4.  So the automatic
     37          1.1  christos # test only checks that wchar_t is wide enough, that is, at least
     38          1.1  christos # four bytes.
     39          1.1  christos 
     40          1.1  christos # The following line forces multi-byte support.
     41          1.1  christos # If your C library does not treat wchar_t as UCS-4, the UTF-8 output
     42          1.1  christos # mode will print garbage.
     43          1.1  christos 
     44          1.1  christos HAVE_WCHAR=1
     45          1.1  christos 
     46          1.1  christos # The following line disables multi-byte support.
     47          1.1  christos # The output modes -Tutf8 and -Tlocale will be the same as -Tascii.
     48          1.1  christos 
     49          1.1  christos HAVE_WCHAR=0
     50          1.1  christos 
     51  1.1.1.1.2.1  pgoyette # When man(1) or apropos(1) is called without -m and -M options,
     52  1.1.1.1.2.1  pgoyette # MANPATH is not set in the environment, man.conf(5) is not available
     53  1.1.1.1.2.1  pgoyette # and manpath(1) not used, manuals are searched for in the following
     54  1.1.1.1.2.1  pgoyette # directory trees by default.
     55  1.1.1.1.2.1  pgoyette 
     56  1.1.1.1.2.1  pgoyette MANPATH_DEFAULT="/usr/share/man:/usr/X11R6/man:/usr/local/man"
     57  1.1.1.1.2.1  pgoyette 
     58          1.1  christos # In manual pages written in the mdoc(7) language, the operating system
     59          1.1  christos # version is displayed in the page footer line.  If an operating system
     60          1.1  christos # is specified as an argument to the .Os macro, that is always used.
     61          1.1  christos # If the .Os macro has no argument and an operation system is specified
     62          1.1  christos # with the mandoc(1) -Ios= command line option, that is used.
     63          1.1  christos # Otherwise, the uname(3) library function is called at runtime to find
     64          1.1  christos # the name of the operating system.
     65          1.1  christos # If you do not want uname(3) to be called but instead want a fixed
     66          1.1  christos # string to be used, use the following line:
     67          1.1  christos 
     68  1.1.1.1.2.1  pgoyette OSNAME="OpenBSD 5.9"
     69          1.1  christos 
     70          1.1  christos # The following installation directories are used.
     71          1.1  christos # It is possible to set only one or a few of these variables,
     72          1.1  christos # there is no need to copy the whole block.
     73          1.1  christos # Even if you set PREFIX to something else, the other variables
     74          1.1  christos # pick it up without copying them all over.
     75          1.1  christos 
     76          1.1  christos PREFIX="/usr/local"
     77          1.1  christos BINDIR="${PREFIX}/bin"
     78          1.1  christos SBINDIR="${PREFIX}/sbin"
     79          1.1  christos INCLUDEDIR="${PREFIX}/include/mandoc"
     80          1.1  christos LIBDIR="${PREFIX}/lib/mandoc"
     81          1.1  christos MANDIR="${PREFIX}/man"
     82          1.1  christos 
     83          1.1  christos # The man(1) utility needs to know where the manuals reside.
     84          1.1  christos # We know of two ways to tell it: via manpath(1) or man.conf(5).
     85          1.1  christos # The latter is used by OpenBSD and NetBSD, the former by most
     86          1.1  christos # other systems.
     87          1.1  christos 
     88          1.1  christos # Force usage of manpath(1).
     89          1.1  christos # If it is not installed or not operational,
     90          1.1  christos # man(1), makewhatis(8), and apropos(1) will not work properly.
     91          1.1  christos HAVE_MANPATH=1
     92          1.1  christos 
     93          1.1  christos # Force usage of man.conf(5).
     94          1.1  christos # If it does not exist or contains no valid configuration,
     95          1.1  christos # man(1), makewhatis(8), and apropos(1) will not work properly.
     96          1.1  christos HAVE_MANPATH=0
     97          1.1  christos 
     98  1.1.1.1.2.1  pgoyette # Some distributions may want to avoid naming conflicts
     99  1.1.1.1.2.1  pgoyette # with the configuration files of other man(1) implementations.
    100  1.1.1.1.2.1  pgoyette # This changes the name of the installed section 5 manual page as well.
    101  1.1.1.1.2.1  pgoyette MANM_MANCONF="mandoc.conf"	# default is "man.conf"
    102  1.1.1.1.2.1  pgoyette 
    103          1.1  christos # Some distributions may want to avoid naming conflicts among manuals.
    104          1.1  christos # If you want to change the names of installed section 7 manual pages,
    105          1.1  christos # the following alternative names are suggested.
    106          1.1  christos # The suffix ".7" will automatically be appended.
    107          1.1  christos # It is possible to set only one or a few of these variables,
    108          1.1  christos # there is no need to copy the whole block.
    109          1.1  christos 
    110          1.1  christos MANM_MAN="mandoc_man"		# default is "man"
    111          1.1  christos MANM_MDOC="mandoc_mdoc"		# default is "mdoc"
    112          1.1  christos MANM_ROFF="mandoc_roff"		# default is "roff"
    113          1.1  christos MANM_EQN="mandoc_eqn"		# default is "eqn"
    114          1.1  christos MANM_TBL="mandoc_tbl"		# default is "tbl"
    115          1.1  christos 
    116          1.1  christos # Some distributions may want to avoid naming conflicts
    117  1.1.1.1.2.1  pgoyette # with other man(1) and soelim(1) utilities.
    118  1.1.1.1.2.1  pgoyette # If you want to change the names of binary programs,
    119  1.1.1.1.2.1  pgoyette # the following alternative names are suggested.
    120  1.1.1.1.2.1  pgoyette # Using different names is possible as well.
    121  1.1.1.1.2.1  pgoyette # This changes the names of the installed section 1 manual pages as well.
    122          1.1  christos 
    123          1.1  christos BINM_MAN=mman			# default is "man"
    124  1.1.1.1.2.1  pgoyette BINM_SOELIM=msoelim		# default is "soelim"
    125  1.1.1.1.2.1  pgoyette 
    126  1.1.1.1.2.1  pgoyette # Before falling back to the bundled version of the ohash(3) hashing
    127  1.1.1.1.2.1  pgoyette # library, autoconfiguration tries the following linker flag to
    128  1.1.1.1.2.1  pgoyette # link against your system version.  If you do have ohash(3) on
    129  1.1.1.1.2.1  pgoyette # your system but it needs different linker flags, set the following
    130  1.1.1.1.2.1  pgoyette # variable to specify the required linker flags.
    131  1.1.1.1.2.1  pgoyette 
    132  1.1.1.1.2.1  pgoyette LD_OHASH="-lutil"
    133  1.1.1.1.2.1  pgoyette 
    134  1.1.1.1.2.1  pgoyette # Some platforms may need additional linker flags to link against libmandoc
    135  1.1.1.1.2.1  pgoyette # that are not autodetected.
    136  1.1.1.1.2.1  pgoyette # For example, Solaris 9 and 10 need -lrt for nanosleep(2).
    137  1.1.1.1.2.1  pgoyette 
    138  1.1.1.1.2.1  pgoyette LDADD="-lrt"
    139  1.1.1.1.2.1  pgoyette 
    140  1.1.1.1.2.1  pgoyette # Some systems may want to set additional linker flags for all the
    141  1.1.1.1.2.1  pgoyette # binaries, not only for those using libmandoc, for example for
    142  1.1.1.1.2.1  pgoyette # hardening options.
    143  1.1.1.1.2.1  pgoyette 
    144  1.1.1.1.2.1  pgoyette LDFLAGS="-Wl,-z,relro"
    145          1.1  christos 
    146          1.1  christos # It is possible to change the utility program used for installation
    147          1.1  christos # and the modes files are installed with.  The defaults are:
    148          1.1  christos 
    149          1.1  christos INSTALL="install"
    150          1.1  christos INSTALL_PROGRAM="${INSTALL} -m 0555"
    151          1.1  christos INSTALL_LIB="${INSTALL} -m 0444"
    152          1.1  christos INSTALL_MAN="${INSTALL} -m 0444"
    153          1.1  christos INSTALL_DATA="${INSTALL} -m 0444"
    154          1.1  christos 
    155          1.1  christos # --- user settings related to database support ------------------------
    156          1.1  christos 
    157          1.1  christos # By default, building makewhatis(8) and apropos(1) is enabled.
    158          1.1  christos # To disable it, for example to avoid the dependency on SQLite3,
    159          1.1  christos # use the following line.  It that case, the remaining settings
    160          1.1  christos # in this section are irrelevant.
    161          1.1  christos 
    162          1.1  christos BUILD_DB=0
    163          1.1  christos 
    164  1.1.1.1.2.1  pgoyette # Autoconfiguration tries the following linker flags to find the
    165  1.1.1.1.2.1  pgoyette # SQLite3 library installed on your system.  If none of these work,
    166  1.1.1.1.2.1  pgoyette # set the following variable to specify the required linker flags.
    167  1.1.1.1.2.1  pgoyette 
    168  1.1.1.1.2.1  pgoyette LD_SQLITE3="-lsqlite3"
    169  1.1.1.1.2.1  pgoyette LD_SQLITE3="-L/usr/local/lib -lsqlite3"
    170          1.1  christos 
    171          1.1  christos # When library autodetection decides to use -L/usr/local/lib,
    172          1.1  christos # -I/usr/local/include is automatically added to CFLAGS.
    173  1.1.1.1.2.1  pgoyette # If you manually set LD_SQLITE3 to something including -L/usr/local/lib,
    174          1.1  christos # chances are you will also need the following line:
    175          1.1  christos 
    176          1.1  christos CFLAGS="${CFLAGS} -I/usr/local/include"
    177          1.1  christos 
    178          1.1  christos # Some distributions may want to avoid naming conflicts
    179          1.1  christos # with another implementation of apropos(1) and makewhatis(8).
    180          1.1  christos # If you want to change the names of the binary programs,
    181          1.1  christos # the following alternative names are suggested.
    182          1.1  christos # Using other names is possible as well.
    183          1.1  christos # This changes the names of the installed section 1 and section 8
    184          1.1  christos # manual pages as well.
    185          1.1  christos # It is possible to set only one or two of these variables,
    186          1.1  christos # there is no need to copy the whole block.
    187          1.1  christos 
    188          1.1  christos BINM_APROPOS=mapropos		# default is "apropos"
    189          1.1  christos BINM_WHATIS=mwhatis		# default is "whatis"
    190          1.1  christos BINM_MAKEWHATIS=mandocdb	# default is "makewhatis"
    191          1.1  christos 
    192          1.1  christos # When using the "homebrew" package manager on Mac OS X, the actual
    193          1.1  christos # manuals are located in a so-called "cellar" and only symlinked
    194          1.1  christos # into the manual trees.  To allow mandoc to follow such symlinks,
    195          1.1  christos # you have to specify the physical location of the cellar as returned
    196          1.1  christos # by realpath(3), for example:
    197          1.1  christos 
    198          1.1  christos PREFIX="/usr/local"
    199          1.1  christos HOMEBREWDIR="${PREFIX}/Cellar"
    200          1.1  christos 
    201          1.1  christos # --- user settings related man.cgi ------------------------------------
    202          1.1  christos 
    203          1.1  christos # By default, building man.cgi(8) is disabled.  To enable it, copy
    204          1.1  christos # cgi.h.example to cgi.h, edit it, and use the following line.
    205          1.1  christos # Obviously, this requires that BUILD_DB is enabled, too.
    206          1.1  christos 
    207          1.1  christos BUILD_CGI=1
    208          1.1  christos 
    209          1.1  christos # The remaining settings in this section are only relevant if BUILD_CGI
    210          1.1  christos # is enabled.  Otherwise, they have no effect either way.
    211          1.1  christos 
    212          1.1  christos # By default, man.cgi(8) is linked statically.
    213          1.1  christos # Some systems do not support static linking, for example Mac OS X.
    214          1.1  christos # In that case, use the following line:
    215          1.1  christos 
    216          1.1  christos STATIC=
    217          1.1  christos 
    218          1.1  christos # Some systems, for example Linux, require -pthread for static linking:
    219          1.1  christos 
    220          1.1  christos STATIC="-static -pthread"
    221          1.1  christos 
    222          1.1  christos # Some directories.
    223          1.1  christos # This works just like PREFIX, see above.
    224          1.1  christos 
    225          1.1  christos WWWPREFIX="/var/www"
    226          1.1  christos HTDOCDIR="${WWWPREFIX}/htdocs"
    227          1.1  christos CGIBINDIR="${WWWPREFIX}/cgi-bin"
    228          1.1  christos 
    229          1.1  christos # --- settings that rarely need to be touched --------------------------
    230          1.1  christos 
    231          1.1  christos # Do not set these variables unless you really need to.
    232          1.1  christos 
    233          1.1  christos # You can manually override the compiler to be used.
    234          1.1  christos # But that's rarely useful because ./configure asks your make(1)
    235          1.1  christos # which compiler to use, and that answer will hardly be wrong.
    236          1.1  christos 
    237          1.1  christos CC=cc
    238          1.1  christos 
    239  1.1.1.1.2.1  pgoyette # IBM AIX may need:
    240  1.1.1.1.2.1  pgoyette 
    241  1.1.1.1.2.1  pgoyette CC=xlc
    242  1.1.1.1.2.1  pgoyette 
    243          1.1  christos # The default compiler flags are:
    244          1.1  christos 
    245          1.1  christos CFLAGS="-g -W -Wall -Wstrict-prototypes -Wno-unused-parameter -Wwrite-strings"
    246          1.1  christos 
    247  1.1.1.1.2.1  pgoyette # IBM AIX xlc does not support -W; in that case, please use:
    248  1.1.1.1.2.1  pgoyette 
    249  1.1.1.1.2.1  pgoyette CFLAGS="-g"
    250  1.1.1.1.2.1  pgoyette 
    251          1.1  christos # In rare cases, it may be required to skip individual automatic tests.
    252          1.1  christos # Each of the following variables can be set to 0 (test will not be run
    253          1.1  christos # and will be regarded as failed) or 1 (test will not be run and will
    254          1.1  christos # be regarded as successful).
    255          1.1  christos 
    256          1.1  christos HAVE_DIRENT_NAMLEN=0
    257  1.1.1.1.2.1  pgoyette HAVE_ERR=0
    258          1.1  christos HAVE_FTS=0
    259  1.1.1.1.2.1  pgoyette HAVE_GETLINE=0
    260          1.1  christos HAVE_GETSUBOPT=0
    261  1.1.1.1.2.1  pgoyette HAVE_ISBLANK=0
    262  1.1.1.1.2.1  pgoyette HAVE_MKDTEMP=0
    263          1.1  christos HAVE_MMAP=0
    264  1.1.1.1.2.1  pgoyette HAVE_PLEDGE=0
    265  1.1.1.1.2.1  pgoyette HAVE_PROGNAME=0
    266          1.1  christos HAVE_REALLOCARRAY=0
    267  1.1.1.1.2.1  pgoyette HAVE_REWB_BSD=0
    268  1.1.1.1.2.1  pgoyette HAVE_REWB_SYSV=0
    269          1.1  christos HAVE_STRCASESTR=0
    270  1.1.1.1.2.1  pgoyette HAVE_STRINGLIST=0
    271          1.1  christos HAVE_STRLCAT=0
    272          1.1  christos HAVE_STRLCPY=0
    273          1.1  christos HAVE_STRPTIME=0
    274          1.1  christos HAVE_STRSEP=0
    275          1.1  christos HAVE_STRTONUM=0
    276  1.1.1.1.2.1  pgoyette HAVE_VASPRINTF=0
    277  1.1.1.1.2.1  pgoyette HAVE_WCHAR=0
    278          1.1  christos 
    279          1.1  christos HAVE_SQLITE3=0
    280          1.1  christos HAVE_SQLITE3_ERRSTR=0
    281          1.1  christos HAVE_OHASH=0
    282