]>
Commit | Line | Data |
---|---|---|
d56128f0 RE |
1 | ## |
2 | ## Makefile for OpenSSL | |
3 | ## | |
4 | ||
0973910f UM |
5 | VERSION= |
6 | MAJOR= | |
7 | MINOR= | |
b436a982 RL |
8 | SHLIB_VERSION_NUMBER= |
9 | SHLIB_VERSION_HISTORY= | |
10 | SHLIB_MAJOR= | |
11 | SHLIB_MINOR= | |
a22fb399 | 12 | SHLIB_EXT= |
d56128f0 | 13 | PLATFORM=dist |
31ff97b2 | 14 | OPTIONS= |
c59cb511 | 15 | CONFIGURE_ARGS= |
b436a982 RL |
16 | SHLIB_TARGET= |
17 | ||
30c08f2e RL |
18 | # HERE indicates where this Makefile lives. This can be used to indicate |
19 | # where sub-Makefiles are expected to be. Currently has very limited usage, | |
20 | # and should probably not be bothered with at all. | |
21 | HERE=. | |
22 | ||
e5f3045f BM |
23 | # INSTALL_PREFIX is for package builders so that they can configure |
24 | # for, say, /usr/ and yet have everything installed to /tmp/somedir/usr/. | |
25 | # Normally it is left empty. | |
26 | INSTALL_PREFIX= | |
462ba4f6 UM |
27 | INSTALLTOP=/usr/local/ssl |
28 | ||
29 | # Do not edit this manually. Use Configure --openssldir=DIR do change this! | |
30 | OPENSSLDIR=/usr/local/ssl | |
d56128f0 | 31 | |
d02b48c6 RE |
32 | # NO_IDEA - Define to build without the IDEA algorithm |
33 | # NO_RC4 - Define to build without the RC4 algorithm | |
34 | # NO_RC2 - Define to build without the RC2 algorithm | |
35 | # THREADS - Define when building with threads, you will probably also need any | |
58964a49 | 36 | # system defines as well, i.e. _REENTERANT for Solaris 2.[34] |
d02b48c6 RE |
37 | # TERMIO - Define the termio terminal subsystem, needed if sgtty is missing. |
38 | # TERMIOS - Define the termios terminal subsystem, Silicon Graphics. | |
39 | # LONGCRYPT - Define to use HPUX 10.x's long password modification to crypt(3). | |
40 | # DEVRANDOM - Give this the value of the 'random device' if your OS supports | |
58964a49 RE |
41 | # one. 32 bytes will be read from this when the random |
42 | # number generator is initalised. | |
baf748ba | 43 | # SSL_FORBID_ENULL - define if you want the server to be not able to use the |
58964a49 | 44 | # NULL encryption ciphers. |
d02b48c6 RE |
45 | # |
46 | # LOCK_DEBUG - turns on lots of lock debug output :-) | |
47 | # REF_CHECK - turn on some xyz_free() assertions. | |
58964a49 | 48 | # REF_PRINT - prints some stuff on structure free. |
d02b48c6 RE |
49 | # CRYPTO_MDEBUG - turns on my 'memory leak' detecting stuff |
50 | # MFUNC - Make all Malloc/Free/Realloc calls call | |
58964a49 RE |
51 | # CRYPTO_malloc/CRYPTO_free/CRYPTO_realloc which can be setup to |
52 | # call application defined callbacks via CRYPTO_set_mem_functions() | |
53 | # MD5_ASM needs to be defined to use the x86 assembler for MD5 | |
54 | # SHA1_ASM needs to be defined to use the x86 assembler for SHA1 | |
55 | # RMD160_ASM needs to be defined to use the x86 assembler for RIPEMD160 | |
dfeab068 RE |
56 | # Do not define B_ENDIAN or L_ENDIAN if 'unsigned long' == 8. It must |
57 | # equal 4. | |
58 | # PKCS1_CHECK - pkcs1 tests. | |
d02b48c6 | 59 | |
67ea999d AP |
60 | CC= cc |
61 | CFLAG= -O | |
f5d7a031 | 62 | DEPFLAG= |
bc29d0e5 | 63 | PEX_LIBS= |
651d0aff | 64 | EX_LIBS= |
967d95f0 | 65 | EXE_EXT= |
179add2b RL |
66 | ARFLAGS= |
67 | AR=ar $(ARFLAGS) r | |
99aab161 | 68 | RANLIB= ranlib |
cbfb39d1 | 69 | NM= nm |
99aab161 | 70 | PERL= perl |
2dbb3ccd | 71 | TAR= tar |
46ebd9e3 | 72 | TARFLAGS= --no-recursion --record-size=10240 |
cf1b7d96 | 73 | MAKEDEPPROG=makedepend |
d5ec7d66 | 74 | LIBDIR=lib |
d02b48c6 | 75 | |
3cc9a89d AP |
76 | # We let the C compiler driver to take care of .s files. This is done in |
77 | # order to be excused from maintaining a separate set of architecture | |
78 | # dependent assembler flags. E.g. if you throw -mcpu=ultrasparc at SPARC | |
79 | # gcc, then the driver will automatically translate it to -xarch=v8plus | |
80 | # and pass it down to assembler. | |
81 | AS=$(CC) -c | |
01fc834b | 82 | ASFLAG=$(CFLAG) |
3cc9a89d | 83 | |
14e21f86 AP |
84 | # For x86 assembler: Set PROCESSOR to 386 if you want to support |
85 | # the 80386. | |
86 | PROCESSOR= | |
87 | ||
88 | # CPUID module collects small commonly used assembler snippets | |
89 | CPUID_OBJ= | |
dfeab068 | 90 | BN_ASM= bn_asm.o |
67ea999d | 91 | DES_ENC= des_enc.o fcrypt_b.o |
0ddd3ea2 | 92 | AES_ENC= aes_core.o aes_cbc.o |
67ea999d AP |
93 | BF_ENC= bf_enc.o |
94 | CAST_ENC= c_enc.o | |
95 | RC4_ENC= rc4_enc.o | |
96 | RC5_ENC= rc5_enc.o | |
97 | MD5_ASM_OBJ= | |
98 | SHA1_ASM_OBJ= | |
99 | RMD160_ASM_OBJ= | |
ed26604a | 100 | WP_ASM_OBJ= |
6a8517f2 | 101 | CMLL_ENC= |
886657a6 AP |
102 | MODES_ASM_OBJ= |
103 | ENGINES_ASM_OBJ= | |
fa8e921f | 104 | PERLASM_SCHEME= |
58964a49 | 105 | |
f9b3bff6 RL |
106 | # KRB5 stuff |
107 | KRB5_INCLUDES= | |
c1269c81 | 108 | LIBKRB5= |
f9b3bff6 | 109 | |
ad2695b1 DSH |
110 | # Zlib stuff |
111 | ZLIB_INCLUDE= | |
112 | LIBZLIB= | |
113 | ||
7207eca1 DSH |
114 | # TOP level FIPS install directory. |
115 | FIPSDIR= | |
116 | ||
117 | # This is the location of fipscanister.o and friends. | |
118 | # The FIPS module build will place it $(INSTALLTOP)/lib | |
119 | # but since $(INSTALLTOP) can only take the default value | |
120 | # when the module is built it will be in /usr/local/ssl/lib | |
121 | # $(INSTALLTOP) for this build may be different so hard | |
122 | # code the path. | |
123 | ||
124 | FIPSLIBDIR= | |
125 | ||
126 | # The location of the library which contains fipscanister.o | |
127 | # normally it will be libcrypto unless fipsdso is set in which | |
128 | # case it will be libfips. If not compiling in FIPS mode at all | |
129 | # this is empty making it a useful test for a FIPS compile. | |
130 | ||
131 | FIPSCANLIB= | |
132 | ||
133 | # Shared library base address. Currently only used on Windows. | |
134 | # | |
135 | ||
136 | BASEADDR= | |
137 | ||
506fec1a | 138 | DIRS= crypto ssl engines apps test tools |
d07692cd | 139 | ENGDIRS= ccgost |
0973910f UM |
140 | SHLIBDIRS= crypto ssl |
141 | ||
d02b48c6 RE |
142 | # dirs in crypto to build |
143 | SDIRS= \ | |
d87b79bf | 144 | objects \ |
d1593e6b | 145 | md2 md4 md5 sha mdc2 hmac ripemd whrlpool \ |
5d48a66a | 146 | des aes rc2 rc4 rc5 idea bf cast camellia seed modes \ |
67ea999d | 147 | bn ec rsa dsa ecdsa dh ecdh dso engine \ |
d87b79bf | 148 | buffer bio stack lhash rand err \ |
a5db6fa5 | 149 | evp asn1 pem x509 x509v3 conf txt_db pkcs7 pkcs12 comp ocsp ui krb5 \ |
260d08b8 | 150 | cms pqueue ts jpake srp store cmac |
02c31fa4 AP |
151 | # keep in mind that the above list is adjusted by ./Configure |
152 | # according to no-xxx arguments... | |
d02b48c6 | 153 | |
f777408f RL |
154 | # tests to perform. "alltests" is a special word indicating that all tests |
155 | # should be performed. | |
156 | TESTS = alltests | |
157 | ||
42ba5d23 | 158 | MAKEFILE= Makefile |
d02b48c6 | 159 | |
e1c55191 | 160 | MANDIR=$(OPENSSLDIR)/man |
d02b48c6 RE |
161 | MAN1=1 |
162 | MAN3=3 | |
1cc087fe | 163 | MANSUFFIX= |
60cdb821 UM |
164 | HTMLSUFFIX=html |
165 | HTMLDIR=$(OPENSSLDIR)/html | |
d02b48c6 RE |
166 | SHELL=/bin/sh |
167 | ||
58964a49 | 168 | TOP= . |
d02b48c6 | 169 | ONEDIRS=out tmp |
7d7d2cbc | 170 | EDIRS= times doc bugs util include certs ms shlib mt demos perl sf dep VMS |
58964a49 | 171 | WDIRS= windows |
b436a982 | 172 | LIBS= libcrypto.a libssl.a |
a22fb399 RL |
173 | SHARED_CRYPTO=libcrypto$(SHLIB_EXT) |
174 | SHARED_SSL=libssl$(SHLIB_EXT) | |
175 | SHARED_LIBS= | |
176 | SHARED_LIBS_LINK_EXTS= | |
a5595fde | 177 | SHARED_LDFLAGS= |
58964a49 RE |
178 | |
179 | GENERAL= Makefile | |
9ce5db45 | 180 | BASENAME= openssl |
58964a49 RE |
181 | NAME= $(BASENAME)-$(VERSION) |
182 | TARFILE= $(NAME).tar | |
183 | WTARFILE= $(NAME)-win.tar | |
cf1b7d96 | 184 | EXHEADER= e_os2.h |
58964a49 | 185 | HEADER= e_os.h |
d02b48c6 | 186 | |
0962fbbf | 187 | all: Makefile build_all openssl.pc libssl.pc libcrypto.pc |
d02b48c6 | 188 | |
02c31fa4 | 189 | # as we stick to -e, CLEARENV ensures that local variables in lower |
a41b0aad AP |
190 | # Makefiles remain local and variable. $${VAR+VAR} is tribute to Korn |
191 | # shell, which [annoyingly enough] terminates unset with error if VAR | |
192 | # is not present:-( TOP= && unset TOP is tribute to HP-UX /bin/sh, | |
193 | # which terminates unset with error if no variable was present:-( | |
194 | CLEARENV= TOP= && unset TOP $${LIB+LIB} $${LIBS+LIBS} \ | |
02c31fa4 AP |
195 | $${INCLUDE+INCLUDE} $${INCLUDES+INCLUDES} \ |
196 | $${DIR+DIR} $${DIRS+DIRS} $${SRC+SRC} \ | |
197 | $${LIBSRC+LIBSRC} $${LIBOBJ+LIBOBJ} $${ALL+ALL} \ | |
198 | $${EXHEADER+EXHEADER} $${HEADER+HEADER} \ | |
199 | $${GENERAL+GENERAL} $${CFLAGS+CFLAGS} \ | |
200 | $${ASFLAGS+ASFLAGS} $${AFLAGS+AFLAGS} \ | |
d36e0ee4 | 201 | $${LDCMD+LDCMD} $${LDFLAGS+LDFLAGS} $${SCRIPTS+SCRIPTS} \ |
2f3c39bc | 202 | $${SHAREDCMD+SHAREDCMD} $${SHAREDFLAGS+SHAREDFLAGS} \ |
02c31fa4 AP |
203 | $${SHARED_LIB+SHARED_LIB} $${LIBEXTRAS+LIBEXTRAS} |
204 | ||
a370537b AP |
205 | BUILDENV= PLATFORM='$(PLATFORM)' PROCESSOR='$(PROCESSOR)' \ |
206 | CC='$(CC)' CFLAG='$(CFLAG)' \ | |
207 | AS='$(CC)' ASFLAG='$(CFLAG) -c' \ | |
208 | AR='$(AR)' NM='$(NM)' RANLIB='$(RANLIB)' \ | |
9b1f24df | 209 | CROSS_COMPILE='$(CROSS_COMPILE)' \ |
d07692cd | 210 | PERL='$(PERL)' ENGDIRS='$(ENGDIRS)' \ |
d5ec7d66 | 211 | SDIRS='$(SDIRS)' LIBRPATH='$(INSTALLTOP)/$(LIBDIR)' \ |
a370537b AP |
212 | INSTALL_PREFIX='$(INSTALL_PREFIX)' \ |
213 | INSTALLTOP='$(INSTALLTOP)' OPENSSLDIR='$(OPENSSLDIR)' \ | |
38437fa1 | 214 | LIBDIR='$(LIBDIR)' \ |
a370537b AP |
215 | MAKEDEPEND='$$$${TOP}/util/domd $$$${TOP} -MD $(MAKEDEPPROG)' \ |
216 | DEPFLAG='-DOPENSSL_NO_DEPRECATED $(DEPFLAG)' \ | |
217 | MAKEDEPPROG='$(MAKEDEPPROG)' \ | |
218 | SHARED_LDFLAGS='$(SHARED_LDFLAGS)' \ | |
219 | KRB5_INCLUDES='$(KRB5_INCLUDES)' LIBKRB5='$(LIBKRB5)' \ | |
8681c66e | 220 | ZLIB_INCLUDE='$(ZLIB_INCLUDE)' LIBZLIB='$(LIBZLIB)' \ |
a370537b AP |
221 | EXE_EXT='$(EXE_EXT)' SHARED_LIBS='$(SHARED_LIBS)' \ |
222 | SHLIB_EXT='$(SHLIB_EXT)' SHLIB_TARGET='$(SHLIB_TARGET)' \ | |
223 | PEX_LIBS='$(PEX_LIBS)' EX_LIBS='$(EX_LIBS)' \ | |
224 | CPUID_OBJ='$(CPUID_OBJ)' \ | |
225 | BN_ASM='$(BN_ASM)' DES_ENC='$(DES_ENC)' \ | |
226 | AES_ENC='$(AES_ENC)' CMLL_ENC='$(CMLL_ENC)' \ | |
227 | BF_ENC='$(BF_ENC)' CAST_ENC='$(CAST_ENC)' \ | |
228 | RC4_ENC='$(RC4_ENC)' RC5_ENC='$(RC5_ENC)' \ | |
229 | SHA1_ASM_OBJ='$(SHA1_ASM_OBJ)' \ | |
230 | MD5_ASM_OBJ='$(MD5_ASM_OBJ)' \ | |
231 | RMD160_ASM_OBJ='$(RMD160_ASM_OBJ)' \ | |
232 | WP_ASM_OBJ='$(WP_ASM_OBJ)' \ | |
886657a6 AP |
233 | MODES_ASM_OBJ='$(MODES_ASM_OBJ)' \ |
234 | ENGINES_ASM_OBJ='$(ENGINES_ASM_OBJ)' \ | |
a370537b | 235 | PERLASM_SCHEME='$(PERLASM_SCHEME)' \ |
7207eca1 DSH |
236 | FIPSLIBDIR='${FIPSLIBDIR}' \ |
237 | FIPSDIR='${FIPSDIR}' \ | |
238 | FIPSCANLIB="$${FIPSCANLIB:-$(FIPSCANLIB)}" \ | |
02c31fa4 AP |
239 | THIS=$${THIS:-$@} MAKEFILE=Makefile MAKEOVERRIDES= |
240 | # MAKEOVERRIDES= effectively "equalizes" GNU-ish and SysV-ish make flavors, | |
241 | # which in turn eliminates ambiguities in variable treatment with -e. | |
d0590fe6 | 242 | |
b480283c RL |
243 | # BUILD_CMD is a generic macro to build a given target in a given |
244 | # subdirectory. The target must be given through the shell variable | |
245 | # `target' and the subdirectory to build in must be given through `dir'. | |
246 | # This macro shouldn't be used directly, use RECURSIVE_BUILD_CMD or | |
247 | # BUILD_ONE_CMD instead. | |
248 | # | |
249 | # BUILD_ONE_CMD is a macro to build a given target in a given | |
250 | # subdirectory if that subdirectory is part of $(DIRS). It requires | |
251 | # exactly the same shell variables as BUILD_CMD. | |
252 | # | |
253 | # RECURSIVE_BUILD_CMD is a macro to build a given target in all | |
254 | # subdirectories defined in $(DIRS). It requires that the target | |
255 | # is given through the shell variable `target'. | |
02c31fa4 AP |
256 | BUILD_CMD= if [ -d "$$dir" ]; then \ |
257 | ( cd $$dir && echo "making $$target in $$dir..." && \ | |
258 | $(CLEARENV) && $(MAKE) -e $(BUILDENV) TOP=.. DIR=$$dir $$target \ | |
259 | ) || exit 1; \ | |
260 | fi | |
261 | RECURSIVE_BUILD_CMD=for dir in $(DIRS); do $(BUILD_CMD); done | |
f5ce5e14 | 262 | BUILD_ONE_CMD=\ |
b3b201b6 | 263 | if expr " $(DIRS) " : ".* $$dir " >/dev/null 2>&1; then \ |
f5ce5e14 RL |
264 | $(BUILD_CMD); \ |
265 | fi | |
88c80b3e | 266 | |
734540f8 | 267 | reflect: |
02c31fa4 | 268 | @[ -n "$(THIS)" ] && $(CLEARENV) && $(MAKE) $(THIS) -e $(BUILDENV) |
734540f8 | 269 | |
4c82171a | 270 | sub_all: build_all |
88c80b3e RL |
271 | build_all: build_libs build_apps build_tests build_tools |
272 | ||
506fec1a | 273 | build_libs: build_crypto build_ssl build_engines |
88c80b3e RL |
274 | |
275 | build_crypto: | |
f5ce5e14 | 276 | @dir=crypto; target=all; $(BUILD_ONE_CMD) |
88c80b3e | 277 | build_ssl: |
f5ce5e14 | 278 | @dir=ssl; target=all; $(BUILD_ONE_CMD) |
506fec1a | 279 | build_engines: |
f5ce5e14 | 280 | @dir=engines; target=all; $(BUILD_ONE_CMD) |
88c80b3e | 281 | build_apps: |
f5ce5e14 | 282 | @dir=apps; target=all; $(BUILD_ONE_CMD) |
88c80b3e | 283 | build_tests: |
f5ce5e14 | 284 | @dir=test; target=all; $(BUILD_ONE_CMD) |
88c80b3e | 285 | build_tools: |
f5ce5e14 | 286 | @dir=tools; target=all; $(BUILD_ONE_CMD) |
ba5477eb RL |
287 | |
288 | all_testapps: build_libs build_testapps | |
289 | build_testapps: | |
f5ce5e14 | 290 | @dir=crypto; target=testapps; $(BUILD_ONE_CMD) |
b436a982 | 291 | |
a168ec1d | 292 | fips_premain_dso$(EXE_EXT): libcrypto.a |
8bfd0ae4 | 293 | [ -z "$(FIPSCANLIB)" ] || $(CC) $(CFLAG) -Iinclude \ |
a168ec1d DSH |
294 | -DFINGERPRINT_PREMAIN_DSO_LOAD -o $@ \ |
295 | $(FIPSLIBDIR)fips_premain.c $(FIPSLIBDIR)fipscanister.o \ | |
296 | libcrypto.a $(EX_LIBS) | |
297 | ||
298 | libcrypto$(SHLIB_EXT): libcrypto.a fips_premain_dso$(EXE_EXT) | |
f4316c36 | 299 | @if [ "$(SHLIB_TARGET)" != "" ]; then \ |
a168ec1d DSH |
300 | if [ "$(FIPSCANLIB)" = "libcrypto" ]; then \ |
301 | FIPSLD_LIBCRYPTO=libcrypto.a ; \ | |
4a18d5c8 | 302 | FIPSLD_CC="$(CC)"; CC=$(FIPSDIR)/bin/fipsld; \ |
a168ec1d DSH |
303 | export CC FIPSLD_CC FIPSLD_LIBCRYPTO; \ |
304 | fi; \ | |
5b56fec6 AP |
305 | $(MAKE) -e SHLIBDIRS=crypto CC="$${CC:-$(CC)}" build-shared && \ |
306 | (touch -c fips_premain_dso$(EXE_EXT) || :); \ | |
f4316c36 RL |
307 | else \ |
308 | echo "There's no support for shared libraries on this platform" >&2; \ | |
d0590fe6 | 309 | exit 1; \ |
f4316c36 | 310 | fi |
0f180d1d | 311 | |
a22fb399 | 312 | libssl$(SHLIB_EXT): libcrypto$(SHLIB_EXT) libssl.a |
f4316c36 | 313 | @if [ "$(SHLIB_TARGET)" != "" ]; then \ |
5ddcb866 | 314 | $(MAKE) SHLIBDIRS=ssl SHLIBDEPS='-lcrypto' build-shared; \ |
f4316c36 RL |
315 | else \ |
316 | echo "There's no support for shared libraries on this platform" >&2; \ | |
d0590fe6 | 317 | exit 1; \ |
f4316c36 | 318 | fi |
b436a982 RL |
319 | |
320 | clean-shared: | |
cfd06a62 | 321 | @set -e; for i in $(SHLIBDIRS); do \ |
a22fb399 RL |
322 | if [ -n "$(SHARED_LIBS_LINK_EXTS)" ]; then \ |
323 | tmp="$(SHARED_LIBS_LINK_EXTS)"; \ | |
324 | for j in $${tmp:-x}; do \ | |
325 | ( set -x; rm -f lib$$i$$j ); \ | |
326 | done; \ | |
327 | fi; \ | |
328 | ( set -x; rm -f lib$$i$(SHLIB_EXT) ); \ | |
49e04548 | 329 | if [ "$(PLATFORM)" = "Cygwin" ]; then \ |
1fe198b6 RL |
330 | ( set -x; rm -f cyg$$i$(SHLIB_EXT) lib$$i$(SHLIB_EXT).a ); \ |
331 | fi; \ | |
b436a982 | 332 | done |
d02b48c6 | 333 | |
a22fb399 | 334 | link-shared: |
a370537b | 335 | @ set -e; for i in $(SHLIBDIRS); do \ |
755c5b33 | 336 | $(MAKE) -f $(HERE)/Makefile.shared -e $(BUILDENV) \ |
a370537b AP |
337 | LIBNAME=$$i LIBVERSION=$(SHLIB_MAJOR).$(SHLIB_MINOR) \ |
338 | LIBCOMPATVERSIONS=";$(SHLIB_VERSION_HISTORY)" \ | |
30afcc07 | 339 | symlink.$(SHLIB_TARGET); \ |
6b86bad5 | 340 | libs="$$libs -l$$i"; \ |
0fd44e2d RL |
341 | done |
342 | ||
30afcc07 RL |
343 | build-shared: do_$(SHLIB_TARGET) link-shared |
344 | ||
345 | do_$(SHLIB_TARGET): | |
a370537b | 346 | @ set -e; libs='-L. $(SHLIBDEPS)'; for i in $(SHLIBDIRS); do \ |
757e9886 | 347 | if [ "$$i" = "ssl" -a -n "$(LIBKRB5)" ]; then \ |
c1269c81 RL |
348 | libs="$(LIBKRB5) $$libs"; \ |
349 | fi; \ | |
02c31fa4 | 350 | $(CLEARENV) && $(MAKE) -f Makefile.shared -e $(BUILDENV) \ |
a370537b AP |
351 | LIBNAME=$$i LIBVERSION=$(SHLIB_MAJOR).$(SHLIB_MINOR) \ |
352 | LIBCOMPATVERSIONS=";$(SHLIB_VERSION_HISTORY)" \ | |
30afcc07 RL |
353 | LIBDEPS="$$libs $(EX_LIBS)" \ |
354 | link_a.$(SHLIB_TARGET); \ | |
c1269c81 | 355 | libs="-l$$i $$libs"; \ |
a3fffd64 RL |
356 | done |
357 | ||
0962fbbf RL |
358 | libcrypto.pc: Makefile |
359 | @ ( echo 'prefix=$(INSTALLTOP)'; \ | |
360 | echo 'exec_prefix=$${prefix}'; \ | |
d5ec7d66 | 361 | echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \ |
0962fbbf RL |
362 | echo 'includedir=$${prefix}/include'; \ |
363 | echo ''; \ | |
364 | echo 'Name: OpenSSL-libcrypto'; \ | |
365 | echo 'Description: OpenSSL cryptography library'; \ | |
366 | echo 'Version: '$(VERSION); \ | |
367 | echo 'Requires: '; \ | |
bf493e8d DSH |
368 | echo 'Libs: -L$${libdir} -lcrypto'; \ |
369 | echo 'Libs.private: $(EX_LIBS)'; \ | |
0962fbbf RL |
370 | echo 'Cflags: -I$${includedir} $(KRB5_INCLUDES)' ) > libcrypto.pc |
371 | ||
372 | libssl.pc: Makefile | |
373 | @ ( echo 'prefix=$(INSTALLTOP)'; \ | |
374 | echo 'exec_prefix=$${prefix}'; \ | |
d5ec7d66 | 375 | echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \ |
0962fbbf RL |
376 | echo 'includedir=$${prefix}/include'; \ |
377 | echo ''; \ | |
378 | echo 'Name: OpenSSL'; \ | |
379 | echo 'Description: Secure Sockets Layer and cryptography libraries'; \ | |
380 | echo 'Version: '$(VERSION); \ | |
381 | echo 'Requires: '; \ | |
bf493e8d DSH |
382 | echo 'Libs: -L$${libdir} -lssl -lcrypto'; \ |
383 | echo 'Libs.private: $(EX_LIBS)'; \ | |
0962fbbf RL |
384 | echo 'Cflags: -I$${includedir} $(KRB5_INCLUDES)' ) > libssl.pc |
385 | ||
42ba5d23 | 386 | openssl.pc: Makefile |
56824b96 RL |
387 | @ ( echo 'prefix=$(INSTALLTOP)'; \ |
388 | echo 'exec_prefix=$${prefix}'; \ | |
d5ec7d66 | 389 | echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \ |
56824b96 RL |
390 | echo 'includedir=$${prefix}/include'; \ |
391 | echo ''; \ | |
392 | echo 'Name: OpenSSL'; \ | |
393 | echo 'Description: Secure Sockets Layer and cryptography libraries and tools'; \ | |
394 | echo 'Version: '$(VERSION); \ | |
395 | echo 'Requires: '; \ | |
bf493e8d DSH |
396 | echo 'Libs: -L$${libdir} -lssl -lcrypto'; \ |
397 | echo 'Libs.private: $(EX_LIBS)'; \ | |
49be7042 | 398 | echo 'Cflags: -I$${includedir} $(KRB5_INCLUDES)' ) > openssl.pc |
56824b96 | 399 | |
c7199e62 BL |
400 | Makefile: Makefile.org Configure config |
401 | @echo "Makefile is older than Makefile.org, Configure or config." | |
49b81422 | 402 | @echo "Reconfigure the source tree (via './config' or 'perl Configure'), please." |
9535d202 BL |
403 | @false |
404 | ||
dfeab068 | 405 | libclean: |
886657a6 | 406 | rm -f *.map *.so *.so.* *.dylib *.dll engines/*.so engines/*.dll engines/*.dylib *.a engines/*.a */lib */*/lib |
dfeab068 | 407 | |
7841edc9 RL |
408 | clean: libclean |
409 | rm -f shlib/*.o *.o core a.out fluff rehash.time testlog make.log cctest cctest.c | |
02c31fa4 AP |
410 | @set -e; target=clean; $(RECURSIVE_BUILD_CMD) |
411 | rm -f $(LIBS) | |
0962fbbf | 412 | rm -f openssl.pc libssl.pc libcrypto.pc |
7841edc9 | 413 | rm -f speed.* .pure |
bb8f3c58 | 414 | rm -f $(TARFILE) |
cfd06a62 | 415 | @set -e; for i in $(ONEDIRS) ;\ |
d02b48c6 | 416 | do \ |
bb8f3c58 | 417 | rm -fr $$i/*; \ |
d02b48c6 RE |
418 | done |
419 | ||
420 | makefile.one: files | |
99aab161 | 421 | $(PERL) util/mk1mf.pl >makefile.one; \ |
d02b48c6 RE |
422 | sh util/do_ms.sh |
423 | ||
bacad008 | 424 | files: |
42ba5d23 | 425 | $(PERL) $(TOP)/util/files.pl Makefile > $(TOP)/MINFO |
02c31fa4 | 426 | @set -e; target=files; $(RECURSIVE_BUILD_CMD) |
d02b48c6 RE |
427 | |
428 | links: | |
6576774b | 429 | @$(PERL) $(TOP)/util/mkdir-p.pl include/openssl |
41d2a336 | 430 | @$(PERL) $(TOP)/util/mklink.pl include/openssl $(EXHEADER) |
02c31fa4 | 431 | @set -e; target=links; $(RECURSIVE_BUILD_CMD) |
d02b48c6 | 432 | |
1cc67fa8 RL |
433 | gentests: |
434 | @(cd test && echo "generating dummy tests (if needed)..." && \ | |
a370537b | 435 | $(CLEARENV) && $(MAKE) -e $(BUILDENV) TESTS='$(TESTS)' OPENSSL_DEBUG_MEMORY=on generate ); |
1cc67fa8 | 436 | |
d02b48c6 | 437 | dclean: |
95553390 | 438 | rm -rf *.bak include/openssl certs/.0 |
02c31fa4 | 439 | @set -e; target=dclean; $(RECURSIVE_BUILD_CMD) |
d02b48c6 | 440 | |
e6e7b5f3 | 441 | rehash: rehash.time |
cbfb39d1 | 442 | rehash.time: certs apps |
9b1f24df | 443 | @if [ -z "$(CROSS_COMPILE)" ]; then \ |
cbfb39d1 | 444 | (OPENSSL="`pwd`/util/opensslwrap.sh"; \ |
6d0624ac | 445 | [ -x "apps/openssl.exe" ] && OPENSSL="apps/openssl.exe" || :; \ |
cbfb39d1 AP |
446 | OPENSSL_DEBUG_MEMORY=on; \ |
447 | export OPENSSL OPENSSL_DEBUG_MEMORY; \ | |
5bb6d965 | 448 | $(PERL) tools/c_rehash certs/demo) && \ |
cbfb39d1 AP |
449 | touch rehash.time; \ |
450 | else :; fi | |
d02b48c6 | 451 | |
58964a49 | 452 | test: tests |
d02b48c6 | 453 | |
73bfb9ad | 454 | tests: rehash |
bb8f3c58 | 455 | @(cd test && echo "testing..." && \ |
c9a17781 DSH |
456 | $(CLEARENV) && $(MAKE) -e $(BUILDENV) TOP=.. TESTS='$(TESTS)' OPENSSL_DEBUG_MEMORY=on OPENSSL_CONF=../apps/openssl.cnf tests ); |
457 | OPENSSL_CONF=apps/openssl.cnf util/opensslwrap.sh version -a | |
d02b48c6 | 458 | |
d7f0ab5f UM |
459 | report: |
460 | @$(PERL) util/selftest.pl | |
461 | ||
d02b48c6 | 462 | depend: |
02c31fa4 | 463 | @set -e; target=depend; $(RECURSIVE_BUILD_CMD) |
d02b48c6 RE |
464 | |
465 | lint: | |
02c31fa4 | 466 | @set -e; target=lint; $(RECURSIVE_BUILD_CMD) |
d02b48c6 RE |
467 | |
468 | tags: | |
a273a282 BL |
469 | rm -f TAGS |
470 | find . -name '[^.]*.[ch]' | xargs etags -a | |
d02b48c6 RE |
471 | |
472 | errors: | |
be60a3fe | 473 | $(PERL) util/ck_errf.pl -strict */*.c */*/*.c |
f6485909 | 474 | $(PERL) util/mkerr.pl -recurse -write |
506fec1a | 475 | (cd engines; $(MAKE) PERL=$(PERL) errors) |
d02b48c6 | 476 | |
a6fbcb42 DSH |
477 | stacks: |
478 | $(PERL) util/mkstack.pl -write | |
479 | ||
7740a1c6 | 480 | util/libeay.num:: |
f6485909 | 481 | $(PERL) util/mkdef.pl crypto update |
7740a1c6 BM |
482 | |
483 | util/ssleay.num:: | |
f6485909 | 484 | $(PERL) util/mkdef.pl ssl update |
7740a1c6 | 485 | |
1d00800e | 486 | crypto/objects/obj_dat.h: crypto/objects/obj_dat.pl crypto/objects/obj_mac.h |
f6485909 | 487 | $(PERL) crypto/objects/obj_dat.pl crypto/objects/obj_mac.h crypto/objects/obj_dat.h |
0357422d | 488 | crypto/objects/obj_mac.h: crypto/objects/objects.pl crypto/objects/objects.txt crypto/objects/obj_mac.num |
f6485909 | 489 | $(PERL) crypto/objects/objects.pl crypto/objects/objects.txt crypto/objects/obj_mac.num crypto/objects/obj_mac.h |
a19c9f17 | 490 | crypto/objects/obj_xref.h: crypto/objects/objxref.pl crypto/objects/obj_xref.txt crypto/objects/obj_mac.num |
aaa29f9e | 491 | $(PERL) crypto/objects/objxref.pl crypto/objects/obj_mac.num crypto/objects/obj_xref.txt >crypto/objects/obj_xref.h |
49e747e6 | 492 | |
2faa930b RL |
493 | apps/openssl-vms.cnf: apps/openssl.cnf |
494 | $(PERL) VMS/VMSify-conf.pl < apps/openssl.cnf > apps/openssl-vms.cnf | |
495 | ||
11cd2397 RL |
496 | crypto/bn/bn_prime.h: crypto/bn/bn_prime.pl |
497 | $(PERL) crypto/bn/bn_prime.pl >crypto/bn/bn_prime.h | |
498 | ||
499 | ||
62c419d6 | 500 | TABLE: Configure |
2330e18b | 501 | (echo 'Output of `Configure TABLE'"':"; \ |
f6485909 | 502 | $(PERL) Configure TABLE) > TABLE |
7740a1c6 | 503 | |
a6fbcb42 | 504 | update: errors stacks util/libeay.num util/ssleay.num crypto/objects/obj_dat.h crypto/objects/obj_xref.h apps/openssl-vms.cnf crypto/bn/bn_prime.h TABLE depend |
7740a1c6 | 505 | |
f9de8446 LJ |
506 | # Build distribution tar-file. As the list of files returned by "find" is |
507 | # pretty long, on several platforms a "too many arguments" error or similar | |
508 | # would occur. Therefore the list of files is temporarily stored into a file | |
509 | # and read directly, requiring GNU-Tar. Call "make TAR=gtar dist" if the normal | |
510 | # tar does not support the --files-from option. | |
d02b48c6 | 511 | tar: |
756b9a00 LJ |
512 | find . -type d -print | xargs chmod 755 |
513 | find . -type f -print | xargs chmod a+r | |
514 | find . -type f -perm -0100 -print | xargs chmod a+x | |
f9de8446 LJ |
515 | find * \! -path CVS/\* \! -path \*/CVS/\* \! -name CVS \! -name .cvsignore \! -name STATUS \! -name TABLE | sort > ../$(TARFILE).list; \ |
516 | $(TAR) $(TARFLAGS) --files-from ../$(TARFILE).list -cvf - | \ | |
5a061129 | 517 | tardy --user_number=0 --user_name=openssl \ |
9ce5db45 RE |
518 | --group_number=0 --group_name=openssl \ |
519 | --prefix=openssl-$(VERSION) - |\ | |
651d0aff | 520 | gzip --best >../$(TARFILE).gz; \ |
f9de8446 | 521 | rm -f ../$(TARFILE).list; \ |
651d0aff | 522 | ls -l ../$(TARFILE).gz |
d02b48c6 | 523 | |
41d2a336 RL |
524 | tar-snap: |
525 | @$(TAR) $(TARFLAGS) -cvf - \ | |
3a7cef3e | 526 | `find * \! -path CVS/\* \! -path \*/CVS/\* \! -name CVS \! -name .cvsignore \! -name STATUS \! -name TABLE \! -name '*.o' \! -name '*.a' \! -name '*.so' \! -name '*.so.*' \! -name 'openssl' \! -name '*test' \! -name '.#*' \! -name '*~' | sort` |\ |
41d2a336 RL |
527 | tardy --user_number=0 --user_name=openssl \ |
528 | --group_number=0 --group_name=openssl \ | |
529 | --prefix=openssl-$(VERSION) - > ../$(TARFILE);\ | |
530 | ls -l ../$(TARFILE) | |
531 | ||
58964a49 | 532 | dist: |
99aab161 | 533 | $(PERL) Configure dist |
d02b48c6 | 534 | @$(MAKE) dist_pem_h |
a370537b AP |
535 | @$(MAKE) SDIRS='$(SDIRS)' clean |
536 | @$(MAKE) TAR='$(TAR)' TARFLAGS='$(TARFLAGS)' tar | |
d02b48c6 RE |
537 | |
538 | dist_pem_h: | |
02c31fa4 | 539 | (cd crypto/pem; $(MAKE) -e $(BUILDENV) pem.h; $(MAKE) clean) |
d02b48c6 | 540 | |
28a80034 RL |
541 | install: all install_docs install_sw |
542 | ||
543 | install_sw: | |
f0588887 | 544 | @$(PERL) $(TOP)/util/mkdir-p.pl $(INSTALL_PREFIX)$(INSTALLTOP)/bin \ |
d5ec7d66 DSH |
545 | $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR) \ |
546 | $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/engines \ | |
547 | $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig \ | |
f0588887 BM |
548 | $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl \ |
549 | $(INSTALL_PREFIX)$(OPENSSLDIR)/misc \ | |
550 | $(INSTALL_PREFIX)$(OPENSSLDIR)/certs \ | |
8d472bdd | 551 | $(INSTALL_PREFIX)$(OPENSSLDIR)/private |
a2ac429d | 552 | @set -e; headerlist="$(EXHEADER)"; for i in $$headerlist;\ |
2a4a0a34 BM |
553 | do \ |
554 | (cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \ | |
555 | chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \ | |
556 | done; | |
02c31fa4 | 557 | @set -e; target=install; $(RECURSIVE_BUILD_CMD) |
886657a6 | 558 | @set -e; liblist="$(LIBS)"; for i in $$liblist ;\ |
d02b48c6 | 559 | do \ |
b436a982 RL |
560 | if [ -f "$$i" ]; then \ |
561 | ( echo installing $$i; \ | |
d5ec7d66 DSH |
562 | cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ |
563 | $(RANLIB) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ | |
564 | chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ | |
565 | mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i ); \ | |
2c975b50 LJ |
566 | fi; \ |
567 | done; | |
cfd06a62 | 568 | @set -e; if [ -n "$(SHARED_LIBS)" ]; then \ |
a22fb399 RL |
569 | tmp="$(SHARED_LIBS)"; \ |
570 | for i in $${tmp:-x}; \ | |
571 | do \ | |
1fe198b6 | 572 | if [ -f "$$i" -o -f "$$i.a" ]; then \ |
a22fb399 | 573 | ( echo installing $$i; \ |
49e04548 | 574 | if [ "$(PLATFORM)" != "Cygwin" ]; then \ |
d5ec7d66 DSH |
575 | cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ |
576 | chmod 555 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ | |
577 | mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i; \ | |
1fe198b6 | 578 | else \ |
447aa490 | 579 | c=`echo $$i | sed 's/^lib\(.*\)\.dll\.a/cyg\1-$(SHLIB_VERSION_NUMBER).dll/'`; \ |
7104c376 RL |
580 | cp $$c $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \ |
581 | chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \ | |
30c08f2e | 582 | mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c; \ |
d5ec7d66 DSH |
583 | cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ |
584 | chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ | |
585 | mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i; \ | |
1fe198b6 | 586 | fi ); \ |
4c1a6e00 LJ |
587 | if expr $(PLATFORM) : 'mingw' > /dev/null; then \ |
588 | ( case $$i in \ | |
589 | *crypto*) i=libeay32.dll;; \ | |
590 | *ssl*) i=ssleay32.dll;; \ | |
591 | esac; \ | |
592 | echo installing $$i; \ | |
593 | cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i.new; \ | |
594 | chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i.new; \ | |
595 | mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i ); \ | |
596 | fi; \ | |
2c975b50 | 597 | fi; \ |
a22fb399 RL |
598 | done; \ |
599 | ( here="`pwd`"; \ | |
a1e11652 | 600 | cd $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR); \ |
4c3a2d64 | 601 | $(MAKE) -f $$here/Makefile HERE="$$here" link-shared ); \ |
e68cb95d RL |
602 | if [ "$(INSTALLTOP)" != "/usr" ]; then \ |
603 | echo 'OpenSSL shared libraries have been installed in:'; \ | |
604 | echo ' $(INSTALLTOP)'; \ | |
605 | echo ''; \ | |
c0cc5c30 | 606 | sed -e '1,/^$$/d' doc/openssl-shared.txt; \ |
e68cb95d | 607 | fi; \ |
a22fb399 | 608 | fi |
d5ec7d66 DSH |
609 | cp libcrypto.pc $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig |
610 | chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libcrypto.pc | |
611 | cp libssl.pc $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig | |
612 | chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libssl.pc | |
613 | cp openssl.pc $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig | |
614 | chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/openssl.pc | |
e6e7b5f3 | 615 | |
60cdb821 UM |
616 | install_html_docs: |
617 | here="`pwd`"; \ | |
618 | for subdir in apps crypto ssl; do \ | |
619 | mkdir -p $(INSTALL_PREFIX)$(HTMLDIR)/$$subdir; \ | |
620 | for i in doc/$$subdir/*.pod; do \ | |
621 | fn=`basename $$i .pod`; \ | |
622 | echo "installing html/$$fn.$(HTMLSUFFIX)"; \ | |
623 | cat $$i \ | |
624 | | sed -r 's/L<([^)]*)(\([0-9]\))?\|([^)]*)(\([0-9]\))?>/L<\1|\3>/g' \ | |
625 | | pod2html --podroot=doc --htmlroot=.. --podpath=apps:crypto:ssl \ | |
626 | | sed -r 's/<!DOCTYPE.*//g' \ | |
627 | > $(INSTALL_PREFIX)$(HTMLDIR)/$$subdir/$$fn.$(HTMLSUFFIX); \ | |
628 | $(PERL) util/extract-names.pl < $$i | \ | |
629 | grep -v $$filecase "^$$fn\$$" | \ | |
630 | (cd $(INSTALL_PREFIX)$(HTMLDIR)/$$subdir; \ | |
631 | while read n; do \ | |
69a0034e | 632 | PLATFORM=$(PLATFORM) $$here/util/point.sh $$fn.$(HTMLSUFFIX) "$$n".$(HTMLSUFFIX); \ |
60cdb821 UM |
633 | done); \ |
634 | done; \ | |
635 | done | |
636 | ||
e6e7b5f3 BM |
637 | install_docs: |
638 | @$(PERL) $(TOP)/util/mkdir-p.pl \ | |
e1c55191 UM |
639 | $(INSTALL_PREFIX)$(MANDIR)/man1 \ |
640 | $(INSTALL_PREFIX)$(MANDIR)/man3 \ | |
641 | $(INSTALL_PREFIX)$(MANDIR)/man5 \ | |
642 | $(INSTALL_PREFIX)$(MANDIR)/man7 | |
6d4943e8 | 643 | @pod2man="`cd ./util; ./pod2mantest $(PERL)`"; \ |
ec9f67f6 RL |
644 | here="`pwd`"; \ |
645 | filecase=; \ | |
94c1672e | 646 | if [ "$(PLATFORM)" = "DJGPP" -o "$(PLATFORM)" = "Cygwin" -o "$(PLATFORM)" = "mingw" ]; then \ |
ec9f67f6 RL |
647 | filecase=-i; \ |
648 | fi; \ | |
cfd06a62 | 649 | set -e; for i in doc/apps/*.pod; do \ |
c6ce792f | 650 | fn=`basename $$i .pod`; \ |
401ee37a | 651 | sec=`$(PERL) util/extract-section.pl 1 < $$i`; \ |
1cc087fe | 652 | echo "installing man$$sec/$$fn.$${sec}$(MANSUFFIX)"; \ |
d13363af | 653 | (cd `$(PERL) util/dirname.pl $$i`; \ |
623e9e66 | 654 | sh -c "$$pod2man \ |
2962243d RL |
655 | --section=$$sec --center=OpenSSL \ |
656 | --release=$(VERSION) `basename $$i`") \ | |
1cc087fe | 657 | > $(INSTALL_PREFIX)$(MANDIR)/man$$sec/$$fn.$${sec}$(MANSUFFIX); \ |
ec9f67f6 | 658 | $(PERL) util/extract-names.pl < $$i | \ |
f6098f2d RL |
659 | (grep -v $$filecase "^$$fn\$$"; true) | \ |
660 | (grep -v "[ ]"; true) | \ | |
ec9f67f6 RL |
661 | (cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \ |
662 | while read n; do \ | |
69a0034e | 663 | PLATFORM=$(PLATFORM) $$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \ |
ec9f67f6 | 664 | done); \ |
f6f99618 | 665 | done; \ |
cfd06a62 | 666 | set -e; for i in doc/crypto/*.pod doc/ssl/*.pod; do \ |
c6ce792f | 667 | fn=`basename $$i .pod`; \ |
401ee37a | 668 | sec=`$(PERL) util/extract-section.pl 3 < $$i`; \ |
1cc087fe | 669 | echo "installing man$$sec/$$fn.$${sec}$(MANSUFFIX)"; \ |
d13363af | 670 | (cd `$(PERL) util/dirname.pl $$i`; \ |
623e9e66 | 671 | sh -c "$$pod2man \ |
2962243d RL |
672 | --section=$$sec --center=OpenSSL \ |
673 | --release=$(VERSION) `basename $$i`") \ | |
1cc087fe | 674 | > $(INSTALL_PREFIX)$(MANDIR)/man$$sec/$$fn.$${sec}$(MANSUFFIX); \ |
ec9f67f6 | 675 | $(PERL) util/extract-names.pl < $$i | \ |
f6098f2d RL |
676 | (grep -v $$filecase "^$$fn\$$"; true) | \ |
677 | (grep -v "[ ]"; true) | \ | |
ec9f67f6 RL |
678 | (cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \ |
679 | while read n; do \ | |
69a0034e | 680 | PLATFORM=$(PLATFORM) $$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \ |
ec9f67f6 | 681 | done); \ |
c6ce792f | 682 | done |
d02b48c6 RE |
683 | |
684 | # DO NOT DELETE THIS LINE -- make depend depends on it. |