New option no-ssl3-method which removes SSLv3_*method
[openssl.git] / makevms.com
1 $!
2 $! MAKEVMS.COM
3 $! Original Author:  UNKNOWN
4 $! Rewritten By:  Robert Byer
5 $!                Vice-President
6 $!                A-Com Computing, Inc.
7 $!                byer@mail.all-net.net
8 $!
9 $! Changes by Richard Levitte <richard@levitte.org>
10 $!            Zoltan Arpadffy <zoli@polarhome.com>
11 $!
12 $! This procedure creates the SSL libraries of "[.xxx.EXE.CRYPTO]LIBCRYPTO.OLB"
13 $! "[.xxx.EXE.SSL]LIBSSL.OLB"
14 $! The "xxx" denotes the machine architecture of ALPHA, IA64 or VAX.
15 $!
16 $! This procedures accepts two command line options listed below.
17 $!
18 $! P1 specifies one of the following build options:
19 $!
20 $!      ALL       Just build "everything".
21 $!      CONFIG    Just build the "[.CRYPTO._xxx]OPENSSLCONF.H" file.
22 $!      BUILDINF  Just build the "[.CRYPTO._xxx]BUILDINF.H" file.
23 $!      SOFTLINKS Just fix the Unix soft links.
24 $!      BUILDALL  Same as ALL, except CONFIG, BUILDINF and SOFTILNKS aren't done.
25 $!      CRYPTO    Just build the "[.xxx.EXE.CRYPTO]LIBCRYPTO.OLB" library.
26 $!      CRYPTO/x  Just build the x part of the
27 $!                "[.xxx.EXE.CRYPTO]LIBCRYPTO.OLB" library.
28 $!      SSL       Just build the "[.xxx.EXE.SSL]LIBSSL.OLB" library.
29 $!      SSL_TASK  Just build the "[.xxx.EXE.SSL]SSL_TASK.EXE" program.
30 $!      TEST      Just build the "[.xxx.EXE.TEST]" test programs for OpenSSL.
31 $!      APPS      Just build the "[.xxx.EXE.APPS]" application programs for OpenSSL.
32 $!      ENGINES   Just build the "[.xxx.EXE.ENGINES]" application programs for OpenSSL.
33 $!
34 $! P2, if defined, specifies the C pointer size.  Ignored on VAX.
35 $!      ("64=ARGV" gives more efficient code with HP C V7.3 or newer.)
36 $!      Supported values are:
37 $!
38 $!      ""       Compile with default (/NOPOINTER_SIZE).
39 $!      32       Compile with /POINTER_SIZE=32 (SHORT).
40 $!      64       Compile with /POINTER_SIZE=64[=ARGV] (LONG[=ARGV]).
41 $!               (Automatically select ARGV if compiler supports it.)
42 $!      64=      Compile with /POINTER_SIZE=64 (LONG).
43 $!      64=ARGV  Compile with /POINTER_SIZE=64=ARGV (LONG=ARGV).
44 $!
45 $! P3 specifies DEBUG or NODEBUG, to compile with or without debugging
46 $!    information.
47 $!
48 $! P4 specifies which compiler to try to compile under.
49 $!
50 $!        VAXC   For VAX C.
51 $!        DECC   For DEC C.
52 $!        GNUC   For GNU C.
53 $!        LINK   To only link the programs from existing object files.
54 $!               (not yet implemented)
55 $!
56 $! If you don't specify a compiler, it will try to determine which
57 $! "C" compiler to use.
58 $!
59 $! P5, if defined, sets a TCP/IP library to use, through one of the following
60 $! keywords:
61 $!
62 $!      UCX             for UCX or UCX emulation
63 $!      TCPIP           for TCP/IP Services or TCP/IP Services emulation
64 $!                      (this is prefered over UCX)
65 $!      SOCKETSHR       for SOCKETSHR+NETLIB
66 $!      NONE            to avoid specifying which TCP/IP implementation to
67 $!                      use at build time (this works with DEC C).  This is
68 $!                      the default.
69 $!
70 $! P6, if defined, sets a compiler thread NOT needed on OpenVMS 7.1 (and up).
71 $!
72 $! P7, if defined, specifies a directory where ZLIB files (zlib.h,
73 $! libz.olb) may be found.  Optionally, a non-default object library
74 $! name may be included ("dev:[dir]libz_64.olb", for example).
75 $!
76 $!
77 $! Announce/identify.
78 $!
79 $ proc = f$environment( "procedure")
80 $ write sys$output "@@@ "+ -
81    f$parse( proc, , , "name")+ f$parse( proc, , , "type")
82 $!
83 $ DEF_ORIG = F$ENVIRONMENT( "DEFAULT")
84 $ ON ERROR THEN GOTO TIDY
85 $ ON CONTROL_C THEN GOTO TIDY
86 $!
87 $! Check if we're in a batch job, and make sure we get to 
88 $! the directory this script is in
89 $!
90 $ IF F$MODE() .EQS. "BATCH"
91 $ THEN
92 $   COMNAME=F$ENVIRONMENT("PROCEDURE")
93 $   COMPATH=F$PARSE("A.;",COMNAME) - "A.;"
94 $   SET DEF 'COMPATH'
95 $ ENDIF
96 $!
97 $! Check What Architecture We Are Using.
98 $!
99 $ IF (F$GETSYI("CPU").LT.128)
100 $ THEN
101 $!
102 $!  The Architecture Is VAX.
103 $!
104 $   ARCH = "VAX"
105 $!
106 $! Else...
107 $!
108 $ ELSE
109 $!
110 $!  The Architecture Is Alpha, IA64 or whatever comes in the future.
111 $!
112 $   ARCH = F$EDIT( F$GETSYI( "ARCH_NAME"), "UPCASE")
113 $   IF (ARCH .EQS. "") THEN ARCH = "UNK"
114 $!
115 $! End The Architecture Check.
116 $!
117 $ ENDIF
118 $!
119 $ ARCHD = ARCH
120 $ LIB32 = "32"
121 $ POINTER_SIZE = ""
122 $!
123 $! Get VMS version.
124 $!
125 $ VMS_VERSION = f$edit( f$getsyi( "VERSION"), "TRIM")
126 $!
127 $! Check To Make Sure We Have Valid Command Line Parameters.
128 $!
129 $ GOSUB CHECK_OPTIONS
130 $!
131 $! Check To See What We Are To Do.
132 $!
133 $ IF (BUILDCOMMAND.EQS."ALL")
134 $ THEN
135 $!
136 $!  Start with building the OpenSSL configuration file.
137 $!
138 $   GOSUB CONFIG
139 $!
140 $!  Create The "BUILDINF.H" Include File.
141 $!
142 $   GOSUB BUILDINF
143 $!
144 $!  Fix The Unix Softlinks.
145 $!
146 $   GOSUB SOFTLINKS
147 $!
148 $ ENDIF
149 $!
150 $ IF (BUILDCOMMAND.EQS."ALL".OR.BUILDCOMMAND.EQS."BUILDALL")
151 $ THEN
152 $!
153 $!  Build The [.xxx.EXE.CRYPTO]LIBCRYPTO.OLB Library.
154 $!
155 $   GOSUB CRYPTO
156 $!
157 $!  Build The [.xxx.EXE.SSL]LIBSSL.OLB Library.
158 $!
159 $   GOSUB SSL
160 $!
161 $!  Build The [.xxx.EXE.SSL]SSL_TASK.EXE DECNet SSL Engine.
162 $!
163 $   GOSUB SSL_TASK
164 $!
165 $!  Build The [.xxx.EXE.TEST] OpenSSL Test Utilities.
166 $!
167 $   GOSUB TEST
168 $!
169 $!  Build The [.xxx.EXE.APPS] OpenSSL Application Utilities.
170 $!
171 $   GOSUB APPS
172 $!
173 $!  Build The [.xxx.EXE.ENGINES] OpenSSL Shareable Engines.
174 $!
175 $   GOSUB ENGINES
176 $!
177 $! Else...
178 $!
179 $ ELSE
180 $!
181 $!    Build Just What The User Wants Us To Build.
182 $!
183 $     GOSUB 'BUILDCOMMAND'
184 $!
185 $ ENDIF
186 $!
187 $! Time To EXIT.
188 $!
189 $ GOTO TIDY
190 $!
191 $! Rebuild The [.CRYPTO._xxx]OPENSSLCONF.H" file.
192 $!
193 $ CONFIG:
194 $!
195 $! Tell The User We Are Creating The [.CRYPTO._xxx]OPENSSLCONF.H File.
196 $!
197 $ WRITE SYS$OUTPUT "Creating [.CRYPTO.''ARCHD']OPENSSLCONF.H Include File."
198 $!
199 $! First, make sure the directory exists.
200 $!
201 $ IF F$PARSE("SYS$DISK:[.CRYPTO.''ARCHD']") .EQS. "" THEN -
202      CREATE/DIRECTORY SYS$DISK:[.CRYPTO.'ARCHD']
203 $!
204 $! Different tar/UnZip versions/option may have named the file differently
205 $ IF F$SEARCH("[.crypto]opensslconf.h_in") .NES. ""
206 $ THEN
207 $   OPENSSLCONF_H_IN = "[.crypto]opensslconf.h_in"
208 $ ELSE
209 $   IF F$SEARCH( "[.crypto]opensslconf_h.in") .NES. ""
210 $   THEN
211 $     OPENSSLCONF_H_IN = "[.crypto]opensslconf_h.in"
212 $   ELSE
213 $     ! For ODS-5
214 $     IF F$SEARCH( "[.crypto]opensslconf.h.in") .NES. ""
215 $     THEN
216 $       OPENSSLCONF_H_IN = "[.crypto]opensslconf.h.in"
217 $     ELSE
218 $       WRITE SYS$ERROR "Couldn't find a [.crypto]opensslconf.h.in.  Exiting!"
219 $       $STATUS = %X00018294 ! "%RMS-F-FNF, file not found".
220 $       GOTO TIDY
221 $     ENDIF
222 $   ENDIF
223 $ ENDIF
224 $!
225 $! Create The [.CRYPTO._xxx]OPENSSLCONF.H File.
226 $! Make sure it has the right format.
227 $!
228 $ OSCH_NAME = "SYS$DISK:[.CRYPTO.''ARCHD']OPENSSLCONF.H"
229 $ CREATE /FDL=SYS$INPUT: 'OSCH_NAME'
230 RECORD
231         FORMAT stream_lf
232 $ OPEN /APPEND H_FILE 'OSCH_NAME'
233 $!
234 $! Write The [.CRYPTO._xxx]OPENSSLCONF.H File.
235 $!
236 $ WRITE H_FILE "/* This file was automatically built using makevms.com */"
237 $ WRITE H_FILE "/* and ''OPENSSLCONF_H_IN' */"
238 $!
239 $! Write a few macros that indicate how this system was built.
240 $!
241 $ WRITE H_FILE ""
242 $ WRITE H_FILE "#ifndef OPENSSL_SYS_VMS"
243 $ WRITE H_FILE "# define OPENSSL_SYS_VMS"
244 $ WRITE H_FILE "#endif"
245 $
246 $! One of the best way to figure out what the list should be is to do
247 $! the following on a Unix system:
248 $!   grep OPENSSL_NO_ crypto/*/*.h ssl/*.h engines/*.h engines/*/*.h|grep ':# *if'|sed -e 's/^.*def //'|sort|uniq
249 $! For that reason, the list will also always end up in alphabetical order
250 $ CONFIG_LOGICALS := AES,-
251                      ASM,INLINE_ASM,-
252                      BF,-
253                      BIO,-
254                      BUFFER,-
255                      BUF_FREELISTS,-
256                      CAMELLIA,-
257                      CAST,-
258                      CMS,-
259                      COMP,-
260                      DEPRECATED,-
261                      DES,-
262                      DGRAM,-
263                      DH,-
264                      DSA,-
265                      EC,-
266                      EC2M,-
267                      ECDH,-
268                      ECDSA,-
269                      EC_NISTP_64_GCC_128,-
270                      ENGINE,-
271                      ERR,-
272                      EVP,-
273                      FP_API,-
274                      GMP,-
275                      GOST,-
276                      HASH_COMP,-
277                      HMAC,-
278                      IDEA,-
279                      JPAKE,-
280                      KRB5,-
281                      LHASH,-
282                      MD2,-
283                      MD4,-
284                      MD5,-
285                      MDC2,-
286                      NEXTPROTONEG,-
287                      OCSP,-
288                      PSK,-
289                      RC2,-
290                      RC4,-
291                      RC5,-
292                      RFC3779,-
293                      RIPEMD,-
294                      RSA,-
295                      SEED,-
296                      SHA,-
297                      SHA0,-
298                      SHA1,-
299                      SHA256,-
300                      SHA512,-
301                      SOCK,-
302                      SRP,-
303                      SSL2,-
304                      SSL_INTERN,-
305                      STACK,-
306                      STATIC_ENGINE,-
307                      STDIO,-
308                      STORE,-
309                      TLSEXT,-
310                      WHIRLPOOL,-
311                      X509
312 $! Add a few that we know about
313 $ CONFIG_LOGICALS := 'CONFIG_LOGICALS',-
314                      THREADS
315 $! The following rules, which dictate how some algorithm choices affect
316 $! others, are picked from Configure.
317 $! Quick syntax:
318 $!  list = item[ ; list]
319 $!  item = algos / dependents
320 $!  algos = algo [, algos]
321 $!  dependents = dependent [, dependents]
322 $! When a list of algos is specified in one item, it means that they must
323 $! all be disabled for the rule to apply.
324 $! When a list of dependents is specified in one item, it means that they
325 $! will all be disabled if the rule applies.
326 $! Rules are checked sequentially.  If a rule disables an algorithm, it will
327 $! affect all following rules that depend on that algorithm being disabled.
328 $! To force something to be enabled or disabled, have no algorithms in the
329 $! algos part.
330 $ CONFIG_DISABLE_RULES := RIJNDAEL/AES;-
331                           DES/MDC2;-
332                           EC/ECDSA,ECDH;-
333                           MD5/SSL2,SSL3,TLS1;-
334                           SHA/SSL3,TLS1;-
335                           RSA/SSL2;-
336                           RSA,DSA/SSL2;-
337                           DH/SSL3,TLS1;-
338                           TLS1/TLSEXT;-
339                           EC/GOST;-
340                           DSA/GOST;-
341                           DH/GOST;-
342                           /STATIC_ENGINE;-
343                           /KRB5;-
344                           /EC_NISTP_64_GCC_128;-
345                           /GMP;-
346                           /MD2;-
347                           /RC5;-
348                           /RFC3779;-
349                           /SCTP
350 $ CONFIG_ENABLE_RULES := ZLIB_DYNAMIC/ZLIB;-
351                          /THREADS
352 $
353 $! Architecture specific rule addtions
354 $ IF ARCH .EQS. "VAX"
355 $ THEN
356 $   ! Disable algorithms that require 64-bit integers in C
357 $   CONFIG_DISABLE_RULES = CONFIG_DISABLE_RULES + -
358                            ";/GOST" + -
359                            ";/WHIRLPOOL"
360 $ ENDIF
361 $
362 $ CONFIG_LOG_I = 0
363 $ CONFIG_LOG_LOOP1:
364 $   CONFIG_LOG_E = F$EDIT(F$ELEMENT(CONFIG_LOG_I,",",CONFIG_LOGICALS),"TRIM")
365 $   CONFIG_LOG_I = CONFIG_LOG_I + 1
366 $   IF CONFIG_LOG_E .EQS. "" THEN GOTO CONFIG_LOG_LOOP1
367 $   IF CONFIG_LOG_E .EQS. "," THEN GOTO CONFIG_LOG_LOOP1_END
368 $   IF F$TRNLNM("OPENSSL_NO_"+CONFIG_LOG_E)
369 $   THEN
370 $       CONFIG_DISABLED_'CONFIG_LOG_E' := YES
371 $       CONFIG_ENABLED_'CONFIG_LOG_E' := NO
372 $       CONFIG_CHANGED_'CONFIG_LOG_E' := YES
373 $   ELSE
374 $       CONFIG_DISABLED_'CONFIG_LOG_E' := NO
375 $       CONFIG_ENABLED_'CONFIG_LOG_E' := YES
376 $       ! Because all algorithms are assumed enabled by default
377 $       CONFIG_CHANGED_'CONFIG_LOG_E' := NO
378 $   ENDIF
379 $   GOTO CONFIG_LOG_LOOP1
380 $ CONFIG_LOG_LOOP1_END:
381 $
382 $! Apply cascading disable rules
383 $ CONFIG_DISABLE_I = 0
384 $ CONFIG_DISABLE_LOOP0:
385 $   CONFIG_DISABLE_E = F$EDIT(F$ELEMENT(CONFIG_DISABLE_I,";", -
386      CONFIG_DISABLE_RULES),"TRIM")
387 $   CONFIG_DISABLE_I = CONFIG_DISABLE_I + 1
388 $   IF CONFIG_DISABLE_E .EQS. "" THEN GOTO CONFIG_DISABLE_LOOP0
389 $   IF CONFIG_DISABLE_E .EQS. ";" THEN GOTO CONFIG_DISABLE_LOOP0_END
390 $
391 $   CONFIG_DISABLE_ALGOS = F$EDIT(F$ELEMENT(0,"/",CONFIG_DISABLE_E),"TRIM")
392 $   CONFIG_DISABLE_DEPENDENTS = F$EDIT(F$ELEMENT(1,"/",CONFIG_DISABLE_E),"TRIM")
393 $   TO_DISABLE := YES
394 $   CONFIG_ALGO_I = 0
395 $   CONFIG_DISABLE_LOOP1:
396 $     CONFIG_ALGO_E = F$EDIT(F$ELEMENT(CONFIG_ALGO_I,",", -
397        CONFIG_DISABLE_ALGOS),"TRIM")
398 $     CONFIG_ALGO_I = CONFIG_ALGO_I + 1
399 $     IF CONFIG_ALGO_E .EQS. "" THEN GOTO CONFIG_DISABLE_LOOP1
400 $     IF CONFIG_ALGO_E .EQS. "," THEN GOTO CONFIG_DISABLE_LOOP1_END
401 $     IF F$TYPE(CONFIG_DISABLED_'CONFIG_ALGO_E') .EQS. ""
402 $     THEN
403 $       TO_DISABLE := NO
404 $     ELSE
405 $       IF .NOT. CONFIG_DISABLED_'CONFIG_ALGO_E' THEN TO_DISABLE := NO
406 $     ENDIF
407 $     GOTO CONFIG_DISABLE_LOOP1
408 $   CONFIG_DISABLE_LOOP1_END:
409 $
410 $   IF TO_DISABLE
411 $   THEN
412 $     CONFIG_DEPENDENT_I = 0
413 $     CONFIG_DISABLE_LOOP2:
414 $       CONFIG_DEPENDENT_E = F$EDIT(F$ELEMENT(CONFIG_DEPENDENT_I,",", -
415          CONFIG_DISABLE_DEPENDENTS),"TRIM")
416 $       CONFIG_DEPENDENT_I = CONFIG_DEPENDENT_I + 1
417 $       IF CONFIG_DEPENDENT_E .EQS. "" THEN GOTO CONFIG_DISABLE_LOOP2
418 $       IF CONFIG_DEPENDENT_E .EQS. "," THEN GOTO CONFIG_DISABLE_LOOP2_END
419 $       CONFIG_DISABLED_'CONFIG_DEPENDENT_E' := YES
420 $       CONFIG_ENABLED_'CONFIG_DEPENDENT_E' := NO
421 $       ! Better not to assume defaults at this point...
422 $       CONFIG_CHANGED_'CONFIG_DEPENDENT_E' := YES
423 $       WRITE SYS$ERROR -
424          "''CONFIG_DEPENDENT_E' disabled by rule ''CONFIG_DISABLE_E'"
425 $       GOTO CONFIG_DISABLE_LOOP2
426 $     CONFIG_DISABLE_LOOP2_END:
427 $   ENDIF
428 $   GOTO CONFIG_DISABLE_LOOP0
429 $ CONFIG_DISABLE_LOOP0_END:
430 $       
431 $! Apply cascading enable rules
432 $ CONFIG_ENABLE_I = 0
433 $ CONFIG_ENABLE_LOOP0:
434 $   CONFIG_ENABLE_E = F$EDIT(F$ELEMENT(CONFIG_ENABLE_I,";", -
435      CONFIG_ENABLE_RULES),"TRIM")
436 $   CONFIG_ENABLE_I = CONFIG_ENABLE_I + 1
437 $   IF CONFIG_ENABLE_E .EQS. "" THEN GOTO CONFIG_ENABLE_LOOP0
438 $   IF CONFIG_ENABLE_E .EQS. ";" THEN GOTO CONFIG_ENABLE_LOOP0_END
439 $
440 $   CONFIG_ENABLE_ALGOS = F$EDIT(F$ELEMENT(0,"/",CONFIG_ENABLE_E),"TRIM")
441 $   CONFIG_ENABLE_DEPENDENTS = F$EDIT(F$ELEMENT(1,"/",CONFIG_ENABLE_E),"TRIM")
442 $   TO_ENABLE := YES
443 $   CONFIG_ALGO_I = 0
444 $   CONFIG_ENABLE_LOOP1:
445 $     CONFIG_ALGO_E = F$EDIT(F$ELEMENT(CONFIG_ALGO_I,",", -
446        CONFIG_ENABLE_ALGOS),"TRIM")
447 $     CONFIG_ALGO_I = CONFIG_ALGO_I + 1
448 $     IF CONFIG_ALGO_E .EQS. "" THEN GOTO CONFIG_ENABLE_LOOP1
449 $     IF CONFIG_ALGO_E .EQS. "," THEN GOTO CONFIG_ENABLE_LOOP1_END
450 $     IF F$TYPE(CONFIG_ENABLED_'CONFIG_ALGO_E') .EQS. ""
451 $     THEN
452 $       TO_ENABLE := NO
453 $     ELSE
454 $       IF .NOT. CONFIG_ENABLED_'CONFIG_ALGO_E' THEN TO_ENABLE := NO
455 $     ENDIF
456 $     GOTO CONFIG_ENABLE_LOOP1
457 $   CONFIG_ENABLE_LOOP1_END:
458 $
459 $   IF TO_ENABLE
460 $   THEN
461 $     CONFIG_DEPENDENT_I = 0
462 $     CONFIG_ENABLE_LOOP2:
463 $       CONFIG_DEPENDENT_E = F$EDIT(F$ELEMENT(CONFIG_DEPENDENT_I,",", -
464          CONFIG_ENABLE_DEPENDENTS),"TRIM")
465 $       CONFIG_DEPENDENT_I = CONFIG_DEPENDENT_I + 1
466 $       IF CONFIG_DEPENDENT_E .EQS. "" THEN GOTO CONFIG_ENABLE_LOOP2
467 $       IF CONFIG_DEPENDENT_E .EQS. "," THEN GOTO CONFIG_ENABLE_LOOP2_END
468 $       CONFIG_DISABLED_'CONFIG_DEPENDENT_E' := NO
469 $       CONFIG_ENABLED_'CONFIG_DEPENDENT_E' := YES
470 $       ! Better not to assume defaults at this point...
471 $       CONFIG_CHANGED_'CONFIG_DEPENDENT_E' := YES
472 $       WRITE SYS$ERROR -
473          "''CONFIG_DEPENDENT_E' enabled by rule ''CONFIG_ENABLE_E'"
474 $       GOTO CONFIG_ENABLE_LOOP2
475 $     CONFIG_ENABLE_LOOP2_END:
476 $   ENDIF
477 $   GOTO CONFIG_ENABLE_LOOP0
478 $ CONFIG_ENABLE_LOOP0_END:
479 $
480 $! Write to the configuration
481 $ CONFIG_LOG_I = 0
482 $ CONFIG_LOG_LOOP2:
483 $   CONFIG_LOG_E = F$EDIT(F$ELEMENT(CONFIG_LOG_I,",",CONFIG_LOGICALS),"TRIM")
484 $   CONFIG_LOG_I = CONFIG_LOG_I + 1
485 $   IF CONFIG_LOG_E .EQS. "" THEN GOTO CONFIG_LOG_LOOP2
486 $   IF CONFIG_LOG_E .EQS. "," THEN GOTO CONFIG_LOG_LOOP2_END
487 $   IF CONFIG_CHANGED_'CONFIG_LOG_E'
488 $   THEN
489 $     IF CONFIG_DISABLED_'CONFIG_LOG_E'
490 $     THEN
491 $       WRITE H_FILE "#ifndef OPENSSL_NO_",CONFIG_LOG_E
492 $       WRITE H_FILE "# define OPENSSL_NO_",CONFIG_LOG_E
493 $       WRITE H_FILE "#endif"
494 $     ELSE
495 $       WRITE H_FILE "#ifndef OPENSSL_",CONFIG_LOG_E
496 $       WRITE H_FILE "# define OPENSSL_",CONFIG_LOG_E
497 $       WRITE H_FILE "#endif"
498 $     ENDIF
499 $   ENDIF
500 $   GOTO CONFIG_LOG_LOOP2
501 $ CONFIG_LOG_LOOP2_END:
502 $!
503 $ WRITE H_FILE ""
504 $ WRITE H_FILE "/* 2011-02-23 SMS."
505 $ WRITE H_FILE " * On VMS (V8.3), setvbuf() doesn't support a 64-bit"
506 $ WRITE H_FILE " * ""in"" pointer, and the help says:"
507 $ WRITE H_FILE " *       Please note that the previously documented"
508 $ WRITE H_FILE " *       value _IONBF is not supported."
509 $ WRITE H_FILE " * So, skip it on VMS."
510 $ WRITE H_FILE " */"
511 $ WRITE H_FILE "#define OPENSSL_NO_SETVBUF_IONBF"
512 $ WRITE H_FILE "/* STCP support comes with TCPIP 5.7 ECO 2 "
513 $ WRITE H_FILE " * enable on newer systems / 2012-02-24 arpadffy */"
514 $ WRITE H_FILE "#define OPENSSL_NO_SCTP"
515 $ WRITE H_FILE ""
516 $!
517 $! Add in the common "crypto/opensslconf.h.in".
518 $!
519 $ TYPE 'OPENSSLCONF_H_IN' /OUTPUT=H_FILE:
520 $!
521 $ IF ARCH .NES. "VAX"
522 $ THEN
523 $!
524 $!  Write the non-VAX specific data
525 $!
526 $   WRITE H_FILE "#if defined(HEADER_RC4_H)"
527 $   WRITE H_FILE "#undef RC4_INT"
528 $   WRITE H_FILE "#define RC4_INT unsigned int"
529 $   WRITE H_FILE "#undef RC4_CHUNK"
530 $   WRITE H_FILE "#define RC4_CHUNK unsigned long long"
531 $   WRITE H_FILE "#endif"
532 $!
533 $   WRITE H_FILE "#if defined(HEADER_DES_LOCL_H)"
534 $   WRITE H_FILE "#undef DES_LONG"
535 $   WRITE H_FILE "#define DES_LONG unsigned int"
536 $   WRITE H_FILE "#undef DES_PTR"
537 $   WRITE H_FILE "#define DES_PTR"
538 $   WRITE H_FILE "#undef DES_RISC1"
539 $   WRITE H_FILE "#undef DES_RISC2"
540 $   WRITE H_FILE "#define DES_RISC1"
541 $   WRITE H_FILE "#undef DES_UNROLL"
542 $   WRITE H_FILE "#define DES_UNROLL"
543 $   WRITE H_FILE "#endif"
544 $!
545 $   WRITE H_FILE "#if defined(HEADER_BN_H)"
546 $   WRITE H_FILE "#undef BN_LLONG"      ! Never define with SIXTY_FOUR_BIT
547 $   WRITE H_FILE "#undef SIXTY_FOUR_BIT_LONG"
548 $   WRITE H_FILE "#undef SIXTY_FOUR_BIT"
549 $   WRITE H_FILE "#define SIXTY_FOUR_BIT"
550 $   WRITE H_FILE "#undef THIRTY_TWO_BIT"
551 $   WRITE H_FILE "#undef SIXTEEN_BIT"
552 $   WRITE H_FILE "#undef EIGHT_BIT"
553 $   WRITE H_FILE "#endif"
554 $
555 $   WRITE H_FILE "#undef OPENSSL_EXPORT_VAR_AS_FUNCTION"
556 $!
557 $!  Else...
558 $!
559 $ ELSE
560 $!
561 $!  Write the VAX specific data
562 $!
563 $   WRITE H_FILE "#if defined(HEADER_RC4_H)"
564 $   WRITE H_FILE "#undef RC4_INT"
565 $   WRITE H_FILE "#define RC4_INT unsigned char"
566 $   WRITE H_FILE "#undef RC4_CHUNK"
567 $   WRITE H_FILE "#define RC4_CHUNK unsigned long"
568 $   WRITE H_FILE "#endif"
569 $!
570 $   WRITE H_FILE "#if defined(HEADER_DES_LOCL_H)"
571 $   WRITE H_FILE "#undef DES_LONG"
572 $   WRITE H_FILE "#define DES_LONG unsigned long"
573 $   WRITE H_FILE "#undef DES_PTR"
574 $   WRITE H_FILE "#define DES_PTR"
575 $   WRITE H_FILE "#undef DES_RISC1"
576 $   WRITE H_FILE "#undef DES_RISC2"
577 $   WRITE H_FILE "#undef DES_UNROLL"
578 $   WRITE H_FILE "#endif"
579 $!
580 $   WRITE H_FILE "#if defined(HEADER_BN_H)"
581 $   WRITE H_FILE "#undef BN_LLONG"      ! VAX C/DEC C doesn't have long long
582 $   WRITE H_FILE "#undef SIXTY_FOUR_BIT_LONG"
583 $   WRITE H_FILE "#undef SIXTY_FOUR_BIT"
584 $   WRITE H_FILE "#undef THIRTY_TWO_BIT"
585 $   WRITE H_FILE "#define THIRTY_TWO_BIT"
586 $   WRITE H_FILE "#undef SIXTEEN_BIT"
587 $   WRITE H_FILE "#undef EIGHT_BIT"
588 $   WRITE H_FILE "#endif"
589 $!
590 $! Oddly enough, the following symbol is tested in crypto/sha/sha512.c
591 $! before sha.h gets included (and HEADER_SHA_H defined), so we will not
592 $! protect this one...
593 $   WRITE H_FILE "#undef OPENSSL_NO_SHA512"
594 $   WRITE H_FILE "#define OPENSSL_NO_SHA512"
595 $!
596 $   WRITE H_FILE "#undef OPENSSL_EXPORT_VAR_AS_FUNCTION"
597 $   WRITE H_FILE "#define OPENSSL_EXPORT_VAR_AS_FUNCTION"
598 $!
599 $!  End
600 $!
601 $ ENDIF
602 $!
603 $! Close the [.CRYPTO._xxx]OPENSSLCONF.H file
604 $!
605 $ CLOSE H_FILE
606 $!
607 $! Purge The [.CRYPTO._xxx]OPENSSLCONF.H file
608 $!
609 $ PURGE SYS$DISK:[.CRYPTO.'ARCHD']OPENSSLCONF.H
610 $!
611 $! That's All, Time To RETURN.
612 $!
613 $ RETURN
614 $!
615 $! Rebuild The "[.CRYPTO._xxx]BUILDINF.H" file.
616 $!
617 $ BUILDINF:
618 $!
619 $! Tell The User We Are Creating The [.CRYPTO._xxx]BUILDINF.H File.
620 $!
621 $ WRITE SYS$OUTPUT "Creating [.CRYPTO.''ARCHD']BUILDINF.H Include File."
622 $!
623 $! Create The [.CRYPTO._xxx]BUILDINF.H File.
624 $!
625 $ BIH_NAME = "SYS$DISK:[.CRYPTO.''ARCHD']BUILDINF.H"
626 $ CREATE /FDL=SYS$INPUT: 'BIH_NAME'
627 RECORD
628         FORMAT stream_lf
629 $!
630 $ OPEN /APPEND H_FILE 'bih_name'
631 $!
632 $! Get The Current Date & Time.
633 $!
634 $ TIME = F$TIME()
635 $!
636 $! Write The [.CRYPTO._xxx]BUILDINF.H File.
637 $!
638 $ CFLAGS = ""
639 $ if (POINTER_SIZE .nes. "")
640 $ then
641 $   CFLAGS = CFLAGS+ "/POINTER_SIZE=''POINTER_SIZE'"
642 $ endif
643 $ if (ZLIB .nes. "")
644 $ then
645 $   if (CFLAGS .nes. "") then CFLAGS = CFLAGS+ " "
646 $   CFLAGS = CFLAGS+ "/DEFINE=ZLIB"
647 $ endif
648 $! 
649 $ WRITE H_FILE "#define CFLAGS ""''CFLAGS'"""
650 $ WRITE H_FILE "#define PLATFORM ""VMS ''ARCHD' ''VMS_VERSION'"""
651 $ WRITE H_FILE "#define DATE ""''TIME'"" "
652 $!
653 $! Close The [.CRYPTO._xxx]BUILDINF.H File.
654 $!
655 $ CLOSE H_FILE
656 $!
657 $! Purge The [.CRYPTO._xxx]BUILDINF.H File.
658 $!
659 $ PURGE SYS$DISK:[.CRYPTO.'ARCHD']BUILDINF.H
660 $!
661 $! Delete [.CRYPTO]BUILDINF.H File, as there might be some residue from Unix.
662 $!
663 $ IF F$SEARCH("[.CRYPTO]BUILDINF.H") .NES. "" THEN -
664      DELETE SYS$DISK:[.CRYPTO]BUILDINF.H;*
665 $!
666 $! That's All, Time To RETURN.
667 $!
668 $ RETURN
669 $!
670 $! Copy a lot of files around.
671 $!
672 $ SOFTLINKS: 
673 $!
674 $!!!! Tell The User We Are Partly Rebuilding The [.APPS] Directory.
675 $!!!!
676 $!!! WRITE SYS$OUTPUT "Rebuilding The '[.APPS]MD4.C' File."
677 $!!!!
678 $!!! DELETE SYS$DISK:[.APPS]MD4.C;*
679 $!!!!
680 $!!!! Copy MD4.C from [.CRYPTO.MD4] into [.APPS]
681 $!!!!
682 $!!! COPY SYS$DISK:[.CRYPTO.MD4]MD4.C SYS$DISK:[.APPS]
683 $!
684 $! Ensure that the [.include.openssl] directory contains a full set of
685 $! real header files.  The distribution kit may have left real or fake
686 $! symlinks there.  Rather than think about what's there, simply delete
687 $! the destination files (fake or real symlinks) before copying the real
688 $! header files in.  (Copying a real header file onto a real symlink
689 $! merely duplicates the real header file at its source.)
690 $!
691 $! Tell The User We Are Rebuilding The [.include.openssl] Directory.
692 $!
693 $ WRITE SYS$OUTPUT "Rebuilding The '[.include.openssl]' Directory."
694 $!
695 $! First, make sure the directory exists.  If it did exist, delete all
696 $! the existing header files (or fake or real symlinks).
697 $!
698 $ if f$parse( "sys$disk:[.include.openssl]") .eqs. ""
699 $ then
700 $   create /directory sys$disk:[.include.openssl]
701 $ else
702 $   delete sys$disk:[.include.openssl]*.h;*
703 $ endif
704 $!
705 $! Copy All The ".H" Files From The Main Directory.
706 $!
707 $ EXHEADER := e_os2.h
708 $ copy 'exheader' sys$disk:[.include.openssl]
709 $!
710 $! Copy All The ".H" Files From The [.CRYPTO] Directory Tree.
711 $!
712 $ SDIRS := , -
713    'ARCHD', -
714    OBJECTS, -
715    MD4, MD5, SHA, MDC2, HMAC, RIPEMD, WHRLPOOL, -
716    DES, AES, RC2, RC4, IDEA, BF, CAST, CAMELLIA, SEED, MODES, -
717    BN, EC, RSA, DSA, ECDSA, DH, ECDH, DSO, ENGINE, -
718    BUFFER, BIO, STACK, LHASH, RAND, ERR, -
719    EVP, ASN1, PEM, X509, X509V3, CONF, TXT_DB, PKCS7, PKCS12, -
720    COMP, OCSP, UI, KRB5, -
721    CMS, PQUEUE, TS, JPAKE, SRP, STORE, CMAC
722 $!
723 $ EXHEADER_ := crypto.h, opensslv.h, ebcdic.h, symhacks.h, ossl_typ.h
724 $ EXHEADER_'ARCHD' := opensslconf.h
725 $ EXHEADER_OBJECTS := objects.h, obj_mac.h
726 $ EXHEADER_MD2 := md2.h
727 $ EXHEADER_MD4 := md4.h
728 $ EXHEADER_MD5 := md5.h
729 $ EXHEADER_SHA := sha.h
730 $ EXHEADER_MDC2 := mdc2.h
731 $ EXHEADER_HMAC := hmac.h
732 $ EXHEADER_RIPEMD := ripemd.h
733 $ EXHEADER_WHRLPOOL := whrlpool.h
734 $ EXHEADER_DES := des.h, des_old.h
735 $ EXHEADER_AES := aes.h
736 $ EXHEADER_RC2 := rc2.h
737 $ EXHEADER_RC4 := rc4.h
738 $ EXHEADER_RC5 := rc5.h
739 $ EXHEADER_IDEA := idea.h
740 $ EXHEADER_BF := blowfish.h
741 $ EXHEADER_CAST := cast.h
742 $ EXHEADER_CAMELLIA := camellia.h
743 $ EXHEADER_SEED := seed.h
744 $ EXHEADER_MODES := modes.h
745 $ EXHEADER_BN := bn.h
746 $ EXHEADER_EC := ec.h
747 $ EXHEADER_RSA := rsa.h
748 $ EXHEADER_DSA := dsa.h
749 $ EXHEADER_ECDSA := ecdsa.h
750 $ EXHEADER_DH := dh.h
751 $ EXHEADER_ECDH := ecdh.h
752 $ EXHEADER_DSO := dso.h
753 $ EXHEADER_ENGINE := engine.h
754 $ EXHEADER_BUFFER := buffer.h
755 $ EXHEADER_BIO := bio.h
756 $ EXHEADER_STACK := stack.h, safestack.h
757 $ EXHEADER_LHASH := lhash.h
758 $ EXHEADER_RAND := rand.h
759 $ EXHEADER_ERR := err.h
760 $ EXHEADER_EVP := evp.h
761 $ EXHEADER_ASN1 := asn1.h, asn1_mac.h, asn1t.h
762 $ EXHEADER_PEM := pem.h, pem2.h
763 $ EXHEADER_X509 := x509.h, x509_vfy.h
764 $ EXHEADER_X509V3 := x509v3.h
765 $ EXHEADER_CONF := conf.h, conf_api.h
766 $ EXHEADER_TXT_DB := txt_db.h
767 $ EXHEADER_PKCS7 := pkcs7.h
768 $ EXHEADER_PKCS12 := pkcs12.h
769 $ EXHEADER_COMP := comp.h
770 $ EXHEADER_OCSP := ocsp.h
771 $ EXHEADER_UI := ui.h, ui_compat.h
772 $ EXHEADER_KRB5 := krb5_asn.h
773 $ EXHEADER_CMS := cms.h
774 $ EXHEADER_PQUEUE := pqueue.h
775 $ EXHEADER_TS := ts.h
776 $ EXHEADER_JPAKE := jpake.h
777 $ EXHEADER_SRP := srp.h
778 $!!! EXHEADER_STORE := store.h, str_compat.h
779 $ EXHEADER_STORE := store.h
780 $ EXHEADER_CMAC := cmac.h
781 $!
782 $ i = 0
783 $ loop_sdirs:
784 $   sdir = f$edit( f$element( i, ",", sdirs), "trim")
785 $   i = i + 1
786 $   if (sdir .eqs. ",") then goto loop_sdirs_end
787 $   hdr_list = exheader_'sdir'
788 $   if (sdir .nes. "") then sdir = "."+ sdir
789 $   copy [.crypto'sdir']'hdr_list' sys$disk:[.include.openssl]
790 $ goto loop_sdirs
791 $ loop_sdirs_end:
792 $!
793 $! Copy All The ".H" Files From The [.SSL] Directory.
794 $!
795 $! (keep these in the same order as ssl/Makefile)
796 $ EXHEADER := ssl.h, ssl2.h, ssl3.h, ssl23.h, tls1.h, dtls1.h, kssl.h, srtp.h
797 $ copy sys$disk:[.ssl]'exheader' sys$disk:[.include.openssl]
798 $!
799 $! Purge the [.include.openssl] header files.
800 $!
801 $ purge sys$disk:[.include.openssl]*.h
802 $!
803 $! That's All, Time To RETURN.
804 $!
805 $ RETURN
806 $!
807 $! Build The "[.xxx.EXE.CRYPTO]SSL_LIBCRYPTO''LIB32'.OLB" Library.
808 $!
809 $ CRYPTO:
810 $!
811 $! Tell The User What We Are Doing.
812 $!
813 $ WRITE SYS$OUTPUT ""
814 $ WRITE SYS$OUTPUT -
815    "Building The [.",ARCHD,".EXE.CRYPTO]SSL_LIBCRYPTO''LIB32'.OLB Library."
816 $!
817 $! Go To The [.CRYPTO] Directory.
818 $!
819 $ SET DEFAULT SYS$DISK:[.CRYPTO]
820 $!
821 $! Build The [.xxx.EXE.CRYPTO]LIBCRYPTO.OLB Library.
822 $!  
823 $ @CRYPTO-LIB LIBRARY 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" -
824    "''ISSEVEN'" "''BUILDPART'" "''POINTER_SIZE'" "''ZLIB'"
825 $!
826 $! Build The [.xxx.EXE.CRYPTO]*.EXE Test Applications.
827 $!  
828 $!!! DISABLED, as these test programs lack any support
829 $!!!$ @CRYPTO-LIB APPS 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" -
830 $!!!   "''ISSEVEN'" "''BUILDPART'" "''POINTER_SIZE'" "''ZLIB'"
831 $!
832 $! Go Back To The Main Directory.
833 $!
834 $ SET DEFAULT [-]
835 $!
836 $! Time To RETURN.
837 $!
838 $ RETURN
839 $!
840 $! Build The "[.xxx.EXE.SSL]SSL_LIBSSL''LIB32'.OLB" Library.
841 $!
842 $ SSL:
843 $!
844 $! Tell The User What We Are Doing.
845 $!
846 $ WRITE SYS$OUTPUT ""
847 $ WRITE SYS$OUTPUT -
848    "Building The [.",ARCHD,".EXE.SSL]SSL_LIBSSL''LIB32'.OLB Library."
849 $!
850 $! Go To The [.SSL] Directory.
851 $!
852 $ SET DEFAULT SYS$DISK:[.SSL]
853 $!
854 $! Build The [.xxx.EXE.SSL]LIBSSL.OLB Library.
855 $!
856 $ @SSL-LIB LIBRARY 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" -
857    "''ISSEVEN'" "''POINTER_SIZE'" "''ZLIB'"
858 $!
859 $! Go Back To The Main Directory.
860 $!
861 $ SET DEFAULT [-]
862 $!
863 $! Time To Return.
864 $!
865 $ RETURN
866 $!
867 $! Build The "[.xxx.EXE.SSL]SSL_TASK.EXE" Program.
868 $!
869 $ SSL_TASK:
870 $!
871 $! Tell The User What We Are Doing.
872 $!
873 $ WRITE SYS$OUTPUT ""
874 $ WRITE SYS$OUTPUT -
875    "Building DECNet Based SSL Engine, [.",ARCHD,".EXE.SSL]SSL_TASK.EXE"
876 $!
877 $! Go To The [.SSL] Directory.
878 $!
879 $ SET DEFAULT SYS$DISK:[.SSL]
880 $!
881 $! Build The [.xxx.EXE.SSL]SSL_TASK.EXE
882 $!
883 $ @SSL-LIB SSL_TASK 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" -
884    "''ISSEVEN'" "''POINTER_SIZE'" "''ZLIB'"
885 $!
886 $! Go Back To The Main Directory.
887 $!
888 $ SET DEFAULT [-]
889 $!
890 $! That's All, Time To RETURN.
891 $!
892 $ RETURN
893 $!
894 $! Build The OpenSSL Test Programs.
895 $!
896 $ TEST:
897 $!
898 $! Tell The User What We Are Doing.
899 $!
900 $ WRITE SYS$OUTPUT ""
901 $ WRITE SYS$OUTPUT "Building The OpenSSL [.",ARCHD,".EXE.TEST] Test Utilities."
902 $!
903 $! Go To The [.TEST] Directory.
904 $!
905 $ SET DEFAULT SYS$DISK:[.TEST]
906 $!
907 $! Build The Test Programs.
908 $!
909 $ @MAKETESTS 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" "''ISSEVEN'" -
910    "''POINTER_SIZE'" "''ZLIB'"
911 $!
912 $! Go Back To The Main Directory.
913 $!
914 $ SET DEFAULT [-]
915 $!
916 $! That's All, Time To RETURN.
917 $!
918 $ RETURN
919 $!
920 $! Build The OpenSSL Application Programs.
921 $!
922 $ APPS:
923 $!
924 $! Tell The User What We Are Doing.
925 $!
926 $ WRITE SYS$OUTPUT ""
927 $ WRITE SYS$OUTPUT "Building OpenSSL [.",ARCHD,".EXE.APPS] Applications."
928 $!
929 $! Go To The [.APPS] Directory.
930 $!
931 $ SET DEFAULT SYS$DISK:[.APPS]
932 $!
933 $! Build The Application Programs.
934 $!
935 $ @MAKEAPPS 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" "''ISSEVEN'" -
936    "" "''POINTER_SIZE'" "''ZLIB'"
937 $!
938 $! Go Back To The Main Directory.
939 $!
940 $ SET DEFAULT [-]
941 $!
942 $! That's All, Time To RETURN.
943 $!
944 $ RETURN
945 $!
946 $! Build The OpenSSL Application Programs.
947 $!
948 $ ENGINES:
949 $!
950 $! Tell The User What We Are Doing.
951 $!
952 $ WRITE SYS$OUTPUT ""
953 $ WRITE SYS$OUTPUT "Building OpenSSL [.",ARCHD,".EXE.ENGINES] Engines."
954 $!
955 $! Go To The [.ENGINES] Directory.
956 $!
957 $ SET DEFAULT SYS$DISK:[.ENGINES]
958 $!
959 $! Build The Application Programs.
960 $!
961 $ @MAKEENGINES ENGINES 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" -
962    "''ISSEVEN'" "''BUILDPART'" "''POINTER_SIZE'" "''ZLIB'"
963 $!
964 $! Go Back To The Main Directory.
965 $!
966 $ SET DEFAULT [-]
967 $!
968 $! That's All, Time To RETURN.
969 $!
970 $ RETURN
971 $!
972 $! Check The User's Options.
973 $!
974 $ CHECK_OPTIONS:
975 $!
976 $! Check if there's a "part", and separate it out
977 $!
978 $ BUILDPART = F$ELEMENT(1,"/",P1)
979 $ IF BUILDPART .EQS. "/"
980 $ THEN
981 $   BUILDPART = ""
982 $ ELSE
983 $   P1 = F$EXTRACT(0,F$LENGTH(P1) - F$LENGTH(BUILDPART) - 1, P1)
984 $ ENDIF
985 $!
986 $! Check To See If P1 Is Blank.
987 $!
988 $ IF (P1.EQS."ALL")
989 $ THEN
990 $!
991 $!   P1 Is ALL, So Build Everything.
992 $!
993 $    BUILDCOMMAND = "ALL"
994 $!
995 $! Else...
996 $!
997 $ ELSE
998 $!
999 $!  Else, Check To See If P1 Has A Valid Argument.
1000 $!
1001 $   IF (P1.EQS."CONFIG").OR.(P1.EQS."BUILDINF").OR.(P1.EQS."SOFTLINKS") -
1002        .OR.(P1.EQS."BUILDALL") -
1003        .OR.(P1.EQS."CRYPTO").OR.(P1.EQS."SSL") -
1004        .OR.(P1.EQS."SSL_TASK").OR.(P1.EQS."TEST").OR.(P1.EQS."APPS") -
1005        .OR.(P1.EQS."ENGINES")
1006 $   THEN
1007 $!
1008 $!    A Valid Argument.
1009 $!
1010 $     BUILDCOMMAND = P1
1011 $!
1012 $!  Else...
1013 $!
1014 $   ELSE
1015 $!
1016 $!    Tell The User We Don't Know What They Want.
1017 $!
1018 $     WRITE SYS$OUTPUT ""
1019 $     WRITE SYS$OUTPUT "USAGE:   @MAKEVMS.COM [Target] [Pointer size] [Debug option] <Compiler>"
1020 $     WRITE SYS$OUTPUT ""
1021 $     WRITE SYS$OUTPUT "Example: @MAKEVMS.COM ALL """" NODEBUG "
1022 $     WRITE SYS$OUTPUT ""
1023 $     WRITE SYS$OUTPUT "The Target ",P1," Is Invalid.  The Valid Target Options Are:"
1024 $     WRITE SYS$OUTPUT ""
1025 $     WRITE SYS$OUTPUT "    ALL      :  Just Build Everything."
1026 $     WRITE SYS$OUTPUT "    CONFIG   :  Just build the [.CRYPTO._xxx]OPENSSLCONF.H file."
1027 $     WRITE SYS$OUTPUT "    BUILDINF :  Just build the [.CRYPTO._xxx]BUILDINF.H file."
1028 $     WRITE SYS$OUTPUT "    SOFTLINKS:  Just Fix The Unix soft links."
1029 $     WRITE SYS$OUTPUT "    BUILDALL :  Same as ALL, except CONFIG, BUILDINF and SOFTILNKS aren't done."
1030 $     WRITE SYS$OUTPUT "    CRYPTO   :  To Build Just The [.xxx.EXE.CRYPTO]LIBCRYPTO.OLB Library."
1031 $     WRITE SYS$OUTPUT "    CRYPTO/x :  To Build Just The x Part Of The"
1032 $     WRITE SYS$OUTPUT "                [.xxx.EXE.CRYPTO]LIBCRYPTO.OLB Library."
1033 $     WRITE SYS$OUTPUT "    SSL      :  To Build Just The [.xxx.EXE.SSL]LIBSSL.OLB Library."
1034 $     WRITE SYS$OUTPUT "    SSL_TASK :  To Build Just The [.xxx.EXE.SSL]SSL_TASK.EXE Program."
1035 $     WRITE SYS$OUTPUT "    TEST     :  To Build Just The OpenSSL Test Programs."
1036 $     WRITE SYS$OUTPUT "    APPS     :  To Build Just The OpenSSL Application Programs."
1037 $     WRITE SYS$OUTPUT "    ENGINES  :  To Build Just The ENGINES"
1038 $     WRITE SYS$OUTPUT ""
1039 $     WRITE SYS$OUTPUT " Where 'xxx' Stands For:"
1040 $     WRITE SYS$OUTPUT ""
1041 $     WRITE SYS$OUTPUT "    ALPHA[64]:  Alpha Architecture."
1042 $     WRITE SYS$OUTPUT "    IA64[64] :  IA64 Architecture."
1043 $     WRITE SYS$OUTPUT "    VAX      :  VAX Architecture."
1044 $     WRITE SYS$OUTPUT ""
1045 $!
1046 $!    Time To EXIT.
1047 $!
1048 $     GOTO TIDY
1049 $!
1050 $!  End The Valid Argument Check.
1051 $!
1052 $   ENDIF
1053 $!
1054 $! End The P1 Check.
1055 $!
1056 $ ENDIF
1057 $!
1058 $! Check P2 (POINTER_SIZE).
1059 $!
1060 $ IF (P2 .NES. "") .AND. (ARCH .NES. "VAX")
1061 $ THEN
1062 $!
1063 $   IF (P2 .EQS. "32")
1064 $   THEN
1065 $     POINTER_SIZE = "32"
1066 $   ELSE
1067 $     POINTER_SIZE = F$EDIT( P2, "COLLAPSE, UPCASE")
1068 $     IF ((POINTER_SIZE .EQS. "64") .OR. -
1069        (POINTER_SIZE .EQS. "64=") .OR. -
1070        (POINTER_SIZE .EQS. "64=ARGV"))
1071 $     THEN
1072 $       ARCHD = ARCH+ "_64"
1073 $       LIB32 = ""
1074 $     ELSE
1075 $!
1076 $!      Tell The User Entered An Invalid Option.
1077 $!
1078 $       WRITE SYS$OUTPUT ""
1079 $       WRITE SYS$OUTPUT "The Option ", P2, -
1080          " Is Invalid.  The Valid Options Are:"
1081 $       WRITE SYS$OUTPUT ""
1082 $       WRITE SYS$OUTPUT -
1083          "    """"       :  Compile with default (short) pointers."
1084 $       WRITE SYS$OUTPUT -
1085          "    32       :  Compile with 32-bit (short) pointers."
1086 $       WRITE SYS$OUTPUT -
1087          "    64       :  Compile with 64-bit (long) pointers (auto ARGV)."
1088 $       WRITE SYS$OUTPUT -
1089          "    64=      :  Compile with 64-bit (long) pointers (no ARGV)."
1090 $       WRITE SYS$OUTPUT -
1091          "    64=ARGV  :  Compile with 64-bit (long) pointers (ARGV)."
1092 $       WRITE SYS$OUTPUT ""
1093 $! 
1094 $!      Time To EXIT.
1095 $!
1096 $       GOTO TIDY
1097 $!
1098 $     ENDIF
1099 $!
1100 $   ENDIF
1101 $!
1102 $! End The P2 (POINTER_SIZE) Check.
1103 $!
1104 $ ENDIF
1105 $!
1106 $! Check To See If P3 Is Blank.
1107 $!
1108 $ IF (P3.EQS."NODEBUG")
1109 $ THEN
1110 $!
1111 $!   P3 Is NODEBUG, So Compile Without Debugger Information.
1112 $!
1113 $    DEBUGGER = "NODEBUG"
1114 $!
1115 $! Else...
1116 $!
1117 $ ELSE
1118 $!
1119 $!  Check To See If We Are To Compile With Debugger Information.
1120 $!
1121 $   IF (P3.EQS."DEBUG")
1122 $   THEN
1123 $!
1124 $!    Compile With Debugger Information.
1125 $!
1126 $     DEBUGGER = "DEBUG"
1127 $!
1128 $!  Else...
1129 $!
1130 $   ELSE
1131 $!
1132 $!    Tell The User Entered An Invalid Option.
1133 $!
1134 $     WRITE SYS$OUTPUT ""
1135 $     WRITE SYS$OUTPUT "The Option ",P3," Is Invalid.  The Valid Options Are:"
1136 $     WRITE SYS$OUTPUT ""
1137 $     WRITE SYS$OUTPUT "    DEBUG    :  Compile With The Debugger Information."
1138 $     WRITE SYS$OUTPUT "    NODEBUG  :  Compile Without The Debugger Information."
1139 $     WRITE SYS$OUTPUT ""
1140 $!
1141 $!    Time To EXIT.
1142 $!
1143 $     GOTO TIDY
1144 $!
1145 $!  End The Valid Argument Check.
1146 $!
1147 $   ENDIF
1148 $!
1149 $! End The P3 Check.
1150 $!
1151 $ ENDIF
1152 $!
1153 $! Check To See If P4 Is Blank.
1154 $!
1155 $ IF (P4.EQS."")
1156 $ THEN
1157 $!
1158 $!  O.K., The User Didn't Specify A Compiler, Let's Try To
1159 $!  Find Out Which One To Use.
1160 $!
1161 $!  Check To See If We Have GNU C.
1162 $!
1163 $   IF (F$TRNLNM("GNU_CC").NES."")
1164 $   THEN
1165 $!
1166 $!    Looks Like GNUC, Set To Use GNUC.
1167 $!
1168 $     COMPILER = "GNUC"
1169 $!
1170 $!    Tell The User We Are Using GNUC.
1171 $!
1172 $     WRITE SYS$OUTPUT "Using GNU 'C' Compiler."
1173 $!
1174 $!  End The GNU C Compiler Check.
1175 $!
1176 $   ENDIF
1177 $!
1178 $!  Check To See If We Have VAXC Or DECC.
1179 $!
1180 $   IF (F$GETSYI("CPU").GE.128).OR.(F$TRNLNM("DECC$CC_DEFAULT").EQS."/DECC")
1181 $   THEN 
1182 $!
1183 $!    Looks Like DECC, Set To Use DECC.
1184 $!
1185 $     COMPILER = "DECC"
1186 $!
1187 $!    Tell The User We Are Using DECC.
1188 $!
1189 $     WRITE SYS$OUTPUT "Using DECC 'C' Compiler."
1190 $!
1191 $!  Else...
1192 $!
1193 $   ELSE
1194 $!
1195 $!    Looks Like VAXC, Set To Use VAXC.
1196 $!
1197 $     COMPILER = "VAXC"
1198 $!
1199 $!    Tell The User We Are Using VAX C.
1200 $!
1201 $     WRITE SYS$OUTPUT "Using VAXC 'C' Compiler."
1202 $!
1203 $!  End The DECC & VAXC Compiler Check.
1204 $!
1205 $   ENDIF
1206 $!
1207 $! Else...
1208 $!
1209 $ ELSE
1210 $!
1211 $!  Check To See If The User Entered A Valid Parameter.
1212 $!
1213 $   IF (P4.EQS."VAXC").OR.(P4.EQS."DECC").OR.(P4.EQS."GNUC")!.OR.(P4.EQS."LINK")
1214 $   THEN
1215 $!
1216 $!    Check To See If The User Wanted To Just LINK.
1217 $!
1218 $     IF (P4.EQS."LINK")
1219 $     THEN
1220 $!
1221 $!      Looks Like LINK-only
1222 $!
1223 $       COMPILER = "LINK"
1224 $!
1225 $!      Tell The User We Are Only Linking.
1226 $!
1227 $       WRITE SYS$OUTPUT "LINK Only.  This actually NOT YET SUPPORTED!"
1228 $!
1229 $!    End LINK Check.
1230 $!
1231 $     ENDIF
1232 $!
1233 $!    Check To See If The User Wanted DECC.
1234 $!
1235 $     IF (P4.EQS."DECC")
1236 $     THEN
1237 $!
1238 $!      Looks Like DECC, Set To Use DECC.
1239 $!
1240 $       COMPILER = "DECC"
1241 $!
1242 $!      Tell The User We Are Using DECC.
1243 $!
1244 $       WRITE SYS$OUTPUT "Using DECC 'C' Compiler."
1245 $!
1246 $!    End DECC Check.
1247 $!
1248 $     ENDIF
1249 $!
1250 $!    Check To See If We Are To Use VAXC.
1251 $!
1252 $     IF (P4.EQS."VAXC")
1253 $     THEN
1254 $!
1255 $!      Looks Like VAXC, Set To Use VAXC.
1256 $!
1257 $       COMPILER = "VAXC"
1258 $!
1259 $!      Tell The User We Are Using VAX C.
1260 $!
1261 $       WRITE SYS$OUTPUT "Using VAXC 'C' Compiler."
1262 $!
1263 $!    End VAXC Check
1264 $!
1265 $     ENDIF
1266 $!
1267 $!    Check To See If We Are To Use GNU C.
1268 $!
1269 $     IF (P4.EQS."GNUC")
1270 $     THEN
1271 $!
1272 $!      Looks Like GNUC, Set To Use GNUC.
1273 $!
1274 $       COMPILER = "GNUC"
1275 $!
1276 $!      Tell The User We Are Using GNUC.
1277 $!
1278 $       WRITE SYS$OUTPUT "Using GNU 'C' Compiler."
1279 $!
1280 $!    End The GNU C Check.
1281 $!
1282 $     ENDIF
1283 $!
1284 $!  Else The User Entered An Invalid Argument.
1285 $!
1286 $   ELSE
1287 $!
1288 $!    Tell The User We Don't Know What They Want.
1289 $!
1290 $     WRITE SYS$OUTPUT ""
1291 $     WRITE SYS$OUTPUT "The Option ",P4," Is Invalid.  The Valid Options Are:"
1292 $     WRITE SYS$OUTPUT ""
1293 $     WRITE SYS$OUTPUT "    VAXC  :  To Compile With VAX C."
1294 $     WRITE SYS$OUTPUT "    DECC  :  To Compile With DEC C."
1295 $     WRITE SYS$OUTPUT "    GNUC  :  To Compile With GNU C."
1296 $     WRITE SYS$OUTPUT ""
1297 $!
1298 $!    Time To EXIT.
1299 $!
1300 $     GOTO TIDY
1301 $!
1302 $!  End The Valid Argument Check.
1303 $!
1304 $   ENDIF
1305 $!
1306 $! End The P4 Check.
1307 $!
1308 $ ENDIF
1309 $!
1310 $! Time to check the contents of P5, and to make sure we get the correct
1311 $! library.
1312 $!
1313 $ IF P5.EQS."SOCKETSHR" .OR. P5.EQS."MULTINET" .OR. P5.EQS."UCX" -
1314      .OR. P5.EQS."TCPIP" .OR. P5.EQS."NONE"
1315 $ THEN
1316 $!
1317 $!  Check to see if SOCKETSHR was chosen
1318 $!
1319 $   IF P5.EQS."SOCKETSHR"
1320 $   THEN
1321 $!
1322 $!    Set the library to use SOCKETSHR
1323 $!
1324 $     TCPIP_LIB = "SYS$DISK:[-.VMS]SOCKETSHR_SHR.OPT /OPTIONS"
1325 $!
1326 $!    Tell the user
1327 $!
1328 $     WRITE SYS$OUTPUT "Using SOCKETSHR for TCP/IP"
1329 $!
1330 $!    Done with SOCKETSHR
1331 $!
1332 $   ENDIF
1333 $!
1334 $!  Check to see if MULTINET was chosen
1335 $!
1336 $   IF P5.EQS."MULTINET"
1337 $   THEN
1338 $!
1339 $!    Set the library to use UCX emulation.
1340 $!
1341 $     P5 = "UCX"
1342 $!
1343 $!    Tell the user
1344 $!
1345 $     WRITE SYS$OUTPUT "Using MultiNet via UCX emulation for TCP/IP"
1346 $!
1347 $!    Done with MULTINET
1348 $!
1349 $   ENDIF
1350 $!
1351 $!  Check to see if UCX was chosen
1352 $!
1353 $   IF P5.EQS."UCX"
1354 $   THEN
1355 $!
1356 $!    Set the library to use UCX.
1357 $!
1358 $     TCPIP_LIB = "SYS$DISK:[-.VMS]UCX_SHR_DECC.OPT /OPTIONS"
1359 $!
1360 $!    Tell the user
1361 $!
1362 $     WRITE SYS$OUTPUT "Using UCX or an emulation thereof for TCP/IP"
1363 $!
1364 $!    Done with UCX
1365 $!
1366 $   ENDIF
1367 $!
1368 $!  Check to see if TCPIP was chosen
1369 $!
1370 $   IF P5.EQS."TCPIP"
1371 $   THEN
1372 $!
1373 $!    Set the library to use TCPIP (post UCX).
1374 $!
1375 $     TCPIP_LIB = "SYS$DISK:[-.VMS]TCPIP_SHR_DECC.OPT /OPTIONS"
1376 $!
1377 $!    Tell the user
1378 $!
1379 $     WRITE SYS$OUTPUT "Using TCPIP (post UCX) for TCP/IP"
1380 $!
1381 $!    Done with TCPIP
1382 $!
1383 $   ENDIF
1384 $!
1385 $!  Check to see if NONE was chosen
1386 $!
1387 $   IF P5.EQS."NONE"
1388 $   THEN
1389 $!
1390 $!    Do not use a TCPIP library.
1391 $!
1392 $     TCPIP_LIB = ""
1393 $!
1394 $!    Tell the user
1395 $!
1396 $     WRITE SYS$OUTPUT "A specific TCPIP library will not be used."
1397 $!
1398 $!    Done with NONE.
1399 $!
1400 $   ENDIF
1401 $!
1402 $!  Set the TCPIP_TYPE symbol
1403 $!
1404 $   TCPIP_TYPE = P5
1405 $!
1406 $!  Print info
1407 $!
1408 $   WRITE SYS$OUTPUT "TCP/IP library spec: ", TCPIP_LIB
1409 $!
1410 $!  Else The User Entered An Invalid Argument.
1411 $!
1412 $ ELSE
1413 $   IF P5 .NES. ""
1414 $   THEN
1415 $!
1416 $!    Tell The User We Don't Know What They Want.
1417 $!
1418 $     WRITE SYS$OUTPUT ""
1419 $     WRITE SYS$OUTPUT "The Option ",P5," Is Invalid.  The Valid Options Are:"
1420 $     WRITE SYS$OUTPUT ""
1421 $     WRITE SYS$OUTPUT "    SOCKETSHR  :  To link with SOCKETSHR TCP/IP library."
1422 $     WRITE SYS$OUTPUT "    UCX        :  To link with UCX TCP/IP library."
1423 $     WRITE SYS$OUTPUT "    TCPIP      :  To link with TCPIP TCP/IP (post UCX) library."
1424 $     WRITE SYS$OUTPUT "    NONE       :  To not link with a specific TCP/IP library."
1425 $     WRITE SYS$OUTPUT ""
1426 $!
1427 $!    Time To EXIT.
1428 $!
1429 $     GOTO TIDY
1430 $   ELSE
1431 $!
1432 $! If TCPIP is not defined, then hardcode it to make
1433 $! it clear that no TCPIP is desired.
1434 $!
1435 $     IF P5 .EQS. ""
1436 $     THEN
1437 $       TCPIP_LIB = ""
1438 $       TCPIP_TYPE = "NONE"
1439 $     ELSE
1440 $!
1441 $!    Set the TCPIP_TYPE symbol
1442 $!
1443 $       TCPIP_TYPE = P5
1444 $     ENDIF
1445 $   ENDIF
1446 $!
1447 $!  Done with TCP/IP libraries
1448 $!
1449 $ ENDIF
1450 $!
1451 $! Special Threads For OpenVMS v7.1 Or Later
1452 $!
1453 $! Written By:  Richard Levitte
1454 $!              richard@levitte.org
1455 $!
1456 $!
1457 $! Check To See If We Have A Option For P6.
1458 $!
1459 $ IF (P6.EQS."")
1460 $ THEN
1461 $!
1462 $!  Get The Version Of VMS We Are Using.
1463 $!
1464 $   ISSEVEN :=
1465 $   TMP = F$ELEMENT(0,"-",F$EXTRACT(1,4,VMS_VERSION))
1466 $   TMP = F$INTEGER(F$ELEMENT(0,".",TMP)+F$ELEMENT(1,".",TMP))
1467 $!
1468 $!  Check To See If The VMS Version Is v7.1 Or Later.
1469 $!
1470 $   IF (TMP.GE.71)
1471 $   THEN
1472 $!
1473 $!    We Have OpenVMS v7.1 Or Later, So Use The Special Threads.
1474 $!
1475 $     ISSEVEN := ,PTHREAD_USE_D4
1476 $!
1477 $!  End The VMS Version Check.
1478 $!
1479 $   ENDIF
1480 $!
1481 $! End The P6 Check.
1482 $!
1483 $ ENDIF
1484 $!
1485 $!
1486 $! Check To See If We Have A ZLIB Option.
1487 $!
1488 $ ZLIB = P7
1489 $ IF (ZLIB .NES. "")
1490 $ THEN
1491 $!
1492 $!  Check for expected ZLIB files.
1493 $!
1494 $   err = 0
1495 $   file1 = f$parse( "zlib.h", ZLIB, , , "SYNTAX_ONLY")
1496 $   if (f$search( file1) .eqs. "")
1497 $   then
1498 $     WRITE SYS$OUTPUT ""
1499 $     WRITE SYS$OUTPUT "The Option ", ZLIB, " Is Invalid."
1500 $     WRITE SYS$OUTPUT "    Can't find header: ''file1'"
1501 $     err = 1
1502 $   endif
1503 $!
1504 $   file2 = f$parse( ZLIB, "libz.olb", , , "SYNTAX_ONLY")
1505 $   if (f$search( file2) .eqs. "")
1506 $   then
1507 $     if (err .eq. 0)
1508 $     then
1509 $       WRITE SYS$OUTPUT ""
1510 $       WRITE SYS$OUTPUT "The Option ", ZLIB, " Is Invalid."
1511 $     endif
1512 $     WRITE SYS$OUTPUT "    Can't find library: ''file2'"
1513 $     WRITE SYS$OUTPUT ""
1514 $     err = err+ 2
1515 $   endif
1516 $   if (err .eq. 1)
1517 $   then
1518 $     WRITE SYS$OUTPUT ""
1519 $   endif
1520 $!
1521 $   if (err .ne. 0)
1522 $   then
1523 $     GOTO TIDY
1524 $   endif
1525 $!
1526 $!  Print info
1527 $!
1528 $   WRITE SYS$OUTPUT "ZLIB library spec: ", file2
1529 $!
1530 $! End The ZLIB Check.
1531 $!
1532 $ ENDIF
1533 $!
1534 $!  Time To RETURN...
1535 $!
1536 $ RETURN
1537 $!
1538 $ TIDY:
1539 $!
1540 $! Close any open files.
1541 $!
1542 $ if (f$trnlnm( "h_file", "LNM$PROCESS", 0, "SUPERVISOR") .nes. "") then -
1543    close h_file
1544 $!
1545 $! Restore the original default device:[directory].
1546 $!
1547 $ SET DEFAULT 'DEF_ORIG'
1548 $!
1549 $ EXIT
1550 $!