1 #----------------------------------------------------------------------------
4 # global configuration for the Makefiles
6 # Copyright (c) 1994, Regents of the University of California
10 # $Header: /cvsroot/pgsql/src/Makefile.global.in,v 1.44 1998/07/24 03:31:04 scrappy Exp $
13 # Essentially all Postgres make files include this file and use the
16 # To override the default setting, create a Makefile.custom in this
17 # directory and put your defines there. (Makefile.custom is included
18 # near the end of this file). Sometimes, a variable gets set in
19 # Makefile.global after Makefile.custom has been included, so you can't
20 # simply set that variable in Makefile.custom. In those cases, there is
21 # often another variable (like CUSTOM_COPT) that you can set in
22 # Makefile.custom that influences the later setting of the true variable
23 # of interest (like CFLAGS) by Makefile.global.
26 # If you change any of these defines you probably have to
28 # since no dependencies are created for these. (of course you can
29 # be crafty and check what files really depend on them and just remake
32 # Before including this file, you must set the SRCDIR variable to the
33 # path of the top of the Postgres source tree (the directory that
34 # contains this file).
36 #-------------------------------------------------------------------------
39 ##############################################################################
41 # CONFIGURATION SECTION
43 # Following are settings pertaining to the postgres build and
47 # Ignore BSD_SHLIB if you're not using one of the BSD ports. But if you
48 # are, and it's one that doesn't have shared libraries (NetBSD/vax is an
49 # example of this), set BSD_SHLIB to null in Makefile.custom.
52 LIBPQDIR:= $(SRCDIR)/interfaces/libpq
54 # For convenience, POSTGRESDIR is where BINDIR, and LIBDIR
55 # and other target destinations are rooted. Of course, each of these is
56 # changable separately.
59 # Where the postgres executables live (changeable by just putting them
60 # somewhere else and putting that directory in your shell PATH)
61 BINDIR= $(POSTGRESDIR)/bin
63 # Where libpq.a gets installed. You must put it where your loader will
64 # look for it if you wish to use the -lpq convention. Otherwise you
65 # can just put the absolute pathname to the library at the end of your
67 LIBDIR= $(POSTGRESDIR)/lib
69 # This is the directory where IPC utilities ipcs and ipcrm are located
74 # Where the man pages (suitable for use with "man") get installed.
75 POSTMANDIR= $(POSTGRESDIR)/man
77 # Where the formatted documents (e.g., the reference manual) get installed.
78 POSTDOCDIR= $(POSTGRESDIR)/doc
80 # Where the header files necessary to build frontend programs get installed.
81 HEADERDIR= $(POSTGRESDIR)/include
83 ##############################################################################
87 # To disable a feature, comment out the entire definition
88 # (that is, prepend '#', don't set it to "0" or "no").
93 # Comment out ENFORCE_ALIGNMENT if you do NOT want unaligned access to
94 # multi-byte types to generate a bus error.
95 ENFORCE_ALIGNMENT= true
97 # Comment out PROFILE to generate a profile version of the binaries
98 #PROFILE= -p -non_shared
100 # If you plan to use Kerberos for authentication...
102 # Comment out KRBVERS if you do not use Kerberos.
103 # Set KRBVERS to "4" for Kerberos v4, "5" for Kerberos v5.
104 # XXX Edit the default Kerberos variables below!
108 # Globally pass Kerberos file locations.
109 # these are used in the postmaster and all libpq applications.
111 # Adjust KRBINCS and KRBLIBS to reflect where you have Kerberos
112 # include files and libraries installed.
113 # PG_KRB_SRVNAM is the name under which POSTGRES is registered in
114 # the Kerberos database (KDC).
115 # PG_KRB_SRVTAB is the location of the server's keytab file.
118 KRBINCS= -I/usr/athena/include
119 KRBLIBS= -L/usr/athena/lib
120 KRBFLAGS+= $(KRBINCS) -DPG_KRB_SRVNAM='"postgres_dbms"'
123 KRBFLAGS+= -DPG_KRB_SRVTAB='"/etc/srvtab"'
124 KRBLIBS+= -lkrb -ldes
128 KRBFLAGS+= -DPG_KRB_SRVTAB='"FILE:/krb5/srvtab.postgres"'
129 KRBLIBS+= -lkrb5 -lcrypto -lcom_err -lisode
135 # location of Tcl/Tk headers and libraries
137 # Uncomment this to build the tcl utilities.
139 # customize these to your site's needs
148 X11_LIBS= -lX11 @X_EXTRA_LIBS@
151 # enable multi-byte support
153 # EUC_JP,EUC_CN,EUC_KR,EUC_TW,UNICODE,MULE_INTERNAL,LATIN1-5
156 ##############################################################################
160 # For many ports, INSTALL is overridden below.
164 INSTLOPTS= @INSTLOPTS@
165 INSTL_EXE_OPTS= @INSTL_EXE_OPTS@
166 INSTL_LIB_OPTS= @INSTL_LIB_OPTS@
167 INSTL_SHLIB_OPTS= @INSTL_SHLIB_OPTS@
169 ##############################################################################
171 # For building shell scripts:
173 # For many ports, these are overridden below.
175 # DASH_N is what we put before the text on an echo command when we don't
176 # want a trailing newline. BACKSLASH_C is what we put at the end of the
177 # string on a echo command when we don't want a trailing newline. On
178 # some systems, you do echo -n "no newline after this", while on others
179 # you do echo "no newline after this\c".
182 BACKSLASH_C= @BACKSLASH_C@
186 #-------------------------------------------------------------
187 # See the subdirectory template for default settings for these
188 #-------------------------------------------------------------
194 CFLAGS= -I$(SRCDIR)/include -I$(SRCDIR)/backend @CPPFLAGS@ @CFLAGS@
195 CFLAGS_SL= @SHARED_LIB@
196 LDFLAGS= @LDFLAGS@ @LIBS@
199 include $(SRCDIR)/Makefile.port
201 ##############################################################################
205 # This includes your local customizations if Makefile.custom exists
206 # in the source directory. This file doesn't exist in the original
207 # distribution so that it doesn't get overwritten when you upgrade.
208 ifneq ($(wildcard $(SRCDIR)/Makefile.custom), )
209 include $(SRCDIR)/Makefile.custom
212 # This goes here so that customization in Makefile.custom is effective
213 ##############################################################################
215 ifneq ($(CUSTOM_INSTALL),)
216 INSTALL= $(CUSTOM_INSTALL)
220 # Flags for CC and LD.
222 ##############################################################################
225 # COPT is for options that the sophisticated builder might want to vary
226 # from one build to the next, like options to build Postgres with debugging
227 # information included. COPT is meant to be set on the make command line,
228 # for example with the command "make COPT=-g". The value you see set here
229 # is the default that gets used if the builder does not give a value for
230 # COPT on his make command.
232 # There is a nonobvious relationship between -O (optimization) and
233 # -Werror (consider all warnings fatal). On some systems, if you don't
234 # optimize, you will always get some warnings because the system header
235 # files will include some unreferenced functions in the code. These are
236 # functions that are supposed to be inline, so there wouldn't ordinarily
237 # be an "unreferenced" problem, but if you don't enable optimization, no
238 # inlining can happen, and hence the problem. Therefore, we include
239 # if you override -O, you override -Werror as well.
241 # CUSTOM_COPT is something the user may set in Makefile.custom
243 # Common values for COPT are: -g for debuggable binaries, -m486 if you are
244 # using a i486 or better.
246 ifneq ($(CUSTOM_CC),)
250 ifneq ($(CUSTOM_COPT),)
255 CFLAGS+= -Wall -Wmissing-prototypes