]> CyberLeo.Net >> Repos - FreeBSD/releng/10.0.git/blob - lib/libpam/libpam/Makefile
- Copy stable/10 (r259064) to releng/10.0 as part of the
[FreeBSD/releng/10.0.git] / lib / libpam / libpam / Makefile
1 #-
2 # Copyright (c) 1998 Juniper Networks, Inc.
3 # All rights reserved.
4 # Copyright (c) 2002 Networks Associates Technology, Inc.
5 # All rights reserved.
6 #
7 # Portions of this software was developed for the FreeBSD Project by
8 # ThinkSec AS and NAI Labs, the Security Research Division of Network
9 # Associates, Inc.  under DARPA/SPAWAR contract N66001-01-C-8035
10 # ("CBOSS"), as part of the DARPA CHATS research program.
11 #
12 # Redistribution and use in source and binary forms, with or without
13 # modification, are permitted provided that the following conditions
14 # are met:
15 # 1. Redistributions of source code must retain the above copyright
16 #    notice, this list of conditions and the following disclaimer.
17 # 2. Redistributions in binary form must reproduce the above copyright
18 #    notice, this list of conditions and the following disclaimer in the
19 #    documentation and/or other materials provided with the distribution.
20 # 3. The name of the author may not be used to endorse or promote
21 #    products derived from this software without specific prior written
22 #    permission.
23 #
24 # THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
25 # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27 # ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
28 # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29 # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30 # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31 # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
33 # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34 # SUCH DAMAGE.
35 #
36 # $FreeBSD$
37
38 OPENPAM=        ${.CURDIR}/../../../contrib/openpam
39 .PATH: ${OPENPAM}/include ${OPENPAM}/lib/libpam ${OPENPAM}/doc/man
40
41 LIB=    pam
42 NO_PROFILE=
43
44 SRCS=   openpam_asprintf.c \
45         openpam_borrow_cred.c \
46         openpam_check_owner_perms.c \
47         openpam_configure.c \
48         openpam_constants.c \
49         openpam_dispatch.c \
50         openpam_dynamic.c \
51         openpam_features.c \
52         openpam_findenv.c \
53         openpam_free_data.c \
54         openpam_free_envlist.c \
55         openpam_get_feature.c \
56         openpam_get_option.c \
57         openpam_load.c \
58         openpam_log.c \
59         openpam_nullconv.c \
60         openpam_readline.c \
61         openpam_readlinev.c \
62         openpam_readword.c \
63         openpam_restore_cred.c \
64         openpam_set_feature.c \
65         openpam_set_option.c \
66         openpam_straddch.c \
67         openpam_strlcat.c \
68         openpam_strlcpy.c \
69         openpam_subst.c \
70         openpam_ttyconv.c \
71         openpam_vasprintf.c \
72         pam_acct_mgmt.c \
73         pam_authenticate.c \
74         pam_chauthtok.c \
75         pam_close_session.c \
76         pam_end.c \
77         pam_error.c \
78         pam_get_authtok.c \
79         pam_get_data.c \
80         pam_get_item.c \
81         pam_get_user.c \
82         pam_getenv.c \
83         pam_getenvlist.c \
84         pam_info.c \
85         pam_open_session.c \
86         pam_prompt.c \
87         pam_putenv.c \
88         pam_set_data.c \
89         pam_set_item.c \
90         pam_setcred.c \
91         pam_setenv.c \
92         pam_start.c \
93         pam_strerror.c \
94         pam_verror.c \
95         pam_vinfo.c \
96         pam_vprompt.c
97 # Local additions
98 SRCS+=  pam_debug_log.c
99
100 MAN=    openpam.3 \
101         openpam_borrow_cred.3 \
102         openpam_free_data.3 \
103         openpam_free_envlist.3 \
104         openpam_get_feature.3 \
105         openpam_get_option.3 \
106         openpam_log.3 \
107         openpam_nullconv.3 \
108         openpam_readline.3 \
109         openpam_readlinev.3 \
110         openpam_readword.3 \
111         openpam_restore_cred.3 \
112         openpam_set_feature.3 \
113         openpam_set_option.3 \
114         openpam_straddch.3 \
115         openpam_subst.3 \
116         openpam_ttyconv.3 \
117         pam.3 \
118         pam_acct_mgmt.3 \
119         pam_authenticate.3 \
120         pam_chauthtok.3 \
121         pam_close_session.3 \
122         pam_conv.3 \
123         pam_end.3 \
124         pam_error.3 \
125         pam_get_authtok.3 \
126         pam_get_data.3 \
127         pam_get_item.3 \
128         pam_get_user.3 \
129         pam_getenv.3 \
130         pam_getenvlist.3 \
131         pam_info.3 \
132         pam_open_session.3 \
133         pam_prompt.3 \
134         pam_putenv.3 \
135         pam_set_data.3 \
136         pam_set_item.3 \
137         pam_setcred.3 \
138         pam_setenv.3 \
139         pam_sm_acct_mgmt.3 \
140         pam_sm_authenticate.3 \
141         pam_sm_chauthtok.3 \
142         pam_sm_close_session.3 \
143         pam_sm_open_session.3 \
144         pam_sm_setcred.3 \
145         pam_start.3 \
146         pam_strerror.3 \
147         pam_verror.3 \
148         pam_vinfo.3 \
149         pam_vprompt.3 \
150         pam.conf.5
151
152 MLINKS= pam.conf.5 pam.d.5
153
154 CSTD?= c99
155 CFLAGS+= -I${.CURDIR} -I${OPENPAM}/include
156 CFLAGS+= -DLIB_MAJ=${SHLIB_MAJOR}
157 CFLAGS+= -DOPENPAM_MODULES_DIR='"${PAM_MOD_DIR:C/\/*$//}/"'
158 CFLAGS+= -DHAVE_DLFUNC=1
159 CFLAGS+= -DHAVE_FDLOPEN=1
160 CFLAGS+= -DHAVE_FPURGE=1
161 CFLAGS+= -DHAVE_STRLCAT=1
162 CFLAGS+= -DHAVE_STRLCPY=1
163
164 HEADERS=        security/openpam.h \
165                 security/openpam_attr.h \
166                 security/openpam_version.h \
167                 security/pam_appl.h \
168                 security/pam_constants.h \
169                 security/pam_modules.h \
170                 security/pam_types.h \
171
172 ADD_HEADERS=    security/pam_mod_misc.h
173
174 #
175 # Static modules
176 #
177 # We build static versions of all modules and of openpam_static.o,
178 # then link them all together into openpam_static_modules.o.  None of
179 # the modules export any symbols, but they store structures with
180 # pointers to their service functions in a linker set which the code
181 # in openpam_static.c traverses to locate the individual modules.
182 #
183 MODULE_DIR=     ../modules
184 .include "${.CURDIR}/${MODULE_DIR}/modules.inc"
185 STATIC_MODULES= ${MODULES:C/.*/${MODULE_DIR}\/&\/lib&.a/}
186 STATICOBJS+=    openpam_static_modules.o
187 CLEANFILES+=    openpam_static.o \
188                 openpam_static_modules.o
189
190 openpam_static_modules.o: openpam_static.o ${STATIC_MODULES}
191         ${LD} -o ${.TARGET} -r --whole-archive ${.ALLSRC}
192
193 # We can't put openpam_static.c in SRCS, but we still want to scan it
194 # for dependencies.
195 DPSRCS=         openpam_static.c
196
197 # Headers
198 INCS=           ${HEADERS} ${ADD_HEADERS}
199 INCSDIR=        ${INCLUDEDIR}/security
200
201 .include <bsd.lib.mk>